]> git.sesse.net Git - ffmpeg/blobdiff - libavformat/rtp_aac.c
Revert the merger of LC_ALL declaration and export.
[ffmpeg] / libavformat / rtp_aac.c
index 267ed932d57475c42928fe637b2703655cb3334d..4cd8e129d23c324d6c2c4980d75d02bf56207aaa 100644 (file)
@@ -22,7 +22,7 @@
 #include "rtp_aac.h"
 #include "rtp_internal.h"
 
-#define MAX_FRAMES_PER_PACKET 5
+#define MAX_FRAMES_PER_PACKET (s->max_frames_per_packet ? s->max_frames_per_packet : 5)
 #define MAX_AU_HEADERS_SIZE (2 + 2 * MAX_FRAMES_PER_PACKET)
 
 void ff_rtp_send_aac(AVFormatContext *s1, const uint8_t *buff, int size)
@@ -67,6 +67,22 @@ void ff_rtp_send_aac(AVFormatContext *s1, const uint8_t *buff, int size)
         memcpy(s->buf_ptr, buff, size);
         s->buf_ptr += size;
     } else {
-        av_log(s1, AV_LOG_ERROR, "Unsupported!\n");
+        if (s->buf_ptr != s->buf + MAX_AU_HEADERS_SIZE) {
+            av_log(s1, AV_LOG_ERROR, "Strange...\n");
+            av_abort();
+        }
+        max_packet_size = s->max_payload_size - 4;
+        p = s->buf;
+        p[0] = 0;
+        p[1] = 16;
+        while (size > 0) {
+            len = FFMIN(size, max_packet_size);
+            p[2] = len >> 5;
+            p[3] = (size & 0x1F) << 3;
+            memcpy(p + 4, buff, len);
+            ff_rtp_send_data(s1, p, len + 4, len == size);
+            size -= len;
+            buff += len;
+        }
     }
 }