Merged revisions 284701 via svnmerge from
[asterisk/asterisk.git] / formats / format_h264.c
index e2bc36c..f8fe75c 100644 (file)
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
-#include <unistd.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-#include <stdlib.h>
-#include <sys/time.h>
-#include <stdio.h>
-#include <errno.h>
-#include <string.h>
-
-#include "asterisk/lock.h"
-#include "asterisk/channel.h"
-#include "asterisk/file.h"
-#include "asterisk/logger.h"
-#include "asterisk/sched.h"
+#include "asterisk/mod_format.h"
 #include "asterisk/module.h"
 #include "asterisk/endian.h"
 
@@ -72,7 +59,7 @@ static struct ast_frame *h264_read(struct ast_filestream *s, int *whennext)
        int mark=0;
        unsigned short len;
        unsigned int ts;
-       struct h264_desc *fs = (struct h264_desc *)s->private;
+       struct h264_desc *fs = (struct h264_desc *)s->_private;
 
        /* Send a frame from the file to the appropriate channel */
        if ((res = fread(&len, 1, sizeof(len), s->f)) < 1)
@@ -85,17 +72,17 @@ static struct ast_frame *h264_read(struct ast_filestream *s, int *whennext)
                len = BUF_SIZE; /* XXX truncate */
        }
        s->fr.frametype = AST_FRAME_VIDEO;
-       s->fr.subclass = AST_FORMAT_H264;
+       s->fr.subclass.codec = AST_FORMAT_H264;
        s->fr.mallocd = 0;
        AST_FRAME_SET_BUFFER(&s->fr, s->buf, AST_FRIENDLY_OFFSET, len);
-       if ((res = fread(s->fr.data, 1, s->fr.datalen, s->f)) != s->fr.datalen) {
+       if ((res = fread(s->fr.data.ptr, 1, s->fr.datalen, s->f)) != s->fr.datalen) {
                if (res)
                        ast_log(LOG_WARNING, "Short read (%d of %d) (%s)!\n", res, len, strerror(errno));
                return NULL;
        }
        s->fr.samples = fs->lastts;
        s->fr.datalen = len;
-       s->fr.subclass |= mark;
+       s->fr.subclass.codec |= mark;
        s->fr.delivery.tv_sec = 0;
        s->fr.delivery.tv_usec = 0;
        if ((res = fread(&ts, 1, sizeof(ts), s->f)) == sizeof(ts)) {
@@ -117,9 +104,9 @@ static int h264_write(struct ast_filestream *s, struct ast_frame *f)
                ast_log(LOG_WARNING, "Asked to write non-video frame!\n");
                return -1;
        }
-       mark = (f->subclass & 0x1) ? 0x8000 : 0;
-       if ((f->subclass & ~0x1) != AST_FORMAT_H264) {
-               ast_log(LOG_WARNING, "Asked to write non-h264 frame (%d)!\n", f->subclass);
+       mark = (f->subclass.codec & 0x1) ? 0x8000 : 0;
+       if ((f->subclass.codec & ~0x1) != AST_FORMAT_H264) {
+               ast_log(LOG_WARNING, "Asked to write non-h264 frame (%s)!\n", ast_getformatname(f->subclass.codec));
                return -1;
        }
        ts = htonl(f->samples);
@@ -132,7 +119,7 @@ static int h264_write(struct ast_filestream *s, struct ast_frame *f)
                ast_log(LOG_WARNING, "Bad write (%d/2): %s\n", res, strerror(errno));
                return -1;
        }
-       if ((res = fwrite(f->data, 1, f->datalen, s->f)) != f->datalen) {
+       if ((res = fwrite(f->data.ptr, 1, f->datalen, s->f)) != f->datalen) {
                ast_log(LOG_WARNING, "Bad write (%d/%d): %s\n", res, f->datalen, strerror(errno));
                return -1;
        }
@@ -183,6 +170,10 @@ static int load_module(void)
 static int unload_module(void)
 {
        return ast_format_unregister(h264_f.name);
-}      
+}
 
-AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Raw H.264 data");
+AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_LOAD_ORDER, "Raw H.264 data",
+       .load = load_module,
+       .unload = unload_module,
+       .load_pri = AST_MODPRI_APP_DEPEND
+);