Merged revisions 284701 via svnmerge from
[asterisk/asterisk.git] / formats / format_h264.c
index 06def31..f8fe75c 100644 (file)
@@ -72,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)) {
@@ -104,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);
@@ -119,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;
        }
@@ -170,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
+);