4 * Copyright (C) 2005, 2006 Princeton Instruments
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation version 2 of the License
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #include <linux/vmalloc.h>
21 #include <linux/kernel.h>
22 #include <linux/errno.h>
23 #include <linux/init.h>
24 #include <linux/slab.h>
25 #include <linux/module.h>
26 #include <linux/smp_lock.h>
27 #include <linux/completion.h>
28 #include <linux/scatterlist.h>
29 #include <linux/usb.h>
31 #include <linux/pagemap.h>
32 #include <linux/ioctl.h>
35 #ifdef CONFIG_USB_DEBUG
40 /* Use our own dbg macro */
42 #define dbg(format, arg...) \
45 printk(KERN_DEBUG __FILE__ ": " format "\n" , ##arg); \
48 /* Version Information */
49 #define DRIVER_VERSION "V1.0.1"
50 #define DRIVER_AUTHOR "Princeton Instruments"
51 #define DRIVER_DESC "PI USB2.0 Device Driver for Linux"
53 /* Define these values to match your devices */
54 #define VENDOR_ID 0x0BD7
55 #define ST133_PID 0xA010
56 #define PIXIS_PID 0xA026
58 /* Get a minor range for your devices from the usb maintainer */
59 #ifdef CONFIG_USB_DYNAMIC_MINORS
60 #define PIUSB_MINOR_BASE 0
62 #define PIUSB_MINOR_BASE 192
65 /* prevent races between open() and disconnect() */
66 static DECLARE_MUTEX(disconnect_sem
);
68 /* Structure to hold all of our device specific stuff */
69 struct device_extension
{
70 struct usb_device
*udev
; /* save off the usb device pointer */
71 struct usb_interface
*interface
; /* the interface for this device */
72 unsigned char minor
; /* the starting minor number
75 size_t bulk_in_size_returned
;
77 struct urb
***PixelUrb
;
80 unsigned int *maplist_numPagesMapped
;
81 int open
; /* if the port is open or not */
82 int present
; /* if the device is not disconnected */
83 int userBufMapped
; /* has the user buffer been mapped ? */
84 struct scatterlist
**sgl
; /* scatter-gather list for user buffer */
85 unsigned int *sgEntries
;
89 char **pendedPixelUrbs
;
90 int iama
; /* PIXIS or ST133 */
91 int num_frames
; /* the number of frames that will fit
95 unsigned long frameSize
;
97 unsigned int hEP
[8]; /* FX2 specific endpoints */
100 #define to_pi_dev(d) container_of(d, struct device_extension, kref)
103 static int MapUserBuffer(struct ioctl_struct
*, struct device_extension
*);
104 static int UnMapUserBuffer(struct device_extension
*);
105 static int piusb_ioctl(struct inode
*inode
, struct file
*file
, unsigned int cmd
,
107 static int piusb_output(struct ioctl_struct
*, unsigned char *, int,
108 struct device_extension
*);
109 static struct usb_driver piusb_driver
;
111 /* table of devices that work with this driver */
112 static struct usb_device_id pi_device_table
[] = {
113 {USB_DEVICE(VENDOR_ID
, ST133_PID
)},
114 {USB_DEVICE(VENDOR_ID
, PIXIS_PID
)},
115 {0, } /* Terminating entry */
118 MODULE_DEVICE_TABLE(usb
, pi_device_table
);
123 static void piusb_delete(struct kref
*kref
)
125 struct device_extension
*pdx
= to_pi_dev(kref
);
127 dev_dbg(&pdx
->udev
->dev
, "%s\n", __func__
);
128 usb_put_dev(pdx
->udev
);
132 static int piusb_open(struct inode
*inode
, struct file
*file
)
134 struct device_extension
*pdx
= NULL
;
135 struct usb_interface
*interface
;
140 subminor
= iminor(inode
);
141 interface
= usb_find_interface(&piusb_driver
, subminor
);
143 printk(KERN_ERR
"%s - error, can't find device for minor %d\n",
149 pdx
= usb_get_intfdata(interface
);
154 dbg("Alternate Setting = %d", interface
->num_altsetting
);
156 pdx
->bulk_in_size_returned
= 0;
157 pdx
->bulk_in_byte_trk
= 0;
158 pdx
->PixelUrb
= NULL
;
161 pdx
->maplist_numPagesMapped
= NULL
;
162 pdx
->userBufMapped
= 0;
164 pdx
->sgEntries
= NULL
;
165 pdx
->gotPixelData
= 0;
166 pdx
->pendingWrite
= 0;
167 pdx
->pendedPixelUrbs
= NULL
;
169 pdx
->active_frame
= 0;
172 /* increment our usage count for the device */
173 kref_get(&pdx
->kref
);
175 /* save our object in the file's private structure */
176 file
->private_data
= pdx
;
182 static int piusb_release(struct inode
*inode
, struct file
*file
)
184 struct device_extension
*pdx
;
187 dbg("Piusb_Release()");
188 pdx
= (struct device_extension
*)file
->private_data
;
190 dbg("%s - object is NULL", __func__
);
194 /* decrement the count on our device */
195 kref_put(&pdx
->kref
, piusb_delete
);
201 static int pixis_io(struct ioctl_struct
*ctrl
, struct device_extension
*pdx
,
202 struct ioctl_struct
*arg
)
204 unsigned int numToRead
= 0;
205 unsigned int totalRead
= 0;
210 uBuf
= kmalloc(ctrl
->numbytes
, GFP_KERNEL
);
212 dbg("Alloc for uBuf failed");
215 numbytes
= (int) ctrl
->numbytes
;
216 numToRead
= (unsigned int) ctrl
->numbytes
;
217 dbg("numbytes to read = %d", numbytes
);
218 dbg("endpoint # %d", ctrl
->endpoint
);
220 if (copy_from_user(uBuf
, ctrl
->pData
, numbytes
)) {
221 dbg("copying ctrl->pData to dummyBuf failed");
226 i
= usb_bulk_msg(pdx
->udev
, pdx
->hEP
[ctrl
->endpoint
],
228 /* EP0 can only handle 64 bytes at a time */
229 (numToRead
> 64) ? 64 : numToRead
,
232 dbg("CMD = %s, Address = 0x%02X",
233 ((uBuf
[3] == 0x02) ? "WRITE" : "READ"),
235 dbg("Number of bytes Attempted to read = %d",
236 (int)ctrl
->numbytes
);
237 dbg("Blocking ReadI/O Failed with status %d", i
);
241 dbg("Pixis EP0 Read %d bytes", numbytes
);
242 totalRead
+= numbytes
;
243 numToRead
-= numbytes
;
246 memcpy(ctrl
->pData
, uBuf
, totalRead
);
247 dbg("Total Bytes Read from PIXIS EP0 = %d", totalRead
);
248 ctrl
->numbytes
= totalRead
;
250 if (copy_to_user(arg
, ctrl
, sizeof(struct ioctl_struct
)))
251 dbg("copy_to_user failed in IORB");
254 return ctrl
->numbytes
;
257 static int pixel_data(struct ioctl_struct
*ctrl
, struct device_extension
*pdx
)
261 if (!pdx
->gotPixelData
)
264 pdx
->gotPixelData
= 0;
265 ctrl
->numbytes
= pdx
->bulk_in_size_returned
;
266 pdx
->bulk_in_size_returned
-= pdx
->frameSize
;
268 for (i
= 0; i
< pdx
->maplist_numPagesMapped
[pdx
->active_frame
]; i
++)
269 SetPageDirty(sg_page(&pdx
->sgl
[pdx
->active_frame
][i
]));
271 pdx
->active_frame
= ((pdx
->active_frame
+ 1) % pdx
->num_frames
);
273 return ctrl
->numbytes
;
279 static int piusb_ioctl(struct inode
*inode
, struct file
*file
, unsigned int cmd
,
282 struct device_extension
*pdx
;
283 char dummyCtlBuf
[] = { 0, 0, 0, 0, 0, 0, 0, 0 };
284 unsigned long devRB
= 0;
287 struct ioctl_struct ctrl
;
288 unsigned short controlData
= 0;
290 pdx
= (struct device_extension
*)file
->private_data
;
291 /* verify that the device wasn't unplugged */
293 dbg("No Device Present\n");
296 /* fill in your device specific stuff here */
297 if (_IOC_DIR(cmd
) & _IOC_READ
)
298 err
= !access_ok(VERIFY_WRITE
, (void __user
*)arg
,
300 else if (_IOC_DIR(cmd
) & _IOC_WRITE
)
301 err
= !access_ok(VERIFY_READ
, (void __user
*)arg
,
304 dev_err(&pdx
->udev
->dev
, "return with error = %d\n", err
);
308 case PIUSB_GETVNDCMD
:
310 (&ctrl
, (void __user
*)arg
, sizeof(struct ioctl_struct
))) {
311 dev_err(&pdx
->udev
->dev
, "copy_from_user failed\n");
314 dbg("%s %x\n", "Get Vendor Command = ", ctrl
.cmd
);
316 usb_control_msg(pdx
->udev
, usb_rcvctrlpipe(pdx
->udev
, 0),
317 ctrl
.cmd
, USB_DIR_IN
, 0, 0, &devRB
,
318 ctrl
.numbytes
, HZ
* 10);
319 if (ctrl
.cmd
== 0xF1) {
320 dbg("FW Version returned from HW = %ld.%ld",
321 (devRB
>> 8), (devRB
& 0xFF));
327 case PIUSB_SETVNDCMD
:
329 (&ctrl
, (void __user
*)arg
, sizeof(struct ioctl_struct
))) {
330 dev_err(&pdx
->udev
->dev
, "copy_from_user failed\n");
333 /* dbg( "%s %x", "Set Vendor Command = ",ctrl.cmd ); */
334 controlData
= ctrl
.pData
[0];
335 controlData
|= (ctrl
.pData
[1] << 8);
336 /* dbg( "%s %d", "Vendor Data =",controlData ); */
337 retval
= usb_control_msg(pdx
->udev
,
338 usb_sndctrlpipe(pdx
->udev
, 0),
340 (USB_DIR_OUT
| USB_TYPE_VENDOR
341 /* | USB_RECIP_ENDPOINT */),
343 &dummyCtlBuf
, ctrl
.numbytes
, HZ
* 10);
346 case PIUSB_ISHIGHSPEED
:
347 return ((pdx
->udev
->speed
== USB_SPEED_HIGH
) ? 1 : 0);
349 case PIUSB_WRITEPIPE
:
350 if (__copy_from_user(&ctrl
, (void __user
*)arg
, _IOC_SIZE(cmd
))) {
351 dev_err(&pdx
->udev
->dev
,
352 "copy_from_user WRITE_DUMMY failed\n");
355 if (!access_ok(VERIFY_READ
, ctrl
.pData
, ctrl
.numbytes
)) {
356 dbg("can't access pData");
359 piusb_output(&ctrl
, ctrl
.pData
/* uBuf */, ctrl
.numbytes
, pdx
);
360 return ctrl
.numbytes
;
362 case PIUSB_USERBUFFER
:
364 (&ctrl
, (void __user
*)arg
, sizeof(struct ioctl_struct
))) {
365 dev_err(&pdx
->udev
->dev
, "copy_from_user failed\n");
368 return MapUserBuffer((struct ioctl_struct
*) &ctrl
, pdx
);
370 case PIUSB_UNMAP_USERBUFFER
:
371 retval
= UnMapUserBuffer(pdx
);
375 if (__copy_from_user(&ctrl
, (void __user
*)arg
,
376 sizeof(struct ioctl_struct
))) {
377 dev_err(&pdx
->udev
->dev
, "copy_from_user failed\n");
380 if (((0 == ctrl
.endpoint
) && (PIXIS_PID
== pdx
->iama
)) ||
381 (1 == ctrl
.endpoint
) || /* ST133IO */
382 (4 == ctrl
.endpoint
)) /* PIXIS IO */
383 return pixis_io(&ctrl
, pdx
,
384 (struct ioctl_struct
*)arg
);
385 else if ((0 == ctrl
.endpoint
) || /* ST133 Pixel Data */
386 (2 == ctrl
.endpoint
) || /* PIXIS Ping */
387 (3 == ctrl
.endpoint
)) /* PIXIS Pong */
388 return pixel_data(&ctrl
, pdx
);
392 case PIUSB_WHATCAMERA
:
395 case PIUSB_SETFRAMESIZE
:
396 dbg("PIUSB_SETFRAMESIZE");
398 (&ctrl
, (void __user
*)arg
, sizeof(struct ioctl_struct
))) {
399 dev_err(&pdx
->udev
->dev
, "copy_from_user failed\n");
402 pdx
->frameSize
= ctrl
.numbytes
;
403 pdx
->num_frames
= ctrl
.numFrames
;
406 kmalloc(sizeof(struct scatterlist
*) *
407 pdx
->num_frames
, GFP_KERNEL
);
410 kmalloc(sizeof(unsigned int) * pdx
->num_frames
,
414 kmalloc(sizeof(struct urb
**) * pdx
->num_frames
,
416 if (!pdx
->maplist_numPagesMapped
)
417 pdx
->maplist_numPagesMapped
=
418 vmalloc(sizeof(unsigned int) * pdx
->num_frames
);
419 if (!pdx
->pendedPixelUrbs
)
420 pdx
->pendedPixelUrbs
=
421 kmalloc(sizeof(char *) * pdx
->num_frames
,
426 dbg("%s\n", "No IOCTL found");
430 /* return that we did not understand this ioctl call */
431 dbg("Returning -ENOTTY");
435 static void piusb_write_bulk_callback(struct urb
*urb
)
437 struct device_extension
*pdx
= urb
->context
;
438 int status
= urb
->status
;
440 /* sync/async unlink faults aren't errors */
441 if (status
&& !(status
== -ENOENT
|| status
== -ECONNRESET
))
442 dev_dbg(&urb
->dev
->dev
,
443 "%s - nonzero write bulk status received: %d",
446 pdx
->pendingWrite
= 0;
447 usb_buffer_free(urb
->dev
, urb
->transfer_buffer_length
,
448 urb
->transfer_buffer
, urb
->transfer_dma
);
451 int piusb_output(struct ioctl_struct
*io
, unsigned char *uBuf
, int len
,
452 struct device_extension
*pdx
)
454 struct urb
*urb
= NULL
;
456 unsigned char *kbuf
= NULL
;
458 urb
= usb_alloc_urb(0, GFP_KERNEL
);
461 usb_buffer_alloc(pdx
->udev
, len
, GFP_KERNEL
,
464 dev_err(&pdx
->udev
->dev
, "buffer_alloc failed\n");
467 if(__copy_from_user(kbuf
, uBuf
, len
)) {
468 dev_err(&pdx
->udev
->dev
, "__copy_from_user failed\n");
471 usb_fill_bulk_urb(urb
, pdx
->udev
, pdx
->hEP
[io
->endpoint
], kbuf
,
472 len
, piusb_write_bulk_callback
, pdx
);
473 urb
->transfer_flags
|= URB_NO_TRANSFER_DMA_MAP
;
474 err
= usb_submit_urb(urb
, GFP_KERNEL
);
476 dev_err(&pdx
->udev
->dev
,
477 "WRITE ERROR:submit urb error = %d\n", err
);
479 pdx
->pendingWrite
= 1;
485 static int UnMapUserBuffer(struct device_extension
*pdx
)
491 for (k
= 0; k
< pdx
->num_frames
; k
++) {
492 dbg("Killing Urbs for Frame %d", k
);
493 for (i
= 0; i
< pdx
->sgEntries
[k
]; i
++) {
494 usb_kill_urb(pdx
->PixelUrb
[k
][i
]);
495 usb_free_urb(pdx
->PixelUrb
[k
][i
]);
496 pdx
->pendedPixelUrbs
[k
][i
] = 0;
498 dbg("Urb error count = %d", errCnt
);
500 dbg("Urbs free'd and Killed for Frame %d", k
);
503 for (k
= 0; k
< pdx
->num_frames
; k
++) {
504 if (pdx
->iama
== PIXIS_PID
)
505 /* which EP should we map this frame to ? */
506 /* PONG, odd frames: hEP[3] */
507 /* PING, even frames and zero hEP[2] */
508 epAddr
= (k
% 2) ? pdx
->hEP
[3] : pdx
->hEP
[2];
510 /* ST133 only has 1 endpoint for Pixel data transfer */
511 epAddr
= pdx
->hEP
[0];
513 usb_buffer_unmap_sg(pdx
->udev
, epAddr
, pdx
->sgl
[k
],
514 pdx
->maplist_numPagesMapped
[k
]);
515 for (i
= 0; i
< pdx
->maplist_numPagesMapped
[k
]; i
++)
516 page_cache_release(sg_page(&pdx
->sgl
[k
][i
]));
518 kfree(pdx
->PixelUrb
[k
]);
519 kfree(pdx
->pendedPixelUrbs
[k
]);
521 pdx
->PixelUrb
[k
] = NULL
;
522 pdx
->pendedPixelUrbs
[k
] = NULL
;
525 kfree(pdx
->sgEntries
);
526 vfree(pdx
->maplist_numPagesMapped
);
527 pdx
->sgEntries
= NULL
;
528 pdx
->maplist_numPagesMapped
= NULL
;
530 kfree(pdx
->pendedPixelUrbs
);
531 kfree(pdx
->PixelUrb
);
533 pdx
->pendedPixelUrbs
= NULL
;
534 pdx
->PixelUrb
= NULL
;
539 static void piusb_readPIXEL_callback(struct urb
*urb
)
542 struct device_extension
*pdx
= urb
->context
;
543 int status
= urb
->status
;
545 if (status
&& !(status
== -ENOENT
|| status
== -ECONNRESET
)) {
546 dbg("%s - nonzero read bulk status received: %d", __func__
,
548 dbg("Error in read EP2 callback");
549 dbg("FrameIndex = %d", pdx
->frameIdx
);
550 dbg("Bytes received before problem occurred = %d",
551 pdx
->bulk_in_byte_trk
);
552 dbg("Urb Idx = %d", pdx
->urbIdx
);
553 pdx
->pendedPixelUrbs
[pdx
->frameIdx
][pdx
->urbIdx
] = 0;
555 pdx
->bulk_in_byte_trk
+= urb
->actual_length
;
556 i
= usb_submit_urb(urb
, GFP_ATOMIC
); /* resubmit the URB */
560 dbg("submit urb in callback failed "
561 "with error code %d", i
);
565 pdx
->urbIdx
++; /* point to next URB when we callback */
566 if (pdx
->bulk_in_byte_trk
>= pdx
->frameSize
) {
567 pdx
->bulk_in_size_returned
=
568 pdx
->bulk_in_byte_trk
;
569 pdx
->bulk_in_byte_trk
= 0;
570 pdx
->gotPixelData
= 1;
573 1) % pdx
->num_frames
);
582 struct ioctl_struct *io - structure containing user address,
584 struct device_extension *pdx - the PIUSB device extension
587 int - status of the task
590 MapUserBuffer maps a buffer passed down through an ioctl.
591 The user buffer is Page Aligned by the app and then passed down.
592 The function get_free_pages(...) does the actual mapping of the buffer
593 from user space to kernel space.
594 From there a scatterlist is created from all the pages.
595 The next function called is to usb_buffer_map_sg which allocated
596 DMA addresses for each page, even coalescing them if possible.
597 The DMA address is placed in the scatterlist structure.
598 The function returns the number of DMA addresses.
599 This may or may not be equal to the number of pages that
600 the user buffer uses.
601 We then build an URB for each DMA address and then submit them.
605 int MapUserBuffer(unsigned long uaddr, unsigned long numbytes,
606 unsigned long frameInfo, struct device_extension *pdx)
608 static int MapUserBuffer(struct ioctl_struct
*io
, struct device_extension
*pdx
)
611 unsigned long numbytes
;
612 int frameInfo
; /* which frame we're mapping */
613 unsigned int epAddr
= 0;
614 unsigned long count
= 0;
618 struct page
**maplist_p
;
619 int numPagesRequired
;
621 frameInfo
= io
->numFrames
;
622 uaddr
= (unsigned long)io
->pData
;
623 numbytes
= io
->numbytes
;
625 if (pdx
->iama
== PIXIS_PID
) {
626 /* which EP should we map this frame to ? */
627 /* PONG, odd frames: hEP[3] */
628 /* PING, even frames and zero hEP[2] */
629 epAddr
= (frameInfo
% 2) ? pdx
->hEP
[3] : pdx
->hEP
[2];
630 dbg("Pixis Frame #%d: EP=%d", frameInfo
,
631 (epAddr
== pdx
->hEP
[2]) ? 2 : 4);
632 } else { /* ST133 only has 1 endpoint for Pixel data transfer */
633 epAddr
= pdx
->hEP
[0];
634 dbg("ST133 Frame #%d: EP=2", frameInfo
);
637 dbg("UserAddress = 0x%08lX", uaddr
);
638 dbg("numbytes = %d", (int)numbytes
);
640 /* number of pages to map the entire user space DMA buffer */
642 ((uaddr
& ~PAGE_MASK
) + count
+ ~PAGE_MASK
) >> PAGE_SHIFT
;
643 dbg("Number of pages needed = %d", numPagesRequired
);
644 maplist_p
= vmalloc(numPagesRequired
* sizeof(struct page
));
646 dbg("Can't Allocate Memory for maplist_p");
650 /* map the user buffer to kernel memory */
651 down_write(¤t
->mm
->mmap_sem
);
652 pdx
->maplist_numPagesMapped
[frameInfo
] = get_user_pages(current
,
653 current
->mm
, (uaddr
& PAGE_MASK
), numPagesRequired
,
654 WRITE
, 0 /* Don't Force*/, maplist_p
, NULL
);
655 up_write(¤t
->mm
->mmap_sem
);
656 dbg("Number of pages mapped = %d",
657 pdx
->maplist_numPagesMapped
[frameInfo
]);
659 for (i
= 0; i
< pdx
->maplist_numPagesMapped
[frameInfo
]; i
++)
660 flush_dcache_page(maplist_p
[i
]);
661 if (!pdx
->maplist_numPagesMapped
[frameInfo
]) {
662 dbg("get_user_pages() failed");
667 /* need to create a scatterlist that spans each frame
668 * that can fit into the mapped buffer
670 pdx
->sgl
[frameInfo
] =
671 kmalloc((pdx
->maplist_numPagesMapped
[frameInfo
] *
672 sizeof(struct scatterlist
)), GFP_ATOMIC
);
673 if (!pdx
->sgl
[frameInfo
]) {
675 dbg("can't allocate mem for sgl");
678 sg_assign_page(&pdx
->sgl
[frameInfo
][0], maplist_p
[0]);
679 pdx
->sgl
[frameInfo
][0].offset
= uaddr
& ~PAGE_MASK
;
680 if (pdx
->maplist_numPagesMapped
[frameInfo
] > 1) {
681 pdx
->sgl
[frameInfo
][0].length
=
682 PAGE_SIZE
- pdx
->sgl
[frameInfo
][0].offset
;
683 count
-= pdx
->sgl
[frameInfo
][0].length
;
684 for (k
= 1; k
< pdx
->maplist_numPagesMapped
[frameInfo
]; k
++) {
685 pdx
->sgl
[frameInfo
][k
].offset
= 0;
686 sg_assign_page(&pdx
->sgl
[frameInfo
][k
], maplist_p
[k
]);
687 pdx
->sgl
[frameInfo
][k
].length
=
688 (count
< PAGE_SIZE
) ? count
: PAGE_SIZE
;
689 count
-= PAGE_SIZE
; /* example had PAGE_SIZE here */
692 pdx
->sgl
[frameInfo
][0].length
= count
;
694 pdx
->sgEntries
[frameInfo
] =
695 usb_buffer_map_sg(pdx
->udev
, epAddr
, pdx
->sgl
[frameInfo
],
696 pdx
->maplist_numPagesMapped
[frameInfo
]);
697 dbg("number of sgEntries = %d", pdx
->sgEntries
[frameInfo
]);
698 pdx
->userBufMapped
= 1;
701 /* Create and Send the URB's for each s/g entry */
702 pdx
->PixelUrb
[frameInfo
] =
703 kmalloc(pdx
->sgEntries
[frameInfo
] * sizeof(struct urb
*),
705 if (!pdx
->PixelUrb
[frameInfo
]) {
706 dbg("Can't Allocate Memory for Urb");
709 for (i
= 0; i
< pdx
->sgEntries
[frameInfo
]; i
++) {
710 /* 0 iso packets because we're using BULK transfers */
711 pdx
->PixelUrb
[frameInfo
][i
] = usb_alloc_urb(0, GFP_KERNEL
);
712 usb_fill_bulk_urb(pdx
->PixelUrb
[frameInfo
][i
],
715 (dma_addr_t
*) sg_dma_address(&pdx
->
718 sg_dma_len(&pdx
->sgl
[frameInfo
][i
]),
719 piusb_readPIXEL_callback
, (void *)pdx
);
720 pdx
->PixelUrb
[frameInfo
][i
]->transfer_dma
=
721 sg_dma_address(&pdx
->sgl
[frameInfo
][i
]);
722 pdx
->PixelUrb
[frameInfo
][i
]->transfer_flags
=
723 URB_NO_TRANSFER_DMA_MAP
| URB_NO_INTERRUPT
;
725 /* only interrupt when last URB completes */
726 pdx
->PixelUrb
[frameInfo
][--i
]->transfer_flags
&= ~URB_NO_INTERRUPT
;
727 pdx
->pendedPixelUrbs
[frameInfo
] =
728 kmalloc((pdx
->sgEntries
[frameInfo
] * sizeof(char)), GFP_KERNEL
);
729 if (!pdx
->pendedPixelUrbs
[frameInfo
])
730 dbg("Can't allocate Memory for pendedPixelUrbs");
731 for (i
= 0; i
< pdx
->sgEntries
[frameInfo
]; i
++) {
732 err
= usb_submit_urb(pdx
->PixelUrb
[frameInfo
][i
], GFP_ATOMIC
);
734 dbg("%s %d\n", "submit urb error =", err
);
735 pdx
->pendedPixelUrbs
[frameInfo
][i
] = 0;
738 pdx
->pendedPixelUrbs
[frameInfo
][i
] = 1;
743 static const struct file_operations piusb_fops
= {
744 .owner
= THIS_MODULE
,
745 .ioctl
= piusb_ioctl
,
747 .release
= piusb_release
,
750 static struct usb_class_driver piusb_class
= {
751 .name
= "usb/rspiusb%d",
753 .minor_base
= PIUSB_MINOR_BASE
,
759 * Called by the usb core when a new device is connected that it thinks
760 * this driver might be interested in.
762 static int piusb_probe(struct usb_interface
*interface
,
763 const struct usb_device_id
*id
)
765 struct device_extension
*pdx
= NULL
;
766 struct usb_host_interface
*iface_desc
;
767 struct usb_endpoint_descriptor
*endpoint
;
769 int retval
= -ENOMEM
;
771 dev_dbg(&interface
->dev
, "%s - Looking for PI USB Hardware", __func__
);
773 pdx
= kzalloc(sizeof(struct device_extension
), GFP_KERNEL
);
775 dev_err(&interface
->dev
, "Out of memory\n");
778 kref_init(&pdx
->kref
);
779 pdx
->udev
= usb_get_dev(interface_to_usbdev(interface
));
780 pdx
->interface
= interface
;
781 iface_desc
= interface
->cur_altsetting
;
783 /* See if the device offered us matches what we can accept */
784 if ((pdx
->udev
->descriptor
.idVendor
!= VENDOR_ID
)
785 || ((pdx
->udev
->descriptor
.idProduct
!= PIXIS_PID
)
786 && (pdx
->udev
->descriptor
.idProduct
!= ST133_PID
)))
789 pdx
->iama
= pdx
->udev
->descriptor
.idProduct
;
792 if (pdx
->udev
->descriptor
.idProduct
== PIXIS_PID
)
793 dbg("PIUSB:Pixis Camera Found");
795 dbg("PIUSB:ST133 USB Controller Found");
796 if (pdx
->udev
->speed
== USB_SPEED_HIGH
)
797 dbg("Highspeed(USB2.0) Device Attached");
799 dbg("Lowspeed (USB1.1) Device Attached");
801 dbg("NumEndpoints in Configuration: %d",
802 iface_desc
->desc
.bNumEndpoints
);
804 for (i
= 0; i
< iface_desc
->desc
.bNumEndpoints
; ++i
) {
805 endpoint
= &iface_desc
->endpoint
[i
].desc
;
807 dbg("Endpoint[%d]->bDescriptorType = %d", i
,
808 endpoint
->bDescriptorType
);
809 dbg("Endpoint[%d]->bEndpointAddress = 0x%02X", i
,
810 endpoint
->bEndpointAddress
);
811 dbg("Endpoint[%d]->bbmAttributes = %d", i
,
812 endpoint
->bmAttributes
);
813 dbg("Endpoint[%d]->MaxPacketSize = %d\n", i
,
814 endpoint
->wMaxPacketSize
);
816 if (usb_endpoint_xfer_bulk(endpoint
)) {
817 if (usb_endpoint_dir_in(endpoint
))
819 usb_rcvbulkpipe(pdx
->udev
,
820 endpoint
->bEndpointAddress
);
823 usb_sndbulkpipe(pdx
->udev
,
824 endpoint
->bEndpointAddress
);
827 usb_set_intfdata(interface
, pdx
);
828 retval
= usb_register_dev(interface
, &piusb_class
);
830 err("Not able to get a minor for this device.");
831 usb_set_intfdata(interface
, NULL
);
836 /* we can register the device now, as it is ready */
837 pdx
->minor
= interface
->minor
;
838 /* let the user know what node this device is now attached to */
839 dbg("PI USB2.0 device now attached to piusb-%d", pdx
->minor
);
844 kref_put(&pdx
->kref
, piusb_delete
);
851 * Called by the usb core when the device is removed from the system.
853 * This routine guarantees that the driver will not submit any more urbs
854 * by clearing pdx->udev. It is also supposed to terminate any currently
855 * active urbs. Unfortunately, usb_bulk_msg(), used in piusb_read(), does
856 * not provide any way to do this. But at least we can cancel an active
859 static void piusb_disconnect(struct usb_interface
*interface
)
861 struct device_extension
*pdx
;
862 int minor
= interface
->minor
;
866 pdx
= usb_get_intfdata(interface
);
867 usb_set_intfdata(interface
, NULL
);
869 /* give back our minor */
870 usb_deregister_dev(interface
, &piusb_class
);
874 /* prevent device read, write and ioctl */
876 kref_put(&pdx
->kref
, piusb_delete
);
877 dbg("PI USB2.0 device #%d now disconnected\n", minor
);
880 static struct usb_driver piusb_driver
= {
882 .probe
= piusb_probe
,
883 .disconnect
= piusb_disconnect
,
884 .id_table
= pi_device_table
,
890 static int __init
piusb_init(void)
897 /* register this driver with the USB subsystem */
898 result
= usb_register(&piusb_driver
);
900 printk(KERN_ERR KBUILD_MODNAME
901 ": usb_register failed. Error number %d\n",
904 printk(KERN_INFO KBUILD_MODNAME
":%s: %s\n", DRIVER_DESC
,
912 static void __exit
piusb_exit(void)
914 /* deregister this driver with the USB subsystem */
915 usb_deregister(&piusb_driver
);
918 module_init(piusb_init
);
919 module_exit(piusb_exit
);
921 /* Module parameters */
922 module_param(debug
, int, 0);
923 MODULE_PARM_DESC(debug
, "Debug enabled or not");
925 MODULE_AUTHOR(DRIVER_AUTHOR
);
926 MODULE_DESCRIPTION(DRIVER_DESC
);
927 MODULE_LICENSE("GPL v2");