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.

tstest.c 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. #include "tsfuncs.h"
  2. #define NOW 1234567890
  3. #define NOW2 1000000000
  4. void ts_pat_test() {
  5. struct ts_pat *pat = ts_pat_alloc_init(0x7878);
  6. ts_pat_dump(pat);
  7. ts_pat_add_program(pat, 1, 0x100);
  8. ts_pat_add_program(pat, 2, 0x100);
  9. ts_pat_add_program(pat, 3, 0x100);
  10. ts_pat_dump(pat);
  11. ts_pat_del_program(pat, 2);
  12. ts_pat_dump(pat);
  13. ts_pat_del_program(pat, 3);
  14. ts_pat_dump(pat);
  15. int i;
  16. for (i=0;i<10;i++) {
  17. ts_pat_add_program(pat, i+10, (i+5)*10);
  18. }
  19. ts_pat_dump(pat);
  20. ts_pat_free(&pat);
  21. }
  22. int ts_tdt_tot_test() {
  23. struct ts_tdt *tdt = ts_tdt_alloc_init(NOW);
  24. struct ts_tdt *tot = ts_tot_alloc_init(time(NULL));
  25. ts_tdt_dump(tdt);
  26. ts_tdt_dump(tot);
  27. ts_tdt_set_time(tdt, NOW2);
  28. ts_tdt_dump(tdt);
  29. ts_tot_set_localtime_offset_sofia(tot);
  30. ts_tdt_dump(tot);
  31. ts_tdt_free(&tdt);
  32. ts_tdt_free(&tot);
  33. return 0;
  34. }
  35. int ts_sdt_test() {
  36. struct ts_sdt *sdt = ts_sdt_alloc_init(1, 2);
  37. ts_sdt_add_service_descriptor(sdt, 1007, 1, "BULSATCOM", "bTV");
  38. ts_sdt_dump(sdt);
  39. int i;
  40. for (i=0;i<25;i++) {
  41. ts_sdt_add_service_descriptor(sdt, 9, 0, "PROVIDER", "SERVICE33333333333333333333333333333333333333333333333333333333333333");
  42. ts_sdt_add_service_descriptor(sdt, 13, 0, "PROddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddVIDER", "SERVICE");
  43. ts_sdt_add_service_descriptor(sdt, 7, 0, "PROVIDER", "SERVICE");
  44. }
  45. ts_sdt_dump(sdt);
  46. // write(1, sdt->section_header->packet_data, sdt->section_header->num_packets * 188);
  47. ts_sdt_free(&sdt);
  48. return 0;
  49. }
  50. void ts_eit_test1(struct ts_eit *eit) { // Exactly one TS packet (188 bytes)
  51. //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) {
  52. ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600,
  53. "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
  54. "yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy****");
  55. }
  56. void ts_eit_test2(struct ts_eit *eit) { // One TS packet + 2 bytes (2 bytes of the CRC are in the next packet
  57. ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600,
  58. "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
  59. "yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy**");
  60. }
  61. void ts_eit_test3(struct ts_eit *eit) { // Test 4096 PSI packet
  62. int i;
  63. for (i=0;i<15;i++) {
  64. // Maximum descriptor size, 255 bytes
  65. if (ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600, "zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz", "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx") != 1) {
  66. break;
  67. }
  68. }
  69. ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600, "00000000000000000000000", "1111111111111111111111111111111");
  70. }
  71. void ts_eit_test4(struct ts_eit *eit) { // Test almost full PSI packet on the TS packet boundary
  72. int i;
  73. for (i=0;i<15;i++) {
  74. // Maximum descriptor size, 255 bytes
  75. if (ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600, "zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz", "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx") != 1) {
  76. break;
  77. }
  78. }
  79. ts_eit_add_short_event_descriptor(eit, 4, 1, NOW, 3600, "aaaaaaaaBBBB", NULL);
  80. }
  81. void ts_eit_test() {
  82. struct ts_eit *eit;
  83. eit = ts_eit_alloc_init(1, 2, 3, 1, 0, 0);
  84. ts_eit_test1(eit);
  85. ts_eit_dump(eit);
  86. ts_eit_free(&eit);
  87. eit = ts_eit_alloc_init(1, 2, 3, 1, 0, 0);
  88. ts_eit_test2(eit);
  89. ts_eit_dump(eit);
  90. ts_eit_free(&eit);
  91. eit = ts_eit_alloc_init(1, 2, 3, 1, 0, 0);
  92. ts_eit_test3(eit);
  93. ts_eit_dump(eit);
  94. ts_eit_free(&eit);
  95. eit = ts_eit_alloc_init(1, 2, 3, 1, 0, 0);
  96. ts_eit_test4(eit);
  97. ts_eit_dump(eit);
  98. ts_eit_free(&eit);
  99. // write(1, eit->section_header->packet_data, eit->section_header->num_packets * TS_PACKET_SIZE);
  100. }
  101. int main() {
  102. ts_pat_test();
  103. ts_tdt_tot_test();
  104. ts_sdt_test();
  105. ts_eit_test();
  106. return 0;
  107. }