OpenCores
URL https://opencores.org/ocsvn/test_project/test_project/trunk

Subversion Repositories test_project

[/] [test_project/] [trunk/] [linux_sd_driver/] [drivers/] [media/] [video/] [cpia.h] - Blame information for rev 78

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 62 marcus.erl
#ifndef cpia_h
2
#define cpia_h
3
 
4
/*
5
 * CPiA Parallel Port Video4Linux driver
6
 *
7
 * Supports CPiA based parallel port Video Camera's.
8
 *
9
 * (C) Copyright 1999 Bas Huisman,
10
 *                    Peter Pregler,
11
 *                    Scott J. Bertin,
12
 *                    VLSI Vision Ltd.
13
 *
14
 * This program is free software; you can redistribute it and/or modify
15
 * it under the terms of the GNU General Public License as published by
16
 * the Free Software Foundation; either version 2 of the License, or
17
 * (at your option) any later version.
18
 *
19
 * This program is distributed in the hope that it will be useful,
20
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
22
 * GNU General Public License for more details.
23
 *
24
 * You should have received a copy of the GNU General Public License
25
 * along with this program; if not, write to the Free Software
26
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
27
 */
28
 
29
#define CPIA_MAJ_VER    1
30
#define CPIA_MIN_VER   2
31
#define CPIA_PATCH_VER  3
32
 
33
#define CPIA_PP_MAJ_VER       CPIA_MAJ_VER
34
#define CPIA_PP_MIN_VER       CPIA_MIN_VER
35
#define CPIA_PP_PATCH_VER     CPIA_PATCH_VER
36
 
37
#define CPIA_USB_MAJ_VER      CPIA_MAJ_VER
38
#define CPIA_USB_MIN_VER      CPIA_MIN_VER
39
#define CPIA_USB_PATCH_VER    CPIA_PATCH_VER
40
 
41
#define CPIA_MAX_FRAME_SIZE_UNALIGNED   (352 * 288 * 4)   /* CIF at RGB32 */
42
#define CPIA_MAX_FRAME_SIZE     ((CPIA_MAX_FRAME_SIZE_UNALIGNED + PAGE_SIZE - 1) & ~(PAGE_SIZE - 1)) /* align above to PAGE_SIZE */
43
 
44
#ifdef __KERNEL__
45
 
46
#include <asm/uaccess.h>
47
#include <linux/videodev.h>
48
#include <media/v4l2-common.h>
49
#include <linux/list.h>
50
#include <linux/mutex.h>
51
 
52
struct cpia_camera_ops
53
{
54
        /* open sets privdata to point to structure for this camera.
55
         * Returns negative value on error, otherwise 0.
56
         */
57
        int (*open)(void *privdata);
58
 
59
        /* Registers callback function cb to be called with cbdata
60
         * when an image is ready.  If cb is NULL, only single image grabs
61
         * should be used.  cb should immediately call streamRead to read
62
         * the data or data may be lost. Returns negative value on error,
63
         * otherwise 0.
64
         */
65
        int (*registerCallback)(void *privdata, void (*cb)(void *cbdata),
66
                                void *cbdata);
67
 
68
        /* transferCmd sends commands to the camera.  command MUST point to
69
         * an  8 byte buffer in kernel space. data can be NULL if no extra
70
         * data is needed.  The size of the data is given by the last 2
71
         * bytes of command.  data must also point to memory in kernel space.
72
         * Returns negative value on error, otherwise 0.
73
         */
74
        int (*transferCmd)(void *privdata, u8 *command, u8 *data);
75
 
76
        /* streamStart initiates stream capture mode.
77
         * Returns negative value on error, otherwise 0.
78
         */
79
        int (*streamStart)(void *privdata);
80
 
81
        /* streamStop terminates stream capture mode.
82
         * Returns negative value on error, otherwise 0.
83
         */
84
        int (*streamStop)(void *privdata);
85
 
86
        /* streamRead reads a frame from the camera.  buffer points to a
87
         * buffer large enough to hold a complete frame in kernel space.
88
         * noblock indicates if this should be a non blocking read.
89
         * Returns the number of bytes read, or negative value on error.
90
         */
91
        int (*streamRead)(void *privdata, u8 *buffer, int noblock);
92
 
93
        /* close disables the device until open() is called again.
94
         * Returns negative value on error, otherwise 0.
95
         */
96
        int (*close)(void *privdata);
97
 
98
        /* If wait_for_stream_ready is non-zero, wait until the streamState
99
         * is STREAM_READY before calling streamRead.
100
         */
101
        int wait_for_stream_ready;
102
 
103
        /*
104
         * Used to maintain lowlevel module usage counts
105
         */
106
        struct module *owner;
107
};
108
 
