Allow ODBC storage to be queried with multiple mailboxes, and remove multiple goto's.
[asterisk/asterisk.git] / formats / format_h264.c
index 5beb826..fa938a8 100644 (file)
  * \brief Save to raw, headerless h264 data.
  * \arg File name extension: h264
  * \ingroup formats
  * \brief Save to raw, headerless h264 data.
  * \arg File name extension: h264
  * \ingroup formats
+ * \arg See \ref AstVideo
  */
  
  */
  
-#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.h"
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
 #include "asterisk.h"
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
-#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"
 
 /* Some Ideas for this code came from makeh264e.c by Jeffrey Chilton */
 
 /* Portions of the conversion code are by guido@sienanet.it */
 #include "asterisk/module.h"
 #include "asterisk/endian.h"
 
 /* Some Ideas for this code came from makeh264e.c by Jeffrey Chilton */
 
 /* Portions of the conversion code are by guido@sienanet.it */
+/*! \todo Check this buf size estimate, it may be totally wrong for large frame video */
+
 #define BUF_SIZE       4096    /* Two Real h264 Frames */
 struct h264_desc {
        unsigned int lastts;
 #define BUF_SIZE       4096    /* Two Real h264 Frames */
 struct h264_desc {
        unsigned int lastts;
@@ -69,7 +59,7 @@ static struct ast_frame *h264_read(struct ast_filestream *s, int *whennext)
        int mark=0;
        unsigned short len;
        unsigned int ts;
        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)
 
        /* Send a frame from the file to the appropriate channel */
        if ((res = fread(&len, 1, sizeof(len), s->f)) < 1)
@@ -84,8 +74,8 @@ static struct ast_frame *h264_read(struct ast_filestream *s, int *whennext)
        s->fr.frametype = AST_FRAME_VIDEO;
        s->fr.subclass = AST_FORMAT_H264;
        s->fr.mallocd = 0;
        s->fr.frametype = AST_FRAME_VIDEO;
        s->fr.subclass = AST_FORMAT_H264;
        s->fr.mallocd = 0;
-       FR_SET_BUF(&s->fr, s->buf, AST_FRIENDLY_OFFSET, len);
-       if ((res = fread(s->fr.data, 1, s->fr.datalen, s->f)) != s->fr.datalen) {
+       AST_FRAME_SET_BUFFER(&s->fr, s->buf, AST_FRIENDLY_OFFSET, len);
+       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;
                if (res)
                        ast_log(LOG_WARNING, "Short read (%d of %d) (%s)!\n", res, len, strerror(errno));
                return NULL;
@@ -129,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;
        }
                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;
        }
                ast_log(LOG_WARNING, "Bad write (%d/%d): %s\n", res, f->datalen, strerror(errno));
                return -1;
        }
@@ -156,8 +146,6 @@ static off_t h264_tell(struct ast_filestream *fs)
        return offset; /* XXX totally bogus, needs fixing */
 }
 
        return offset; /* XXX totally bogus, needs fixing */
 }
 
-static struct ast_format_lock me = { .usecnt = -1 };
-
 static const struct ast_format h264_f = {
        .name = "h264",
        .exts = "h264",
 static const struct ast_format h264_f = {
        .name = "h264",
        .exts = "h264",
@@ -170,30 +158,18 @@ static const struct ast_format h264_f = {
        .read = h264_read,
        .buf_size = BUF_SIZE + AST_FRIENDLY_OFFSET,
        .desc_size = sizeof(struct h264_desc),
        .read = h264_read,
        .buf_size = BUF_SIZE + AST_FRIENDLY_OFFSET,
        .desc_size = sizeof(struct h264_desc),
-       .lockp = &me,
 };
 
 };
 
-int load_module()
+static int load_module(void)
 {
 {
-       return ast_format_register(&h264_f);
+       if (ast_format_register(&h264_f))
+               return AST_MODULE_LOAD_FAILURE;
+       return AST_MODULE_LOAD_SUCCESS;
 }
 
 }
 
-int unload_module()
+static int unload_module(void)
 {
        return ast_format_unregister(h264_f.name);
 }      
 
 {
        return ast_format_unregister(h264_f.name);
 }      
 
-int usecount()
-{
-       return me.usecnt;
-}
-
-char *description()
-{
-       return "Raw h264 data";
-}
-
-char *key()
-{
-       return ASTERISK_GPL_KEY;
-}
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Raw H.264 data");