Estoy implementando la especificación ATSC-153, que básicamente transmite un perfil de video H.264 de línea de base en IP/UDP/RTP según RFC 3984. Los fragmentos del los marcos se vuelven a ensamblar, y en su mayor parte se reproducen en el procesador integrado con el que estoy trabajando, aunque con cierta corrupción que está ocurriendo por alguna razón que estoy intentando rastrear. Estoy tratando de encapsular esto en un MPEG-TS para renderizarlo en Windows (VLC) para una comparación, y estoy teniendo dificultades por alguna razón. VLC, TSReader y MPEG2Repair no pueden encontrar el video por alguna razón. Los pasos que estoy haciendo son los siguientes, que son los mismos para las tramas SPS o PPS H.264 que estoy recibiendo.MPEG-ES H.264 Video de RTP a MPEG-TS
Crear una PAT/PMT, PMT PID 0x11, tipo de vídeo es 0x1b, vídeo PID es 0x280, y PCR pid es 0x1FFF (sin PCR). En realidad, paso esto en cada 15 fotogramas más o menos.
Anexo al marco el delimitador de la unidad de acceso, NAL número 9. Creo que se supone que debe anexarse a todos los cuadros H.264 en un transporte. El tipo de imagen principal es 1 (0x30 bytes), que correspondería al I, P del perfil de referencia.
Añado a esto un marco de encabezado PES, que tiene el PTS del encabezado RTP.
Añado el encabezado TS de 4 bytes. Al comienzo del cuadro, configuré el bit PUS. Guardo un contador de 4 bits para la secuencia.
Cualquier exceso de bytes no divisible por 184, puse en un paquete de TS con un campo de adaptación (conjunto de longitud, byte de indicador puesto a 0) rellenado (o rellenado) con los bytes restantes.
Me aseguro de que la transmisión comience con un marco SPS. A mi entender (que puede no ser tan bueno), esto debería contener una imagen real. Las tramas SPS tienen 15K bytes más o menos en la transmisión. Aquí es un basurero del primer paquete 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
En el paquete anterior, el fotograma de vídeo real que he recibido se inicia en el desplazamiento 0x18. Todo antes de eso, agregué. El 00 00 00 01 67 debe indicar SPS.
Para el marco de PPS, que normalmente se ejecuta 3Kbytes a 4Kbytes, el siguiente es el volcado de él:
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
Sólo puedo esperar que en este momento me estoy perdiendo algo que se necesita, he hecho algo incorrectamente, o algo con el reensamblaje RFC 3984 está yendo terriblemente mal tanto que los decodificadores no reconocen esto como video.
Entonces, comenzaré haciendo las dos primeras preguntas. ¿Hay algo de las especificaciones que me estoy perdiendo? ¿Implementé esto correctamente como se ve desde los vertederos?
Muchas gracias.
Muchas disculpas por los vertederos, no entraron como pensé que debían. – davroslyrad
Muchas gracias osgx por reformatear esto para mí. Todavía soy un novato. – davroslyrad