109
struct cpia_frame {
110
        u8 *data;
111
        int count;
112
        int width;
113
        int height;
114
        volatile int state;
115
};
116
 
117
struct cam_params {
118
        struct {
119
                u8 firmwareVersion;
120
                u8 firmwareRevision;
121
                u8 vcVersion;
122
                u8 vcRevision;
123
        } version;
124
        struct {
125
                u16 vendor;
126
                u16 product;
127
                u16 deviceRevision;
128
        } pnpID;
129
        struct {
130
                u8 vpVersion;
131
                u8 vpRevision;
132
                u16 cameraHeadID;
133
        } vpVersion;
134
        struct {
135
                u8 systemState;
136
                u8 grabState;
137
                u8 streamState;
138
                u8 fatalError;
139
                u8 cmdError;
140
                u8 debugFlags;
141
                u8 vpStatus;
142
                u8 errorCode;
143
        } status;
144
        struct {
145
                u8 brightness;
146
                u8 contrast;
147
                u8 saturation;
148
        } colourParams;
149
        struct {
150
                u8 gainMode;
151
                u8 expMode;
152
                u8 compMode;
153
                u8 centreWeight;
154
                u8 gain;
155
                u8 fineExp;
156
                u8 coarseExpLo;
157
                u8 coarseExpHi;
158
                u8 redComp;
159
                u8 green1Comp;
160
                u8 green2Comp;
161
                u8 blueComp;
162
        } exposure;
163
        struct {
164
                u8 balanceMode;
165
                u8 redGain;
166
                u8 greenGain;
167
                u8 blueGain;
168
        } colourBalance;
169
        struct {
170
                u8 divisor;
171
                u8 baserate;
172
        } sensorFps;
173
        struct {
174
                u8 gain1;
175
                u8 gain2;
176
                u8 gain4;
177
                u8 gain8;
178
        } apcor;
179
        struct {
180
                u8 disabled;
181
                u8 flickerMode;
182
                u8 coarseJump;
183
                int allowableOverExposure;
184
        } flickerControl;
185
        struct {
186
                u8 gain1;
187
                u8 gain2;
188
                u8 gain4;
189
                u8 gain8;
190
        } vlOffset;
191
        struct {
192
                u8 mode;
193
                u8 decimation;
194
        } compression;
195
        struct {
196
                u8 frTargeting;
197
                u8 targetFR;
198
                u8 targetQ;
199
        } compressionTarget;
200
        struct {
201
                u8 yThreshold;
202
                u8 uvThreshold;
203
        } yuvThreshold;
204
        struct {
205
                u8 hysteresis;
206
                u8 threshMax;
207
                u8 smallStep;
208
                u8 largeStep;
209
                u8 decimationHysteresis;
210
                u8 frDiffStepThresh;
211
                u8 qDiffStepThresh;
212
                u8 decimationThreshMod;
213
        } compressionParams;
214
        struct {
215
                u8 videoSize;           /* CIF/QCIF */
216
                u8 subSample;
217
                u8 yuvOrder;
218
        } format;
219
        struct {                        /* Intel QX3 specific data */
220
                u8 qx3_detected;        /* a QX3 is present */
221
                u8 toplight;            /* top light lit , R/W */
222
                u8 bottomlight;         /* bottom light lit, R/W */
223
                u8 button;              /* snapshot button pressed (R/O) */
224
                u8 cradled;             /* microscope is in cradle (R/O) */
225
        } qx3;
226
        struct {
227
                u8 colStart;            /* skip first 8*colStart pixels */
228
                u8 colEnd;              /* finish at 8*colEnd pixels */
229
                u8 rowStart;            /* skip first 4*rowStart lines */
230
                u8 rowEnd;              /* finish at 4*rowEnd lines */
231
        } roi;
232
        u8 ecpTiming;
233
        u8 streamStartLine;
234
};
235
 
236
enum v4l_camstates {
237
        CPIA_V4L_IDLE = 0,
238
        CPIA_V4L_ERROR,
239
        CPIA_V4L_COMMAND,
240
        CPIA_V4L_GRABBING,
241
        CPIA_V4L_STREAMING,
242
        CPIA_V4L_STREAMING_PAUSED,
243
};
244
 
245
#define FRAME_NUM       2       /* double buffering for now */
246
 
