libtsfuncs is a library for mpeg PSI parsing and generation. https://georgi.unixsol.org/programs/libtsfuncs/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

tsfuncs.h 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. #ifndef LIBTS_TSFUNCS_H
  2. #define LIBTS_TSFUNCS_H
  3. #include <time.h>
  4. #include <netdb.h>
  5. #include "tsdata.h"
  6. #include "log.h"
  7. // Usage bit_on(0xff, 0x02)
  8. #define bit_on(__bit, __mask) ((__bit & __mask) ? 1 : 0)
  9. #define bit_1 (0x01)
  10. #define bit_2 (0x02)
  11. #define bit_3 (0x04)
  12. #define bit_4 (0x08)
  13. #define bit_5 (0x10)
  14. #define bit_6 (0x20)
  15. #define bit_7 (0x40)
  16. #define bit_8 (0x80)
  17. #define NO_PCR (-1ull)
  18. #define NO_PCR_BASE (-1ull)
  19. #define NO_PCR_EXT (0xffff)
  20. #define NO_PCR (-1ull)
  21. #define NO_PTS (-1ull)
  22. #define NO_DTS (-1ull)
  23. enum ts_scrambled_type {
  24. not_scrambled = 0x00,
  25. scrambled_reserved = 0x01,
  26. scrambled_with_odd_key = 0x02,
  27. scrambled_with_even_key = 0x03
  28. };
  29. // Packet manipulation
  30. void ts_packet_init_null (uint8_t *ts_packet);
  31. static inline int ts_packet_is_pusi(uint8_t *ts_packet) {
  32. return (ts_packet[1] &~ 0xbf) >> 6;
  33. }
  34. static inline uint16_t ts_packet_get_pid(uint8_t *ts_packet) {
  35. return (ts_packet[1] &~ 0xE0) << 8 | ts_packet[2];
  36. }
  37. static inline void ts_packet_set_pid(uint8_t *ts_packet, uint16_t new_pid) {
  38. ts_packet[1] = (ts_packet[1] &~ 0x1f) | (new_pid >> 8); // 111xxxxx xxxxxxxx
  39. ts_packet[2] = new_pid &~ 0xff00;
  40. }
  41. static inline uint8_t ts_packet_get_cont(uint8_t *ts_packet) {
  42. return (ts_packet[3] &~ 0xF0); // 1111xxxx
  43. }
  44. static inline void ts_packet_set_cont(uint8_t *ts_packet, uint8_t value) {
  45. // Mask the last 4 bits (continuity), then set the continuity
  46. ts_packet[3] = (ts_packet[3] &~ 0x0F) | (value &~ 0xF0);
  47. }
  48. static inline void ts_packet_inc_cont(uint8_t *ts_packet, uint8_t increment) {
  49. ts_packet_set_cont(ts_packet, ts_packet_get_cont(ts_packet) + increment);
  50. }
  51. static inline int ts_packet_get_scrambled(uint8_t *ts_packet) {
  52. return ts_packet[3] >> 6; // 0 is not scamlbed, 1 is reserved, 2 or 3 mean scrambled
  53. }
  54. static inline int ts_packet_is_scrambled(uint8_t *ts_packet) {
  55. return ts_packet_get_scrambled(ts_packet) > 1;
  56. }
  57. static inline void ts_packet_set_not_scrambled(uint8_t *ts_packet) {
  58. ts_packet[3] = ts_packet[3] &~ 0xc0; // Mask top two bits (11xxxxxx)
  59. }
  60. void ts_packet_set_scrambled(uint8_t *ts_packet, enum ts_scrambled_type stype);
  61. uint8_t ts_packet_get_payload_offset(uint8_t *ts_packet);
  62. int ts_packet_has_pcr (uint8_t *ts_packet);
  63. uint64_t ts_packet_get_pcr_ex (uint8_t *ts_packet, uint64_t *pcr_base, uint16_t *pcr_ext);
  64. uint64_t ts_packet_get_pcr (uint8_t *ts_packet);
  65. void ts_packet_set_pcr_ex (uint8_t *ts_packet, uint64_t pcr_base, uint16_t pcr_ext);
  66. void ts_packet_set_pcr (uint8_t *ts_packet, uint64_t pcr);
  67. /*
  68. * guard 2 == pts
  69. * guard 3 == pts before dts
  70. * guard 1 == dts
  71. */
  72. void ts_encode_pts_dts (uint8_t *data, int guard, uint64_t value);
  73. void ts_decode_pts_dts (uint8_t *data, uint64_t *value);
  74. int ts_packet_has_pes (uint8_t *ts_packet, uint16_t *pes_packet_len);
  75. int ts_packet_has_pts_dts (uint8_t *ts_packet, uint64_t *pts, uint64_t *dts);
  76. void ts_packet_change_pts (uint8_t *ts_packet, uint64_t pts);
  77. void ts_packet_change_pts_dts (uint8_t *ts_packet, uint64_t pts, uint64_t dts);
  78. // TS packet headers
  79. uint8_t * ts_packet_header_parse (uint8_t *ts_packet, struct ts_header *ts_header);
  80. void ts_packet_header_generate (uint8_t *ts_packet, struct ts_header *ts_header);
  81. void ts_packet_header_dump (struct ts_header *ts_header);
  82. // Sections
  83. uint8_t * ts_section_header_parse (uint8_t *ts_packet, struct ts_header *ts_header, struct ts_section_header *ts_section_header);
  84. void ts_section_header_generate (uint8_t *ts_packet, struct ts_section_header *ts_section_header, uint8_t start);
  85. void ts_section_header_dump (struct ts_section_header *t);
  86. void ts_section_dump (struct ts_section_header *sec);
  87. void ts_section_header_set_private_vars (struct ts_section_header *ts_section_header);
  88. int ts_section_is_same(struct ts_section_header *s1, struct ts_section_header *s2);
  89. uint8_t * ts_section_data_alloc_section ();
  90. uint8_t * ts_section_data_alloc_packet ();
  91. struct ts_section_header * ts_section_data_alloc ();
  92. void ts_section_data_clear (struct ts_section_header *sec);
  93. void ts_section_data_free (struct ts_section_header **ts_section_header);
  94. void ts_section_data_copy (struct ts_section_header *src, struct ts_section_header *dst);
  95. void ts_section_add_packet (struct ts_section_header *sec, struct ts_header *ts_header, uint8_t *ts_packet);
  96. uint32_t ts_section_data_calculate_crc (uint8_t *section_data, int section_data_size);
  97. void ts_section_data_gen_ts_packets (struct ts_header *ts_header, uint8_t *section_data, int section_data_sz, uint8_t pointer_field, uint8_t **packets, int *num_packets);
  98. // PAT
  99. struct ts_pat * ts_pat_alloc ();
  100. struct ts_pat * ts_pat_alloc_init (uint16_t transport_stream_id);
  101. struct ts_pat * ts_pat_push_packet (struct ts_pat *pat, uint8_t *ts_packet);
  102. void ts_pat_clear (struct ts_pat *pat);
  103. void ts_pat_free (struct ts_pat **pat);
  104. int ts_pat_parse (struct ts_pat *pat);
  105. void ts_pat_dump (struct ts_pat *pat);
  106. void ts_pat_generate (struct ts_pat *pat, uint8_t **ts_packets, int *num_packets);
  107. struct ts_pat * ts_pat_copy (struct ts_pat *pat);
  108. void ts_pat_regenerate_packets (struct ts_pat *pat);
  109. int ts_pat_add_program (struct ts_pat *pat, uint16_t program, uint16_t pat_pid);
  110. int ts_pat_del_program (struct ts_pat *pat, uint16_t program);
  111. int ts_pat_is_same (struct ts_pat *pat1, struct ts_pat *pat2);
  112. // CAT
  113. struct ts_cat * ts_cat_alloc ();
  114. struct ts_cat * ts_cat_push_packet (struct ts_cat *cat, uint8_t *ts_packet);
  115. void ts_cat_clear (struct ts_cat *cat);
  116. void ts_cat_free (struct ts_cat **cat);
  117. int ts_cat_parse (struct ts_cat *cat);
  118. void ts_cat_dump (struct ts_cat *cat);
  119. struct ts_cat * ts_cat_copy (struct ts_cat *cat);
  120. int ts_cat_is_same (struct ts_cat *cat1, struct ts_cat *cat2);
  121. enum CA_system ts_get_CA_sys (uint16_t CA_id);
  122. char * ts_get_CA_sys_txt (enum CA_system CA_sys);
  123. int ts_get_emm_info (struct ts_cat *cat, enum CA_system CA_sys, uint16_t *CA_id, uint16_t *CA_pid);
  124. int ts_get_ecm_info (struct ts_pmt *pmt, enum CA_system CA_sys, uint16_t *CA_id, uint16_t *CA_pid);
  125. // PMT
  126. struct ts_pmt * ts_pmt_alloc ();
  127. struct ts_pmt * ts_pmt_alloc_init (uint16_t org_network_id, uint16_t transport_stream_id);
  128. struct ts_pmt * ts_pmt_push_packet (struct ts_pmt *pmt, uint8_t *ts_packet);
  129. void ts_pmt_clear (struct ts_pmt *pmt);
  130. void ts_pmt_free (struct ts_pmt **pmt);
  131. int ts_pmt_parse (struct ts_pmt *pmt);
  132. void ts_pmt_dump (struct ts_pmt *pmt);
  133. void ts_pmt_generate (struct ts_pmt *pmt, uint8_t **ts_packets, int *num_packets);
  134. struct ts_pmt * ts_pmt_copy (struct ts_pmt *pmt);
  135. void ts_pmt_regenerate_packets (struct ts_pmt *pmt);
  136. int ts_pmt_is_same (struct ts_pmt *pmt1, struct ts_pmt *pmt2);
  137. // NIT
  138. struct ts_nit * ts_nit_alloc ();
  139. struct ts_nit * ts_nit_alloc_init (uint16_t network_id);
  140. struct ts_nit * ts_nit_push_packet (struct ts_nit *nit, uint8_t *ts_packet);
  141. void ts_nit_clear (struct ts_nit *nit);
  142. void ts_nit_free (struct ts_nit **nit);
  143. int ts_nit_parse (struct ts_nit *nit);
  144. void ts_nit_dump (struct ts_nit *nit);
  145. void ts_nit_generate (struct ts_nit *nit, uint8_t **ts_packets, int *num_packets);
  146. int ts_nit_add_network_name_descriptor (struct ts_nit *nit, char *network_name);
  147. int ts_nit_add_frequency_list_descriptor_cable (struct ts_nit *nit, uint16_t ts_id, uint16_t org_net_id, uint32_t *freqs, uint8_t num_freqs);
  148. int ts_nit_add_cable_delivery_descriptor (struct ts_nit *nit, uint16_t ts_id, uint16_t org_net_id, uint32_t freq, uint8_t modulation, uint32_t symbol_rate);
  149. int ts_nit_add_service_list_descriptor (struct ts_nit *nit, uint16_t ts_id, uint16_t org_net_id, uint32_t *services, uint8_t num_services);
  150. struct ts_nit * ts_nit_copy (struct ts_nit *nit);
  151. int ts_nit_is_same (struct ts_nit *nit1, struct ts_nit *nit2);
  152. // SDT
  153. struct ts_sdt * ts_sdt_alloc ();
  154. struct ts_sdt * ts_sdt_alloc_init (uint16_t org_network_id, uint16_t transport_stream_id);
  155. struct ts_sdt * ts_sdt_push_packet (struct ts_sdt *sdt, uint8_t *ts_packet);
  156. void ts_sdt_clear (struct ts_sdt *sdt);
  157. void ts_sdt_free (struct ts_sdt **sdt);
  158. int ts_sdt_parse (struct ts_sdt *sdt);
  159. void ts_sdt_dump (struct ts_sdt *sdt);
  160. void ts_sdt_generate (struct ts_sdt *sdt, uint8_t **ts_packets, int *num_packets);
  161. int ts_sdt_add_service_descriptor(struct ts_sdt *sdt, uint16_t service_id, uint8_t video, char *provider_name, char *service_name);
  162. struct ts_sdt * ts_sdt_copy (struct ts_sdt *sdt);
  163. int ts_sdt_is_same (struct ts_sdt *sdt1, struct ts_sdt *sdt2);
  164. // EIT
  165. struct ts_eit * ts_eit_alloc ();
  166. struct ts_eit * ts_eit_alloc_init (uint16_t service_id, uint16_t transport_stream_id, uint16_t org_network_id, uint8_t table_id, uint8_t sec_number, uint8_t last_sec_number);
  167. struct ts_eit * ts_eit_alloc_init_pf (uint16_t service_id, uint16_t transport_stream_id, uint16_t org_network_id, uint8_t sec_number, uint8_t last_sec_number); // Shortcut using table_id 0x4e
  168. struct ts_eit * ts_eit_alloc_init_schedule (uint16_t service_id, uint16_t transport_stream_id, uint16_t org_network_id, uint8_t sec_number, uint8_t last_sec_number); // Shortcut using table_id 0x50
  169. struct ts_eit * ts_eit_push_packet (struct ts_eit *eit, uint8_t *ts_packet);
  170. void ts_eit_clear (struct ts_eit *eit);
  171. void ts_eit_free (struct ts_eit **eit);
  172. int ts_eit_parse (struct ts_eit *eit);
  173. void ts_eit_dump (struct ts_eit *eit);
  174. void ts_eit_generate (struct ts_eit *eit, uint8_t **ts_packets, int *num_packets);
  175. struct ts_eit * ts_eit_copy (struct ts_eit *eit);
  176. void ts_eit_regenerate_packets (struct ts_eit *eit);
  177. int ts_eit_add_short_event_descriptor (struct ts_eit *eit, uint16_t event_id, uint8_t running, time_t start_time, int duration_sec, char *event_name, char *event_short_descr);
  178. int ts_eit_add_extended_event_descriptor(struct ts_eit *eit, uint16_t event_id, uint8_t running, time_t start_time, int duration_sec, char *text);
  179. int ts_eit_is_same (struct ts_eit *eit1, struct ts_eit *eit2);
  180. // TDT
  181. struct ts_tdt * ts_tdt_alloc();
  182. struct ts_tdt * ts_tdt_alloc_init (time_t ts);
  183. struct ts_tdt * ts_tot_alloc_init (time_t ts);
  184. void ts_tdt_clear (struct ts_tdt *tdt);
  185. void ts_tdt_free (struct ts_tdt **tdt);
  186. int ts_tdt_parse (struct ts_tdt *tdt);
  187. struct ts_tdt * ts_tdt_push_packet (struct ts_tdt *tdt, uint8_t *ts_packet);
  188. void ts_tdt_generate (struct ts_tdt *tdt, uint8_t **ts_packets, int *num_packets);
  189. void ts_tdt_dump (struct ts_tdt *tdt);
  190. void ts_tdt_set_time (struct ts_tdt *tdt, time_t ts);
  191. void ts_tot_set_localtime_offset (struct ts_tdt *tdt, time_t now, time_t change_time, uint8_t polarity, uint16_t ofs, uint16_t ofs_next);
  192. void ts_tot_set_localtime_offset_sofia (struct ts_tdt *tdt, time_t now);
  193. struct ts_tdt * ts_tdt_copy (struct ts_tdt *tdt);
  194. int ts_tdt_is_same (struct ts_tdt *tdt1, struct ts_tdt *tdt2);
  195. // Private section
  196. struct ts_privsec * ts_privsec_alloc();
  197. void ts_privsec_clear (struct ts_privsec *pprivsec);
  198. void ts_privsec_free (struct ts_privsec **pprivsec);
  199. struct ts_privsec * ts_privsec_push_packet (struct ts_privsec *privsec, uint8_t *ts_packet);
  200. int ts_privsec_is_same (struct ts_privsec *p1, struct ts_privsec *p2);
  201. void ts_privsec_dump (struct ts_privsec *privsec);
  202. void ts_privsec_copy (struct ts_privsec *src, struct ts_privsec *dst);
  203. // Time
  204. uint32_t ts_time_encode_bcd (int duration_sec);
  205. void ts_time_decode_bcd (int duration_bcd, int *duration_sec, int *hour, int *min, int *sec);
  206. void ts_time_encode_mjd (uint16_t *mjd, uint32_t *bcd, time_t *ts, struct tm *tm);
  207. time_t ts_time_decode_mjd (uint16_t mjd, uint32_t bcd, struct tm *tm);
  208. // Descriptors
  209. void ts_descriptor_dump (uint8_t *desc_data, int desc_data_len);
  210. int ts_is_stream_type_video (uint8_t stream_type);
  211. int ts_is_stream_type_ac3 (uint8_t stream_type);
  212. int ts_is_stream_type_audio (uint8_t stream_type);
  213. char * h222_stream_type_desc (uint8_t stream_type);
  214. char * h222_stream_id_desc (uint8_t stream_id);
  215. // PES
  216. struct ts_pes * ts_pes_alloc ();
  217. void ts_pes_clear (struct ts_pes *pes);
  218. void ts_pes_free (struct ts_pes **pes);
  219. void ts_pes_fill_type (struct ts_pes *pes, struct ts_pmt *pmt, uint16_t pid);
  220. int ts_pes_is_finished (struct ts_pes *pes, uint8_t *ts_packet);
  221. struct ts_pes * ts_pes_push_packet (struct ts_pes *pes, uint8_t *ts_packet, struct ts_pmt *pmt, uint16_t pid);
  222. int ts_pes_parse (struct ts_pes *pes);
  223. void ts_pes_dump (struct ts_pes *pes);
  224. struct pes_array * pes_array_alloc ();
  225. void pes_array_dump (struct pes_array *pa);
  226. void pes_array_free (struct pes_array **ppa);
  227. struct pes_entry * pes_array_push_packet (struct pes_array *pa, uint16_t pid, struct ts_pat *pat, struct ts_pmt *pmt, uint8_t *ts_packet);
  228. // ES functions
  229. int ts_pes_es_mpeg_audio_header_parse (struct mpeg_audio_header *mpghdr, uint8_t *data, int datasz);
  230. void ts_pes_es_mpeg_audio_header_dump (struct mpeg_audio_header *mpghdr);
  231. void ts_pes_es_parse (struct ts_pes *pes);
  232. void ts_pes_es_dump (struct ts_pes *pes);
  233. // CRC
  234. uint32_t ts_crc32 (uint8_t *data, int data_size);
  235. uint32_t ts_crc32_section (struct ts_section_header *section_header);
  236. int ts_crc32_section_check (struct ts_section_header *section_header, char *table);
  237. // Misc
  238. int dec2bcd (int dec);
  239. int bcd2dec (int bcd);
  240. void ts_compare_data (char *prefix, uint8_t *a, uint8_t *b, int size);
  241. void ts_hex_dump_buf (char *buf, int bufsz, uint8_t *d, int size, int col);
  242. char * ts_hex_dump (uint8_t *d, int size, int col);
  243. void ts_print_bytes (char *prefix, uint8_t *d, int size);
  244. char * init_dvb_string_utf8 (char *text);
  245. char * init_dvb_string_iso_8859_5 (char *text);
  246. int ts_is_psi_pid (uint16_t pid, struct ts_pat *pat);
  247. void pidmap_clear (pidmap_t *pm);
  248. void pidmap_set (pidmap_t *pm, uint16_t pid);
  249. void pidmap_set_val (pidmap_t *pm, uint16_t pid, uint8_t val);
  250. int pidmap_get (pidmap_t *pm, uint16_t pid);
  251. #endif