• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /****************************************************************************
3  *
4  *  Filename: cpia2_usb.c
5  *
6  *  Copyright 2001, STMicrolectronics, Inc.
7  *      Contact:  steve.miller@st.com
8  *
9  *  Description:
10  *     This is a USB driver for CPia2 based video cameras.
11  *     The infrastructure of this driver is based on the cpia usb driver by
12  *     Jochen Scharrlach and Johannes Erdfeldt.
13  *
14  *  Stripped of 2.4 stuff ready for main kernel submit by
15  *		Alan Cox <alan@lxorguk.ukuu.org.uk>
16  ****************************************************************************/
17 
18 #include <linux/kernel.h>
19 #include <linux/slab.h>
20 #include <linux/usb.h>
21 #include <linux/module.h>
22 
23 #include "cpia2.h"
24 
25 static int frame_sizes[] = {
26 	0,	// USBIF_CMDONLY
27 	0,	// USBIF_BULK
28 	128,	// USBIF_ISO_1
29 	384,	// USBIF_ISO_2
30 	640,	// USBIF_ISO_3
31 	768,	// USBIF_ISO_4
32 	896,	// USBIF_ISO_5
33 	1023,	// USBIF_ISO_6
34 };
35 
36 #define FRAMES_PER_DESC    10
37 #define FRAME_SIZE_PER_DESC   frame_sizes[cam->cur_alt]
38 
39 static void process_frame(struct camera_data *cam);
40 static void cpia2_usb_complete(struct urb *urb);
41 static int cpia2_usb_probe(struct usb_interface *intf,
42 			   const struct usb_device_id *id);
43 static void cpia2_usb_disconnect(struct usb_interface *intf);
44 static int cpia2_usb_suspend(struct usb_interface *intf, pm_message_t message);
45 static int cpia2_usb_resume(struct usb_interface *intf);
46 
47 static void free_sbufs(struct camera_data *cam);
48 static void add_APPn(struct camera_data *cam);
49 static void add_COM(struct camera_data *cam);
50 static int submit_urbs(struct camera_data *cam);
51 static int set_alternate(struct camera_data *cam, unsigned int alt);
52 static int configure_transfer_mode(struct camera_data *cam, unsigned int alt);
53 
54 static const struct usb_device_id cpia2_id_table[] = {
55 	{USB_DEVICE(0x0553, 0x0100)},
56 	{USB_DEVICE(0x0553, 0x0140)},
57 	{USB_DEVICE(0x0553, 0x0151)},  /* STV0676 */
58 	{}			/* Terminating entry */
59 };
60 MODULE_DEVICE_TABLE(usb, cpia2_id_table);
61 
62 static struct usb_driver cpia2_driver = {
63 	.name		= "cpia2",
64 	.probe		= cpia2_usb_probe,
65 	.disconnect	= cpia2_usb_disconnect,
66 	.suspend	= cpia2_usb_suspend,
67 	.resume		= cpia2_usb_resume,
68 	.reset_resume	= cpia2_usb_resume,
69 	.id_table	= cpia2_id_table
70 };
71 
72 
73 /******************************************************************************
74  *
75  *  process_frame
76  *
77  *****************************************************************************/
process_frame(struct camera_data * cam)78 static void process_frame(struct camera_data *cam)
79 {
80 	static int frame_count;
81 
82 	unsigned char *inbuff = cam->workbuff->data;
83 
84 	DBG("Processing frame #%d, current:%d\n",
85 	    cam->workbuff->num, cam->curbuff->num);
86 
87 	if(cam->workbuff->length > cam->workbuff->max_length)
88 		cam->workbuff->max_length = cam->workbuff->length;
89 
90 	if ((inbuff[0] == 0xFF) && (inbuff[1] == 0xD8)) {
91 		frame_count++;
92 	} else {
93 		cam->workbuff->status = FRAME_ERROR;
94 		DBG("Start of frame not found\n");
95 		return;
96 	}
97 
98 	/***
99 	 * Now the output buffer should have a JPEG image in it.
100 	 ***/
101 	if(!cam->first_image_seen) {
102 		/* Always skip the first image after streaming
103 		 * starts. It is almost certainly corrupt. */
104 		cam->first_image_seen = 1;
105 		cam->workbuff->status = FRAME_EMPTY;
106 		return;
107 	}
108 	if (cam->workbuff->length > 3) {
109 		if(cam->mmapped &&
110 		   cam->workbuff->length < cam->workbuff->max_length) {
111 			/* No junk in the buffers */
112 			memset(cam->workbuff->data+cam->workbuff->length,
113 			       0, cam->workbuff->max_length-
114 				  cam->workbuff->length);
115 		}
116 		cam->workbuff->max_length = cam->workbuff->length;
117 		cam->workbuff->status = FRAME_READY;
118 
119 		if(!cam->mmapped && cam->num_frames > 2) {
120 			/* During normal reading, the most recent
121 			 * frame will be read.  If the current frame
122 			 * hasn't started reading yet, it will never
123 			 * be read, so mark it empty.  If the buffer is
124 			 * mmapped, or we have few buffers, we need to
125 			 * wait for the user to free the buffer.
126 			 *
127 			 * NOTE: This is not entirely foolproof with 3
128 			 * buffers, but it would take an EXTREMELY
129 			 * overloaded system to cause problems (possible
130 			 * image data corruption).  Basically, it would
131 			 * need to take more time to execute cpia2_read
132 			 * than it would for the camera to send
133 			 * cam->num_frames-2 frames before problems
134 			 * could occur.
135 			 */
136 			cam->curbuff->status = FRAME_EMPTY;
137 		}
138 		cam->curbuff = cam->workbuff;
139 		cam->workbuff = cam->workbuff->next;
140 		DBG("Changed buffers, work:%d, current:%d\n",
141 		    cam->workbuff->num, cam->curbuff->num);
142 		return;
143 	} else {
144 		DBG("Not enough data for an image.\n");
145 	}
146 
147 	cam->workbuff->status = FRAME_ERROR;
148 	return;
149 }
150 
151 /******************************************************************************
152  *
153  *  add_APPn
154  *
155  *  Adds a user specified APPn record
156  *****************************************************************************/
add_APPn(struct camera_data * cam)157 static void add_APPn(struct camera_data *cam)
158 {
159 	if(cam->APP_len > 0) {
160 		cam->workbuff->data[cam->workbuff->length++] = 0xFF;
161 		cam->workbuff->data[cam->workbuff->length++] = 0xE0+cam->APPn;
162 		cam->workbuff->data[cam->workbuff->length++] = 0;
163 		cam->workbuff->data[cam->workbuff->length++] = cam->APP_len+2;
164 		memcpy(cam->workbuff->data+cam->workbuff->length,
165 		       cam->APP_data, cam->APP_len);
166 		cam->workbuff->length += cam->APP_len;
167 	}
168 }
169 
170 /******************************************************************************
171  *
172  *  add_COM
173  *
174  *  Adds a user specified COM record
175  *****************************************************************************/
add_COM(struct camera_data * cam)176 static void add_COM(struct camera_data *cam)
177 {
178 	if(cam->COM_len > 0) {
179 		cam->workbuff->data[cam->workbuff->length++] = 0xFF;
180 		cam->workbuff->data[cam->workbuff->length++] = 0xFE;
181 		cam->workbuff->data[cam->workbuff->length++] = 0;
182 		cam->workbuff->data[cam->workbuff->length++] = cam->COM_len+2;
183 		memcpy(cam->workbuff->data+cam->workbuff->length,
184 		       cam->COM_data, cam->COM_len);
185 		cam->workbuff->length += cam->COM_len;
186 	}
187 }
188 
189 /******************************************************************************
190  *
191  *  cpia2_usb_complete
192  *
193  *  callback when incoming packet is received
194  *****************************************************************************/
cpia2_usb_complete(struct urb * urb)195 static void cpia2_usb_complete(struct urb *urb)
196 {
197 	int i;
198 	unsigned char *cdata;
199 	static bool frame_ready = false;
200 	struct camera_data *cam = (struct camera_data *) urb->context;
201 
202 	if (urb->status!=0) {
203 		if (!(urb->status == -ENOENT ||
204 		      urb->status == -ECONNRESET ||
205 		      urb->status == -ESHUTDOWN))
206 		{
207 			DBG("urb->status = %d!\n", urb->status);
208 		}
209 		DBG("Stopping streaming\n");
210 		return;
211 	}
212 
213 	if (!cam->streaming || !video_is_registered(&cam->vdev)) {
214 		LOG("Will now stop the streaming: streaming = %d, present=%d\n",
215 		    cam->streaming, video_is_registered(&cam->vdev));
216 		return;
217 	}
218 
219 	/***
220 	 * Packet collater
221 	 ***/
222 	//DBG("Collating %d packets\n", urb->number_of_packets);
223 	for (i = 0; i < urb->number_of_packets; i++) {
224 		u16 checksum, iso_checksum;
225 		int j;
226 		int n = urb->iso_frame_desc[i].actual_length;
227 		int st = urb->iso_frame_desc[i].status;
228 
229 		if(cam->workbuff->status == FRAME_READY) {
230 			struct framebuf *ptr;
231 			/* Try to find an available buffer */
232 			DBG("workbuff full, searching\n");
233 			for (ptr = cam->workbuff->next;
234 			     ptr != cam->workbuff;
235 			     ptr = ptr->next)
236 			{
237 				if (ptr->status == FRAME_EMPTY) {
238 					ptr->status = FRAME_READING;
239 					ptr->length = 0;
240 					break;
241 				}
242 			}
243 			if (ptr == cam->workbuff)
244 				break; /* No READING or EMPTY buffers left */
245 
246 			cam->workbuff = ptr;
247 		}
248 
249 		if (cam->workbuff->status == FRAME_EMPTY ||
250 		    cam->workbuff->status == FRAME_ERROR) {
251 			cam->workbuff->status = FRAME_READING;
252 			cam->workbuff->length = 0;
253 		}
254 
255 		//DBG("   Packet %d length = %d, status = %d\n", i, n, st);
256 		cdata = urb->transfer_buffer + urb->iso_frame_desc[i].offset;
257 
258 		if (st) {
259 			LOG("cpia2 data error: [%d] len=%d, status = %d\n",
260 			    i, n, st);
261 			if(!ALLOW_CORRUPT)
262 				cam->workbuff->status = FRAME_ERROR;
263 			continue;
264 		}
265 
266 		if(n<=2)
267 			continue;
268 
269 		checksum = 0;
270 		for(j=0; j<n-2; ++j)
271 			checksum += cdata[j];
272 		iso_checksum = cdata[j] + cdata[j+1]*256;
273 		if(checksum != iso_checksum) {
274 			LOG("checksum mismatch: [%d] len=%d, calculated = %x, checksum = %x\n",
275 			    i, n, (int)checksum, (int)iso_checksum);
276 			if(!ALLOW_CORRUPT) {
277 				cam->workbuff->status = FRAME_ERROR;
278 				continue;
279 			}
280 		}
281 		n -= 2;
282 
283 		if(cam->workbuff->status != FRAME_READING) {
284 			if((0xFF == cdata[0] && 0xD8 == cdata[1]) ||
285 			   (0xD8 == cdata[0] && 0xFF == cdata[1] &&
286 			    0 != cdata[2])) {
287 				/* frame is skipped, but increment total
288 				 * frame count anyway */
289 				cam->frame_count++;
290 			}
291 			DBG("workbuff not reading, status=%d\n",
292 			    cam->workbuff->status);
293 			continue;
294 		}
295 
296 		if (cam->frame_size < cam->workbuff->length + n) {
297 			ERR("buffer overflow! length: %d, n: %d\n",
298 			    cam->workbuff->length, n);
299 			cam->workbuff->status = FRAME_ERROR;
300 			if(cam->workbuff->length > cam->workbuff->max_length)
301 				cam->workbuff->max_length =
302 					cam->workbuff->length;
303 			continue;
304 		}
305 
306 		if (cam->workbuff->length == 0) {
307 			int data_offset;
308 			if ((0xD8 == cdata[0]) && (0xFF == cdata[1])) {
309 				data_offset = 1;
310 			} else if((0xFF == cdata[0]) && (0xD8 == cdata[1])
311 				  && (0xFF == cdata[2])) {
312 				data_offset = 2;
313 			} else {
314 				DBG("Ignoring packet, not beginning!\n");
315 				continue;
316 			}
317 			DBG("Start of frame pattern found\n");
318 			cam->workbuff->ts = ktime_get_ns();
319 			cam->workbuff->seq = cam->frame_count++;
320 			cam->workbuff->data[0] = 0xFF;
321 			cam->workbuff->data[1] = 0xD8;
322 			cam->workbuff->length = 2;
323 			add_APPn(cam);
324 			add_COM(cam);
325 			memcpy(cam->workbuff->data+cam->workbuff->length,
326 			       cdata+data_offset, n-data_offset);
327 			cam->workbuff->length += n-data_offset;
328 		} else if (cam->workbuff->length > 0) {
329 			memcpy(cam->workbuff->data + cam->workbuff->length,
330 			       cdata, n);
331 			cam->workbuff->length += n;
332 		}
333 
334 		if ((cam->workbuff->length >= 3) &&
335 		    (cam->workbuff->data[cam->workbuff->length - 3] == 0xFF) &&
336 		    (cam->workbuff->data[cam->workbuff->length - 2] == 0xD9) &&
337 		    (cam->workbuff->data[cam->workbuff->length - 1] == 0xFF)) {
338 			frame_ready = true;
339 			cam->workbuff->data[cam->workbuff->length - 1] = 0;
340 			cam->workbuff->length -= 1;
341 		} else if ((cam->workbuff->length >= 2) &&
342 		   (cam->workbuff->data[cam->workbuff->length - 2] == 0xFF) &&
343 		   (cam->workbuff->data[cam->workbuff->length - 1] == 0xD9)) {
344 			frame_ready = true;
345 		}
346 
347 		if (frame_ready) {
348 			DBG("Workbuff image size = %d\n",cam->workbuff->length);
349 			process_frame(cam);
350 
351 			frame_ready = false;
352 
353 			if (waitqueue_active(&cam->wq_stream))
354 				wake_up_interruptible(&cam->wq_stream);
355 		}
356 	}
357 
358 	if(cam->streaming) {
359 		/* resubmit */
360 		urb->dev = cam->dev;
361 		if ((i = usb_submit_urb(urb, GFP_ATOMIC)) != 0)
362 			ERR("%s: usb_submit_urb ret %d!\n", __func__, i);
363 	}
364 }
365 
366 /******************************************************************************
367  *
368  * configure_transfer_mode
369  *
370  *****************************************************************************/
configure_transfer_mode(struct camera_data * cam,unsigned int alt)371 static int configure_transfer_mode(struct camera_data *cam, unsigned int alt)
372 {
373 	static unsigned char iso_regs[8][4] = {
374 		{0x00, 0x00, 0x00, 0x00},
375 		{0x00, 0x00, 0x00, 0x00},
376 		{0xB9, 0x00, 0x00, 0x7E},
377 		{0xB9, 0x00, 0x01, 0x7E},
378 		{0xB9, 0x00, 0x02, 0x7E},
379 		{0xB9, 0x00, 0x02, 0xFE},
380 		{0xB9, 0x00, 0x03, 0x7E},
381 		{0xB9, 0x00, 0x03, 0xFD}
382 	};
383 	struct cpia2_command cmd;
384 	unsigned char reg;
385 
386 	if (!video_is_registered(&cam->vdev))
387 		return -ENODEV;
388 
389 	/***
390 	 * Write the isoc registers according to the alternate selected
391 	 ***/
392 	cmd.direction = TRANSFER_WRITE;
393 	cmd.buffer.block_data[0] = iso_regs[alt][0];
394 	cmd.buffer.block_data[1] = iso_regs[alt][1];
395 	cmd.buffer.block_data[2] = iso_regs[alt][2];
396 	cmd.buffer.block_data[3] = iso_regs[alt][3];
397 	cmd.req_mode = CAMERAACCESS_TYPE_BLOCK | CAMERAACCESS_VC;
398 	cmd.start = CPIA2_VC_USB_ISOLIM;
399 	cmd.reg_count = 4;
400 	cpia2_send_command(cam, &cmd);
401 
402 	/***
403 	 * Enable relevant streams before starting polling.
404 	 * First read USB Stream Config Register.
405 	 ***/
406 	cmd.direction = TRANSFER_READ;
407 	cmd.req_mode = CAMERAACCESS_TYPE_BLOCK | CAMERAACCESS_VC;
408 	cmd.start = CPIA2_VC_USB_STRM;
409 	cmd.reg_count = 1;
410 	cpia2_send_command(cam, &cmd);
411 	reg = cmd.buffer.block_data[0];
412 
413 	/* Clear iso, bulk, and int */
414 	reg &= ~(CPIA2_VC_USB_STRM_BLK_ENABLE |
415 		 CPIA2_VC_USB_STRM_ISO_ENABLE |
416 		 CPIA2_VC_USB_STRM_INT_ENABLE);
417 
418 	if (alt == USBIF_BULK) {
419 		DBG("Enabling bulk xfer\n");
420 		reg |= CPIA2_VC_USB_STRM_BLK_ENABLE;	/* Enable Bulk */
421 		cam->xfer_mode = XFER_BULK;
422 	} else if (alt >= USBIF_ISO_1) {
423 		DBG("Enabling ISOC xfer\n");
424 		reg |= CPIA2_VC_USB_STRM_ISO_ENABLE;
425 		cam->xfer_mode = XFER_ISOC;
426 	}
427 
428 	cmd.buffer.block_data[0] = reg;
429 	cmd.direction = TRANSFER_WRITE;
430 	cmd.start = CPIA2_VC_USB_STRM;
431 	cmd.reg_count = 1;
432 	cmd.req_mode = CAMERAACCESS_TYPE_BLOCK | CAMERAACCESS_VC;
433 	cpia2_send_command(cam, &cmd);
434 
435 	return 0;
436 }
437 
438 /******************************************************************************
439  *
440  * cpia2_usb_change_streaming_alternate
441  *
442  *****************************************************************************/
cpia2_usb_change_streaming_alternate(struct camera_data * cam,unsigned int alt)443 int cpia2_usb_change_streaming_alternate(struct camera_data *cam,
444 					 unsigned int alt)
445 {
446 	int ret = 0;
447 
448 	if(alt < USBIF_ISO_1 || alt > USBIF_ISO_6)
449 		return -EINVAL;
450 
451 	if(alt == cam->params.camera_state.stream_mode)
452 		return 0;
453 
454 	cpia2_usb_stream_pause(cam);
455 
456 	configure_transfer_mode(cam, alt);
457 
458 	cam->params.camera_state.stream_mode = alt;
459 
460 	/* Reset the camera to prevent image quality degradation */
461 	cpia2_reset_camera(cam);
462 
463 	cpia2_usb_stream_resume(cam);
464 
465 	return ret;
466 }
467 
468 /******************************************************************************
469  *
470  * set_alternate
471  *
472  *****************************************************************************/
set_alternate(struct camera_data * cam,unsigned int alt)473 static int set_alternate(struct camera_data *cam, unsigned int alt)
474 {
475 	int ret = 0;
476 
477 	if(alt == cam->cur_alt)
478 		return 0;
479 
480 	if (cam->cur_alt != USBIF_CMDONLY) {
481 		DBG("Changing from alt %d to %d\n", cam->cur_alt, USBIF_CMDONLY);
482 		ret = usb_set_interface(cam->dev, cam->iface, USBIF_CMDONLY);
483 		if (ret != 0)
484 			return ret;
485 	}
486 	if (alt != USBIF_CMDONLY) {
487 		DBG("Changing from alt %d to %d\n", USBIF_CMDONLY, alt);
488 		ret = usb_set_interface(cam->dev, cam->iface, alt);
489 		if (ret != 0)
490 			return ret;
491 	}
492 
493 	cam->old_alt = cam->cur_alt;
494 	cam->cur_alt = alt;
495 
496 	return ret;
497 }
498 
499 /******************************************************************************
500  *
501  * free_sbufs
502  *
503  * Free all cam->sbuf[]. All non-NULL .data and .urb members that are non-NULL
504  * are assumed to be allocated. Non-NULL .urb members are also assumed to be
505  * submitted (and must therefore be killed before they are freed).
506  *****************************************************************************/
free_sbufs(struct camera_data * cam)507 static void free_sbufs(struct camera_data *cam)
508 {
509 	int i;
510 
511 	for (i = 0; i < NUM_SBUF; i++) {
512 		if(cam->sbuf[i].urb) {
513 			usb_kill_urb(cam->sbuf[i].urb);
514 			usb_free_urb(cam->sbuf[i].urb);
515 			cam->sbuf[i].urb = NULL;
516 		}
517 		if(cam->sbuf[i].data) {
518 			kfree(cam->sbuf[i].data);
519 			cam->sbuf[i].data = NULL;
520 		}
521 	}
522 }
523 
524 /*******
525 * Convenience functions
526 *******/
527 /****************************************************************************
528  *
529  *  write_packet
530  *
531  ***************************************************************************/
write_packet(struct usb_device * udev,u8 request,u8 * registers,u16 start,size_t size)532 static int write_packet(struct usb_device *udev,
533 			u8 request, u8 * registers, u16 start, size_t size)
534 {
535 	unsigned char *buf;
536 	int ret;
537 
538 	if (!registers || size <= 0)
539 		return -EINVAL;
540 
541 	buf = kmemdup(registers, size, GFP_KERNEL);
542 	if (!buf)
543 		return -ENOMEM;
544 
545 	ret = usb_control_msg(udev,
546 			       usb_sndctrlpipe(udev, 0),
547 			       request,
548 			       USB_TYPE_VENDOR | USB_RECIP_DEVICE,
549 			       start,	/* value */
550 			       0,	/* index */
551 			       buf,	/* buffer */
552 			       size,
553 			       1000);
554 
555 	kfree(buf);
556 	return ret;
557 }
558 
559 /****************************************************************************
560  *
561  *  read_packet
562  *
563  ***************************************************************************/
read_packet(struct usb_device * udev,u8 request,u8 * registers,u16 start,size_t size)564 static int read_packet(struct usb_device *udev,
565 		       u8 request, u8 * registers, u16 start, size_t size)
566 {
567 	unsigned char *buf;
568 	int ret;
569 
570 	if (!registers || size <= 0)
571 		return -EINVAL;
572 
573 	buf = kmalloc(size, GFP_KERNEL);
574 	if (!buf)
575 		return -ENOMEM;
576 
577 	ret = usb_control_msg(udev,
578 			       usb_rcvctrlpipe(udev, 0),
579 			       request,
580 			       USB_DIR_IN|USB_TYPE_VENDOR|USB_RECIP_DEVICE,
581 			       start,	/* value */
582 			       0,	/* index */
583 			       buf,	/* buffer */
584 			       size,
585 			       1000);
586 
587 	if (ret >= 0)
588 		memcpy(registers, buf, size);
589 
590 	kfree(buf);
591 
592 	return ret;
593 }
594 
595 /******************************************************************************
596  *
597  *  cpia2_usb_transfer_cmd
598  *
599  *****************************************************************************/
cpia2_usb_transfer_cmd(struct camera_data * cam,void * registers,u8 request,u8 start,u8 count,u8 direction)600 int cpia2_usb_transfer_cmd(struct camera_data *cam,
601 			   void *registers,
602 			   u8 request, u8 start, u8 count, u8 direction)
603 {
604 	int err = 0;
605 	struct usb_device *udev = cam->dev;
606 
607 	if (!udev) {
608 		ERR("%s: Internal driver error: udev is NULL\n", __func__);
609 		return -EINVAL;
610 	}
611 
612 	if (!registers) {
613 		ERR("%s: Internal driver error: register array is NULL\n", __func__);
614 		return -EINVAL;
615 	}
616 
617 	if (direction == TRANSFER_READ) {
618 		err = read_packet(udev, request, (u8 *)registers, start, count);
619 		if (err > 0)
620 			err = 0;
621 	} else if (direction == TRANSFER_WRITE) {
622 		err =write_packet(udev, request, (u8 *)registers, start, count);
623 		if (err < 0) {
624 			LOG("Control message failed, err val = %d\n", err);
625 			LOG("Message: request = 0x%0X, start = 0x%0X\n",
626 			    request, start);
627 			LOG("Message: count = %d, register[0] = 0x%0X\n",
628 			    count, ((unsigned char *) registers)[0]);
629 		} else
630 			err=0;
631 	} else {
632 		LOG("Unexpected first byte of direction: %d\n",
633 		       direction);
634 		return -EINVAL;
635 	}
636 
637 	if(err != 0)
638 		LOG("Unexpected error: %d\n", err);
639 	return err;
640 }
641 
642 
643 /******************************************************************************
644  *
645  *  submit_urbs
646  *
647  *****************************************************************************/
submit_urbs(struct camera_data * cam)648 static int submit_urbs(struct camera_data *cam)
649 {
650 	struct urb *urb;
651 	int fx, err, i, j;
652 
653 	for(i=0; i<NUM_SBUF; ++i) {
654 		if (cam->sbuf[i].data)
655 			continue;
656 		cam->sbuf[i].data =
657 		    kmalloc_array(FRAME_SIZE_PER_DESC, FRAMES_PER_DESC,
658 				  GFP_KERNEL);
659 		if (!cam->sbuf[i].data) {
660 			while (--i >= 0) {
661 				kfree(cam->sbuf[i].data);
662 				cam->sbuf[i].data = NULL;
663 			}
664 			return -ENOMEM;
665 		}
666 	}
667 
668 	/* We double buffer the Isoc lists, and also know the polling
669 	 * interval is every frame (1 == (1 << (bInterval -1))).
670 	 */
671 	for(i=0; i<NUM_SBUF; ++i) {
672 		if(cam->sbuf[i].urb) {
673 			continue;
674 		}
675 		urb = usb_alloc_urb(FRAMES_PER_DESC, GFP_KERNEL);
676 		if (!urb) {
677 			for (j = 0; j < i; j++)
678 				usb_free_urb(cam->sbuf[j].urb);
679 			for (j = 0; j < NUM_SBUF; j++) {
680 				kfree(cam->sbuf[j].data);
681 				cam->sbuf[j].data = NULL;
682 			}
683 			return -ENOMEM;
684 		}
685 
686 		cam->sbuf[i].urb = urb;
687 		urb->dev = cam->dev;
688 		urb->context = cam;
689 		urb->pipe = usb_rcvisocpipe(cam->dev, 1 /*ISOC endpoint*/);
690 		urb->transfer_flags = URB_ISO_ASAP;
691 		urb->transfer_buffer = cam->sbuf[i].data;
692 		urb->complete = cpia2_usb_complete;
693 		urb->number_of_packets = FRAMES_PER_DESC;
694 		urb->interval = 1;
695 		urb->transfer_buffer_length =
696 			FRAME_SIZE_PER_DESC * FRAMES_PER_DESC;
697 
698 		for (fx = 0; fx < FRAMES_PER_DESC; fx++) {
699 			urb->iso_frame_desc[fx].offset =
700 				FRAME_SIZE_PER_DESC * fx;
701 			urb->iso_frame_desc[fx].length = FRAME_SIZE_PER_DESC;
702 		}
703 	}
704 
705 
706 	/* Queue the ISO urbs, and resubmit in the completion handler */
707 	for(i=0; i<NUM_SBUF; ++i) {
708 		err = usb_submit_urb(cam->sbuf[i].urb, GFP_KERNEL);
709 		if (err) {
710 			ERR("usb_submit_urb[%d]() = %d\n", i, err);
711 			return err;
712 		}
713 	}
714 
715 	return 0;
716 }
717 
718 /******************************************************************************
719  *
720  *  cpia2_usb_stream_start
721  *
722  *****************************************************************************/
cpia2_usb_stream_start(struct camera_data * cam,unsigned int alternate)723 int cpia2_usb_stream_start(struct camera_data *cam, unsigned int alternate)
724 {
725 	int ret;
726 	int old_alt;
727 
728 	if(cam->streaming)
729 		return 0;
730 
731 	if (cam->flush) {
732 		int i;
733 		DBG("Flushing buffers\n");
734 		for(i=0; i<cam->num_frames; ++i) {
735 			cam->buffers[i].status = FRAME_EMPTY;
736 			cam->buffers[i].length = 0;
737 		}
738 		cam->curbuff = &cam->buffers[0];
739 		cam->workbuff = cam->curbuff->next;
740 		cam->flush = false;
741 	}
742 
743 	old_alt = cam->params.camera_state.stream_mode;
744 	cam->params.camera_state.stream_mode = 0;
745 	ret = cpia2_usb_change_streaming_alternate(cam, alternate);
746 	if (ret < 0) {
747 		int ret2;
748 		ERR("cpia2_usb_change_streaming_alternate() = %d!\n", ret);
749 		cam->params.camera_state.stream_mode = old_alt;
750 		ret2 = set_alternate(cam, USBIF_CMDONLY);
751 		if (ret2 < 0) {
752 			ERR("cpia2_usb_change_streaming_alternate(%d) =%d has already failed. Then tried to call set_alternate(USBIF_CMDONLY) = %d.\n",
753 			    alternate, ret, ret2);
754 		}
755 	} else {
756 		cam->frame_count = 0;
757 		cam->streaming = 1;
758 		ret = cpia2_usb_stream_resume(cam);
759 	}
760 	return ret;
761 }
762 
763 /******************************************************************************
764  *
765  *  cpia2_usb_stream_pause
766  *
767  *****************************************************************************/
cpia2_usb_stream_pause(struct camera_data * cam)768 int cpia2_usb_stream_pause(struct camera_data *cam)
769 {
770 	int ret = 0;
771 	if(cam->streaming) {
772 		free_sbufs(cam);
773 		ret = set_alternate(cam, USBIF_CMDONLY);
774 	}
775 	return ret;
776 }
777 
778 /******************************************************************************
779  *
780  *  cpia2_usb_stream_resume
781  *
782  *****************************************************************************/
cpia2_usb_stream_resume(struct camera_data * cam)783 int cpia2_usb_stream_resume(struct camera_data *cam)
784 {
785 	int ret = 0;
786 	if(cam->streaming) {
787 		cam->first_image_seen = 0;
788 		ret = set_alternate(cam, cam->params.camera_state.stream_mode);
789 		if(ret == 0) {
790 			/* for some reason the user effects need to be set
791 			   again when starting streaming. */
792 			cpia2_do_command(cam, CPIA2_CMD_SET_USER_EFFECTS, TRANSFER_WRITE,
793 					cam->params.vp_params.user_effects);
794 			ret = submit_urbs(cam);
795 		}
796 	}
797 	return ret;
798 }
799 
800 /******************************************************************************
801  *
802  *  cpia2_usb_stream_stop
803  *
804  *****************************************************************************/
cpia2_usb_stream_stop(struct camera_data * cam)805 int cpia2_usb_stream_stop(struct camera_data *cam)
806 {
807 	int ret;
808 
809 	ret = cpia2_usb_stream_pause(cam);
810 	cam->streaming = 0;
811 	configure_transfer_mode(cam, 0);
812 	return ret;
813 }
814 
815 /******************************************************************************
816  *
817  *  cpia2_usb_probe
818  *
819  *  Probe and initialize.
820  *****************************************************************************/
cpia2_usb_probe(struct usb_interface * intf,const struct usb_device_id * id)821 static int cpia2_usb_probe(struct usb_interface *intf,
822 			   const struct usb_device_id *id)
823 {
824 	struct usb_device *udev = interface_to_usbdev(intf);
825 	struct usb_interface_descriptor *interface;
826 	struct camera_data *cam;
827 	int ret;
828 
829 	/* A multi-config CPiA2 camera? */
830 	if (udev->descriptor.bNumConfigurations != 1)
831 		return -ENODEV;
832 	interface = &intf->cur_altsetting->desc;
833 
834 	/* If we get to this point, we found a CPiA2 camera */
835 	LOG("CPiA2 USB camera found\n");
836 
837 	cam = cpia2_init_camera_struct(intf);
838 	if (cam == NULL)
839 		return -ENOMEM;
840 
841 	cam->dev = udev;
842 	cam->iface = interface->bInterfaceNumber;
843 
844 	ret = set_alternate(cam, USBIF_CMDONLY);
845 	if (ret < 0) {
846 		ERR("%s: usb_set_interface error (ret = %d)\n", __func__, ret);
847 		goto alt_err;
848 	}
849 
850 
851 	if((ret = cpia2_init_camera(cam)) < 0) {
852 		ERR("%s: failed to initialize cpia2 camera (ret = %d)\n", __func__, ret);
853 		goto alt_err;
854 	}
855 	LOG("  CPiA Version: %d.%02d (%d.%d)\n",
856 	       cam->params.version.firmware_revision_hi,
857 	       cam->params.version.firmware_revision_lo,
858 	       cam->params.version.asic_id,
859 	       cam->params.version.asic_rev);
860 	LOG("  CPiA PnP-ID: %04x:%04x:%04x\n",
861 	       cam->params.pnp_id.vendor,
862 	       cam->params.pnp_id.product,
863 	       cam->params.pnp_id.device_revision);
864 	LOG("  SensorID: %d.(version %d)\n",
865 	       cam->params.version.sensor_flags,
866 	       cam->params.version.sensor_rev);
867 
868 	usb_set_intfdata(intf, cam);
869 
870 	ret = cpia2_register_camera(cam);
871 	if (ret < 0) {
872 		ERR("%s: Failed to register cpia2 camera (ret = %d)\n", __func__, ret);
873 		goto alt_err;
874 	}
875 
876 	return 0;
877 
878 alt_err:
879 	cpia2_deinit_camera_struct(cam, intf);
880 	return ret;
881 }
882 
883 /******************************************************************************
884  *
885  *  cpia2_disconnect
886  *
887  *****************************************************************************/
cpia2_usb_disconnect(struct usb_interface * intf)888 static void cpia2_usb_disconnect(struct usb_interface *intf)
889 {
890 	struct camera_data *cam = usb_get_intfdata(intf);
891 	usb_set_intfdata(intf, NULL);
892 
893 	DBG("Stopping stream\n");
894 	cpia2_usb_stream_stop(cam);
895 
896 	mutex_lock(&cam->v4l2_lock);
897 	DBG("Unregistering camera\n");
898 	cpia2_unregister_camera(cam);
899 	v4l2_device_disconnect(&cam->v4l2_dev);
900 	mutex_unlock(&cam->v4l2_lock);
901 
902 	if(cam->buffers) {
903 		DBG("Wakeup waiting processes\n");
904 		cam->curbuff->status = FRAME_READY;
905 		cam->curbuff->length = 0;
906 		wake_up_interruptible(&cam->wq_stream);
907 	}
908 
909 	v4l2_device_put(&cam->v4l2_dev);
910 
911 	LOG("CPiA2 camera disconnected.\n");
912 }
913 
cpia2_usb_suspend(struct usb_interface * intf,pm_message_t message)914 static int cpia2_usb_suspend(struct usb_interface *intf, pm_message_t message)
915 {
916 	struct camera_data *cam = usb_get_intfdata(intf);
917 
918 	mutex_lock(&cam->v4l2_lock);
919 	if (cam->streaming) {
920 		cpia2_usb_stream_stop(cam);
921 		cam->streaming = 1;
922 	}
923 	mutex_unlock(&cam->v4l2_lock);
924 
925 	dev_info(&intf->dev, "going into suspend..\n");
926 	return 0;
927 }
928 
929 /* Resume device - start device. */
cpia2_usb_resume(struct usb_interface * intf)930 static int cpia2_usb_resume(struct usb_interface *intf)
931 {
932 	struct camera_data *cam = usb_get_intfdata(intf);
933 
934 	mutex_lock(&cam->v4l2_lock);
935 	v4l2_ctrl_handler_setup(&cam->hdl);
936 	if (cam->streaming) {
937 		cam->streaming = 0;
938 		cpia2_usb_stream_start(cam,
939 				cam->params.camera_state.stream_mode);
940 	}
941 	mutex_unlock(&cam->v4l2_lock);
942 
943 	dev_info(&intf->dev, "coming out of suspend..\n");
944 	return 0;
945 }
946 
947 /******************************************************************************
948  *
949  *  usb_cpia2_init
950  *
951  *****************************************************************************/
cpia2_usb_init(void)952 int cpia2_usb_init(void)
953 {
954 	return usb_register(&cpia2_driver);
955 }
956 
957 /******************************************************************************
958  *
959  *  usb_cpia_cleanup
960  *
961  *****************************************************************************/
cpia2_usb_cleanup(void)962 void cpia2_usb_cleanup(void)
963 {
964 	schedule_timeout(2 * HZ);
965 	usb_deregister(&cpia2_driver);
966 }
967