247
struct cam_data {
248
        struct list_head cam_data_list;
249
 
250
        struct mutex busy_lock;         /* guard against SMP multithreading */
251
        struct cpia_camera_ops *ops;    /* lowlevel driver operations */
252
        void *lowlevel_data;            /* private data for lowlevel driver */
253
        u8 *raw_image;                  /* buffer for raw image data */
254
        struct cpia_frame decompressed_frame;
255
                                        /* buffer to hold decompressed frame */
256
        int image_size;                 /* sizeof last decompressed image */
257
        int open_count;                 /* # of process that have camera open */
258
 
259
                                /* camera status */
260
        int fps;                        /* actual fps reported by the camera */
261
        int transfer_rate;              /* transfer rate from camera in kB/s */
262
        u8 mainsFreq;                   /* for flicker control */
263
 
264
                                /* proc interface */
265
        struct mutex param_lock;        /* params lock for this camera */
266
        struct cam_params params;       /* camera settings */
267
        struct proc_dir_entry *proc_entry;      /* /proc/cpia/videoX */
268
 
269
                                        /* v4l */
270
        int video_size;                 /* VIDEO_SIZE_ */
271
        volatile enum v4l_camstates camstate;   /* v4l layer status */
272
        struct video_device vdev;       /* v4l videodev */
273
        struct video_picture vp;        /* v4l camera settings */
274
        struct video_window vw;         /* v4l capture area */
275
        struct video_capture vc;        /* v4l subcapture area */
276
 
277
                                /* mmap interface */
278
        int curframe;                   /* the current frame to grab into */
279
        u8 *frame_buf;                  /* frame buffer data */
280
        struct cpia_frame frame[FRAME_NUM];
281
                                /* FRAME_NUM-buffering, so we need a array */
282
 
283
        int first_frame;
284
        int mmap_kludge;                /* 'wrong' byte order for mmap */
285
        volatile u32 cmd_queue;         /* queued commands */
286
        int exposure_status;            /* EXPOSURE_* */
287
        int exposure_count;             /* number of frames at this status */
288
};
289
 
290
/* cpia_register_camera is called by low level driver for each camera.
291
 * A unique camera number is returned, or a negative value on error */
292
struct cam_data *cpia_register_camera(struct cpia_camera_ops *ops, void *lowlevel);
293
 
294
/* cpia_unregister_camera is called by low level driver when a camera
295
 * is removed.  This must not fail. */
296
void cpia_unregister_camera(struct cam_data *cam);
297
 
298
/* raw CIF + 64 byte header + (2 bytes line_length + EOL) per line + 4*EOI +
299
 * one byte 16bit DMA alignment
300
 */
301
#define CPIA_MAX_IMAGE_SIZE ((352*288*2)+64+(288*3)+5)
302
 
303
/* constant value's */
304
#define MAGIC_0         0x19
305
#define MAGIC_1         0x68
306
#define DATA_IN         0xC0
307
#define DATA_OUT        0x40
308
#define VIDEOSIZE_QCIF  0        /* 176x144 */
309
#define VIDEOSIZE_CIF   1       /* 352x288 */
310
#define VIDEOSIZE_SIF   2       /* 320x240 */
311
#define VIDEOSIZE_QSIF  3       /* 160x120 */
312
#define VIDEOSIZE_48_48         4 /* where no one has gone before, iconsize! */
313
#define VIDEOSIZE_64_48         5
314
#define VIDEOSIZE_128_96        6
315
#define VIDEOSIZE_160_120       VIDEOSIZE_QSIF
316
#define VIDEOSIZE_176_144       VIDEOSIZE_QCIF
317
#define VIDEOSIZE_192_144       7
318
#define VIDEOSIZE_224_168       8
319
#define VIDEOSIZE_256_192       9
320
#define VIDEOSIZE_288_216       10
321
#define VIDEOSIZE_320_240       VIDEOSIZE_SIF
322
#define VIDEOSIZE_352_288       VIDEOSIZE_CIF
323
#define VIDEOSIZE_88_72         11 /* quarter CIF */
324
#define SUBSAMPLE_420   0
325
#define SUBSAMPLE_422   1
326
#define YUVORDER_YUYV   0
327
#define YUVORDER_UYVY   1
328
#define NOT_COMPRESSED  0
329
#define COMPRESSED      1
330
#define NO_DECIMATION   0
331
#define DECIMATION_ENAB 1
332
#define EOI             0xff    /* End Of Image */
333
#define EOL             0xfd    /* End Of Line */
334
#define FRAME_HEADER_SIZE       64
335
 
