Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 1 | /* |
Alex Elder | 908a85d | 2014-09-24 05:16:16 -0500 | [diff] [blame] | 2 | * Greybus module manifest definition |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 3 | * |
Alex Elder | cb705e0 | 2014-09-24 05:16:17 -0500 | [diff] [blame] | 4 | * See "Greybus Application Protocol" document (version 0.1) for |
Alex Elder | 908a85d | 2014-09-24 05:16:16 -0500 | [diff] [blame] | 5 | * details on these values and structures. |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 6 | * |
| 7 | * Copyright 2014 Google Inc. |
Alex Elder | 908a85d | 2014-09-24 05:16:16 -0500 | [diff] [blame] | 8 | * |
Greg Kroah-Hartman | 9b60aa0 | 2014-10-06 20:37:53 -0700 | [diff] [blame] | 9 | * Released under the GPLv2 and BSD licenses. |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 10 | */ |
| 11 | |
Alex Elder | 1dd7f58 | 2014-09-26 20:55:32 -0500 | [diff] [blame] | 12 | #ifndef __GREYBUS_MANIFEST_H |
| 13 | #define __GREYBUS_MANIFEST_H |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 14 | |
Greg Kroah-Hartman | 48123e0 | 2014-09-02 10:51:56 -0700 | [diff] [blame] | 15 | #pragma pack(push, 1) |
| 16 | |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 17 | enum greybus_descriptor_type { |
Alex Elder | 72b0ffc | 2014-09-26 20:55:33 -0500 | [diff] [blame] | 18 | GREYBUS_TYPE_INVALID = 0x00, |
| 19 | GREYBUS_TYPE_MODULE = 0x01, |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 20 | GREYBUS_TYPE_STRING = 0x02, |
| 21 | GREYBUS_TYPE_INTERFACE = 0x03, |
| 22 | GREYBUS_TYPE_CPORT = 0x04, |
| 23 | GREYBUS_TYPE_CLASS = 0x05, |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 24 | }; |
| 25 | |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 26 | enum greybus_protocol { |
| 27 | GREYBUS_PROTOCOL_CONTROL = 0x00, |
| 28 | GREYBUS_PROTOCOL_AP = 0x01, |
| 29 | GREYBUS_PROTOCOL_GPIO = 0x02, |
| 30 | GREYBUS_PROTOCOL_I2C = 0x03, |
| 31 | GREYBUS_PROTOCOL_UART = 0x04, |
| 32 | GREYBUS_PROTOCOL_HID = 0x05, |
Alex Elder | 19d03de | 2014-11-05 16:12:53 -0600 | [diff] [blame] | 33 | GREYBUS_PROTOCOL_SDIO = 0x06, |
Greg Kroah-Hartman | 2bb7eae | 2014-10-20 15:24:57 +0800 | [diff] [blame] | 34 | GREYBUS_PROTOCOL_BATTERY = 0x08, |
Greg Kroah-Hartman | 42d4a22 | 2014-10-20 16:02:56 +0800 | [diff] [blame] | 35 | GREYBUS_PROTOCOL_LED = 0x0e, |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 36 | /* ... */ |
| 37 | GREYBUS_PROTOCOL_VENDOR = 0xff, |
| 38 | }; |
| 39 | |
| 40 | enum greybus_class_type { |
Alex Elder | 063e6ec | 2014-10-03 14:14:23 -0500 | [diff] [blame] | 41 | GREYBUS_CLASS_CONTROL = 0x00, |
Greg Kroah-Hartman | 6ce3e03 | 2014-10-20 13:27:42 +0800 | [diff] [blame] | 42 | GREYBUS_CLASS_AP = 0x01, |
Alex Elder | 063e6ec | 2014-10-03 14:14:23 -0500 | [diff] [blame] | 43 | GREYBUS_CLASS_GPIO = 0x02, |
Greg Kroah-Hartman | 6ce3e03 | 2014-10-20 13:27:42 +0800 | [diff] [blame] | 44 | GREYBUS_CLASS_I2C = 0x03, |
Alex Elder | 063e6ec | 2014-10-03 14:14:23 -0500 | [diff] [blame] | 45 | GREYBUS_CLASS_UART = 0x04, |
Greg Kroah-Hartman | 6ce3e03 | 2014-10-20 13:27:42 +0800 | [diff] [blame] | 46 | GREYBUS_CLASS_HID = 0x05, |
| 47 | GREYBUS_CLASS_USB = 0x06, |
| 48 | GREYBUS_CLASS_SDIO = 0x07, |
| 49 | GREYBUS_CLASS_BATTERY = 0x08, |
| 50 | GREYBUS_CLASS_PWM = 0x09, |
| 51 | GREYBUS_CLASS_I2S = 0x0a, |
| 52 | GREYBUS_CLASS_SPI = 0x0b, |
| 53 | GREYBUS_CLASS_DISPLAY = 0x0c, |
| 54 | GREYBUS_CLASS_CAMERA = 0x0d, |
| 55 | GREYBUS_CLASS_SENSOR = 0x0e, |
Alex Elder | 063e6ec | 2014-10-03 14:14:23 -0500 | [diff] [blame] | 56 | GREYBUS_CLASS_VENDOR = 0xff, |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 57 | }; |
| 58 | |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 59 | /* |
| 60 | * A module descriptor describes information about a module as a |
| 61 | * whole, *not* the functions within it. |
| 62 | */ |
Matt Porter | 6d63ff7 | 2014-09-26 20:49:48 -0500 | [diff] [blame] | 63 | struct greybus_descriptor_module { |
Greg Kroah-Hartman | d587780 | 2014-09-01 10:59:08 -0700 | [diff] [blame] | 64 | __le16 vendor; |
| 65 | __le16 product; |
| 66 | __le16 version; |
| 67 | __u8 vendor_stringid; |
| 68 | __u8 product_stringid; |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 69 | __le64 unique_id; |
Greg Kroah-Hartman | d587780 | 2014-09-01 10:59:08 -0700 | [diff] [blame] | 70 | }; |
| 71 | |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 72 | /* |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 73 | * The string in a string descriptor is not NUL-terminated. The |
| 74 | * size of the descriptor will be rounded up to a multiple of 4 |
| 75 | * bytes, by padding the string with 0x00 bytes if necessary. |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 76 | */ |
Greg Kroah-Hartman | d587780 | 2014-09-01 10:59:08 -0700 | [diff] [blame] | 77 | struct greybus_descriptor_string { |
Matt Porter | cbd0fd7 | 2014-09-26 20:49:51 -0500 | [diff] [blame] | 78 | __u8 length; |
Greg Kroah-Hartman | d587780 | 2014-09-01 10:59:08 -0700 | [diff] [blame] | 79 | __u8 id; |
| 80 | __u8 string[0]; |
| 81 | }; |
| 82 | |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 83 | /* |
| 84 | * An interface descriptor simply defines a module-unique id for |
| 85 | * each interface present on a module. Its sole purpose is to allow |
| 86 | * CPort descriptors to specify which interface they are associated |
| 87 | * with. Normally there's only one interface, with id 0. The |
| 88 | * second one must have id 1, and so on consecutively. |
| 89 | * |
| 90 | * The largest CPort id associated with an interface (defined by a |
| 91 | * CPort descriptor in the manifest) is used to determine how to |
| 92 | * encode the device id and module number in UniPro packets |
| 93 | * that use the interface. |
| 94 | */ |
| 95 | struct greybus_descriptor_interface { |
| 96 | __u8 id; /* module-relative id (0..) */ |
| 97 | }; |
| 98 | |
| 99 | /* |
| 100 | * A CPort descriptor indicates the id of the interface within the |
| 101 | * module it's associated with, along with the CPort id used to |
Alex Elder | 7fba007 | 2014-10-28 19:35:59 -0500 | [diff] [blame] | 102 | * address the CPort. The protocol id defines the format of messages |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 103 | * exchanged using the CPort. |
| 104 | */ |
| 105 | struct greybus_descriptor_cport { |
| 106 | __u8 interface; |
| 107 | __le16 id; |
Alex Elder | 7fba007 | 2014-10-28 19:35:59 -0500 | [diff] [blame] | 108 | __u8 protocol_id; /* enum greybus_protocol */ |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 109 | }; |
| 110 | |
| 111 | /* |
| 112 | * A class descriptor defines functionality supplied by a module. |
| 113 | * Beyond that, not much else is defined yet... |
| 114 | */ |
| 115 | struct greybus_descriptor_class { |
| 116 | __u8 class; /* enum greybus_class_type */ |
| 117 | }; |
| 118 | |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 119 | struct greybus_descriptor_header { |
| 120 | __le16 size; |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 121 | __u8 type; /* enum greybus_descriptor_type */ |
Greg Kroah-Hartman | d587780 | 2014-09-01 10:59:08 -0700 | [diff] [blame] | 122 | }; |
| 123 | |
Greg Kroah-Hartman | 6dca7b9 | 2014-09-01 13:42:43 -0700 | [diff] [blame] | 124 | struct greybus_descriptor { |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 125 | struct greybus_descriptor_header header; |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 126 | union { |
Matt Porter | 6d63ff7 | 2014-09-26 20:49:48 -0500 | [diff] [blame] | 127 | struct greybus_descriptor_module module; |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 128 | struct greybus_descriptor_string string; |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 129 | struct greybus_descriptor_interface interface; |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 130 | struct greybus_descriptor_cport cport; |
Alex Elder | 63cc932 | 2014-10-02 12:30:02 -0500 | [diff] [blame] | 131 | struct greybus_descriptor_class class; |
Greg Kroah-Hartman | 80ebe8a | 2014-08-31 18:08:52 -0700 | [diff] [blame] | 132 | }; |
| 133 | }; |
| 134 | |
Alex Elder | ecf7d57 | 2014-10-01 21:54:10 -0500 | [diff] [blame] | 135 | struct greybus_manifest_header { |
| 136 | __le16 size; |
| 137 | __u8 version_major; |
| 138 | __u8 version_minor; |
| 139 | }; |
| 140 | |
Alex Elder | badad68 | 2014-09-09 13:55:04 -0500 | [diff] [blame] | 141 | struct greybus_manifest { |
| 142 | struct greybus_manifest_header header; |
| 143 | struct greybus_descriptor descriptors[0]; |
| 144 | }; |
| 145 | |
Greg Kroah-Hartman | 48123e0 | 2014-09-02 10:51:56 -0700 | [diff] [blame] | 146 | #pragma pack(pop) |
| 147 | |
Alex Elder | 1dd7f58 | 2014-09-26 20:55:32 -0500 | [diff] [blame] | 148 | #endif /* __GREYBUS_MANIFEST_H */ |