start using asterisk/network.h for network related headers.
[asterisk/asterisk.git] / formats / format_h264.c
index 3e35808..05b2624 100644 (file)
  * \brief Save to raw, headerless h264 data.
  * \arg File name extension: h264
  * \ingroup formats
+ * \arg See \ref AstVideo
  */
  
-#include <unistd.h>
+#include "asterisk.h"
+
+ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
+
 #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/lock.h"
 #include "asterisk/channel.h"
@@ -47,6 +44,8 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 /* 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;
@@ -84,7 +83,7 @@ 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;
-       FR_SET_BUF(&s->fr, s->buf, AST_FRIENDLY_OFFSET, len);
+       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)
                        ast_log(LOG_WARNING, "Short read (%d of %d) (%s)!\n", res, len, strerror(errno));
@@ -156,8 +155,6 @@ static off_t h264_tell(struct ast_filestream *fs)
        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",
@@ -170,30 +167,18 @@ static const struct ast_format h264_f = {
        .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);
 }      
 
-int usecount()
-{
-       return me.usecnt;
-}
-
-const char *description()
-{
-       return "Raw h264 data";
-}
-
-const char *key()
-{
-       return ASTERISK_GPL_KEY;
-}
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Raw H.264 data");