336
/* Image grab modes */
337
#define CPIA_GRAB_SINGLE        0
338
#define CPIA_GRAB_CONTINUOUS    1
339
 
340
/* Compression parameters */
341
#define CPIA_COMPRESSION_NONE   0
342
#define CPIA_COMPRESSION_AUTO   1
343
#define CPIA_COMPRESSION_MANUAL 2
344
#define CPIA_COMPRESSION_TARGET_QUALITY         0
345
#define CPIA_COMPRESSION_TARGET_FRAMERATE       1
346
 
347
/* Return offsets for GetCameraState */
348
#define SYSTEMSTATE     0
349
#define GRABSTATE       1
350
#define STREAMSTATE     2
351
#define FATALERROR      3
352
#define CMDERROR        4
353
#define DEBUGFLAGS      5
354
#define VPSTATUS        6
355
#define ERRORCODE       7
356
 
357
/* SystemState */
358
#define UNINITIALISED_STATE     0
359
#define PASS_THROUGH_STATE      1
360
#define LO_POWER_STATE          2
361
#define HI_POWER_STATE          3
362
#define WARM_BOOT_STATE         4
363
 
364
/* GrabState */
365
#define GRAB_IDLE               0
366
#define GRAB_ACTIVE             1
367
#define GRAB_DONE               2
368
 
369
/* StreamState */
370
#define STREAM_NOT_READY        0
371
#define STREAM_READY            1
372
#define STREAM_OPEN             2
373
#define STREAM_PAUSED           3
374
#define STREAM_FINISHED         4
375
 
376
/* Fatal Error, CmdError, and DebugFlags */
377
#define CPIA_FLAG         1
378
#define SYSTEM_FLAG       2
379
#define INT_CTRL_FLAG     4
380
#define PROCESS_FLAG      8
381
#define COM_FLAG         16
382
#define VP_CTRL_FLAG     32
383
#define CAPTURE_FLAG     64
384
#define DEBUG_FLAG      128
385
 
386
/* VPStatus */
387
#define VP_STATE_OK                     0x00
388
 
389
#define VP_STATE_FAILED_VIDEOINIT       0x01
390
#define VP_STATE_FAILED_AECACBINIT      0x02
391
#define VP_STATE_AEC_MAX                0x04
392
#define VP_STATE_ACB_BMAX               0x08
393
 
394
#define VP_STATE_ACB_RMIN               0x10
395
#define VP_STATE_ACB_GMIN               0x20
396
#define VP_STATE_ACB_RMAX               0x40
397
#define VP_STATE_ACB_GMAX               0x80
398
 
399
/* default (minimum) compensation values */
400
#define COMP_RED        220
401
#define COMP_GREEN1     214
402
#define COMP_GREEN2     COMP_GREEN1
403
#define COMP_BLUE       230
404
 
405
/* exposure status */
406
#define EXPOSURE_VERY_LIGHT 0
407
#define EXPOSURE_LIGHT      1
408
#define EXPOSURE_NORMAL     2
409
#define EXPOSURE_DARK       3
410
#define EXPOSURE_VERY_DARK  4
411
 
412
/* ErrorCode */
413
#define ERROR_FLICKER_BELOW_MIN_EXP     0x01 /*flicker exposure got below minimum exposure */
414
#define ALOG(fmt,args...) printk(fmt, ##args)
415
#define LOG(fmt,args...) ALOG(KERN_INFO __FILE__ ":%s(%d):" fmt, __FUNCTION__ , __LINE__ , ##args)
416
 
417
#ifdef _CPIA_DEBUG_
418
#define ADBG(fmt,args...) printk(fmt, jiffies, ##args)
419
#define DBG(fmt,args...) ADBG(KERN_DEBUG __FILE__" (%ld):%s(%d):" fmt, __FUNCTION__, __LINE__ , ##args)
420
#else
421
#define DBG(fmn,args...) do {} while(0)
422
#endif
423
 
424
#define DEB_BYTE(p)\
425
  DBG("%1d %1d %1d %1d %1d %1d %1d %1d \n",\
426
      (p)&0x80?1:0, (p)&0x40?1:0, (p)&0x20?1:0, (p)&0x10?1:0,\
427
        (p)&0x08?1:0, (p)&0x04?1:0, (p)&0x02?1:0, (p)&0x01?1:0);
428
 
429
#endif /* __KERNEL__ */
430
 
431
#endif /* cpia_h */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.