OSDN Git Service

Gives the CLI a separate option for adding the iPod UUID atom to mp4 files, instead...
[handbrake-jp/handbrake-jp-git.git] / libhb / common.h
1 /* $Id: common.h,v 1.51 2005/11/04 13:09:40 titer Exp $
2
3    This file is part of the HandBrake source code.
4    Homepage: <http://handbrake.m0k.org/>.
5    It may be used under the terms of the GNU General Public License. */
6
7 #ifndef HB_COMMON_H
8 #define HB_COMMON_H
9
10 #include <math.h>
11 #include <stdio.h>
12 #include <stdlib.h>
13 #include <stdarg.h>
14 #include <string.h>
15 #include <unistd.h>
16 #include <inttypes.h>
17 #include <sys/types.h>
18 #include <sys/stat.h>
19 #include <dirent.h>
20
21 #ifndef MIN
22 #define MIN( a, b ) ( (a) > (b) ? (b) : (a) )
23 #endif
24 #ifndef MAX
25 #define MAX( a, b ) ( (a) > (b) ? (a) : (b) )
26 #endif
27
28 #define EVEN( a )        ( (a) + ( (a) & 1 ) )
29 #define MULTIPLE_16( a ) ( 16 * ( ( (a) + 8 ) / 16 ) )
30 #define MULTIPLE_MOD( a, b ) ( b * ( ( (a) + (b / 2) ) / b ) )
31
32 #define HB_DVD_READ_BUFFER_SIZE 2048
33
34 typedef struct hb_handle_s hb_handle_t;
35 typedef struct hb_list_s hb_list_t;
36 typedef struct hb_rate_s hb_rate_t;
37 typedef struct hb_mixdown_s hb_mixdown_t;
38 typedef struct hb_job_s  hb_job_t;
39 typedef struct hb_title_s hb_title_t;
40 typedef struct hb_chapter_s hb_chapter_t;
41 typedef struct hb_audio_s hb_audio_t;
42 typedef struct hb_subtitle_s hb_subtitle_t;
43 typedef struct hb_state_s hb_state_t;
44 typedef union  hb_esconfig_u     hb_esconfig_t;
45 typedef struct hb_work_private_s hb_work_private_t;
46 typedef struct hb_work_object_s  hb_work_object_t;
47 typedef struct hb_filter_private_s hb_filter_private_t;
48 typedef struct hb_filter_object_s  hb_filter_object_t;
49 typedef struct hb_buffer_s hb_buffer_t;
50 typedef struct hb_fifo_s hb_fifo_t;
51 typedef struct hb_lock_s hb_lock_t;
52
53 #include "ports.h"
54 #ifdef __LIBHB__
55 #include "internal.h"
56 #endif
57
58 hb_list_t * hb_list_init();
59 int         hb_list_count( hb_list_t * );
60 void        hb_list_add( hb_list_t *, void * );
61 void        hb_list_rem( hb_list_t *, void * );
62 void      * hb_list_item( hb_list_t *, int );
63 void        hb_list_close( hb_list_t ** );
64
65 void hb_reduce( int *x, int *y, int num, int den );
66
67 #define HB_KEEP_WIDTH  0
68 #define HB_KEEP_HEIGHT 1
69 void hb_fix_aspect( hb_job_t * job, int keep );
70
71 int hb_calc_bitrate( hb_job_t *, int size );
72
73 struct hb_rate_s
74 {
75     char * string;
76     int    rate;
77 };
78
79 struct hb_mixdown_s
80 {
81     char * human_readable_name;
82     char * internal_name;
83     char * short_name;
84     int    amixdown;
85 };
86
87 #define HB_ASPECT_BASE 9
88 #define HB_VIDEO_RATE_BASE   27000000
89
90 extern hb_rate_t    hb_video_rates[];
91 extern int          hb_video_rates_count;
92 extern hb_rate_t    hb_audio_rates[];
93 extern int          hb_audio_rates_count;
94 extern int          hb_audio_rates_default;
95 extern hb_rate_t    hb_audio_bitrates[];
96 extern int          hb_audio_bitrates_count;
97 extern int          hb_audio_bitrates_default;
98 extern hb_mixdown_t hb_audio_mixdowns[];
99 extern int          hb_audio_mixdowns_count;
100 int hb_mixdown_get_mixdown_from_short_name( const char * short_name );
101 const char * hb_mixdown_get_short_name_from_mixdown( int amixdown );
102
103 /******************************************************************************
104  * hb_job_t: settings to be filled by the UI
105  *****************************************************************************/
106 struct hb_job_s
107 {
108     /* ID assigned by UI so it can groups job passes together */
109     int             sequence_id;
110         
111     /* Pointer to the title to be ripped */
112     hb_title_t    * title;
113     
114     /* Chapter selection */
115     int             chapter_start;
116     int             chapter_end;
117
118         /* Include chapter marker track in mp4? */
119     int             chapter_markers;
120
121     /* Picture settings:
122          crop:                must be multiples of 2 (top/bottom/left/right)
123          deinterlace:         0 or 1
124          width:               must be a multiple of 16
125          height:              must be a multiple of 16
126          keep_ratio:          used by UIs 
127          pixel_ratio:         store pixel aspect ratio in the video
128          pixel_aspect_width:  numerator for pixel aspect ratio
129          pixel_aspect_height: denominator for pixel aspect ratio
130                  maxWidth:                        keep width below this
131                  maxHeight:                       keep height below this */
132
133     int             crop[4];
134     int             deinterlace;
135     hb_list_t     * filters;
136     int             width;
137     int             height;
138     int             keep_ratio;
139     int             grayscale;
140     int             pixel_ratio;
141     int             pixel_aspect_width;
142     int             pixel_aspect_height;
143     int             modulus;
144         int                             maxWidth;
145         int                             maxHeight;
146
147
148     /* Video settings:
149          vcodec:            output codec
150          vquality:          output quality (0.0..1.0)
151                             if < 0.0 or > 1.0, bitrate is used instead
152          vbitrate:          output bitrate (kbps)
153          pass:              0, 1 or 2 (or -1 for scan)
154          vrate, vrate_base: output framerate is vrate / vrate_base
155          h264_level:        boolean for whether or not we're encoding for iPod
156          crf:               boolean for whether to use constant rate factor with x264
157          x264opts:          string of extra x264 options 
158          areBframes:        boolean to note if b-frames are included in x264opts */
159 #define HB_VCODEC_MASK   0x0000FF
160 #define HB_VCODEC_FFMPEG 0x000001
161 #define HB_VCODEC_XVID   0x000002
162 #define HB_VCODEC_X264   0x000004
163
164     int             vcodec;
165     float           vquality;
166     int             vbitrate;
167     int             vrate;
168     int             vrate_base;
169     int             pass;
170     int             h264_13;
171     int             h264_level;
172     int             crf;
173     char            *x264opts;
174     int             areBframes;
175     int             vfr;
176
177     /* Audio tracks:
178          audios:          Indexes in hb_title_t's audios list, starting from 0.
179                           -1 indicates the end of the list
180         audio_mixdowns:  The mixdown to be used for each audio track in audios[] */
181
182 /* define some masks, used to extract the various information from the HB_AMIXDOWN_XXXX values */
183 #define HB_AMIXDOWN_DCA_FORMAT_MASK             0x00FFF000
184 #define HB_AMIXDOWN_A52_FORMAT_MASK             0x00000FF0
185 #define HB_AMIXDOWN_DISCRETE_CHANNEL_COUNT_MASK 0x0000000F
186
187 /* define the HB_AMIXDOWN_XXXX values */
188
189 #define HB_AMIXDOWN_MONO                        0x01000001
190 // DCA_FORMAT of DCA_MONO                  = 0    = 0x000
191 // A52_FORMAT of A52_MONO                  = 1    = 0x01
192 // discrete channel count of 1
193
194 #define HB_AMIXDOWN_STEREO                      0x02002022
195 // DCA_FORMAT of DCA_STEREO                = 2    = 0x002
196 // A52_FORMAT of A52_STEREO                = 2    = 0x02
197 // discrete channel count of 2
198
199 #define HB_AMIXDOWN_DOLBY                       0x042070A2
200 // DCA_FORMAT of DCA_3F1R | DCA_OUT_DPLI   = 519  = 0x207
201 // A52_FORMAT of A52_DOLBY                 = 10   = 0x0A
202 // discrete channel count of 2
203
204 #define HB_AMIXDOWN_DOLBYPLII                   0x084094A2
205 // DCA_FORMAT of DCA_3F2R | DCA_OUT_DPLII  = 1033 = 0x409
206 // A52_FORMAT of A52_DOLBY | A52_USE_DPLII = 74   = 0x4A
207 // discrete channel count of 2
208
209 #define HB_AMIXDOWN_6CH                         0x10089176
210 // DCA_FORMAT of DCA_3F2R | DCA_LFE        = 137  = 0x089
211 // A52_FORMAT of A52_3F2R | A52_LFE        = 23   = 0x17
212 // discrete channel count of 6
213
214 /* define some macros to extract the various information from the HB_AMIXDOWN_XXXX values */
215 #define HB_AMIXDOWN_GET_DCA_FORMAT( a ) ( ( a & HB_AMIXDOWN_DCA_FORMAT_MASK ) >> 12 )
216 #define HB_AMIXDOWN_GET_A52_FORMAT( a ) ( ( a & HB_AMIXDOWN_A52_FORMAT_MASK ) >> 4 )
217 #define HB_AMIXDOWN_GET_DISCRETE_CHANNEL_COUNT( a ) ( ( a & HB_AMIXDOWN_DISCRETE_CHANNEL_COUNT_MASK ) )
218
219     int             audios[8];
220         int             audio_mixdowns[8];
221
222     /* Audio settings:
223          acodec:   output codec
224          abitrate: output bitrate (kbps)
225          arate:    output samplerate (Hz)
226        HB_ACODEC_AC3 means pass-through, then abitrate and arate are
227        ignored */
228 #define HB_ACODEC_MASK   0x00FF00
229 #define HB_ACODEC_FAAC   0x000100
230 #define HB_ACODEC_LAME   0x000200
231 #define HB_ACODEC_VORBIS 0x000400
232 #define HB_ACODEC_AC3    0x000800
233 #define HB_ACODEC_MPGA   0x001000
234 #define HB_ACODEC_LPCM   0x002000
235 #define HB_ACODEC_DCA    0x004000
236     int             acodec;
237     int             abitrate;
238     int             arate;
239
240     /* Subtitle settings:
241          subtitle: index in hb_title_t's subtitles list, starting
242          from 0. -1 means no subtitle */
243     int             subtitle;
244     int                         subtitleSmartAdjust;
245
246     /* Muxer settings
247          mux:  output file format
248          file: file path */
249 #define HB_MUX_MASK 0xFF0000
250 #define HB_MUX_MP4  0x010000
251 #define HB_MUX_PSP  0x020000
252 #define HB_MUX_AVI  0x040000
253 #define HB_MUX_OGM  0x080000
254 #define HB_MUX_IPOD 0x100000
255 #define HB_MUX_MKV  0x200000
256         
257     int             mux;
258     const char          * file;
259
260     /* Allow MP4 files > 4 gigs */
261     int             largeFileSize;
262     int             mp4_optimize;
263     int             ipod_atom;
264
265     int indepth_scan;
266     hb_subtitle_t ** select_subtitle;
267     int subtitle_force;
268     char * native_language;
269
270 #ifdef __LIBHB__
271     /* Internal data */
272     hb_handle_t   * h;
273     hb_lock_t     * pause;
274     volatile int  * die;
275     volatile int    done;
276
277     hb_fifo_t     * fifo_mpeg2;   /* MPEG-2 video ES */
278     hb_fifo_t     * fifo_raw;     /* Raw pictures */
279     hb_fifo_t     * fifo_sync;    /* Raw pictures, framerate corrected */
280     hb_fifo_t     * fifo_render;  /* Raw pictures, scaled */
281     hb_fifo_t     * fifo_mpeg4;   /* MPEG-4 video ES */
282
283     hb_thread_t   * reader;
284     hb_thread_t   * muxer;
285
286     hb_list_t     * list_work;
287
288     hb_esconfig_t config;
289
290     hb_mux_data_t * mux_data;
291 #endif
292 };
293
294 struct hb_audio_s
295 {
296     int  id;
297     char lang[1024];
298     char lang_simple[1024];
299     char iso639_2[4];
300     int  codec;
301     int  rate;
302     int  bitrate;
303     
304     /* ac3flags is only set when the source audio format is HB_ACODEC_AC3 */
305     int ac3flags;
306
307     /* dcaflags is only set when the source audio format is HB_ACODEC_DCA */
308     int dcaflags;
309
310 /* define some masks, used to extract the various information from the HB_AMIXDOWN_XXXX values */
311 #define HB_INPUT_CH_LAYOUT_DISCRETE_FRONT_MASK  0x00F0000
312 #define HB_INPUT_CH_LAYOUT_DISCRETE_REAR_MASK   0x000F000
313 #define HB_INPUT_CH_LAYOUT_DISCRETE_LFE_MASK    0x0000F00
314 #define HB_INPUT_CH_LAYOUT_DISCRETE_NO_LFE_MASK 0xFFFF0FF
315 #define HB_INPUT_CH_LAYOUT_ENCODED_FRONT_MASK   0x00000F0
316 #define HB_INPUT_CH_LAYOUT_ENCODED_REAR_MASK    0x000000F
317
318 /* define the input channel layouts used to describe the channel layout of this audio */
319 #define HB_INPUT_CH_LAYOUT_MONO    0x0110010
320 #define HB_INPUT_CH_LAYOUT_STEREO  0x0220020
321 #define HB_INPUT_CH_LAYOUT_DOLBY   0x0320031
322 #define HB_INPUT_CH_LAYOUT_3F      0x0430030
323 #define HB_INPUT_CH_LAYOUT_2F1R    0x0521021
324 #define HB_INPUT_CH_LAYOUT_3F1R    0x0631031
325 #define HB_INPUT_CH_LAYOUT_2F2R    0x0722022
326 #define HB_INPUT_CH_LAYOUT_3F2R    0x0832032
327 #define HB_INPUT_CH_LAYOUT_4F2R    0x0942042
328 #define HB_INPUT_CH_LAYOUT_HAS_LFE 0x0000100
329
330 /* define some macros to extract the various information from the HB_AMIXDOWN_XXXX values */
331 #define HB_INPUT_CH_LAYOUT_GET_DISCRETE_FRONT_COUNT( a ) ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_FRONT_MASK ) >> 16 )
332 #define HB_INPUT_CH_LAYOUT_GET_DISCRETE_REAR_COUNT( a )  ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_REAR_MASK ) >> 12 )
333 #define HB_INPUT_CH_LAYOUT_GET_DISCRETE_LFE_COUNT( a )   ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_LFE_MASK ) >> 8 )
334 #define HB_INPUT_CH_LAYOUT_GET_DISCRETE_COUNT( a ) ( ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_FRONT_MASK ) >> 16 ) + ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_REAR_MASK ) >> 12 ) + ( ( a & HB_INPUT_CH_LAYOUT_DISCRETE_LFE_MASK ) >> 8 ) )
335 #define HB_INPUT_CH_LAYOUT_GET_ENCODED_FRONT_COUNT( a )   ( ( a & HB_INPUT_CH_LAYOUT_ENCODED_FRONT_MASK ) >> 4 )
336 #define HB_INPUT_CH_LAYOUT_GET_ENCODED_REAR_COUNT( a )   ( ( a & HB_INPUT_CH_LAYOUT_ENCODED_REAR_MASK ) )
337
338         /* input_channel_layout is the channel layout of this audio */
339         /* this is used to provide a common way of describing the source audio */
340         int input_channel_layout;
341
342 #ifdef __LIBHB__
343     /* Internal data */
344     hb_fifo_t * fifo_in;   /* AC3/MPEG/LPCM ES */
345     hb_fifo_t * fifo_raw;  /* Raw audio */
346     hb_fifo_t * fifo_sync; /* Resampled, synced raw audio */
347     hb_fifo_t * fifo_out;  /* MP3/AAC/Vorbis ES */
348
349     hb_esconfig_t config;
350     hb_mux_data_t * mux_data;
351
352         /* amixdown is the mixdown format to be used for this audio track */
353         int amixdown;
354
355         /* Source PID is only valid for MPEG Transport Streams */
356         int source_pid;
357 #endif
358 };
359
360 struct hb_chapter_s
361 {
362     int      index;
363     int      cell_start;
364     int      cell_end;
365     int      block_start;
366     int      block_end;
367     int      block_count;
368
369     /* Visual-friendly duration */
370     int      hours;
371     int      minutes;
372     int      seconds;
373
374     /* Exact duration (in 1/90000s) */
375     uint64_t duration;
376     
377     /* Optional chapter title */
378     char     title[1024];
379 };
380
381 struct hb_subtitle_s
382 {
383     int  id;
384     char lang[1024];
385     char iso639_2[4];
386
387     int hits;     /* How many hits/occurrences of this subtitle */
388     int forced_hits; /* How many forced hits in this subtitle */
389
390 #ifdef __LIBHB__
391     /* Internal data */
392     hb_fifo_t * fifo_in;  /* SPU ES */
393     hb_fifo_t * fifo_raw; /* Decodec SPU */
394 #endif
395 };
396
397 struct hb_title_s
398 {
399     char        dvd[1024];
400     char        name[1024];
401     int         index;
402     int         vts;
403     int         ttn;
404     int         cell_start;
405     int         cell_end;
406     int         block_start;
407     int         block_end;
408     int         block_count;
409
410     /* Visual-friendly duration */
411     int         hours;
412     int         minutes;
413     int         seconds;
414
415     /* Exact duration (in 1/90000s) */
416     uint64_t    duration;
417
418     int         width;
419     int         height;
420     int         aspect;
421     int         rate;
422     int         rate_base;
423     int         crop[4];
424
425     uint32_t    palette[16];
426
427     hb_list_t * list_chapter;
428     hb_list_t * list_audio;
429     hb_list_t * list_subtitle;
430
431     /* Job template for this title */
432     hb_job_t  * job;
433 };
434
435
436 struct hb_state_s
437 {
438 #define HB_STATE_IDLE     1
439 #define HB_STATE_SCANNING 2
440 #define HB_STATE_SCANDONE 4
441 #define HB_STATE_WORKING  8
442 #define HB_STATE_PAUSED   16
443 #define HB_STATE_WORKDONE 32
444 #define HB_STATE_MUXING   64
445     int state;
446
447     union
448     {
449         struct
450         {
451             /* HB_STATE_SCANNING */
452             int title_cur;
453             int title_count;
454         } scanning;
455
456         struct
457         {
458             /* HB_STATE_WORKING */
459             float progress;
460             int   job_cur;
461             int   job_count;
462             float rate_cur;
463             float rate_avg;
464             int   hours;
465             int   minutes;
466             int   seconds;
467         } working;
468
469         struct
470         {
471             /* HB_STATE_WORKDONE */
472 #define HB_ERROR_NONE     0
473 #define HB_ERROR_CANCELED 1
474 #define HB_ERROR_UNKNOWN  2
475             int error;
476         } workdone;
477
478         struct
479         {
480             /* HB_STATE_MUXING */
481             float progress;
482         } muxing;
483     } param;
484 };
485
486 struct hb_work_object_s
487 {
488     int                 id;
489     char              * name;
490
491 #ifdef __LIBHB__
492     int              (* init)  ( hb_work_object_t *, hb_job_t * );
493     int              (* work)  ( hb_work_object_t *, hb_buffer_t **,
494                                  hb_buffer_t ** );
495     void             (* close) ( hb_work_object_t * );
496
497     hb_fifo_t         * fifo_in;
498     hb_fifo_t         * fifo_out;
499     hb_esconfig_t     * config;
500
501         /* amixdown is the mixdown format to be used if the work object is an audio track */
502         int               amixdown;
503     /* source_acodec is the source audio codec if the work object is an audio track */
504     int               source_acodec;
505
506     hb_work_private_t * private_data;
507
508     hb_thread_t       * thread;
509     volatile int      * done;
510
511     hb_work_object_t  * next;
512         int                               thread_sleep_interval;
513 #endif
514 };
515
516 extern hb_work_object_t hb_sync;
517 extern hb_work_object_t hb_decmpeg2;
518 extern hb_work_object_t hb_decsub;
519 extern hb_work_object_t hb_render;
520 extern hb_work_object_t hb_encavcodec;
521 extern hb_work_object_t hb_encxvid;
522 extern hb_work_object_t hb_encx264;
523 extern hb_work_object_t hb_deca52;
524 extern hb_work_object_t hb_decdca;
525 extern hb_work_object_t hb_decavcodec;
526 extern hb_work_object_t hb_declpcm;
527 extern hb_work_object_t hb_encfaac;
528 extern hb_work_object_t hb_enclame;
529 extern hb_work_object_t hb_encvorbis;
530
531 #define FILTER_OK      0
532 #define FILTER_DELAY   1
533 #define FILTER_FAILED  2
534 #define FILTER_DROP    3
535
536 struct hb_filter_object_s
537 {
538     int                     id;
539     char                  * name;
540     char                  * settings;
541
542 #ifdef __LIBHB__
543     hb_filter_private_t* (* init)  ( int, int, int, char * );
544     
545     int                  (* work)  ( const hb_buffer_t *, hb_buffer_t **,
546                                      int, int, int, hb_filter_private_t * );
547     
548     void                 (* close) ( hb_filter_private_t * );
549     
550     hb_filter_private_t   * private_data;
551     //hb_buffer_t           * buffer;
552 #endif
553 };
554
555 extern hb_filter_object_t hb_filter_detelecine;
556 extern hb_filter_object_t hb_filter_deinterlace;
557 extern hb_filter_object_t hb_filter_deblock;
558 extern hb_filter_object_t hb_filter_denoise;
559
560 typedef void hb_error_handler_t( const char *errmsg );
561
562 extern void hb_register_error_handler( hb_error_handler_t * handler );
563
564 #endif