initial commit
[goodguy/history.git] / cinelerra-5.0 / cinelerra / device1394input.h
1
2 /*
3  * CINELERRA
4  * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
5  * 
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  * 
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  * 
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  * 
20  */
21
22 #ifndef DEVICE1394INPUT_H
23 #define DEVICE1394INPUT_H
24
25
26
27 #ifdef HAVE_FIREWIRE
28
29 #include "condition.inc"
30 #include "libdv.h"
31 #include "dv1394.h"
32 #include "mutex.inc"
33 #include "libraw1394/raw1394.h"
34 #include "thread.h"
35 #include "vframe.inc"
36
37 // Common 1394 input for audio and video
38
39 // Extracts video and audio from the single DV stream
40 class Device1394Input : public Thread
41 {
42 public:
43         Device1394Input();
44         ~Device1394Input();
45
46         int open(int port,
47                 int channel,
48                 int length,
49                 int channels,
50                 int samplerate,
51                 int bits,
52                 int w,
53                 int h);
54         void run();
55         void increment_counter(int *counter);
56         void decrement_counter(int *counter);
57
58 // Read a video frame with timed blocking
59
60         int read_video(VFrame *data);
61
62
63 // Read audio with timed blocking
64
65         int read_audio(char *data, int samples);
66
67 // Storage of all frames
68         char **buffer;
69         int *buffer_valid;
70         int buffer_size;
71         int total_buffers;
72         int current_inbuffer;
73
74 // For extracting audio
75         dv_t *decoder;
76
77 // Storage of audio data
78         char *audio_buffer;
79         int audio_samples;
80
81 // number of next video buffer to read
82         int current_outbuffer;
83         unsigned char *input_buffer;
84
85         Mutex *buffer_lock;
86         Condition *video_lock;
87         Condition *audio_lock;
88         int done;
89
90         int fd;
91         int channel;
92         int length;
93         int channels;
94         int samplerate;
95         int bits;
96         int w;
97         int h;
98         int is_pal;
99 };
100
101
102
103
104
105 #endif
106
107
108
109 #endif