2010-12-15 25 views
8

Wdrażam specyfikację ATSC-153, która zasadniczo nadaje podstawowy profil wideo H.264 w IP/UDP/RTP zgodnie z RFC 3984. Fragmenty ramki są ponownie montowane, a większość z nich gra na wbudowanym procesorze, z którym pracuję, aczkolwiek z pewną korupcją, która ma miejsce z jakiegoś powodu, który próbuję wyśledzić. Próbuję enkapsulate to do MPEG-TS w celu renderowania go w systemie Windows (VLC) dla niektórych porównania i mam pewne trudności z jakiegoś powodu. VLC, TSReader i MPEG2Repair nie mogą znaleźć wideo z jakiegoś powodu. Kroki, które robię są następujące, które są takie same dla otrzymywanych ramek SPS lub PPS H.264.MPEG-ES H.264 Wideo z RTP na MPEG-TS

  1. Tworzenie PAT/PMT PID PMT 0x11 typu wideo jest 0x1b, video PID jest 0x280 i PCR PID jest 0x1fff (no PCR). Właściwie to przez to co 15 klatek.

  2. Dołączam do ramki ogranicznik jednostki dostępu, numer NAL 9. Myślę, że to ma być dołączone do wszystkich ramek H.264 w transporcie. Typ podstawowy pic to 1 (0x30 bajt), który odpowiadałby I, P profilu bazowego.

  3. Dołączam do tego ramkę nagłówka PES, która ma PTS z nagłówka RTP.

  4. Dołączam 4 bajtowy nagłówek TS. Na początku ramki ustawiam bit PUS. Mam 4-bitowy licznik dla sekwencji.

  5. Wszelkie pozostałe bajty niepodzielne przez 184, wstawiłem do pakietu TS z polem adaptacyjnym (zestaw długości, bajt flag ustawiony na 0) wyściełanym (lub wypchanym) do pozostałych bajtów.

Upewniam się, że strumień rozpoczyna się ramką SPS. Dla mojego zrozumienia (które może nie być świetne), powinno to zawierać rzeczywisty obraz. Ramki SPS mają 15 KB lub więcej w strumieniu. Oto zrzut pierwszego pakietu TS:

000 47 42 80 15 00 00 01 E0 00 00 81 80 05 21 AA BB 
010 9A 91 00 00 00 01 09 30 00 00 00 01 67 42 C0 14 
020 9A 44 0D 0F 9F F8 00 08 00 08 04 00 00 00 01 68 
030 DE 24 88 00 00 00 01 E6 87 26 D6 AC FA 58 78 24 
040 0E EB B5 5B 02 AF 6C EB E1 E4 9F 35 BD 61 56 F8 
050 4A 4E 58 00 00 01 65 88 80 20 20 9E 1D 60 20 61 
060 15 D8 02 70 F9 29 C0 00 40 C6 23 3A 76 CA 78 9A 
070 4D 7D 79 C1 6E 94 3E A8 76 50 4B F7 B5 B0 40 2B 
080 52 48 93 B1 A2 4A 4F 3D 14 F1 B8 7E FA 98 91 FE 
090 DC EB 0F 11 BF EB D1 B8 E0 3F 5A C2 91 2D FA 83 
0A0 03 EF 51 10 18 D6 D4 77 90 78 97 D5 BF 94 61 6D 
0B0 69 53 AF 5B 42 FE D7 A3 9D 21 81 FC 

W powyższym pakiecie faktyczna ramka wideo, którą otrzymałem, zaczyna się od przesunięcia 0x18. Wszystko wcześniej dodałem. 00 00 00 01 67 powinien wskazywać SPS.

Na ramie PPS, które zwykle uruchamiane 3Kbytes do 4Kbytes, oto zrzut z niego:

000 47 42 80 19 00 00 01 E0 00 00 81 80 05 21 AA BB 
010 F8 51 00 00 00 01 09 30 00 00 00 01 41 9A 01 05 
020 0F FF F4 3D FE 9B 0F 5E BE 18 15 20 00 50 0D 51 
030 58 32 47 F5 E7 86 1B 43 A6 FC F5 CA 64 A6 7F CF 
040 CB 94 C8 1F F2 FF 51 F7 7D DD DF 51 97 C7 C2 97 
050 77 77 77 BB B4 8B E9 B8 F9 70 D7 75 7A FF D8 64 
060 E8 C1 CE 06 83 58 20 24 00 06 66 70 BC DB C3 8D 
070 8E 6D FC 8C 5D EE 0D CC 63 61 13 BB F3 0F 0D 9F 
080 28 82 54 E4 A2 1C 21 55 BF F3 C1 86 7D 90 47 52 
090 5F C2 C6 E2 A7 3B 5E E0 A1 5B A2 C3 24 05 97 17 
0A0 A1 B2 04 22 78 F0 6F 0C DA 85 DC 7C E3 69 85 2B 
0B0 AC 02 02 01 9C 5B 11 DC B5 85 44 CE 

mogę się spodziewać dopiero w tym momencie brakuje mi czegoś, co jest potrzebne, mam zrobić coś niepoprawnie, lub coś z ponownym montażem RFC 3984 idzie tak straszliwie źle, więc dekodery nie rozpoznają tego jako wideo.

Zacznę od zadania dwóch pierwszych pytań. Czy jest coś z specyfikacji, których mi brakuje? Czy zaimplementowałem to poprawnie, jak widać z wysypisk?

Wielkie dzięki.

+0

Wiele przeprosin za wysypiska, nie weszły tak, jak myślałem, że powinny. – davroslyrad

+0

Wielkie dzięki osgx za sformatowanie tego dla mnie. Nadal jestem bardzo początkującym. – davroslyrad

Odpowiedz

5

Cóż, ogólnie to rozgryzłem. Problem dotyczył PMT, którego nie dostarczyłem. Powyższe enkapsulacje są poprawne. Po naprawieniu PMT strumień jest odtwarzany na tablicy docelowej.