changeset 28879:fad277267be5

Get rid of nuppelvideo.h and its ugly packed struct and instead write the frame header directly in nuv encoder.
author reimar
date Mon, 09 Mar 2009 15:01:12 +0000
parents 2f71bc5f5f12
children fa0b56ac4423
files libmpcodecs/ve_nuv.c libmpdemux/nuppelvideo.h
diffstat 2 files changed, 17 insertions(+), 98 deletions(-) [+]
line wrap: on
line diff
--- a/libmpcodecs/ve_nuv.c	Mon Mar 09 14:49:17 2009 +0000
+++ b/libmpcodecs/ve_nuv.c	Mon Mar 09 15:01:12 2009 +0000
@@ -19,7 +19,7 @@
 #include "mp_image.h"
 #include "vf.h"
 
-#include "libmpdemux/nuppelvideo.h"
+#include "libavutil/intreadwrite.h"
 #include <lzo/lzo1x.h>
 #include "native/rtjpegn.h"
 
@@ -68,6 +68,7 @@
 
 
 #define COMPDATASIZE (128*4)
+#define FRAMEHEADERSIZE 12
 
 static int config(struct vf_instance_s* vf,
         int width, int height, int d_width, int d_height,
@@ -102,13 +103,13 @@
 }
 
 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi, double pts){
-  struct rtframeheader* ench = (struct rtframeheader*)vf->priv->buffer;
+  uint8_t *header  = vf->priv->buffer;
   uint8_t* data = vf->priv->buffer + FRAMEHEADERSIZE;
   uint8_t* zdata = vf->priv->zbuffer + FRAMEHEADERSIZE;
   int len = 0, r;
   size_t zlen = 0;
 
-  memset(vf->priv->buffer,0,FRAMEHEADERSIZE); // Reset the header
+  memset(header, 0, FRAMEHEADERSIZE); // Reset the header
   if(vf->priv->lzo)
     memset(vf->priv->zbuffer,0,FRAMEHEADERSIZE);
     
@@ -117,15 +118,14 @@
     RTjpeg_init_compress((uint32_t *)data,mpi->width,mpi->height,vf->priv->q);
     RTjpeg_init_mcompress();
 
-    ench->frametype = 'D'; // compressor data
-    ench->comptype  = 'R'; // compressor data for RTjpeg
-    ench->packetlength = COMPDATASIZE;
+    header[0] = 'D'; // frametype: compressor data
+    header[1] = 'R'; // comptype:  compressor data for RTjpeg
+    AV_WL32(header + 8, COMPDATASIZE); // packetlength
   
-    le2me_rtframeheader(ench);
     mux_v->buffer=vf->priv->buffer;
     muxer_write_chunk(mux_v,FRAMEHEADERSIZE + COMPDATASIZE, 0x10, MP_NOPTS_VALUE, MP_NOPTS_VALUE);
     vf->priv->tbl_wrote = 1;
-    memset(ench,0,FRAMEHEADERSIZE); // Reset the header
+    memset(header, 0, FRAMEHEADERSIZE); // Reset the header
   }
 
   // Raw picture
@@ -143,10 +143,10 @@
 
     if(zlen <= 0 || zlen > len) {
       memcpy(data,mpi->planes[0],len);
-      ench->comptype = '0';
+      header[1] = '0'; // comptype: uncompressed
     } else { // Use lzo only if it's littler
-      ench = (struct rtframeheader*)vf->priv->zbuffer;
-      ench->comptype = '3';
+      header = vf->priv->zbuffer;
+      header[1] = '3'; //comptype: lzo
       len = zlen;
     }
 
@@ -167,19 +167,18 @@
     }
 
     if(zlen <= 0 || zlen > len)
-      ench->comptype = '1';
+      header[1] = '1'; // comptype: RTjpeg
     else {
-      ench = (struct rtframeheader*)vf->priv->zbuffer;
-      ench->comptype = '2';
+      header = vf->priv->zbuffer;
+      header[1] = '2'; // comptype: RTjpeg + LZO
       len = zlen;
     }
 
   }
     
