6 #include "libavutil/intfloat_readwrite.h"
8 typedef struct __attribute__((packed
)) rtfileheader
10 char finfo
[12]; // "NuppelVideo" + \0
11 char version
[5]; // "0.05" + \0
15 int desiredwidth
; // 0 .. as it is
16 int desiredheight
; // 0 .. as it is
17 char pimode
; // P .. progressive
18 // I .. interlaced (2 half pics) [NI]
20 double aspect
; // 1.0 .. square pixel (1.5 .. e.g. width=480: width*1.5=720
21 // for capturing for svcd material
23 int videoblocks
; // count of video-blocks -1 .. unknown 0 .. no video
24 int audioblocks
; // count of audio-blocks -1 .. unknown 0 .. no audio
25 int textsblocks
; // count of text-blocks -1 .. unknown 0 .. no text
29 typedef struct __attribute__((packed
)) rtframeheader
31 char frametype
; // A .. Audio, V .. Video, S .. Sync, T .. Text
32 // R .. Seekpoint: String RTjjjjjjjj (use full packet)
33 // D .. Addition Data for Compressors
34 // ct: R .. RTjpeg Tables
36 char comptype
; // V: 0 .. Uncompressed [NI]
38 // 2 .. RTJpeg with lzo afterwards
40 // L .. simply copy last frame (if lost frames)
41 // A: 0 .. Uncompressed (44100/sec 16bit 2ch)
42 // 1 .. lzo compression [NI]
43 // 2 .. layer2 (packet) [NI]
44 // 3 .. layer3 (packet) [NI]
45 // F .. flac (lossless) [NI]
46 // S .. shorten (lossless) [NI]
47 // N .. null frame loudless
48 // L .. simply copy last frame (may sound bad) NI
49 // S: B .. Audio and Video sync point [NI]
50 // A .. Audio Sync Information
51 // timecode == effective dsp-frequency*100
52 // when reaching this audio sync point
53 // because many cheap soundcards are unexact
54 // and have a range from 44000 to 44250
55 // instead of the expected exact 44100 S./sec
56 // V .. Next Video Sync
57 // timecode == next video framenumber
58 // S .. Audio,Video,Text Correlation [NI]
59 char keyframe
; // 0 .. keyframe
60 // 1 .. nr of frame in gop => no keyframe
62 char filters
; // Every bit stands for one type of filter
63 // 1 .. Gauss 5 Pixel (8*m+2*l+2*r+2*a+2*b)/16 [NYI]
64 // 2 .. Gauss 5 Pixel (8*m+1*l+1*r+1*a+1*b)/12 [NYI]
65 // 4 .. Cartoon Filter [NI]
66 // 8 .. Reserverd Filter [NI]
67 // 16 .. Reserverd Filter [NI]
68 // 32 .. Reserverd Filter [NI]
69 // 64 .. Reserverd Filter [NI]
70 // 128 .. Reserverd Filter [NI]
72 int timecode
; // Timecodeinformation sec*1000 + msecs
74 int packetlength
; // V,A,T: length of following data in stream
75 // S: length of packet correl. information [NI]
76 // R: do not use here! (fixed 'RTjjjjjjjjjjjjjj')
80 typedef struct __attribute__((packed
)) extendeddata
82 int version
; // yes, this is repeated from the file header
83 int video_fourcc
; // video encoding method used
84 int audio_fourcc
; // audio encoding method used
86 int audio_sample_rate
;
87 int audio_bits_per_sample
;
91 int audio_compression_ratio
;
95 int rtjpeg_luma_filter
;
96 int rtjpeg_chroma_filter
;
102 // unused for later -- total size of 128 integers.
103 // new fields must be added at the end, above this comment.
107 #define FRAMEHEADERSIZE sizeof(rtframeheader)
108 #define FILEHEADERSIZE sizeof(rtfileheader)
110 typedef struct vidbuffertype
116 unsigned char *buffer_offset
;
119 typedef struct audbuffertype
125 unsigned char *buffer_offset
;
128 #define le2me_rtfileheader(h) { \
129 (h)->width = le2me_32((h)->width); \
130 (h)->height = le2me_32((h)->height); \
131 (h)->desiredwidth = le2me_32((h)->desiredwidth); \
132 (h)->desiredheight = le2me_32((h)->desiredheight); \
133 (h)->aspect = av_int2dbl(le2me_64(*(uint64_t *)&(h)->aspect));\
134 (h)->fps = av_int2dbl(le2me_64(*(uint64_t *)&(h)->fps)); \
135 (h)->videoblocks = le2me_32((h)->videoblocks); \
136 (h)->audioblocks = le2me_32((h)->audioblocks); \
137 (h)->textsblocks = le2me_32((h)->textsblocks); \
138 (h)->keyframedist = le2me_32((h)->keyframedist); \
140 #define le2me_rtframeheader(h) { \
141 (h)->timecode = le2me_32((h)->timecode); \
142 (h)->packetlength = le2me_32((h)->packetlength); \
144 #define le2me_extendeddata(h) { \
145 (h)->version = le2me_32((h)->version); \
146 (h)->video_fourcc = le2me_32((h)->video_fourcc); \
147 (h)->audio_fourcc = le2me_32((h)->audio_fourcc); \
148 (h)->audio_sample_rate = le2me_32((h)->audio_sample_rate); \
149 (h)->audio_bits_per_sample = le2me_32((h)->audio_bits_per_sample);\
150 (h)->audio_channels = le2me_32((h)->audio_channels); \
151 (h)->audio_compression_ratio = le2me_32((h)->audio_compression_ratio);\
152 (h)->audio_quality = le2me_32((h)->audio_quality); \
153 (h)->rtjpeg_quality = le2me_32((h)->rtjpeg_quality); \
154 (h)->rtjpeg_luma_filter = le2me_32((h)->rtjpeg_luma_filter); \
155 (h)->rtjpeg_chroma_filter = le2me_32((h)->rtjpeg_chroma_filter);\
156 (h)->lavc_bitrate = le2me_32((h)->lavc_bitrate); \
157 (h)->lavc_qmin = le2me_32((h)->lavc_qmin); \
158 (h)->lavc_qmax = le2me_32((h)->lavc_qmax); \
159 (h)->lavc_maxqdiff = le2me_32((h)->lavc_maxqdiff); \
162 #endif /* NUPPELVIDEO_H */