extended_event_descriptor.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /*
  2. * section and descriptor parser
  3. *
  4. * Copyright (C) 2005 Kenneth Aafloy (kenneth@linuxtv.org)
  5. * Copyright (C) 2005 Andrew de Quincey (adq_dvb@lidskialf.net)
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this library; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
  20. */
  21. #ifndef _UCSI_DVB_EXTENDED_EVENT_DESCRIPTOR
  22. #define _UCSI_DVB_EXTENDED_EVENT_DESCRIPTOR 1
  23. #ifdef __cplusplus
  24. extern "C"
  25. {
  26. #endif
  27. #include <libucsi/descriptor.h>
  28. #include <libucsi/endianops.h>
  29. #include <libucsi/types.h>
  30. /**
  31. * dvb_extended_event_descriptor structure.
  32. */
  33. struct dvb_extended_event_descriptor {
  34. struct descriptor d;
  35. EBIT2(uint8_t descriptor_number : 4; ,
  36. uint8_t last_descriptor_number : 4; );
  37. iso639lang_t language_code;
  38. uint8_t length_of_items;
  39. /* struct dvb_extended_event_item items[] */
  40. /* struct dvb_extended_event_descriptor_part2 part2 */
  41. } __ucsi_packed;
  42. /**
  43. * An entry in the items field of a dvb_extended_event_descriptor.
  44. */
  45. struct dvb_extended_event_item {
  46. uint8_t item_description_length;
  47. /* uint8_t item_description[] */
  48. /* struct dvb_extended_event_item_part2 part2 */
  49. } __ucsi_packed;
  50. /**
  51. * The second part of a dvb_extended_event_item, following the variable length
  52. * description field.
  53. */
  54. struct dvb_extended_event_item_part2 {
  55. uint8_t item_length;
  56. /* uint8_t item[] */
  57. } __ucsi_packed;
  58. /**
  59. * The second part of a dvb_extended_event_descriptor, following the variable
  60. * length items field.
  61. */
  62. struct dvb_extended_event_descriptor_part2 {
  63. uint8_t text_length;
  64. /* uint8_t text[] */
  65. } __ucsi_packed;
  66. /**
  67. * Process a dvb_extended_event_descriptor.
  68. *
  69. * @param d Generic descriptor structure.
  70. * @return dvb_extended_event_descriptor pointer, or NULL on error.
  71. */
  72. static inline struct dvb_extended_event_descriptor*
  73. dvb_extended_event_descriptor_codec(struct descriptor* d)
  74. {
  75. uint8_t* buf = (uint8_t*) d + 2;
  76. uint32_t pos = 0;
  77. uint32_t len = d->len;
  78. struct dvb_extended_event_descriptor * p =
  79. (struct dvb_extended_event_descriptor *) d;
  80. struct dvb_extended_event_descriptor_part2 *p2;
  81. pos += sizeof(struct dvb_extended_event_descriptor) - 2;
  82. if (pos > len)
  83. return NULL;
  84. pos += p->length_of_items;
  85. if (pos > len)
  86. return NULL;
  87. p2 = (struct dvb_extended_event_descriptor_part2*) (buf+pos);
  88. pos += sizeof(struct dvb_extended_event_descriptor_part2);
  89. if (pos > len)
  90. return NULL;
  91. pos += p2->text_length;
  92. if (pos != len)
  93. return NULL;
  94. return p;
  95. }
  96. /**
  97. * Iterator for the items field of a dvb_extended_event_descriptor.
  98. *
  99. * @param d dvb_extended_event_descriptor pointer.
  100. * @param pos Variable containing a pointer to the current dvb_extended_event_item.
  101. */
  102. #define dvb_extended_event_descriptor_items_for_each(d, pos) \
  103. for ((pos) = dvb_extended_event_descriptor_items_first(d); \
  104. (pos); \
  105. (pos) = dvb_extended_event_descriptor_items_next(d, pos))
  106. /**
  107. * Accessor for the description field of a dvb_extended_event_item.
  108. *
  109. * @param d dvb_extended_event_item pointer.
  110. * @return Pointer to the field.
  111. */
  112. static inline uint8_t*
  113. dvb_extended_event_item_description(struct dvb_extended_event_item *d)
  114. {
  115. return (uint8_t*) d + sizeof(struct dvb_extended_event_item);
  116. }
  117. /**
  118. * Accessor for the second part of a dvb_extended_event_item.
  119. *
  120. * @param dvb_extended_event_item pointer.
  121. * @return dvb_extended_event_item_part2 pointer.
  122. */
  123. static inline struct dvb_extended_event_item_part2*
  124. dvb_extended_event_item_part2(struct dvb_extended_event_item *d)
  125. {
  126. return (struct dvb_extended_event_item_part2*)
  127. ((uint8_t*) d + sizeof(struct dvb_extended_event_item) +
  128. d->item_description_length);
  129. }
  130. /**
  131. * Accessor for the item field of a dvb_extended_event_item_part2.
  132. *
  133. * @param d dvb_extended_event_item_part2 pointer.
  134. * @return Pointer to the item field.
  135. */
  136. static inline uint8_t*
  137. dvb_extended_event_item_part2_item(struct dvb_extended_event_item_part2 *d)
  138. {
  139. return (uint8_t*) d + sizeof(struct dvb_extended_event_item_part2);
  140. }
  141. /**
  142. * Accessor for the second part of a dvb_extended_event_descriptor.
  143. *
  144. * @param d dvb_extended_event_descriptor pointer.
  145. * @return dvb_extended_event_descriptor_part2 pointer.
  146. */
  147. static inline struct dvb_extended_event_descriptor_part2*
  148. dvb_extended_event_descriptor_part2(struct dvb_extended_event_descriptor *d)
  149. {
  150. return (struct dvb_extended_event_descriptor_part2*)
  151. ((uint8_t*) d + sizeof(struct dvb_extended_event_descriptor) +
  152. d->length_of_items);
  153. }
  154. /**
  155. * Accessor for the text field of an dvb_extended_event_descriptor_part2.
  156. *
  157. * @param d dvb_extended_event_descriptor_part2 pointer.
  158. * @return Pointer to the text field.
  159. */
  160. static inline uint8_t*
  161. dvb_extended_event_descriptor_part2_text(struct dvb_extended_event_descriptor_part2 *d)
  162. {
  163. return (uint8_t*)
  164. ((uint8_t*) d + sizeof(struct dvb_extended_event_descriptor_part2));
  165. }
  166. /******************************** PRIVATE CODE ********************************/
  167. static inline struct dvb_extended_event_item*
  168. dvb_extended_event_descriptor_items_first(struct dvb_extended_event_descriptor *d)
  169. {
  170. if (d->length_of_items == 0)
  171. return NULL;
  172. return (struct dvb_extended_event_item *)
  173. ((uint8_t*) d + sizeof(struct dvb_extended_event_descriptor));
  174. }
  175. static inline struct dvb_extended_event_item*
  176. dvb_extended_event_descriptor_items_next(struct dvb_extended_event_descriptor *d,
  177. struct dvb_extended_event_item *pos)
  178. {
  179. struct dvb_extended_event_item_part2* part2 =
  180. dvb_extended_event_item_part2(pos);
  181. uint8_t *end = (uint8_t*) d + sizeof(struct dvb_extended_event_descriptor) + d->length_of_items;
  182. uint8_t *next = (uint8_t *) part2 +
  183. sizeof(struct dvb_extended_event_item_part2) +
  184. part2->item_length;
  185. if (next >= end)
  186. return NULL;
  187. return (struct dvb_extended_event_item *) next;
  188. }
  189. #ifdef __cplusplus
  190. }
  191. #endif
  192. #endif