-  ench->frametype = 'V'; // video frame
-  ench->packetlength = len;
-  le2me_rtframeheader(ench);
-  mux_v->buffer=(void*)ench;
+  header[0] = 'V'; // frametype: video frame
+  AV_WL32(header + 8, len); // packetlength
+  mux_v->buffer = header;
   muxer_write_chunk(mux_v, len + FRAMEHEADERSIZE, 0x10, pts, pts);
   return 1;
 }
--- a/libmpdemux/nuppelvideo.h	Mon Mar 09 14:49:17 2009 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,80 +0,0 @@
-/*
-   nuppelvideo.h taken from NuppelVideo, by
-   (c) Roman Hochleitner roman@mars.tuwien.ac.at
-
-    This program is free software; you can redistribute it and/or modify
-    it under the terms of the GNU General Public License as published by
-    the Free Software Foundation; either version 2 of the License, or
-    (at your option) any later version.
-
-    This program is distributed in the hope that it will be useful,
-    but WITHOUT ANY WARRANTY; without even the implied warranty of
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-    GNU General Public License for more details.
-
-    You should have received a copy of the GNU General Public License
-    along with this program; if not, write to the Free Software
-    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-*/
-
-#ifndef MPLAYER_NUPPELVIDEO_H
-#define MPLAYER_NUPPELVIDEO_H
-
-typedef struct  __attribute__((packed)) rtframeheader
-{
-   char frametype;			// A .. Audio, V .. Video, S .. Sync, T .. Text
-   					// R .. Seekpoint: String RTjjjjjjjj (use full packet)
-					// D .. Addition Data for Compressors
-   					//      ct: R .. RTjpeg Tables
-
-   char comptype;			// V: 0 .. Uncompressed [NI]
-					//    1 .. RTJpeg
-					//    2 .. RTJpeg with lzo afterwards
-					//    N .. black frame
-					//    L .. simply copy last frame (if lost frames)
-    					// A: 0 .. Uncompressed (44100/sec 16bit 2ch)
-    					//    1 .. lzo compression [NI]
-    					//    2 .. layer2 (packet) [NI]
-    					//    3 .. layer3 (packet) [NI]
-    					//    F .. flac (lossless) [NI]
-    					//    S .. shorten (lossless) [NI]
-					//    N .. null frame loudless
-					//    L .. simply copy last frame (may sound bad) NI
-					// S: B .. Audio and Video sync point [NI]
-                                        //    A .. Audio Sync Information
-					//         timecode == effective dsp-frequency*100
-					//         when reaching this audio sync point
-					//         because many cheap soundcards are unexact 
-					//         and have a range from 44000 to 44250
-					//         instead of the expected exact 44100 S./sec
-					//    V .. Next Video Sync 
-					//         timecode == next video framenumber
-					//    S .. Audio,Video,Text Correlation [NI]
-   char keyframe;			//    0 .. keyframe
-					//    1 .. nr of frame in gop => no keyframe
-
-   char filters;			//    Every bit stands for one type of filter
-					//    1 .. Gauss 5 Pixel (8*m+2*l+2*r+2*a+2*b)/16 [NYI]
-					//    2 .. Gauss 5 Pixel (8*m+1*l+1*r+1*a+1*b)/12 [NYI]
-					//    4 .. Cartoon Filter   [NI]
-					//    8 .. Reserverd Filter [NI]
-					//   16 .. Reserverd Filter [NI]
-					//   32 .. Reserverd Filter [NI]
-					//   64 .. Reserverd Filter [NI]
-					//  128 .. Reserverd Filter [NI]
-
-   int  timecode;			// Timecodeinformation sec*1000 + msecs
- 
-   int  packetlength;                   // V,A,T: length of following data in stream
-   					// S:     length of packet correl. information [NI]
-   					// R:     do not use here! (fixed 'RTjjjjjjjjjjjjjj')
-} rtframeheader;
-
-#define FRAMEHEADERSIZE sizeof(rtframeheader)
-
-#define le2me_rtframeheader(h) {				\
-    (h)->timecode = le2me_32((h)->timecode);			\
-    (h)->packetlength = le2me_32((h)->packetlength);		\
-  }
-
-#endif /* MPLAYER_NUPPELVIDEO_H */