[FFmpeg-cvslog] rtp: Factorize the check for distinguishing RTCP packets from RTP

Martin Storsjö git at videolan.org
Fri Feb 17 00:45:06 CET 2012


ffmpeg | branch: master | Martin Storsjö <martin at martin.st> | Thu Feb 16 17:31:03 2012 +0100| [298a587f447fbc9103f66a50b8433aab977afc9b] | committer: Martin Storsjö

rtp: Factorize the check for distinguishing RTCP packets from RTP

The binary doesn't change after this patch.

Signed-off-by: Martin Storsjö <martin at martin.st>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=298a587f447fbc9103f66a50b8433aab977afc9b
---

 libavformat/movenchint.c |    2 +-
 libavformat/rtp.h        |    2 ++
 libavformat/rtpdec.c     |    2 +-
 libavformat/rtpproto.c   |    2 +-
 libavformat/rtsp.c       |    2 +-
 libavformat/rtspenc.c    |    2 +-
 6 files changed, 7 insertions(+), 5 deletions(-)

diff --git a/libavformat/movenchint.c b/libavformat/movenchint.c
index f3eb0f2..579d040 100644
--- a/libavformat/movenchint.c
+++ b/libavformat/movenchint.c
@@ -333,7 +333,7 @@ static int write_hint_packets(AVIOContext *out, const uint8_t *data,
         size -= 4;
         if (packet_len > size || packet_len <= 12)
             break;
-        if (data[1] >= RTCP_SR && data[1] <= RTCP_APP) {
+        if (RTP_PT_IS_RTCP(data[1])) {
             /* RTCP packet, just skip */
             data += packet_len;
             size -= packet_len;
diff --git a/libavformat/rtp.h b/libavformat/rtp.h
index e619008..e9f8778 100644
--- a/libavformat/rtp.h
+++ b/libavformat/rtp.h
@@ -91,4 +91,6 @@ enum RTCPType {
     RTCP_APP   // 204
 };
 
+#define RTP_PT_IS_RTCP(x) ((x) >= RTCP_SR && (x) <= RTCP_APP)
+
 #endif /* AVFORMAT_RTP_H */
diff --git a/libavformat/rtpdec.c b/libavformat/rtpdec.c
index 668755b..a8c5c3f 100644
--- a/libavformat/rtpdec.c
+++ b/libavformat/rtpdec.c
@@ -695,7 +695,7 @@ static int rtp_parse_one_packet(RTPDemuxContext *s, AVPacket *pkt,
 
     if ((buf[0] & 0xc0) != (RTP_VERSION << 6))
         return -1;
-    if (buf[1] >= RTCP_SR && buf[1] <= RTCP_APP) {
+    if (RTP_PT_IS_RTCP(buf[1])) {
         return rtcp_parse_packet(s, buf, len);
     }
 
diff --git a/libavformat/rtpproto.c b/libavformat/rtpproto.c
index 03794ae..c93de4a 100644
--- a/libavformat/rtpproto.c
+++ b/libavformat/rtpproto.c
@@ -266,7 +266,7 @@ static int rtp_write(URLContext *h, const uint8_t *buf, int size)
     int ret;
     URLContext *hd;
 
-    if (buf[1] >= RTCP_SR && buf[1] <= RTCP_APP) {
+    if (RTP_PT_IS_RTCP(buf[1])) {
         /* RTCP payload type */
         hd = s->rtcp_hd;
     } else {
diff --git a/libavformat/rtsp.c b/libavformat/rtsp.c
index f8611de..359d910 100644
--- a/libavformat/rtsp.c
+++ b/libavformat/rtsp.c
@@ -1927,7 +1927,7 @@ static int rtp_read_header(AVFormatContext *s)
             continue;
         }
 
-        if (recvbuf[1] >= RTCP_SR && recvbuf[1] <= RTCP_APP)
+        if (RTP_PT_IS_RTCP(recvbuf[1]))
             continue;
 
         payload_type = recvbuf[1] & 0x7f;
diff --git a/libavformat/rtspenc.c b/libavformat/rtspenc.c
index 86621cf..6c14fe6 100644
--- a/libavformat/rtspenc.c
+++ b/libavformat/rtspenc.c
@@ -159,7 +159,7 @@ static int tcp_write_packet(AVFormatContext *s, RTSPStream *rtsp_st)
         size -= 4;
         if (packet_len > size || packet_len < 2)
             break;
-        if (ptr[1] >= RTCP_SR && ptr[1] <= RTCP_APP)
+        if (RTP_PT_IS_RTCP(ptr[1]))
             id = rtsp_st->interleaved_max; /* RTCP */
         else
             id = rtsp_st->interleaved_min; /* RTP */



More information about the ffmpeg-cvslog mailing list