从RTP到MPEG-TS的MPEG-ES H.264视频

时间:2010-12-15 23:39:48

标签: video-streaming h.264 mpeg

我正在实施ATSC-153规范,该规范基本上根据RFC 3984在IP / UDP / RTP中广播基线H.264视频配置文件。帧的片段正在重新组装,并且大部分播放在我正在使用的嵌入式处理器上,尽管由于某种原因我正试图追踪的一些腐败现象正在发生。我试图将其封装到MPEG-TS中以便在Windows(VLC)上进行渲染以进行一些比较,并且由于某种原因我遇到了困难。由于某种原因,VLC,TSReader和MPEG2Repair无法找到视频。我正在做的步骤如下,对于我收到的SPS或PPS H.264帧都是一样的。

  1. 创建PAT / PMT,PMT PID 0x11,视频类型为0x1b,视频PID为0x280,PCR pid为0x1fff(无pcr)。实际上,我每15帧左右通过一次。

  2. 我在帧中附加了访问单元分隔符,NAL号9.我认为这应该附加到传输中的所有H.264帧。主要的pic类型是1(0x30字节),它对应于基线配置文件的I,P。

  3. 我附加了一个PES标题帧,它有来自RTP标题的PTS。

  4. 我追加4字节的TS标头。在帧的开头,我设置了PUS位。我为序列保留了一个4位计数器。

  5. 任何不能被184整除的剩余字节,我将一个带有适配字段(长度设置,标志字节设置为0)的TS数据包填充(或填充)到剩余字节。

    < / LI>

    我确保流以SPS帧开头。根据我的理解(可能不是很好),这应该包含一个实际的图片。 SPS帧在流中是15K字节左右。这是第一个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 
    

    在上面的数据包中,我收到的实际视频帧从偏移量0x18开始。之前的一切我都补充说。 00 00 00 01 67应指示SPS。

    对于PPS帧,通常运行3K字节到4K字节,以下是它的转储:

    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 
    

    我只能期望在这一点上我错过了所需要的东西,我做错了什么,或者RFC 3984重新组装的事情发生了可怕的错误,因此解码器不会将其识别为视频。

    所以,我先问问前两个问题。我缺少什么样的规格?从转储中看到我是否正确实现了这个?

    非常感谢。

1 个答案:

答案 0 :(得分:5)

嗯,总的来说,我想出来了。问题在于PMT,我没有提供转储。上面的封装是正确的。一旦我修复了PMT,流就会在目标板上播放。