1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3 * Motion Eye video4linux driver for Sony Vaio PictureBook
4 *
5 * Copyright (C) 2001-2004 Stelian Pop <stelian@popies.net>
6 *
7 * Copyright (C) 2001-2002 Alcôve <www.alcove.com>
8 *
9 * Copyright (C) 2000 Andrew Tridgell <tridge@valinux.com>
10 *
11 * Earlier work by Werner Almesberger, Paul `Rusty' Russell and Paul Mackerras.
12 *
13 * Some parts borrowed from various video4linux drivers, especially
14 * bttv-driver.c and zoran.c, see original files for credits.
15 */
16 #include <linux/module.h>
17 #include <linux/pci.h>
18 #include <linux/sched.h>
19 #include <linux/init.h>
20 #include <linux/gfp.h>
21 #include <linux/videodev2.h>
22 #include <media/v4l2-common.h>
23 #include <media/v4l2-device.h>
24 #include <media/v4l2-ioctl.h>
25 #include <media/v4l2-fh.h>
26 #include <media/v4l2-event.h>
27 #include <linux/uaccess.h>
28 #include <asm/io.h>
29 #include <linux/delay.h>
30 #include <linux/interrupt.h>
31 #include <linux/vmalloc.h>
32 #include <linux/dma-mapping.h>
33
34 #include "meye.h"
35 #include <linux/meye.h>
36
37 MODULE_AUTHOR("Stelian Pop <stelian@popies.net>");
38 MODULE_DESCRIPTION("v4l2 driver for the MotionEye camera");
39 MODULE_LICENSE("GPL");
40 MODULE_VERSION(MEYE_DRIVER_VERSION);
41
42 /* number of grab buffers */
43 static unsigned int gbuffers = 2;
44 module_param(gbuffers, int, 0444);
45 MODULE_PARM_DESC(gbuffers, "number of capture buffers, default is 2 (32 max)");
46
47 /* size of a grab buffer */
48 static unsigned int gbufsize = MEYE_MAX_BUFSIZE;
49 module_param(gbufsize, int, 0444);
50 MODULE_PARM_DESC(gbufsize, "size of the capture buffers, default is 614400 (will be rounded up to a page multiple)");
51
52 /* /dev/videoX registration number */
53 static int video_nr = -1;
54 module_param(video_nr, int, 0444);
55 MODULE_PARM_DESC(video_nr, "video device to register (0=/dev/video0, etc)");
56
57 /* driver structure - only one possible */
58 static struct meye meye;
59
60 /****************************************************************************/
61 /* Memory allocation routines (stolen from bttv-driver.c) */
62 /****************************************************************************/
rvmalloc(unsigned long size)63 static void *rvmalloc(unsigned long size)
64 {
65 void *mem;
66 unsigned long adr;
67
68 size = PAGE_ALIGN(size);
69 mem = vmalloc_32(size);
70 if (mem) {
71 memset(mem, 0, size);
72 adr = (unsigned long) mem;
73 while (size > 0) {
74 SetPageReserved(vmalloc_to_page((void *)adr));
75 adr += PAGE_SIZE;
76 size -= PAGE_SIZE;
77 }
78 }
79 return mem;
80 }
81
rvfree(void * mem,unsigned long size)82 static void rvfree(void * mem, unsigned long size)
83 {
84 unsigned long adr;
85
86 if (mem) {
87 adr = (unsigned long) mem;
88 while ((long) size > 0) {
89 ClearPageReserved(vmalloc_to_page((void *)adr));
90 adr += PAGE_SIZE;
91 size -= PAGE_SIZE;
92 }
93 vfree(mem);
94 }
95 }
96
97 /*
98 * return a page table pointing to N pages of locked memory
99 *
100 * NOTE: The meye device expects DMA addresses on 32 bits, we build
101 * a table of 1024 entries = 4 bytes * 1024 = 4096 bytes.
102 */
ptable_alloc(void)103 static int ptable_alloc(void)
104 {
105 u32 *pt;
106 int i;
107
108 memset(meye.mchip_ptable, 0, sizeof(meye.mchip_ptable));
109
110 /* give only 32 bit DMA addresses */
111 if (dma_set_mask(&meye.mchip_dev->dev, DMA_BIT_MASK(32)))
112 return -1;
113
114 meye.mchip_ptable_toc = dma_alloc_coherent(&meye.mchip_dev->dev,
115 PAGE_SIZE,
116 &meye.mchip_dmahandle,
117 GFP_KERNEL);
118 if (!meye.mchip_ptable_toc) {
119 meye.mchip_dmahandle = 0;
120 return -1;
121 }
122
123 pt = meye.mchip_ptable_toc;
124 for (i = 0; i < MCHIP_NB_PAGES; i++) {
125 dma_addr_t dma;
126 meye.mchip_ptable[i] = dma_alloc_coherent(&meye.mchip_dev->dev,
127 PAGE_SIZE,
128 &dma,
129 GFP_KERNEL);
130 if (!meye.mchip_ptable[i]) {
131 int j;
132 pt = meye.mchip_ptable_toc;
133 for (j = 0; j < i; ++j) {
134 dma = (dma_addr_t) *pt;
135 dma_free_coherent(&meye.mchip_dev->dev,
136 PAGE_SIZE,
137 meye.mchip_ptable[j], dma);
138 pt++;
139 }
140 dma_free_coherent(&meye.mchip_dev->dev,
141 PAGE_SIZE,
142 meye.mchip_ptable_toc,
143 meye.mchip_dmahandle);
144 meye.mchip_ptable_toc = NULL;
145 meye.mchip_dmahandle = 0;
146 return -1;
147 }
148 *pt = (u32) dma;
149 pt++;
150 }
151 return 0;
152 }
153
ptable_free(void)154 static void ptable_free(void)
155 {
156 u32 *pt;
157 int i;
158
159 pt = meye.mchip_ptable_toc;
160 for (i = 0; i < MCHIP_NB_PAGES; i++) {
161 dma_addr_t dma = (dma_addr_t) *pt;
162 if (meye.mchip_ptable[i])
163 dma_free_coherent(&meye.mchip_dev->dev,
164 PAGE_SIZE,
165 meye.mchip_ptable[i], dma);
166 pt++;
167 }
168
169 if (meye.mchip_ptable_toc)
170 dma_free_coherent(&meye.mchip_dev->dev,
171 PAGE_SIZE,
172 meye.mchip_ptable_toc,
173 meye.mchip_dmahandle);
174
175 memset(meye.mchip_ptable, 0, sizeof(meye.mchip_ptable));
176 meye.mchip_ptable_toc = NULL;
177 meye.mchip_dmahandle = 0;
178 }
179
180 /* copy data from ptable into buf */
ptable_copy(u8 * buf,int start,int size,int pt_pages)181 static void ptable_copy(u8 *buf, int start, int size, int pt_pages)
182 {
183 int i;
184
185 for (i = 0; i < (size / PAGE_SIZE) * PAGE_SIZE; i += PAGE_SIZE) {
186 memcpy(buf + i, meye.mchip_ptable[start++], PAGE_SIZE);
187 if (start >= pt_pages)
188 start = 0;
189 }
190 memcpy(buf + i, meye.mchip_ptable[start], size % PAGE_SIZE);
191 }
192
193 /****************************************************************************/
194 /* JPEG tables at different qualities to load into the VRJ chip */
195 /****************************************************************************/
196
197 /* return a set of quantisation tables based on a quality from 1 to 10 */
jpeg_quantisation_tables(int * length,int quality)198 static u16 *jpeg_quantisation_tables(int *length, int quality)
199 {
200 static u16 jpeg_tables[][70] = { {
201 0xdbff, 0x4300, 0xff00, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
202 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
203 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
204 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
205 0xffff, 0xffff, 0xffff,
206 0xdbff, 0x4300, 0xff01, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
207 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
208 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
209 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
210 0xffff, 0xffff, 0xffff,
211 },
212 {
213 0xdbff, 0x4300, 0x5000, 0x3c37, 0x3c46, 0x5032, 0x4146, 0x5a46,
214 0x5055, 0x785f, 0x82c8, 0x6e78, 0x786e, 0xaff5, 0x91b9, 0xffc8,
215 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
216 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
217 0xffff, 0xffff, 0xffff,
218 0xdbff, 0x4300, 0x5501, 0x5a5a, 0x6978, 0xeb78, 0x8282, 0xffeb,
219 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
220 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
221 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
222 0xffff, 0xffff, 0xffff,
223 },
224 {
225 0xdbff, 0x4300, 0x2800, 0x1e1c, 0x1e23, 0x2819, 0x2123, 0x2d23,
226 0x282b, 0x3c30, 0x4164, 0x373c, 0x3c37, 0x587b, 0x495d, 0x9164,
227 0x9980, 0x8f96, 0x8c80, 0xa08a, 0xe6b4, 0xa0c3, 0xdaaa, 0x8aad,
228 0xc88c, 0xcbff, 0xeeda, 0xfff5, 0xffff, 0xc19b, 0xffff, 0xfaff,
229 0xe6ff, 0xfffd, 0xfff8,
230 0xdbff, 0x4300, 0x2b01, 0x2d2d, 0x353c, 0x763c, 0x4141, 0xf876,
231 0x8ca5, 0xf8a5, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8,
232 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8,
233 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8, 0xf8f8,
234 0xf8f8, 0xf8f8, 0xfff8,
235 },
236 {
237 0xdbff, 0x4300, 0x1b00, 0x1412, 0x1417, 0x1b11, 0x1617, 0x1e17,
238 0x1b1c, 0x2820, 0x2b42, 0x2528, 0x2825, 0x3a51, 0x303d, 0x6042,
239 0x6555, 0x5f64, 0x5d55, 0x6a5b, 0x9978, 0x6a81, 0x9071, 0x5b73,
240 0x855d, 0x86b5, 0x9e90, 0xaba3, 0xabad, 0x8067, 0xc9bc, 0xa6ba,
241 0x99c7, 0xaba8, 0xffa4,
242 0xdbff, 0x4300, 0x1c01, 0x1e1e, 0x2328, 0x4e28, 0x2b2b, 0xa44e,
243 0x5d6e, 0xa46e, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4,
244 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4,
245 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4, 0xa4a4,
246 0xa4a4, 0xa4a4, 0xffa4,
247 },
248 {
249 0xdbff, 0x4300, 0x1400, 0x0f0e, 0x0f12, 0x140d, 0x1012, 0x1712,
250 0x1415, 0x1e18, 0x2132, 0x1c1e, 0x1e1c, 0x2c3d, 0x242e, 0x4932,
251 0x4c40, 0x474b, 0x4640, 0x5045, 0x735a, 0x5062, 0x6d55, 0x4556,
252 0x6446, 0x6588, 0x776d, 0x817b, 0x8182, 0x604e, 0x978d, 0x7d8c,
253 0x7396, 0x817e, 0xff7c,
254 0xdbff, 0x4300, 0x1501, 0x1717, 0x1a1e, 0x3b1e, 0x2121, 0x7c3b,
255 0x4653, 0x7c53, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c,
256 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c,
257 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c, 0x7c7c,
258 0x7c7c, 0x7c7c, 0xff7c,
259 },
260 {
261 0xdbff, 0x4300, 0x1000, 0x0c0b, 0x0c0e, 0x100a, 0x0d0e, 0x120e,
262 0x1011, 0x1813, 0x1a28, 0x1618, 0x1816, 0x2331, 0x1d25, 0x3a28,
263 0x3d33, 0x393c, 0x3833, 0x4037, 0x5c48, 0x404e, 0x5744, 0x3745,
264 0x5038, 0x516d, 0x5f57, 0x6762, 0x6768, 0x4d3e, 0x7971, 0x6470,
265 0x5c78, 0x6765, 0xff63,
266 0xdbff, 0x4300, 0x1101, 0x1212, 0x1518, 0x2f18, 0x1a1a, 0x632f,
267 0x3842, 0x6342, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363,
268 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363,
269 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363, 0x6363,
270 0x6363, 0x6363, 0xff63,
271 },
272 {
273 0xdbff, 0x4300, 0x0d00, 0x0a09, 0x0a0b, 0x0d08, 0x0a0b, 0x0e0b,
274 0x0d0e, 0x130f, 0x1520, 0x1213, 0x1312, 0x1c27, 0x171e, 0x2e20,
275 0x3129, 0x2e30, 0x2d29, 0x332c, 0x4a3a, 0x333e, 0x4636, 0x2c37,
276 0x402d, 0x4157, 0x4c46, 0x524e, 0x5253, 0x3e32, 0x615a, 0x505a,
277 0x4a60, 0x5251, 0xff4f,
278 0xdbff, 0x4300, 0x0e01, 0x0e0e, 0x1113, 0x2613, 0x1515, 0x4f26,
279 0x2d35, 0x4f35, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f,
280 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f,
281 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f, 0x4f4f,
282 0x4f4f, 0x4f4f, 0xff4f,
283 },
284 {
285 0xdbff, 0x4300, 0x0a00, 0x0707, 0x0708, 0x0a06, 0x0808, 0x0b08,
286 0x0a0a, 0x0e0b, 0x1018, 0x0d0e, 0x0e0d, 0x151d, 0x1116, 0x2318,
287 0x251f, 0x2224, 0x221f, 0x2621, 0x372b, 0x262f, 0x3429, 0x2129,
288 0x3022, 0x3141, 0x3934, 0x3e3b, 0x3e3e, 0x2e25, 0x4944, 0x3c43,
289 0x3748, 0x3e3d, 0xff3b,
290 0xdbff, 0x4300, 0x0a01, 0x0b0b, 0x0d0e, 0x1c0e, 0x1010, 0x3b1c,
291 0x2228, 0x3b28, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b,
292 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b,
293 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b, 0x3b3b,
294 0x3b3b, 0x3b3b, 0xff3b,
295 },
296 {
297 0xdbff, 0x4300, 0x0600, 0x0504, 0x0506, 0x0604, 0x0506, 0x0706,
298 0x0607, 0x0a08, 0x0a10, 0x090a, 0x0a09, 0x0e14, 0x0c0f, 0x1710,
299 0x1814, 0x1718, 0x1614, 0x1a16, 0x251d, 0x1a1f, 0x231b, 0x161c,
300 0x2016, 0x202c, 0x2623, 0x2927, 0x292a, 0x1f19, 0x302d, 0x282d,
301 0x2530, 0x2928, 0xff28,
302 0xdbff, 0x4300, 0x0701, 0x0707, 0x080a, 0x130a, 0x0a0a, 0x2813,
303 0x161a, 0x281a, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828,
304 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828,
305 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828, 0x2828,
306 0x2828, 0x2828, 0xff28,
307 },
308 {
309 0xdbff, 0x4300, 0x0300, 0x0202, 0x0203, 0x0302, 0x0303, 0x0403,
310 0x0303, 0x0504, 0x0508, 0x0405, 0x0504, 0x070a, 0x0607, 0x0c08,
311 0x0c0a, 0x0b0c, 0x0b0a, 0x0d0b, 0x120e, 0x0d10, 0x110e, 0x0b0e,
312 0x100b, 0x1016, 0x1311, 0x1514, 0x1515, 0x0f0c, 0x1817, 0x1416,
313 0x1218, 0x1514, 0xff14,
314 0xdbff, 0x4300, 0x0301, 0x0404, 0x0405, 0x0905, 0x0505, 0x1409,
315 0x0b0d, 0x140d, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414,
316 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414,
317 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414, 0x1414,
318 0x1414, 0x1414, 0xff14,
319 },
320 {
321 0xdbff, 0x4300, 0x0100, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
322 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
323 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
324 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
325 0x0101, 0x0101, 0xff01,
326 0xdbff, 0x4300, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
327 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
328 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
329 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101, 0x0101,
330 0x0101, 0x0101, 0xff01,
331 } };
332
333 if (quality < 0 || quality > 10) {
334 printk(KERN_WARNING
335 "meye: invalid quality level %d - using 8\n", quality);
336 quality = 8;
337 }
338
339 *length = ARRAY_SIZE(jpeg_tables[quality]);
340 return jpeg_tables[quality];
341 }
342
343 /* return a generic set of huffman tables */
jpeg_huffman_tables(int * length)344 static u16 *jpeg_huffman_tables(int *length)
345 {
346 static u16 tables[] = {
347 0xC4FF, 0xB500, 0x0010, 0x0102, 0x0303, 0x0402, 0x0503, 0x0405,
348 0x0004, 0x0100, 0x017D, 0x0302, 0x0400, 0x0511, 0x2112, 0x4131,
349 0x1306, 0x6151, 0x2207, 0x1471, 0x8132, 0xA191, 0x2308, 0xB142,
350 0x15C1, 0xD152, 0x24F0, 0x6233, 0x8272, 0x0A09, 0x1716, 0x1918,
351 0x251A, 0x2726, 0x2928, 0x342A, 0x3635, 0x3837, 0x3A39, 0x4443,
352 0x4645, 0x4847, 0x4A49, 0x5453, 0x5655, 0x5857, 0x5A59, 0x6463,
353 0x6665, 0x6867, 0x6A69, 0x7473, 0x7675, 0x7877, 0x7A79, 0x8483,
354 0x8685, 0x8887, 0x8A89, 0x9392, 0x9594, 0x9796, 0x9998, 0xA29A,
355 0xA4A3, 0xA6A5, 0xA8A7, 0xAAA9, 0xB3B2, 0xB5B4, 0xB7B6, 0xB9B8,
356 0xC2BA, 0xC4C3, 0xC6C5, 0xC8C7, 0xCAC9, 0xD3D2, 0xD5D4, 0xD7D6,
357 0xD9D8, 0xE1DA, 0xE3E2, 0xE5E4, 0xE7E6, 0xE9E8, 0xF1EA, 0xF3F2,
358 0xF5F4, 0xF7F6, 0xF9F8, 0xFFFA,
359 0xC4FF, 0xB500, 0x0011, 0x0102, 0x0402, 0x0304, 0x0704, 0x0405,
360 0x0004, 0x0201, 0x0077, 0x0201, 0x1103, 0x0504, 0x3121, 0x1206,
361 0x5141, 0x6107, 0x1371, 0x3222, 0x0881, 0x4214, 0xA191, 0xC1B1,
362 0x2309, 0x5233, 0x15F0, 0x7262, 0x0AD1, 0x2416, 0xE134, 0xF125,
363 0x1817, 0x1A19, 0x2726, 0x2928, 0x352A, 0x3736, 0x3938, 0x433A,
364 0x4544, 0x4746, 0x4948, 0x534A, 0x5554, 0x5756, 0x5958, 0x635A,
365 0x6564, 0x6766, 0x6968, 0x736A, 0x7574, 0x7776, 0x7978, 0x827A,
366 0x8483, 0x8685, 0x8887, 0x8A89, 0x9392, 0x9594, 0x9796, 0x9998,
367 0xA29A, 0xA4A3, 0xA6A5, 0xA8A7, 0xAAA9, 0xB3B2, 0xB5B4, 0xB7B6,
368 0xB9B8, 0xC2BA, 0xC4C3, 0xC6C5, 0xC8C7, 0xCAC9, 0xD3D2, 0xD5D4,
369 0xD7D6, 0xD9D8, 0xE2DA, 0xE4E3, 0xE6E5, 0xE8E7, 0xEAE9, 0xF3F2,
370 0xF5F4, 0xF7F6, 0xF9F8, 0xFFFA,
371 0xC4FF, 0x1F00, 0x0000, 0x0501, 0x0101, 0x0101, 0x0101, 0x0000,
372 0x0000, 0x0000, 0x0000, 0x0201, 0x0403, 0x0605, 0x0807, 0x0A09,
373 0xFF0B,
374 0xC4FF, 0x1F00, 0x0001, 0x0103, 0x0101, 0x0101, 0x0101, 0x0101,
375 0x0000, 0x0000, 0x0000, 0x0201, 0x0403, 0x0605, 0x0807, 0x0A09,
376 0xFF0B
377 };
378
379 *length = ARRAY_SIZE(tables);
380 return tables;
381 }
382
383 /****************************************************************************/
384 /* MCHIP low-level functions */
385 /****************************************************************************/
386
387 /* returns the horizontal capture size */
mchip_hsize(void)388 static inline int mchip_hsize(void)
389 {
390 return meye.params.subsample ? 320 : 640;
391 }
392
393 /* returns the vertical capture size */
mchip_vsize(void)394 static inline int mchip_vsize(void)
395 {
396 return meye.params.subsample ? 240 : 480;
397 }
398
399 /* waits for a register to be available */
mchip_sync(int reg)400 static void mchip_sync(int reg)
401 {
402 u32 status;
403 int i;
404
405 if (reg == MCHIP_MM_FIFO_DATA) {
406 for (i = 0; i < MCHIP_REG_TIMEOUT; i++) {
407 status = readl(meye.mchip_mmregs +
408 MCHIP_MM_FIFO_STATUS);
409 if (!(status & MCHIP_MM_FIFO_WAIT)) {
410 printk(KERN_WARNING "meye: fifo not ready\n");
411 return;
412 }
413 if (status & MCHIP_MM_FIFO_READY)
414 return;
415 udelay(1);
416 }
417 } else if (reg > 0x80) {
418 u32 mask = (reg < 0x100) ? MCHIP_HIC_STATUS_MCC_RDY
419 : MCHIP_HIC_STATUS_VRJ_RDY;
420 for (i = 0; i < MCHIP_REG_TIMEOUT; i++) {
421 status = readl(meye.mchip_mmregs + MCHIP_HIC_STATUS);
422 if (status & mask)
423 return;
424 udelay(1);
425 }
426 } else
427 return;
428 printk(KERN_WARNING
429 "meye: mchip_sync() timeout on reg 0x%x status=0x%x\n",
430 reg, status);
431 }
432
433 /* sets a value into the register */
mchip_set(int reg,u32 v)434 static inline void mchip_set(int reg, u32 v)
435 {
436 mchip_sync(reg);
437 writel(v, meye.mchip_mmregs + reg);
438 }
439
440 /* get the register value */
mchip_read(int reg)441 static inline u32 mchip_read(int reg)
442 {
443 mchip_sync(reg);
444 return readl(meye.mchip_mmregs + reg);
445 }
446
447 /* wait for a register to become a particular value */
mchip_delay(u32 reg,u32 v)448 static inline int mchip_delay(u32 reg, u32 v)
449 {
450 int n = 10;
451 while (--n && mchip_read(reg) != v)
452 udelay(1);
453 return n;
454 }
455
456 /* setup subsampling */
mchip_subsample(void)457 static void mchip_subsample(void)
458 {
459 mchip_set(MCHIP_MCC_R_SAMPLING, meye.params.subsample);
460 mchip_set(MCHIP_MCC_R_XRANGE, mchip_hsize());
461 mchip_set(MCHIP_MCC_R_YRANGE, mchip_vsize());
462 mchip_set(MCHIP_MCC_B_XRANGE, mchip_hsize());
463 mchip_set(MCHIP_MCC_B_YRANGE, mchip_vsize());
464 mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE);
465 }
466
467 /* set the framerate into the mchip */
mchip_set_framerate(void)468 static void mchip_set_framerate(void)
469 {
470 mchip_set(MCHIP_HIC_S_RATE, meye.params.framerate);
471 }
472
473 /* load some huffman and quantisation tables into the VRJ chip ready
474 for JPEG compression */
mchip_load_tables(void)475 static void mchip_load_tables(void)
476 {
477 int i;
478 int length;
479 u16 *tables;
480
481 tables = jpeg_huffman_tables(&length);
482 for (i = 0; i < length; i++)
483 writel(tables[i], meye.mchip_mmregs + MCHIP_VRJ_TABLE_DATA);
484
485 tables = jpeg_quantisation_tables(&length, meye.params.quality);
486 for (i = 0; i < length; i++)
487 writel(tables[i], meye.mchip_mmregs + MCHIP_VRJ_TABLE_DATA);
488 }
489
490 /* setup the VRJ parameters in the chip */
mchip_vrj_setup(u8 mode)491 static void mchip_vrj_setup(u8 mode)
492 {
493 mchip_set(MCHIP_VRJ_BUS_MODE, 5);
494 mchip_set(MCHIP_VRJ_SIGNAL_ACTIVE_LEVEL, 0x1f);
495 mchip_set(MCHIP_VRJ_PDAT_USE, 1);
496 mchip_set(MCHIP_VRJ_IRQ_FLAG, 0xa0);
497 mchip_set(MCHIP_VRJ_MODE_SPECIFY, mode);
498 mchip_set(MCHIP_VRJ_NUM_LINES, mchip_vsize());
499 mchip_set(MCHIP_VRJ_NUM_PIXELS, mchip_hsize());
500 mchip_set(MCHIP_VRJ_NUM_COMPONENTS, 0x1b);
501 mchip_set(MCHIP_VRJ_LIMIT_COMPRESSED_LO, 0xFFFF);
502 mchip_set(MCHIP_VRJ_LIMIT_COMPRESSED_HI, 0xFFFF);
503 mchip_set(MCHIP_VRJ_COMP_DATA_FORMAT, 0xC);
504 mchip_set(MCHIP_VRJ_RESTART_INTERVAL, 0);
505 mchip_set(MCHIP_VRJ_SOF1, 0x601);
506 mchip_set(MCHIP_VRJ_SOF2, 0x1502);
507 mchip_set(MCHIP_VRJ_SOF3, 0x1503);
508 mchip_set(MCHIP_VRJ_SOF4, 0x1596);
509 mchip_set(MCHIP_VRJ_SOS, 0x0ed0);
510
511 mchip_load_tables();
512 }
513
514 /* sets the DMA parameters into the chip */
mchip_dma_setup(dma_addr_t dma_addr)515 static void mchip_dma_setup(dma_addr_t dma_addr)
516 {
517 int i;
518
519 mchip_set(MCHIP_MM_PT_ADDR, (u32)dma_addr);
520 for (i = 0; i < 4; i++)
521 mchip_set(MCHIP_MM_FIR(i), 0);
522 meye.mchip_fnum = 0;
523 }
524
525 /* setup for DMA transfers - also zeros the framebuffer */
mchip_dma_alloc(void)526 static int mchip_dma_alloc(void)
527 {
528 if (!meye.mchip_dmahandle)
529 if (ptable_alloc())
530 return -1;
531 return 0;
532 }
533
534 /* frees the DMA buffer */
mchip_dma_free(void)535 static void mchip_dma_free(void)
536 {
537 if (meye.mchip_dmahandle) {
538 mchip_dma_setup(0);
539 ptable_free();
540 }
541 }
542
543 /* stop any existing HIC action and wait for any dma to complete then
544 reset the dma engine */
mchip_hic_stop(void)545 static void mchip_hic_stop(void)
546 {
547 int i, j;
548
549 meye.mchip_mode = MCHIP_HIC_MODE_NOOP;
550 if (!(mchip_read(MCHIP_HIC_STATUS) & MCHIP_HIC_STATUS_BUSY))
551 return;
552 for (i = 0; i < 20; ++i) {
553 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_STOP);
554 mchip_delay(MCHIP_HIC_CMD, 0);
555 for (j = 0; j < 100; ++j) {
556 if (mchip_delay(MCHIP_HIC_STATUS,
557 MCHIP_HIC_STATUS_IDLE))
558 return;
559 msleep(1);
560 }
561 printk(KERN_ERR "meye: need to reset HIC!\n");
562
563 mchip_set(MCHIP_HIC_CTL, MCHIP_HIC_CTL_SOFT_RESET);
564 msleep(250);
565 }
566 printk(KERN_ERR "meye: resetting HIC hanged!\n");
567 }
568
569 /****************************************************************************/
570 /* MCHIP frame processing functions */
571 /****************************************************************************/
572
573 /* get the next ready frame from the dma engine */
mchip_get_frame(void)574 static u32 mchip_get_frame(void)
575 {
576 return mchip_read(MCHIP_MM_FIR(meye.mchip_fnum));
577 }
578
579 /* frees the current frame from the dma engine */
mchip_free_frame(void)580 static void mchip_free_frame(void)
581 {
582 mchip_set(MCHIP_MM_FIR(meye.mchip_fnum), 0);
583 meye.mchip_fnum++;
584 meye.mchip_fnum %= 4;
585 }
586
587 /* read one frame from the framebuffer assuming it was captured using
588 a uncompressed transfer */
mchip_cont_read_frame(u32 v,u8 * buf,int size)589 static void mchip_cont_read_frame(u32 v, u8 *buf, int size)
590 {
591 int pt_id;
592
593 pt_id = (v >> 17) & 0x3FF;
594
595 ptable_copy(buf, pt_id, size, MCHIP_NB_PAGES);
596 }
597
598 /* read a compressed frame from the framebuffer */
mchip_comp_read_frame(u32 v,u8 * buf,int size)599 static int mchip_comp_read_frame(u32 v, u8 *buf, int size)
600 {
601 int pt_start, pt_end, trailer;
602 int fsize;
603 int i;
604
605 pt_start = (v >> 19) & 0xFF;
606 pt_end = (v >> 11) & 0xFF;
607 trailer = (v >> 1) & 0x3FF;
608
609 if (pt_end < pt_start)
610 fsize = (MCHIP_NB_PAGES_MJPEG - pt_start) * PAGE_SIZE +
611 pt_end * PAGE_SIZE + trailer * 4;
612 else
613 fsize = (pt_end - pt_start) * PAGE_SIZE + trailer * 4;
614
615 if (fsize > size) {
616 printk(KERN_WARNING "meye: oversized compressed frame %d\n",
617 fsize);
618 return -1;
619 }
620
621 ptable_copy(buf, pt_start, fsize, MCHIP_NB_PAGES_MJPEG);
622
623 #ifdef MEYE_JPEG_CORRECTION
624
625 /* Some mchip generated jpeg frames are incorrect. In most
626 * (all ?) of those cases, the final EOI (0xff 0xd9) marker
627 * is not present at the end of the frame.
628 *
629 * Since adding the final marker is not enough to restore
630 * the jpeg integrity, we drop the frame.
631 */
632
633 for (i = fsize - 1; i > 0 && buf[i] == 0xff; i--) ;
634
635 if (i < 2 || buf[i - 1] != 0xff || buf[i] != 0xd9)
636 return -1;
637
638 #endif
639
640 return fsize;
641 }
642
643 /* take a picture into SDRAM */
mchip_take_picture(void)644 static void mchip_take_picture(void)
645 {
646 int i;
647
648 mchip_hic_stop();
649 mchip_subsample();
650 mchip_dma_setup(meye.mchip_dmahandle);
651
652 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_STILL_CAP);
653 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
654
655 mchip_delay(MCHIP_HIC_CMD, 0);
656
657 for (i = 0; i < 100; ++i) {
658 if (mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE))
659 break;
660 msleep(1);
661 }
662 }
663
664 /* dma a previously taken picture into a buffer */
mchip_get_picture(u8 * buf,int bufsize)665 static void mchip_get_picture(u8 *buf, int bufsize)
666 {
667 u32 v;
668 int i;
669
670 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_STILL_OUT);
671 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
672
673 mchip_delay(MCHIP_HIC_CMD, 0);
674 for (i = 0; i < 100; ++i) {
675 if (mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE))
676 break;
677 msleep(1);
678 }
679 for (i = 0; i < 4; ++i) {
680 v = mchip_get_frame();
681 if (v & MCHIP_MM_FIR_RDY) {
682 mchip_cont_read_frame(v, buf, bufsize);
683 break;
684 }
685 mchip_free_frame();
686 }
687 }
688
689 /* start continuous dma capture */
mchip_continuous_start(void)690 static void mchip_continuous_start(void)
691 {
692 mchip_hic_stop();
693 mchip_subsample();
694 mchip_set_framerate();
695 mchip_dma_setup(meye.mchip_dmahandle);
696
697 meye.mchip_mode = MCHIP_HIC_MODE_CONT_OUT;
698
699 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_CONT_OUT);
700 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
701
702 mchip_delay(MCHIP_HIC_CMD, 0);
703 }
704
705 /* compress one frame into a buffer */
mchip_compress_frame(u8 * buf,int bufsize)706 static int mchip_compress_frame(u8 *buf, int bufsize)
707 {
708 u32 v;
709 int len = -1, i;
710
711 mchip_vrj_setup(0x3f);
712 udelay(50);
713
714 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_STILL_COMP);
715 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
716
717 mchip_delay(MCHIP_HIC_CMD, 0);
718 for (i = 0; i < 100; ++i) {
719 if (mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE))
720 break;
721 msleep(1);
722 }
723
724 for (i = 0; i < 4; ++i) {
725 v = mchip_get_frame();
726 if (v & MCHIP_MM_FIR_RDY) {
727 len = mchip_comp_read_frame(v, buf, bufsize);
728 break;
729 }
730 mchip_free_frame();
731 }
732 return len;
733 }
734
735 #if 0
736 /* uncompress one image into a buffer */
737 static int mchip_uncompress_frame(u8 *img, int imgsize, u8 *buf, int bufsize)
738 {
739 mchip_vrj_setup(0x3f);
740 udelay(50);
741
742 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_STILL_DECOMP);
743 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
744
745 mchip_delay(MCHIP_HIC_CMD, 0);
746
747 return mchip_comp_read_frame(buf, bufsize);
748 }
749 #endif
750
751 /* start continuous compressed capture */
mchip_cont_compression_start(void)752 static void mchip_cont_compression_start(void)
753 {
754 mchip_hic_stop();
755 mchip_vrj_setup(0x3f);
756 mchip_subsample();
757 mchip_set_framerate();
758 mchip_dma_setup(meye.mchip_dmahandle);
759
760 meye.mchip_mode = MCHIP_HIC_MODE_CONT_COMP;
761
762 mchip_set(MCHIP_HIC_MODE, MCHIP_HIC_MODE_CONT_COMP);
763 mchip_set(MCHIP_HIC_CMD, MCHIP_HIC_CMD_START);
764
765 mchip_delay(MCHIP_HIC_CMD, 0);
766 }
767
768 /****************************************************************************/
769 /* Interrupt handling */
770 /****************************************************************************/
771
meye_irq(int irq,void * dev_id)772 static irqreturn_t meye_irq(int irq, void *dev_id)
773 {
774 u32 v;
775 int reqnr;
776 static int sequence;
777
778 v = mchip_read(MCHIP_MM_INTA);
779
780 if (meye.mchip_mode != MCHIP_HIC_MODE_CONT_OUT &&
781 meye.mchip_mode != MCHIP_HIC_MODE_CONT_COMP)
782 return IRQ_NONE;
783
784 again:
785 v = mchip_get_frame();
786 if (!(v & MCHIP_MM_FIR_RDY))
787 return IRQ_HANDLED;
788
789 if (meye.mchip_mode == MCHIP_HIC_MODE_CONT_OUT) {
790 if (kfifo_out_locked(&meye.grabq, (unsigned char *)&reqnr,
791 sizeof(int), &meye.grabq_lock) != sizeof(int)) {
792 mchip_free_frame();
793 return IRQ_HANDLED;
794 }
795 mchip_cont_read_frame(v, meye.grab_fbuffer + gbufsize * reqnr,
796 mchip_hsize() * mchip_vsize() * 2);
797 meye.grab_buffer[reqnr].size = mchip_hsize() * mchip_vsize() * 2;
798 meye.grab_buffer[reqnr].state = MEYE_BUF_DONE;
799 meye.grab_buffer[reqnr].ts = ktime_get_ns();
800 meye.grab_buffer[reqnr].sequence = sequence++;
801 kfifo_in_locked(&meye.doneq, (unsigned char *)&reqnr,
802 sizeof(int), &meye.doneq_lock);
803 wake_up_interruptible(&meye.proc_list);
804 } else {
805 int size;
806 size = mchip_comp_read_frame(v, meye.grab_temp, gbufsize);
807 if (size == -1) {
808 mchip_free_frame();
809 goto again;
810 }
811 if (kfifo_out_locked(&meye.grabq, (unsigned char *)&reqnr,
812 sizeof(int), &meye.grabq_lock) != sizeof(int)) {
813 mchip_free_frame();
814 goto again;
815 }
816 memcpy(meye.grab_fbuffer + gbufsize * reqnr, meye.grab_temp,
817 size);
818 meye.grab_buffer[reqnr].size = size;
819 meye.grab_buffer[reqnr].state = MEYE_BUF_DONE;
820 meye.grab_buffer[reqnr].ts = ktime_get_ns();
821 meye.grab_buffer[reqnr].sequence = sequence++;
822 kfifo_in_locked(&meye.doneq, (unsigned char *)&reqnr,
823 sizeof(int), &meye.doneq_lock);
824 wake_up_interruptible(&meye.proc_list);
825 }
826 mchip_free_frame();
827 goto again;
828 }
829
830 /****************************************************************************/
831 /* video4linux integration */
832 /****************************************************************************/
833
meye_open(struct file * file)834 static int meye_open(struct file *file)
835 {
836 int i;
837
838 if (test_and_set_bit(0, &meye.in_use))
839 return -EBUSY;
840
841 mchip_hic_stop();
842
843 if (mchip_dma_alloc()) {
844 printk(KERN_ERR "meye: mchip framebuffer allocation failed\n");
845 clear_bit(0, &meye.in_use);
846 return -ENOBUFS;
847 }
848
849 for (i = 0; i < MEYE_MAX_BUFNBRS; i++)
850 meye.grab_buffer[i].state = MEYE_BUF_UNUSED;
851 kfifo_reset(&meye.grabq);
852 kfifo_reset(&meye.doneq);
853 return v4l2_fh_open(file);
854 }
855
meye_release(struct file * file)856 static int meye_release(struct file *file)
857 {
858 mchip_hic_stop();
859 mchip_dma_free();
860 clear_bit(0, &meye.in_use);
861 return v4l2_fh_release(file);
862 }
863
meyeioc_g_params(struct meye_params * p)864 static int meyeioc_g_params(struct meye_params *p)
865 {
866 *p = meye.params;
867 return 0;
868 }
869
meyeioc_s_params(struct meye_params * jp)870 static int meyeioc_s_params(struct meye_params *jp)
871 {
872 if (jp->subsample > 1)
873 return -EINVAL;
874
875 if (jp->quality > 10)
876 return -EINVAL;
877
878 if (jp->sharpness > 63 || jp->agc > 63 || jp->picture > 63)
879 return -EINVAL;
880
881 if (jp->framerate > 31)
882 return -EINVAL;
883
884 mutex_lock(&meye.lock);
885
886 if (meye.params.subsample != jp->subsample ||
887 meye.params.quality != jp->quality)
888 mchip_hic_stop(); /* need restart */
889
890 meye.params = *jp;
891 sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERASHARPNESS,
892 meye.params.sharpness);
893 sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERAAGC,
894 meye.params.agc);
895 sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERAPICTURE,
896 meye.params.picture);
897 mutex_unlock(&meye.lock);
898
899 return 0;
900 }
901
meyeioc_qbuf_capt(int * nb)902 static int meyeioc_qbuf_capt(int *nb)
903 {
904 if (!meye.grab_fbuffer)
905 return -EINVAL;
906
907 if (*nb >= gbuffers)
908 return -EINVAL;
909
910 if (*nb < 0) {
911 /* stop capture */
912 mchip_hic_stop();
913 return 0;
914 }
915
916 if (meye.grab_buffer[*nb].state != MEYE_BUF_UNUSED)
917 return -EBUSY;
918
919 mutex_lock(&meye.lock);
920
921 if (meye.mchip_mode != MCHIP_HIC_MODE_CONT_COMP)
922 mchip_cont_compression_start();
923
924 meye.grab_buffer[*nb].state = MEYE_BUF_USING;
925 kfifo_in_locked(&meye.grabq, (unsigned char *)nb, sizeof(int),
926 &meye.grabq_lock);
927 mutex_unlock(&meye.lock);
928
929 return 0;
930 }
931
meyeioc_sync(struct file * file,void * fh,int * i)932 static int meyeioc_sync(struct file *file, void *fh, int *i)
933 {
934 int unused;
935
936 if (*i < 0 || *i >= gbuffers)
937 return -EINVAL;
938
939 mutex_lock(&meye.lock);
940 switch (meye.grab_buffer[*i].state) {
941
942 case MEYE_BUF_UNUSED:
943 mutex_unlock(&meye.lock);
944 return -EINVAL;
945 case MEYE_BUF_USING:
946 if (file->f_flags & O_NONBLOCK) {
947 mutex_unlock(&meye.lock);
948 return -EAGAIN;
949 }
950 if (wait_event_interruptible(meye.proc_list,
951 (meye.grab_buffer[*i].state != MEYE_BUF_USING))) {
952 mutex_unlock(&meye.lock);
953 return -EINTR;
954 }
955 fallthrough;
956 case MEYE_BUF_DONE:
957 meye.grab_buffer[*i].state = MEYE_BUF_UNUSED;
958 if (kfifo_out_locked(&meye.doneq, (unsigned char *)&unused,
959 sizeof(int), &meye.doneq_lock) != sizeof(int))
960 break;
961 }
962 *i = meye.grab_buffer[*i].size;
963 mutex_unlock(&meye.lock);
964 return 0;
965 }
966
meyeioc_stillcapt(void)967 static int meyeioc_stillcapt(void)
968 {
969 if (!meye.grab_fbuffer)
970 return -EINVAL;
971
972 if (meye.grab_buffer[0].state != MEYE_BUF_UNUSED)
973 return -EBUSY;
974
975 mutex_lock(&meye.lock);
976 meye.grab_buffer[0].state = MEYE_BUF_USING;
977 mchip_take_picture();
978
979 mchip_get_picture(meye.grab_fbuffer,
980 mchip_hsize() * mchip_vsize() * 2);
981
982 meye.grab_buffer[0].state = MEYE_BUF_DONE;
983 mutex_unlock(&meye.lock);
984
985 return 0;
986 }
987
meyeioc_stilljcapt(int * len)988 static int meyeioc_stilljcapt(int *len)
989 {
990 if (!meye.grab_fbuffer)
991 return -EINVAL;
992
993 if (meye.grab_buffer[0].state != MEYE_BUF_UNUSED)
994 return -EBUSY;
995
996 mutex_lock(&meye.lock);
997 meye.grab_buffer[0].state = MEYE_BUF_USING;
998 *len = -1;
999
1000 while (*len == -1) {
1001 mchip_take_picture();
1002 *len = mchip_compress_frame(meye.grab_fbuffer, gbufsize);
1003 }
1004
1005 meye.grab_buffer[0].state = MEYE_BUF_DONE;
1006 mutex_unlock(&meye.lock);
1007 return 0;
1008 }
1009
vidioc_querycap(struct file * file,void * fh,struct v4l2_capability * cap)1010 static int vidioc_querycap(struct file *file, void *fh,
1011 struct v4l2_capability *cap)
1012 {
1013 strscpy(cap->driver, "meye", sizeof(cap->driver));
1014 strscpy(cap->card, "meye", sizeof(cap->card));
1015 return 0;
1016 }
1017
vidioc_enum_input(struct file * file,void * fh,struct v4l2_input * i)1018 static int vidioc_enum_input(struct file *file, void *fh, struct v4l2_input *i)
1019 {
1020 if (i->index != 0)
1021 return -EINVAL;
1022
1023 strscpy(i->name, "Camera", sizeof(i->name));
1024 i->type = V4L2_INPUT_TYPE_CAMERA;
1025
1026 return 0;
1027 }
1028
vidioc_g_input(struct file * file,void * fh,unsigned int * i)1029 static int vidioc_g_input(struct file *file, void *fh, unsigned int *i)
1030 {
1031 *i = 0;
1032 return 0;
1033 }
1034
vidioc_s_input(struct file * file,void * fh,unsigned int i)1035 static int vidioc_s_input(struct file *file, void *fh, unsigned int i)
1036 {
1037 if (i != 0)
1038 return -EINVAL;
1039
1040 return 0;
1041 }
1042
meye_s_ctrl(struct v4l2_ctrl * ctrl)1043 static int meye_s_ctrl(struct v4l2_ctrl *ctrl)
1044 {
1045 mutex_lock(&meye.lock);
1046 switch (ctrl->id) {
1047 case V4L2_CID_BRIGHTNESS:
1048 sony_pic_camera_command(
1049 SONY_PIC_COMMAND_SETCAMERABRIGHTNESS, ctrl->val);
1050 meye.brightness = ctrl->val << 10;
1051 break;
1052 case V4L2_CID_HUE:
1053 sony_pic_camera_command(
1054 SONY_PIC_COMMAND_SETCAMERAHUE, ctrl->val);
1055 meye.hue = ctrl->val << 10;
1056 break;
1057 case V4L2_CID_CONTRAST:
1058 sony_pic_camera_command(
1059 SONY_PIC_COMMAND_SETCAMERACONTRAST, ctrl->val);
1060 meye.contrast = ctrl->val << 10;
1061 break;
1062 case V4L2_CID_SATURATION:
1063 sony_pic_camera_command(
1064 SONY_PIC_COMMAND_SETCAMERACOLOR, ctrl->val);
1065 meye.colour = ctrl->val << 10;
1066 break;
1067 case V4L2_CID_MEYE_AGC:
1068 sony_pic_camera_command(
1069 SONY_PIC_COMMAND_SETCAMERAAGC, ctrl->val);
1070 meye.params.agc = ctrl->val;
1071 break;
1072 case V4L2_CID_SHARPNESS:
1073 sony_pic_camera_command(
1074 SONY_PIC_COMMAND_SETCAMERASHARPNESS, ctrl->val);
1075 meye.params.sharpness = ctrl->val;
1076 break;
1077 case V4L2_CID_MEYE_PICTURE:
1078 sony_pic_camera_command(
1079 SONY_PIC_COMMAND_SETCAMERAPICTURE, ctrl->val);
1080 meye.params.picture = ctrl->val;
1081 break;
1082 case V4L2_CID_JPEG_COMPRESSION_QUALITY:
1083 meye.params.quality = ctrl->val;
1084 break;
1085 case V4L2_CID_MEYE_FRAMERATE:
1086 meye.params.framerate = ctrl->val;
1087 break;
1088 default:
1089 mutex_unlock(&meye.lock);
1090 return -EINVAL;
1091 }
1092 mutex_unlock(&meye.lock);
1093
1094 return 0;
1095 }
1096
vidioc_enum_fmt_vid_cap(struct file * file,void * fh,struct v4l2_fmtdesc * f)1097 static int vidioc_enum_fmt_vid_cap(struct file *file, void *fh,
1098 struct v4l2_fmtdesc *f)
1099 {
1100 if (f->index > 1)
1101 return -EINVAL;
1102
1103 if (f->index == 0) {
1104 /* standard YUV 422 capture */
1105 f->flags = 0;
1106 f->pixelformat = V4L2_PIX_FMT_YUYV;
1107 } else {
1108 /* compressed MJPEG capture */
1109 f->pixelformat = V4L2_PIX_FMT_MJPEG;
1110 }
1111
1112 return 0;
1113 }
1114
vidioc_try_fmt_vid_cap(struct file * file,void * fh,struct v4l2_format * f)1115 static int vidioc_try_fmt_vid_cap(struct file *file, void *fh,
1116 struct v4l2_format *f)
1117 {
1118 if (f->fmt.pix.pixelformat != V4L2_PIX_FMT_YUYV &&
1119 f->fmt.pix.pixelformat != V4L2_PIX_FMT_MJPEG)
1120 return -EINVAL;
1121
1122 if (f->fmt.pix.field != V4L2_FIELD_ANY &&
1123 f->fmt.pix.field != V4L2_FIELD_NONE)
1124 return -EINVAL;
1125
1126 f->fmt.pix.field = V4L2_FIELD_NONE;
1127
1128 if (f->fmt.pix.width <= 320) {
1129 f->fmt.pix.width = 320;
1130 f->fmt.pix.height = 240;
1131 } else {
1132 f->fmt.pix.width = 640;
1133 f->fmt.pix.height = 480;
1134 }
1135
1136 f->fmt.pix.bytesperline = f->fmt.pix.width * 2;
1137 f->fmt.pix.sizeimage = f->fmt.pix.height *
1138 f->fmt.pix.bytesperline;
1139 f->fmt.pix.colorspace = 0;
1140
1141 return 0;
1142 }
1143
vidioc_g_fmt_vid_cap(struct file * file,void * fh,struct v4l2_format * f)1144 static int vidioc_g_fmt_vid_cap(struct file *file, void *fh,
1145 struct v4l2_format *f)
1146 {
1147 switch (meye.mchip_mode) {
1148 case MCHIP_HIC_MODE_CONT_OUT:
1149 default:
1150 f->fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
1151 break;
1152 case MCHIP_HIC_MODE_CONT_COMP:
1153 f->fmt.pix.pixelformat = V4L2_PIX_FMT_MJPEG;
1154 break;
1155 }
1156
1157 f->fmt.pix.field = V4L2_FIELD_NONE;
1158 f->fmt.pix.width = mchip_hsize();
1159 f->fmt.pix.height = mchip_vsize();
1160 f->fmt.pix.bytesperline = f->fmt.pix.width * 2;
1161 f->fmt.pix.sizeimage = f->fmt.pix.height *
1162 f->fmt.pix.bytesperline;
1163
1164 return 0;
1165 }
1166
vidioc_s_fmt_vid_cap(struct file * file,void * fh,struct v4l2_format * f)1167 static int vidioc_s_fmt_vid_cap(struct file *file, void *fh,
1168 struct v4l2_format *f)
1169 {
1170 if (f->fmt.pix.pixelformat != V4L2_PIX_FMT_YUYV &&
1171 f->fmt.pix.pixelformat != V4L2_PIX_FMT_MJPEG)
1172 return -EINVAL;
1173
1174 if (f->fmt.pix.field != V4L2_FIELD_ANY &&
1175 f->fmt.pix.field != V4L2_FIELD_NONE)
1176 return -EINVAL;
1177
1178 f->fmt.pix.field = V4L2_FIELD_NONE;
1179 mutex_lock(&meye.lock);
1180
1181 if (f->fmt.pix.width <= 320) {
1182 f->fmt.pix.width = 320;
1183 f->fmt.pix.height = 240;
1184 meye.params.subsample = 1;
1185 } else {
1186 f->fmt.pix.width = 640;
1187 f->fmt.pix.height = 480;
1188 meye.params.subsample = 0;
1189 }
1190
1191 switch (f->fmt.pix.pixelformat) {
1192 case V4L2_PIX_FMT_YUYV:
1193 meye.mchip_mode = MCHIP_HIC_MODE_CONT_OUT;
1194 break;
1195 case V4L2_PIX_FMT_MJPEG:
1196 meye.mchip_mode = MCHIP_HIC_MODE_CONT_COMP;
1197 break;
1198 }
1199
1200 mutex_unlock(&meye.lock);
1201 f->fmt.pix.bytesperline = f->fmt.pix.width * 2;
1202 f->fmt.pix.sizeimage = f->fmt.pix.height *
1203 f->fmt.pix.bytesperline;
1204 f->fmt.pix.colorspace = 0;
1205
1206 return 0;
1207 }
1208
vidioc_reqbufs(struct file * file,void * fh,struct v4l2_requestbuffers * req)1209 static int vidioc_reqbufs(struct file *file, void *fh,
1210 struct v4l2_requestbuffers *req)
1211 {
1212 int i;
1213
1214 if (req->memory != V4L2_MEMORY_MMAP)
1215 return -EINVAL;
1216
1217 if (meye.grab_fbuffer && req->count == gbuffers) {
1218 /* already allocated, no modifications */
1219 return 0;
1220 }
1221
1222 mutex_lock(&meye.lock);
1223 if (meye.grab_fbuffer) {
1224 for (i = 0; i < gbuffers; i++)
1225 if (meye.vma_use_count[i]) {
1226 mutex_unlock(&meye.lock);
1227 return -EINVAL;
1228 }
1229 rvfree(meye.grab_fbuffer, gbuffers * gbufsize);
1230 meye.grab_fbuffer = NULL;
1231 }
1232
1233 gbuffers = max(2, min((int)req->count, MEYE_MAX_BUFNBRS));
1234 req->count = gbuffers;
1235 meye.grab_fbuffer = rvmalloc(gbuffers * gbufsize);
1236
1237 if (!meye.grab_fbuffer) {
1238 printk(KERN_ERR "meye: v4l framebuffer allocation failed\n");
1239 mutex_unlock(&meye.lock);
1240 return -ENOMEM;
1241 }
1242
1243 for (i = 0; i < gbuffers; i++)
1244 meye.vma_use_count[i] = 0;
1245
1246 mutex_unlock(&meye.lock);
1247
1248 return 0;
1249 }
1250
vidioc_querybuf(struct file * file,void * fh,struct v4l2_buffer * buf)1251 static int vidioc_querybuf(struct file *file, void *fh, struct v4l2_buffer *buf)
1252 {
1253 unsigned int index = buf->index;
1254
1255 if (index >= gbuffers)
1256 return -EINVAL;
1257
1258 buf->bytesused = meye.grab_buffer[index].size;
1259 buf->flags = V4L2_BUF_FLAG_MAPPED | V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
1260
1261 if (meye.grab_buffer[index].state == MEYE_BUF_USING)
1262 buf->flags |= V4L2_BUF_FLAG_QUEUED;
1263
1264 if (meye.grab_buffer[index].state == MEYE_BUF_DONE)
1265 buf->flags |= V4L2_BUF_FLAG_DONE;
1266
1267 buf->field = V4L2_FIELD_NONE;
1268 v4l2_buffer_set_timestamp(buf, meye.grab_buffer[index].ts);
1269 buf->sequence = meye.grab_buffer[index].sequence;
1270 buf->memory = V4L2_MEMORY_MMAP;
1271 buf->m.offset = index * gbufsize;
1272 buf->length = gbufsize;
1273
1274 return 0;
1275 }
1276
vidioc_qbuf(struct file * file,void * fh,struct v4l2_buffer * buf)1277 static int vidioc_qbuf(struct file *file, void *fh, struct v4l2_buffer *buf)
1278 {
1279 if (buf->memory != V4L2_MEMORY_MMAP)
1280 return -EINVAL;
1281
1282 if (buf->index >= gbuffers)
1283 return -EINVAL;
1284
1285 if (meye.grab_buffer[buf->index].state != MEYE_BUF_UNUSED)
1286 return -EINVAL;
1287
1288 mutex_lock(&meye.lock);
1289 buf->flags |= V4L2_BUF_FLAG_QUEUED;
1290 buf->flags &= ~V4L2_BUF_FLAG_DONE;
1291 meye.grab_buffer[buf->index].state = MEYE_BUF_USING;
1292 kfifo_in_locked(&meye.grabq, (unsigned char *)&buf->index,
1293 sizeof(int), &meye.grabq_lock);
1294 mutex_unlock(&meye.lock);
1295
1296 return 0;
1297 }
1298
vidioc_dqbuf(struct file * file,void * fh,struct v4l2_buffer * buf)1299 static int vidioc_dqbuf(struct file *file, void *fh, struct v4l2_buffer *buf)
1300 {
1301 int reqnr;
1302
1303 if (buf->memory != V4L2_MEMORY_MMAP)
1304 return -EINVAL;
1305
1306 mutex_lock(&meye.lock);
1307
1308 if (kfifo_len(&meye.doneq) == 0 && file->f_flags & O_NONBLOCK) {
1309 mutex_unlock(&meye.lock);
1310 return -EAGAIN;
1311 }
1312
1313 if (wait_event_interruptible(meye.proc_list,
1314 kfifo_len(&meye.doneq) != 0) < 0) {
1315 mutex_unlock(&meye.lock);
1316 return -EINTR;
1317 }
1318
1319 if (!kfifo_out_locked(&meye.doneq, (unsigned char *)&reqnr,
1320 sizeof(int), &meye.doneq_lock)) {
1321 mutex_unlock(&meye.lock);
1322 return -EBUSY;
1323 }
1324
1325 if (meye.grab_buffer[reqnr].state != MEYE_BUF_DONE) {
1326 mutex_unlock(&meye.lock);
1327 return -EINVAL;
1328 }
1329
1330 buf->index = reqnr;
1331 buf->bytesused = meye.grab_buffer[reqnr].size;
1332 buf->flags = V4L2_BUF_FLAG_MAPPED | V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
1333 buf->field = V4L2_FIELD_NONE;
1334 v4l2_buffer_set_timestamp(buf, meye.grab_buffer[reqnr].ts);
1335 buf->sequence = meye.grab_buffer[reqnr].sequence;
1336 buf->memory = V4L2_MEMORY_MMAP;
1337 buf->m.offset = reqnr * gbufsize;
1338 buf->length = gbufsize;
1339 meye.grab_buffer[reqnr].state = MEYE_BUF_UNUSED;
1340 mutex_unlock(&meye.lock);
1341
1342 return 0;
1343 }
1344
vidioc_streamon(struct file * file,void * fh,enum v4l2_buf_type i)1345 static int vidioc_streamon(struct file *file, void *fh, enum v4l2_buf_type i)
1346 {
1347 mutex_lock(&meye.lock);
1348
1349 switch (meye.mchip_mode) {
1350 case MCHIP_HIC_MODE_CONT_OUT:
1351 mchip_continuous_start();
1352 break;
1353 case MCHIP_HIC_MODE_CONT_COMP:
1354 mchip_cont_compression_start();
1355 break;
1356 default:
1357 mutex_unlock(&meye.lock);
1358 return -EINVAL;
1359 }
1360
1361 mutex_unlock(&meye.lock);
1362
1363 return 0;
1364 }
1365
vidioc_streamoff(struct file * file,void * fh,enum v4l2_buf_type i)1366 static int vidioc_streamoff(struct file *file, void *fh, enum v4l2_buf_type i)
1367 {
1368 mutex_lock(&meye.lock);
1369 mchip_hic_stop();
1370 kfifo_reset(&meye.grabq);
1371 kfifo_reset(&meye.doneq);
1372
1373 for (i = 0; i < MEYE_MAX_BUFNBRS; i++)
1374 meye.grab_buffer[i].state = MEYE_BUF_UNUSED;
1375
1376 mutex_unlock(&meye.lock);
1377 return 0;
1378 }
1379
vidioc_default(struct file * file,void * fh,bool valid_prio,unsigned int cmd,void * arg)1380 static long vidioc_default(struct file *file, void *fh, bool valid_prio,
1381 unsigned int cmd, void *arg)
1382 {
1383 switch (cmd) {
1384 case MEYEIOC_G_PARAMS:
1385 return meyeioc_g_params((struct meye_params *) arg);
1386
1387 case MEYEIOC_S_PARAMS:
1388 return meyeioc_s_params((struct meye_params *) arg);
1389
1390 case MEYEIOC_QBUF_CAPT:
1391 return meyeioc_qbuf_capt((int *) arg);
1392
1393 case MEYEIOC_SYNC:
1394 return meyeioc_sync(file, fh, (int *) arg);
1395
1396 case MEYEIOC_STILLCAPT:
1397 return meyeioc_stillcapt();
1398
1399 case MEYEIOC_STILLJCAPT:
1400 return meyeioc_stilljcapt((int *) arg);
1401
1402 default:
1403 return -ENOTTY;
1404 }
1405
1406 }
1407
meye_poll(struct file * file,poll_table * wait)1408 static __poll_t meye_poll(struct file *file, poll_table *wait)
1409 {
1410 __poll_t res = v4l2_ctrl_poll(file, wait);
1411
1412 mutex_lock(&meye.lock);
1413 poll_wait(file, &meye.proc_list, wait);
1414 if (kfifo_len(&meye.doneq))
1415 res |= EPOLLIN | EPOLLRDNORM;
1416 mutex_unlock(&meye.lock);
1417 return res;
1418 }
1419
meye_vm_open(struct vm_area_struct * vma)1420 static void meye_vm_open(struct vm_area_struct *vma)
1421 {
1422 long idx = (long)vma->vm_private_data;
1423 meye.vma_use_count[idx]++;
1424 }
1425
meye_vm_close(struct vm_area_struct * vma)1426 static void meye_vm_close(struct vm_area_struct *vma)
1427 {
1428 long idx = (long)vma->vm_private_data;
1429 meye.vma_use_count[idx]--;
1430 }
1431
1432 static const struct vm_operations_struct meye_vm_ops = {
1433 .open = meye_vm_open,
1434 .close = meye_vm_close,
1435 };
1436
meye_mmap(struct file * file,struct vm_area_struct * vma)1437 static int meye_mmap(struct file *file, struct vm_area_struct *vma)
1438 {
1439 unsigned long start = vma->vm_start;
1440 unsigned long size = vma->vm_end - vma->vm_start;
1441 unsigned long offset = vma->vm_pgoff << PAGE_SHIFT;
1442 unsigned long page, pos;
1443
1444 mutex_lock(&meye.lock);
1445 if (size > gbuffers * gbufsize || offset > gbuffers * gbufsize - size) {
1446 mutex_unlock(&meye.lock);
1447 return -EINVAL;
1448 }
1449 if (!meye.grab_fbuffer) {
1450 int i;
1451
1452 /* lazy allocation */
1453 meye.grab_fbuffer = rvmalloc(gbuffers*gbufsize);
1454 if (!meye.grab_fbuffer) {
1455 printk(KERN_ERR "meye: v4l framebuffer allocation failed\n");
1456 mutex_unlock(&meye.lock);
1457 return -ENOMEM;
1458 }
1459 for (i = 0; i < gbuffers; i++)
1460 meye.vma_use_count[i] = 0;
1461 }
1462 pos = (unsigned long)meye.grab_fbuffer + offset;
1463
1464 while (size > 0) {
1465 page = vmalloc_to_pfn((void *)pos);
1466 if (remap_pfn_range(vma, start, page, PAGE_SIZE, PAGE_SHARED)) {
1467 mutex_unlock(&meye.lock);
1468 return -EAGAIN;
1469 }
1470 start += PAGE_SIZE;
1471 pos += PAGE_SIZE;
1472 if (size > PAGE_SIZE)
1473 size -= PAGE_SIZE;
1474 else
1475 size = 0;
1476 }
1477
1478 vma->vm_ops = &meye_vm_ops;
1479 vma->vm_flags &= ~VM_IO; /* not I/O memory */
1480 vma->vm_flags |= VM_DONTEXPAND | VM_DONTDUMP;
1481 vma->vm_private_data = (void *) (offset / gbufsize);
1482 meye_vm_open(vma);
1483
1484 mutex_unlock(&meye.lock);
1485 return 0;
1486 }
1487
1488 static const struct v4l2_file_operations meye_fops = {
1489 .owner = THIS_MODULE,
1490 .open = meye_open,
1491 .release = meye_release,
1492 .mmap = meye_mmap,
1493 .unlocked_ioctl = video_ioctl2,
1494 .poll = meye_poll,
1495 };
1496
1497 static const struct v4l2_ioctl_ops meye_ioctl_ops = {
1498 .vidioc_querycap = vidioc_querycap,
1499 .vidioc_enum_input = vidioc_enum_input,
1500 .vidioc_g_input = vidioc_g_input,
1501 .vidioc_s_input = vidioc_s_input,
1502 .vidioc_enum_fmt_vid_cap = vidioc_enum_fmt_vid_cap,
1503 .vidioc_try_fmt_vid_cap = vidioc_try_fmt_vid_cap,
1504 .vidioc_g_fmt_vid_cap = vidioc_g_fmt_vid_cap,
1505 .vidioc_s_fmt_vid_cap = vidioc_s_fmt_vid_cap,
1506 .vidioc_reqbufs = vidioc_reqbufs,
1507 .vidioc_querybuf = vidioc_querybuf,
1508 .vidioc_qbuf = vidioc_qbuf,
1509 .vidioc_dqbuf = vidioc_dqbuf,
1510 .vidioc_streamon = vidioc_streamon,
1511 .vidioc_streamoff = vidioc_streamoff,
1512 .vidioc_log_status = v4l2_ctrl_log_status,
1513 .vidioc_subscribe_event = v4l2_ctrl_subscribe_event,
1514 .vidioc_unsubscribe_event = v4l2_event_unsubscribe,
1515 .vidioc_default = vidioc_default,
1516 };
1517
1518 static const struct video_device meye_template = {
1519 .name = "meye",
1520 .fops = &meye_fops,
1521 .ioctl_ops = &meye_ioctl_ops,
1522 .release = video_device_release_empty,
1523 .device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING,
1524 };
1525
1526 static const struct v4l2_ctrl_ops meye_ctrl_ops = {
1527 .s_ctrl = meye_s_ctrl,
1528 };
1529
meye_suspend(struct device * dev)1530 static int __maybe_unused meye_suspend(struct device *dev)
1531 {
1532 meye.pm_mchip_mode = meye.mchip_mode;
1533 mchip_hic_stop();
1534 mchip_set(MCHIP_MM_INTA, 0x0);
1535 return 0;
1536 }
1537
meye_resume(struct device * dev)1538 static int __maybe_unused meye_resume(struct device *dev)
1539 {
1540 pci_write_config_word(meye.mchip_dev, MCHIP_PCI_SOFTRESET_SET, 1);
1541
1542 mchip_delay(MCHIP_HIC_CMD, 0);
1543 mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE);
1544 msleep(1);
1545 mchip_set(MCHIP_VRJ_SOFT_RESET, 1);
1546 msleep(1);
1547 mchip_set(MCHIP_MM_PCI_MODE, 5);
1548 msleep(1);
1549 mchip_set(MCHIP_MM_INTA, MCHIP_MM_INTA_HIC_1_MASK);
1550
1551 switch (meye.pm_mchip_mode) {
1552 case MCHIP_HIC_MODE_CONT_OUT:
1553 mchip_continuous_start();
1554 break;
1555 case MCHIP_HIC_MODE_CONT_COMP:
1556 mchip_cont_compression_start();
1557 break;
1558 }
1559 return 0;
1560 }
1561
meye_probe(struct pci_dev * pcidev,const struct pci_device_id * ent)1562 static int meye_probe(struct pci_dev *pcidev, const struct pci_device_id *ent)
1563 {
1564 static const struct v4l2_ctrl_config ctrl_agc = {
1565 .id = V4L2_CID_MEYE_AGC,
1566 .type = V4L2_CTRL_TYPE_INTEGER,
1567 .ops = &meye_ctrl_ops,
1568 .name = "AGC",
1569 .max = 63,
1570 .step = 1,
1571 .def = 48,
1572 .flags = V4L2_CTRL_FLAG_SLIDER,
1573 };
1574 static const struct v4l2_ctrl_config ctrl_picture = {
1575 .id = V4L2_CID_MEYE_PICTURE,
1576 .type = V4L2_CTRL_TYPE_INTEGER,
1577 .ops = &meye_ctrl_ops,
1578 .name = "Picture",
1579 .max = 63,
1580 .step = 1,
1581 };
1582 static const struct v4l2_ctrl_config ctrl_framerate = {
1583 .id = V4L2_CID_MEYE_FRAMERATE,
1584 .type = V4L2_CTRL_TYPE_INTEGER,
1585 .ops = &meye_ctrl_ops,
1586 .name = "Framerate",
1587 .max = 31,
1588 .step = 1,
1589 };
1590 struct v4l2_device *v4l2_dev = &meye.v4l2_dev;
1591 int ret = -EBUSY;
1592 unsigned long mchip_adr;
1593
1594 if (meye.mchip_dev != NULL) {
1595 printk(KERN_ERR "meye: only one device allowed!\n");
1596 return ret;
1597 }
1598
1599 ret = v4l2_device_register(&pcidev->dev, v4l2_dev);
1600 if (ret < 0) {
1601 v4l2_err(v4l2_dev, "Could not register v4l2_device\n");
1602 return ret;
1603 }
1604 ret = -ENOMEM;
1605 meye.mchip_dev = pcidev;
1606
1607 meye.grab_temp = vmalloc(array_size(PAGE_SIZE, MCHIP_NB_PAGES_MJPEG));
1608 if (!meye.grab_temp)
1609 goto outvmalloc;
1610
1611 spin_lock_init(&meye.grabq_lock);
1612 if (kfifo_alloc(&meye.grabq, sizeof(int) * MEYE_MAX_BUFNBRS,
1613 GFP_KERNEL))
1614 goto outkfifoalloc1;
1615
1616 spin_lock_init(&meye.doneq_lock);
1617 if (kfifo_alloc(&meye.doneq, sizeof(int) * MEYE_MAX_BUFNBRS,
1618 GFP_KERNEL))
1619 goto outkfifoalloc2;
1620
1621 meye.vdev = meye_template;
1622 meye.vdev.v4l2_dev = &meye.v4l2_dev;
1623
1624 ret = sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERA, 1);
1625 if (ret) {
1626 v4l2_err(v4l2_dev, "meye: unable to power on the camera\n");
1627 v4l2_err(v4l2_dev, "meye: did you enable the camera in sonypi using the module options ?\n");
1628 goto outsonypienable;
1629 }
1630
1631 ret = pci_enable_device(meye.mchip_dev);
1632 if (ret) {
1633 v4l2_err(v4l2_dev, "meye: pci_enable_device failed\n");
1634 goto outenabledev;
1635 }
1636
1637 ret = -EIO;
1638 mchip_adr = pci_resource_start(meye.mchip_dev,0);
1639 if (!mchip_adr) {
1640 v4l2_err(v4l2_dev, "meye: mchip has no device base address\n");
1641 goto outregions;
1642 }
1643 if (!request_mem_region(pci_resource_start(meye.mchip_dev, 0),
1644 pci_resource_len(meye.mchip_dev, 0),
1645 "meye")) {
1646 v4l2_err(v4l2_dev, "meye: request_mem_region failed\n");
1647 goto outregions;
1648 }
1649 meye.mchip_mmregs = ioremap(mchip_adr, MCHIP_MM_REGS);
1650 if (!meye.mchip_mmregs) {
1651 v4l2_err(v4l2_dev, "meye: ioremap failed\n");
1652 goto outremap;
1653 }
1654
1655 meye.mchip_irq = pcidev->irq;
1656 if (request_irq(meye.mchip_irq, meye_irq,
1657 IRQF_SHARED, "meye", meye_irq)) {
1658 v4l2_err(v4l2_dev, "request_irq failed\n");
1659 goto outreqirq;
1660 }
1661
1662 pci_write_config_byte(meye.mchip_dev, PCI_CACHE_LINE_SIZE, 8);
1663 pci_write_config_byte(meye.mchip_dev, PCI_LATENCY_TIMER, 64);
1664
1665 pci_set_master(meye.mchip_dev);
1666
1667 /* Ask the camera to perform a soft reset. */
1668 pci_write_config_word(meye.mchip_dev, MCHIP_PCI_SOFTRESET_SET, 1);
1669
1670 mchip_delay(MCHIP_HIC_CMD, 0);
1671 mchip_delay(MCHIP_HIC_STATUS, MCHIP_HIC_STATUS_IDLE);
1672
1673 msleep(1);
1674 mchip_set(MCHIP_VRJ_SOFT_RESET, 1);
1675
1676 msleep(1);
1677 mchip_set(MCHIP_MM_PCI_MODE, 5);
1678
1679 msleep(1);
1680 mchip_set(MCHIP_MM_INTA, MCHIP_MM_INTA_HIC_1_MASK);
1681
1682 mutex_init(&meye.lock);
1683 init_waitqueue_head(&meye.proc_list);
1684
1685 v4l2_ctrl_handler_init(&meye.hdl, 3);
1686 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1687 V4L2_CID_BRIGHTNESS, 0, 63, 1, 32);
1688 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1689 V4L2_CID_HUE, 0, 63, 1, 32);
1690 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1691 V4L2_CID_CONTRAST, 0, 63, 1, 32);
1692 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1693 V4L2_CID_SATURATION, 0, 63, 1, 32);
1694 v4l2_ctrl_new_custom(&meye.hdl, &ctrl_agc, NULL);
1695 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1696 V4L2_CID_SHARPNESS, 0, 63, 1, 32);
1697 v4l2_ctrl_new_custom(&meye.hdl, &ctrl_picture, NULL);
1698 v4l2_ctrl_new_std(&meye.hdl, &meye_ctrl_ops,
1699 V4L2_CID_JPEG_COMPRESSION_QUALITY, 0, 10, 1, 8);
1700 v4l2_ctrl_new_custom(&meye.hdl, &ctrl_framerate, NULL);
1701 if (meye.hdl.error) {
1702 v4l2_err(v4l2_dev, "couldn't register controls\n");
1703 goto outvideoreg;
1704 }
1705
1706 v4l2_ctrl_handler_setup(&meye.hdl);
1707 meye.vdev.ctrl_handler = &meye.hdl;
1708
1709 if (video_register_device(&meye.vdev, VFL_TYPE_VIDEO,
1710 video_nr) < 0) {
1711 v4l2_err(v4l2_dev, "video_register_device failed\n");
1712 goto outvideoreg;
1713 }
1714
1715 v4l2_info(v4l2_dev, "Motion Eye Camera Driver v%s.\n",
1716 MEYE_DRIVER_VERSION);
1717 v4l2_info(v4l2_dev, "mchip KL5A72002 rev. %d, base %lx, irq %d\n",
1718 meye.mchip_dev->revision, mchip_adr, meye.mchip_irq);
1719
1720 return 0;
1721
1722 outvideoreg:
1723 v4l2_ctrl_handler_free(&meye.hdl);
1724 free_irq(meye.mchip_irq, meye_irq);
1725 outreqirq:
1726 iounmap(meye.mchip_mmregs);
1727 outremap:
1728 release_mem_region(pci_resource_start(meye.mchip_dev, 0),
1729 pci_resource_len(meye.mchip_dev, 0));
1730 outregions:
1731 pci_disable_device(meye.mchip_dev);
1732 outenabledev:
1733 sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERA, 0);
1734 outsonypienable:
1735 kfifo_free(&meye.doneq);
1736 outkfifoalloc2:
1737 kfifo_free(&meye.grabq);
1738 outkfifoalloc1:
1739 vfree(meye.grab_temp);
1740 outvmalloc:
1741 return ret;
1742 }
1743
meye_remove(struct pci_dev * pcidev)1744 static void meye_remove(struct pci_dev *pcidev)
1745 {
1746 video_unregister_device(&meye.vdev);
1747
1748 mchip_hic_stop();
1749
1750 mchip_dma_free();
1751
1752 /* disable interrupts */
1753 mchip_set(MCHIP_MM_INTA, 0x0);
1754
1755 free_irq(meye.mchip_irq, meye_irq);
1756
1757 iounmap(meye.mchip_mmregs);
1758
1759 release_mem_region(pci_resource_start(meye.mchip_dev, 0),
1760 pci_resource_len(meye.mchip_dev, 0));
1761
1762 pci_disable_device(meye.mchip_dev);
1763
1764 sony_pic_camera_command(SONY_PIC_COMMAND_SETCAMERA, 0);
1765
1766 kfifo_free(&meye.doneq);
1767 kfifo_free(&meye.grabq);
1768
1769 vfree(meye.grab_temp);
1770
1771 if (meye.grab_fbuffer) {
1772 rvfree(meye.grab_fbuffer, gbuffers*gbufsize);
1773 meye.grab_fbuffer = NULL;
1774 }
1775
1776 printk(KERN_INFO "meye: removed\n");
1777 }
1778
1779 static const struct pci_device_id meye_pci_tbl[] = {
1780 { PCI_VDEVICE(KAWASAKI, PCI_DEVICE_ID_MCHIP_KL5A72002), 0 },
1781 { }
1782 };
1783
1784 MODULE_DEVICE_TABLE(pci, meye_pci_tbl);
1785
1786 static SIMPLE_DEV_PM_OPS(meye_pm_ops, meye_suspend, meye_resume);
1787
1788 static struct pci_driver meye_driver = {
1789 .name = "meye",
1790 .id_table = meye_pci_tbl,
1791 .probe = meye_probe,
1792 .remove = meye_remove,
1793 .driver.pm = &meye_pm_ops,
1794 };
1795
meye_init(void)1796 static int __init meye_init(void)
1797 {
1798 gbuffers = max(2, min((int)gbuffers, MEYE_MAX_BUFNBRS));
1799 if (gbufsize > MEYE_MAX_BUFSIZE)
1800 gbufsize = MEYE_MAX_BUFSIZE;
1801 gbufsize = PAGE_ALIGN(gbufsize);
1802 printk(KERN_INFO "meye: using %d buffers with %dk (%dk total) for capture\n",
1803 gbuffers,
1804 gbufsize / 1024, gbuffers * gbufsize / 1024);
1805 return pci_register_driver(&meye_driver);
1806 }
1807
meye_exit(void)1808 static void __exit meye_exit(void)
1809 {
1810 pci_unregister_driver(&meye_driver);
1811 }
1812
1813 module_init(meye_init);
1814 module_exit(meye_exit);
1815