mdc800.c 24 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * copyright (C) 1999/2000 by Henning Zabel <henning@uni-paderborn.de>
  4. */
  5. /*
  6. * USB-Kernel Driver for the Mustek MDC800 Digital Camera
  7. * (c) 1999/2000 Henning Zabel <henning@uni-paderborn.de>
  8. *
  9. *
  10. * The driver brings the USB functions of the MDC800 to Linux.
  11. * To use the Camera you must support the USB Protocol of the camera
  12. * to the Kernel Node.
  13. * The Driver uses a misc device Node. Create it with :
  14. * mknod /dev/mustek c 180 32
  15. *
  16. * The driver supports only one camera.
  17. *
  18. * Fix: mdc800 used sleep_on and slept with io_lock held.
  19. * Converted sleep_on to waitqueues with schedule_timeout and made io_lock
  20. * a semaphore from a spinlock.
  21. * by Oliver Neukum <oliver@neukum.name>
  22. * (02/12/2001)
  23. *
  24. * Identify version on module load.
  25. * (08/04/2001) gb
  26. *
  27. * version 0.7.5
  28. * Fixed potential SMP races with Spinlocks.
  29. * Thanks to Oliver Neukum <oliver@neukum.name> who
  30. * noticed the race conditions.
  31. * (30/10/2000)
  32. *
  33. * Fixed: Setting urb->dev before submitting urb.
  34. * by Greg KH <greg@kroah.com>
  35. * (13/10/2000)
  36. *
  37. * version 0.7.3
  38. * bugfix : The mdc800->state field gets set to READY after the
  39. * disconnect function sets it to NOT_CONNECTED. This makes the
  40. * driver running like the camera is connected and causes some
  41. * hang ups.
  42. *
  43. * version 0.7.1
  44. * MOD_INC and MOD_DEC are changed in usb_probe to prevent load/unload
  45. * problems when compiled as Module.
  46. * (04/04/2000)
  47. *
  48. * The mdc800 driver gets assigned the USB Minor 32-47. The Registration
  49. * was updated to use these values.
  50. * (26/03/2000)
  51. *
  52. * The Init und Exit Module Function are updated.
  53. * (01/03/2000)
  54. *
  55. * version 0.7.0
  56. * Rewrite of the driver : The driver now uses URB's. The old stuff
  57. * has been removed.
  58. *
  59. * version 0.6.0
  60. * Rewrite of this driver: The Emulation of the rs232 protocoll
  61. * has been removed from the driver. A special executeCommand function
  62. * for this driver is included to gphoto.
  63. * The driver supports two kind of communication to bulk endpoints.
  64. * Either with the dev->bus->ops->bulk... or with callback function.
  65. * (09/11/1999)
  66. *
  67. * version 0.5.0:
  68. * first Version that gets a version number. Most of the needed
  69. * functions work.
  70. * (20/10/1999)
  71. */
  72. #include <linux/sched/signal.h>
  73. #include <linux/signal.h>
  74. #include <linux/spinlock.h>
  75. #include <linux/errno.h>
  76. #include <linux/random.h>
  77. #include <linux/poll.h>
  78. #include <linux/init.h>
  79. #include <linux/slab.h>
  80. #include <linux/module.h>
  81. #include <linux/wait.h>
  82. #include <linux/mutex.h>
  83. #include <linux/usb.h>
  84. #include <linux/fs.h>
  85. /*
  86. * Version Information
  87. */
  88. #define DRIVER_VERSION "v0.7.5 (30/10/2000)"
  89. #define DRIVER_AUTHOR "Henning Zabel <henning@uni-paderborn.de>"
  90. #define DRIVER_DESC "USB Driver for Mustek MDC800 Digital Camera"
  91. /* Vendor and Product Information */
  92. #define MDC800_VENDOR_ID 0x055f
  93. #define MDC800_PRODUCT_ID 0xa800
  94. /* Timeouts (msec) */
  95. #define TO_DOWNLOAD_GET_READY 1500
  96. #define TO_DOWNLOAD_GET_BUSY 1500
  97. #define TO_WRITE_GET_READY 1000
  98. #define TO_DEFAULT_COMMAND 5000
  99. #define TO_READ_FROM_IRQ TO_DEFAULT_COMMAND
  100. #define TO_GET_READY TO_DEFAULT_COMMAND
  101. /* Minor Number of the device (create with mknod /dev/mustek c 180 32) */
  102. #define MDC800_DEVICE_MINOR_BASE 32
  103. /**************************************************************************
  104. Data and structs
  105. ***************************************************************************/
  106. typedef enum {
  107. NOT_CONNECTED, READY, WORKING, DOWNLOAD
  108. } mdc800_state;
  109. /* Data for the driver */
  110. struct mdc800_data
  111. {
  112. struct usb_device * dev; // Device Data
  113. mdc800_state state;
  114. unsigned int endpoint [4];
  115. struct urb * irq_urb;
  116. wait_queue_head_t irq_wait;
  117. int irq_woken;
  118. char* irq_urb_buffer;
  119. int camera_busy; // is camera busy ?
  120. int camera_request_ready; // Status to synchronize with irq
  121. char camera_response [8]; // last Bytes send after busy
  122. struct urb * write_urb;
  123. char* write_urb_buffer;
  124. wait_queue_head_t write_wait;
  125. int written;
  126. struct urb * download_urb;
  127. char* download_urb_buffer;
  128. wait_queue_head_t download_wait;
  129. int downloaded;
  130. int download_left; // Bytes left to download ?
  131. /* Device Data */
  132. char out [64]; // Answer Buffer
  133. int out_ptr; // Index to the first not readen byte
  134. int out_count; // Bytes in the buffer
  135. int open; // Camera device open ?
  136. struct mutex io_lock; // IO -lock
  137. char in [8]; // Command Input Buffer
  138. int in_count;
  139. int pic_index; // Cache for the Imagesize (-1 for nothing cached )
  140. int pic_len;
  141. int minor;
  142. };
  143. /* Specification of the Endpoints */
  144. static struct usb_endpoint_descriptor mdc800_ed [4] =
  145. {
  146. {
  147. .bLength = 0,
  148. .bDescriptorType = 0,
  149. .bEndpointAddress = 0x01,
  150. .bmAttributes = 0x02,
  151. .wMaxPacketSize = cpu_to_le16(8),
  152. .bInterval = 0,
  153. .bRefresh = 0,
  154. .bSynchAddress = 0,
  155. },
  156. {
  157. .bLength = 0,
  158. .bDescriptorType = 0,
  159. .bEndpointAddress = 0x82,
  160. .bmAttributes = 0x03,
  161. .wMaxPacketSize = cpu_to_le16(8),
  162. .bInterval = 0,
  163. .bRefresh = 0,
  164. .bSynchAddress = 0,
  165. },
  166. {
  167. .bLength = 0,
  168. .bDescriptorType = 0,
  169. .bEndpointAddress = 0x03,
  170. .bmAttributes = 0x02,
  171. .wMaxPacketSize = cpu_to_le16(64),
  172. .bInterval = 0,
  173. .bRefresh = 0,
  174. .bSynchAddress = 0,
  175. },
  176. {
  177. .bLength = 0,
  178. .bDescriptorType = 0,
  179. .bEndpointAddress = 0x84,
  180. .bmAttributes = 0x02,
  181. .wMaxPacketSize = cpu_to_le16(64),
  182. .bInterval = 0,
  183. .bRefresh = 0,
  184. .bSynchAddress = 0,
  185. },
  186. };
  187. /* The Variable used by the driver */
  188. static struct mdc800_data* mdc800;
  189. /***************************************************************************
  190. The USB Part of the driver
  191. ****************************************************************************/
  192. static int mdc800_endpoint_equals (struct usb_endpoint_descriptor *a,struct usb_endpoint_descriptor *b)
  193. {
  194. return (
  195. ( a->bEndpointAddress == b->bEndpointAddress )
  196. && ( a->bmAttributes == b->bmAttributes )
  197. && ( a->wMaxPacketSize == b->wMaxPacketSize )
  198. );
  199. }
  200. /*
  201. * Checks whether the camera responds busy
  202. */
  203. static int mdc800_isBusy (char* ch)
  204. {
  205. int i=0;
  206. while (i<8)
  207. {
  208. if (ch [i] != (char)0x99)
  209. return 0;
  210. i++;
  211. }
  212. return 1;
  213. }
  214. /*
  215. * Checks whether the Camera is ready
  216. */
  217. static int mdc800_isReady (char *ch)
  218. {
  219. int i=0;
  220. while (i<8)
  221. {
  222. if (ch [i] != (char)0xbb)
  223. return 0;
  224. i++;
  225. }
  226. return 1;
  227. }
  228. /*
  229. * USB IRQ Handler for InputLine
  230. */
  231. static void mdc800_usb_irq (struct urb *urb)
  232. {
  233. int data_received=0, wake_up;
  234. unsigned char* b=urb->transfer_buffer;
  235. struct mdc800_data* mdc800=urb->context;
  236. struct device *dev = &mdc800->dev->dev;
  237. int status = urb->status;
  238. if (status >= 0) {
  239. if (mdc800_isBusy (b))
  240. {
  241. if (!mdc800->camera_busy)
  242. {
  243. mdc800->camera_busy=1;
  244. dev_dbg(dev, "gets busy\n");
  245. }
  246. }
  247. else
  248. {
  249. if (mdc800->camera_busy && mdc800_isReady (b))
  250. {
  251. mdc800->camera_busy=0;
  252. dev_dbg(dev, "gets ready\n");
  253. }
  254. }
  255. if (!(mdc800_isBusy (b) || mdc800_isReady (b)))
  256. {
  257. /* Store Data in camera_answer field */
  258. dev_dbg(dev, "%i %i %i %i %i %i %i %i \n",b[0],b[1],b[2],b[3],b[4],b[5],b[6],b[7]);
  259. memcpy (mdc800->camera_response,b,8);
  260. data_received=1;
  261. }
  262. }
  263. wake_up= ( mdc800->camera_request_ready > 0 )
  264. &&
  265. (
  266. ((mdc800->camera_request_ready == 1) && (!mdc800->camera_busy))
  267. ||
  268. ((mdc800->camera_request_ready == 2) && data_received)
  269. ||
  270. ((mdc800->camera_request_ready == 3) && (mdc800->camera_busy))
  271. ||
  272. (status < 0)
  273. );
  274. if (wake_up)
  275. {
  276. mdc800->camera_request_ready=0;
  277. mdc800->irq_woken=1;
  278. wake_up (&mdc800->irq_wait);
  279. }
  280. }
  281. /*
  282. * Waits a while until the irq responds that camera is ready
  283. *
  284. * mode : 0: Wait for camera gets ready
  285. * 1: Wait for receiving data
  286. * 2: Wait for camera gets busy
  287. *
  288. * msec: Time to wait
  289. */
  290. static int mdc800_usb_waitForIRQ (int mode, int msec)
  291. {
  292. mdc800->camera_request_ready=1+mode;
  293. wait_event_timeout(mdc800->irq_wait, mdc800->irq_woken,
  294. msecs_to_jiffies(msec));
  295. mdc800->irq_woken = 0;
  296. if (mdc800->camera_request_ready>0)
  297. {
  298. mdc800->camera_request_ready=0;
  299. dev_err(&mdc800->dev->dev, "timeout waiting for camera.\n");
  300. return -1;
  301. }
  302. if (mdc800->state == NOT_CONNECTED)
  303. {
  304. printk(KERN_WARNING "mdc800: Camera gets disconnected "
  305. "during waiting for irq.\n");
  306. mdc800->camera_request_ready=0;
  307. return -2;
  308. }
  309. return 0;
  310. }
  311. /*
  312. * The write_urb callback function
  313. */
  314. static void mdc800_usb_write_notify (struct urb *urb)
  315. {
  316. struct mdc800_data* mdc800=urb->context;
  317. int status = urb->status;
  318. if (status != 0)
  319. dev_err(&mdc800->dev->dev,
  320. "writing command fails (status=%i)\n", status);
  321. else
  322. mdc800->state=READY;
  323. mdc800->written = 1;
  324. wake_up (&mdc800->write_wait);
  325. }
  326. /*
  327. * The download_urb callback function
  328. */
  329. static void mdc800_usb_download_notify (struct urb *urb)
  330. {
  331. struct mdc800_data* mdc800=urb->context;
  332. int status = urb->status;
  333. if (status == 0) {
  334. /* Fill output buffer with these data */
  335. memcpy (mdc800->out, urb->transfer_buffer, 64);
  336. mdc800->out_count=64;
  337. mdc800->out_ptr=0;
  338. mdc800->download_left-=64;
  339. if (mdc800->download_left == 0)
  340. {
  341. mdc800->state=READY;
  342. }
  343. } else {
  344. dev_err(&mdc800->dev->dev,
  345. "request bytes fails (status:%i)\n", status);
  346. }
  347. mdc800->downloaded = 1;
  348. wake_up (&mdc800->download_wait);
  349. }
  350. /***************************************************************************
  351. Probing for the Camera
  352. ***************************************************************************/
  353. static struct usb_driver mdc800_usb_driver;
  354. static const struct file_operations mdc800_device_ops;
  355. static struct usb_class_driver mdc800_class = {
  356. .name = "mdc800%d",
  357. .fops = &mdc800_device_ops,
  358. .minor_base = MDC800_DEVICE_MINOR_BASE,
  359. };
  360. /*
  361. * Callback to search the Mustek MDC800 on the USB Bus
  362. */
  363. static int mdc800_usb_probe (struct usb_interface *intf,
  364. const struct usb_device_id *id)
  365. {
  366. int i,j;
  367. struct usb_host_interface *intf_desc;
  368. struct usb_device *dev = interface_to_usbdev (intf);
  369. int irq_interval=0;
  370. int retval;
  371. dev_dbg(&intf->dev, "(%s) called.\n", __func__);
  372. if (mdc800->dev != NULL)
  373. {
  374. dev_warn(&intf->dev, "only one Mustek MDC800 is supported.\n");
  375. return -ENODEV;
  376. }
  377. if (dev->descriptor.bNumConfigurations != 1)
  378. {
  379. dev_err(&intf->dev,
  380. "probe fails -> wrong Number of Configuration\n");
  381. return -ENODEV;
  382. }
  383. intf_desc = intf->cur_altsetting;
  384. if (
  385. ( intf_desc->desc.bInterfaceClass != 0xff )
  386. || ( intf_desc->desc.bInterfaceSubClass != 0 )
  387. || ( intf_desc->desc.bInterfaceProtocol != 0 )
  388. || ( intf_desc->desc.bNumEndpoints != 4)
  389. )
  390. {
  391. dev_err(&intf->dev, "probe fails -> wrong Interface\n");
  392. return -ENODEV;
  393. }
  394. /* Check the Endpoints */
  395. for (i=0; i<4; i++)
  396. {
  397. mdc800->endpoint[i]=-1;
  398. for (j=0; j<4; j++)
  399. {
  400. if (mdc800_endpoint_equals (&intf_desc->endpoint [j].desc,&mdc800_ed [i]))
  401. {
  402. mdc800->endpoint[i]=intf_desc->endpoint [j].desc.bEndpointAddress ;
  403. if (i==1)
  404. {
  405. irq_interval=intf_desc->endpoint [j].desc.bInterval;
  406. }
  407. }
  408. }
  409. if (mdc800->endpoint[i] == -1)
  410. {
  411. dev_err(&intf->dev, "probe fails -> Wrong Endpoints.\n");
  412. return -ENODEV;
  413. }
  414. }
  415. dev_info(&intf->dev, "Found Mustek MDC800 on USB.\n");
  416. mutex_lock(&mdc800->io_lock);
  417. retval = usb_register_dev(intf, &mdc800_class);
  418. if (retval) {
  419. dev_err(&intf->dev, "Not able to get a minor for this device.\n");
  420. mutex_unlock(&mdc800->io_lock);
  421. return -ENODEV;
  422. }
  423. mdc800->dev=dev;
  424. mdc800->open=0;
  425. /* Setup URB Structs */
  426. usb_fill_int_urb (
  427. mdc800->irq_urb,
  428. mdc800->dev,
  429. usb_rcvintpipe (mdc800->dev,mdc800->endpoint [1]),
  430. mdc800->irq_urb_buffer,
  431. 8,
  432. mdc800_usb_irq,
  433. mdc800,
  434. irq_interval
  435. );
  436. usb_fill_bulk_urb (
  437. mdc800->write_urb,
  438. mdc800->dev,
  439. usb_sndbulkpipe (mdc800->dev, mdc800->endpoint[0]),
  440. mdc800->write_urb_buffer,
  441. 8,
  442. mdc800_usb_write_notify,
  443. mdc800
  444. );
  445. usb_fill_bulk_urb (
  446. mdc800->download_urb,
  447. mdc800->dev,
  448. usb_rcvbulkpipe (mdc800->dev, mdc800->endpoint [3]),
  449. mdc800->download_urb_buffer,
  450. 64,
  451. mdc800_usb_download_notify,
  452. mdc800
  453. );
  454. mdc800->state=READY;
  455. mutex_unlock(&mdc800->io_lock);
  456. usb_set_intfdata(intf, mdc800);
  457. return 0;
  458. }
  459. /*
  460. * Disconnect USB device (maybe the MDC800)
  461. */
  462. static void mdc800_usb_disconnect (struct usb_interface *intf)
  463. {
  464. struct mdc800_data* mdc800 = usb_get_intfdata(intf);
  465. dev_dbg(&intf->dev, "(%s) called\n", __func__);
  466. if (mdc800) {
  467. if (mdc800->state == NOT_CONNECTED)
  468. return;
  469. usb_deregister_dev(intf, &mdc800_class);
  470. /* must be under lock to make sure no URB
  471. is submitted after usb_kill_urb() */
  472. mutex_lock(&mdc800->io_lock);
  473. mdc800->state=NOT_CONNECTED;
  474. usb_kill_urb(mdc800->irq_urb);
  475. usb_kill_urb(mdc800->write_urb);
  476. usb_kill_urb(mdc800->download_urb);
  477. mutex_unlock(&mdc800->io_lock);
  478. mdc800->dev = NULL;
  479. usb_set_intfdata(intf, NULL);
  480. }
  481. dev_info(&intf->dev, "Mustek MDC800 disconnected from USB.\n");
  482. }
  483. /***************************************************************************
  484. The Misc device Part (file_operations)
  485. ****************************************************************************/
  486. /*
  487. * This Function calc the Answersize for a command.
  488. */
  489. static int mdc800_getAnswerSize (char command)
  490. {
  491. switch ((unsigned char) command)
  492. {
  493. case 0x2a:
  494. case 0x49:
  495. case 0x51:
  496. case 0x0d:
  497. case 0x20:
  498. case 0x07:
  499. case 0x01:
  500. case 0x25:
  501. case 0x00:
  502. return 8;
  503. case 0x05:
  504. case 0x3e:
  505. return mdc800->pic_len;
  506. case 0x09:
  507. return 4096;
  508. default:
  509. return 0;
  510. }
  511. }
  512. /*
  513. * Init the device: (1) alloc mem (2) Increase MOD Count ..
  514. */
  515. static int mdc800_device_open (struct inode* inode, struct file *file)
  516. {
  517. int retval=0;
  518. int errn=0;
  519. mutex_lock(&mdc800->io_lock);
  520. if (mdc800->state == NOT_CONNECTED)
  521. {
  522. errn=-EBUSY;
  523. goto error_out;
  524. }
  525. if (mdc800->open)
  526. {
  527. errn=-EBUSY;
  528. goto error_out;
  529. }
  530. mdc800->in_count=0;
  531. mdc800->out_count=0;
  532. mdc800->out_ptr=0;
  533. mdc800->pic_index=0;
  534. mdc800->pic_len=-1;
  535. mdc800->download_left=0;
  536. mdc800->camera_busy=0;
  537. mdc800->camera_request_ready=0;
  538. mdc800->irq_urb->dev = mdc800->dev;
  539. retval = usb_submit_urb (mdc800->irq_urb, GFP_KERNEL);
  540. if (retval) {
  541. dev_err(&mdc800->dev->dev,
  542. "request USB irq fails (submit_retval=%i).\n", retval);
  543. errn = -EIO;
  544. goto error_out;
  545. }
  546. mdc800->open=1;
  547. dev_dbg(&mdc800->dev->dev, "Mustek MDC800 device opened.\n");
  548. error_out:
  549. mutex_unlock(&mdc800->io_lock);
  550. return errn;
  551. }
  552. /*
  553. * Close the Camera and release Memory
  554. */
  555. static int mdc800_device_release (struct inode* inode, struct file *file)
  556. {
  557. int retval=0;
  558. mutex_lock(&mdc800->io_lock);
  559. if (mdc800->open && (mdc800->state != NOT_CONNECTED))
  560. {
  561. usb_kill_urb(mdc800->irq_urb);
  562. usb_kill_urb(mdc800->write_urb);
  563. usb_kill_urb(mdc800->download_urb);
  564. mdc800->open=0;
  565. }
  566. else
  567. {
  568. retval=-EIO;
  569. }
  570. mutex_unlock(&mdc800->io_lock);
  571. return retval;
  572. }
  573. /*
  574. * The Device read callback Function
  575. */
  576. static ssize_t mdc800_device_read (struct file *file, char __user *buf, size_t len, loff_t *pos)
  577. {
  578. size_t left=len, sts=len; /* single transfer size */
  579. char __user *ptr = buf;
  580. int retval;
  581. mutex_lock(&mdc800->io_lock);
  582. if (mdc800->state == NOT_CONNECTED)
  583. {
  584. mutex_unlock(&mdc800->io_lock);
  585. return -EBUSY;
  586. }
  587. if (mdc800->state == WORKING)
  588. {
  589. printk(KERN_WARNING "mdc800: Illegal State \"working\""
  590. "reached during read ?!\n");
  591. mutex_unlock(&mdc800->io_lock);
  592. return -EBUSY;
  593. }
  594. if (!mdc800->open)
  595. {
  596. mutex_unlock(&mdc800->io_lock);
  597. return -EBUSY;
  598. }
  599. while (left)
  600. {
  601. if (signal_pending (current))
  602. {
  603. mutex_unlock(&mdc800->io_lock);
  604. return -EINTR;
  605. }
  606. sts=left > (mdc800->out_count-mdc800->out_ptr)?mdc800->out_count-mdc800->out_ptr:left;
  607. if (sts <= 0)
  608. {
  609. /* Too less Data in buffer */
  610. if (mdc800->state == DOWNLOAD)
  611. {
  612. mdc800->out_count=0;
  613. mdc800->out_ptr=0;
  614. /* Download -> Request new bytes */
  615. mdc800->download_urb->dev = mdc800->dev;
  616. retval = usb_submit_urb (mdc800->download_urb, GFP_KERNEL);
  617. if (retval) {
  618. dev_err(&mdc800->dev->dev,
  619. "Can't submit download urb "
  620. "(retval=%i)\n", retval);
  621. mutex_unlock(&mdc800->io_lock);
  622. return len-left;
  623. }
  624. wait_event_timeout(mdc800->download_wait,
  625. mdc800->downloaded,
  626. msecs_to_jiffies(TO_DOWNLOAD_GET_READY));
  627. mdc800->downloaded = 0;
  628. if (mdc800->download_urb->status != 0)
  629. {
  630. dev_err(&mdc800->dev->dev,
  631. "request download-bytes fails "
  632. "(status=%i)\n",
  633. mdc800->download_urb->status);
  634. mutex_unlock(&mdc800->io_lock);
  635. return len-left;
  636. }
  637. }
  638. else
  639. {
  640. /* No more bytes -> that's an error*/
  641. mutex_unlock(&mdc800->io_lock);
  642. return -EIO;
  643. }
  644. }
  645. else
  646. {
  647. /* Copy Bytes */
  648. if (copy_to_user(ptr, &mdc800->out [mdc800->out_ptr],
  649. sts)) {
  650. mutex_unlock(&mdc800->io_lock);
  651. return -EFAULT;
  652. }
  653. ptr+=sts;
  654. left-=sts;
  655. mdc800->out_ptr+=sts;
  656. }
  657. }
  658. mutex_unlock(&mdc800->io_lock);
  659. return len-left;
  660. }
  661. /*
  662. * The Device write callback Function
  663. * If a 8Byte Command is received, it will be send to the camera.
  664. * After this the driver initiates the request for the answer or
  665. * just waits until the camera becomes ready.
  666. */
  667. static ssize_t mdc800_device_write (struct file *file, const char __user *buf, size_t len, loff_t *pos)
  668. {
  669. size_t i=0;
  670. int retval;
  671. mutex_lock(&mdc800->io_lock);
  672. if (mdc800->state != READY)
  673. {
  674. mutex_unlock(&mdc800->io_lock);
  675. return -EBUSY;
  676. }
  677. if (!mdc800->open )
  678. {
  679. mutex_unlock(&mdc800->io_lock);
  680. return -EBUSY;
  681. }
  682. while (i<len)
  683. {
  684. unsigned char c;
  685. if (signal_pending (current))
  686. {
  687. mutex_unlock(&mdc800->io_lock);
  688. return -EINTR;
  689. }
  690. if(get_user(c, buf+i))
  691. {
  692. mutex_unlock(&mdc800->io_lock);
  693. return -EFAULT;
  694. }
  695. /* check for command start */
  696. if (c == 0x55)
  697. {
  698. mdc800->in_count=0;
  699. mdc800->out_count=0;
  700. mdc800->out_ptr=0;
  701. mdc800->download_left=0;
  702. }
  703. /* save command byte */
  704. if (mdc800->in_count < 8)
  705. {
  706. mdc800->in[mdc800->in_count] = c;
  707. mdc800->in_count++;
  708. }
  709. else
  710. {
  711. mutex_unlock(&mdc800->io_lock);
  712. return -EIO;
  713. }
  714. /* Command Buffer full ? -> send it to camera */
  715. if (mdc800->in_count == 8)
  716. {
  717. int answersize;
  718. if (mdc800_usb_waitForIRQ (0,TO_GET_READY))
  719. {
  720. dev_err(&mdc800->dev->dev,
  721. "Camera didn't get ready.\n");
  722. mutex_unlock(&mdc800->io_lock);
  723. return -EIO;
  724. }
  725. answersize=mdc800_getAnswerSize (mdc800->in[1]);
  726. mdc800->state=WORKING;
  727. memcpy (mdc800->write_urb->transfer_buffer, mdc800->in,8);
  728. mdc800->write_urb->dev = mdc800->dev;
  729. retval = usb_submit_urb (mdc800->write_urb, GFP_KERNEL);
  730. if (retval) {
  731. dev_err(&mdc800->dev->dev,
  732. "submitting write urb fails "
  733. "(retval=%i)\n", retval);
  734. mutex_unlock(&mdc800->io_lock);
  735. return -EIO;
  736. }
  737. wait_event_timeout(mdc800->write_wait, mdc800->written,
  738. msecs_to_jiffies(TO_WRITE_GET_READY));
  739. mdc800->written = 0;
  740. if (mdc800->state == WORKING)
  741. {
  742. usb_kill_urb(mdc800->write_urb);
  743. mutex_unlock(&mdc800->io_lock);
  744. return -EIO;
  745. }
  746. switch ((unsigned char) mdc800->in[1])
  747. {
  748. case 0x05: /* Download Image */
  749. case 0x3e: /* Take shot in Fine Mode (WCam Mode) */
  750. if (mdc800->pic_len < 0)
  751. {
  752. dev_err(&mdc800->dev->dev,
  753. "call 0x07 before "
  754. "0x05,0x3e\n");
  755. mdc800->state=READY;
  756. mutex_unlock(&mdc800->io_lock);
  757. return -EIO;
  758. }
  759. mdc800->pic_len=-1;
  760. fallthrough;
  761. case 0x09: /* Download Thumbnail */
  762. mdc800->download_left=answersize+64;
  763. mdc800->state=DOWNLOAD;
  764. mdc800_usb_waitForIRQ (0,TO_DOWNLOAD_GET_BUSY);
  765. break;
  766. default:
  767. if (answersize)
  768. {
  769. if (mdc800_usb_waitForIRQ (1,TO_READ_FROM_IRQ))
  770. {
  771. dev_err(&mdc800->dev->dev, "requesting answer from irq fails\n");
  772. mutex_unlock(&mdc800->io_lock);
  773. return -EIO;
  774. }
  775. /* Write dummy data, (this is ugly but part of the USB Protocol */
  776. /* if you use endpoint 1 as bulk and not as irq) */
  777. memcpy (mdc800->out, mdc800->camera_response,8);
  778. /* This is the interpreted answer */
  779. memcpy (&mdc800->out[8], mdc800->camera_response,8);
  780. mdc800->out_ptr=0;
  781. mdc800->out_count=16;
  782. /* Cache the Imagesize, if command was getImageSize */
  783. if (mdc800->in [1] == (char) 0x07)
  784. {
  785. mdc800->pic_len=(int) 65536*(unsigned char) mdc800->camera_response[0]+256*(unsigned char) mdc800->camera_response[1]+(unsigned char) mdc800->camera_response[2];
  786. dev_dbg(&mdc800->dev->dev, "cached imagesize = %i\n", mdc800->pic_len);
  787. }
  788. }
  789. else
  790. {
  791. if (mdc800_usb_waitForIRQ (0,TO_DEFAULT_COMMAND))
  792. {
  793. dev_err(&mdc800->dev->dev, "Command Timeout.\n");
  794. mutex_unlock(&mdc800->io_lock);
  795. return -EIO;
  796. }
  797. }
  798. mdc800->state=READY;
  799. break;
  800. }
  801. }
  802. i++;
  803. }
  804. mutex_unlock(&mdc800->io_lock);
  805. return i;
  806. }
  807. /***************************************************************************
  808. Init and Cleanup this driver (Structs and types)
  809. ****************************************************************************/
  810. /* File Operations of this drivers */
  811. static const struct file_operations mdc800_device_ops =
  812. {
  813. .owner = THIS_MODULE,
  814. .read = mdc800_device_read,
  815. .write = mdc800_device_write,
  816. .open = mdc800_device_open,
  817. .release = mdc800_device_release,
  818. .llseek = noop_llseek,
  819. };
  820. static const struct usb_device_id mdc800_table[] = {
  821. { USB_DEVICE(MDC800_VENDOR_ID, MDC800_PRODUCT_ID) },
  822. { } /* Terminating entry */
  823. };
  824. MODULE_DEVICE_TABLE (usb, mdc800_table);
  825. /*
  826. * USB Driver Struct for this device
  827. */
  828. static struct usb_driver mdc800_usb_driver =
  829. {
  830. .name = "mdc800",
  831. .probe = mdc800_usb_probe,
  832. .disconnect = mdc800_usb_disconnect,
  833. .id_table = mdc800_table
  834. };
  835. /************************************************************************
  836. Init and Cleanup this driver (Main Functions)
  837. *************************************************************************/
  838. static int __init usb_mdc800_init (void)
  839. {
  840. int retval = -ENODEV;
  841. /* Allocate Memory */
  842. mdc800=kzalloc (sizeof (struct mdc800_data), GFP_KERNEL);
  843. if (!mdc800)
  844. goto cleanup_on_fail;
  845. mdc800->dev = NULL;
  846. mdc800->state=NOT_CONNECTED;
  847. mutex_init (&mdc800->io_lock);
  848. init_waitqueue_head (&mdc800->irq_wait);
  849. init_waitqueue_head (&mdc800->write_wait);
  850. init_waitqueue_head (&mdc800->download_wait);
  851. mdc800->irq_woken = 0;
  852. mdc800->downloaded = 0;
  853. mdc800->written = 0;
  854. mdc800->irq_urb_buffer=kmalloc (8, GFP_KERNEL);
  855. if (!mdc800->irq_urb_buffer)
  856. goto cleanup_on_fail;
  857. mdc800->write_urb_buffer=kmalloc (8, GFP_KERNEL);
  858. if (!mdc800->write_urb_buffer)
  859. goto cleanup_on_fail;
  860. mdc800->download_urb_buffer=kmalloc (64, GFP_KERNEL);
  861. if (!mdc800->download_urb_buffer)
  862. goto cleanup_on_fail;
  863. mdc800->irq_urb=usb_alloc_urb (0, GFP_KERNEL);
  864. if (!mdc800->irq_urb)
  865. goto cleanup_on_fail;
  866. mdc800->download_urb=usb_alloc_urb (0, GFP_KERNEL);
  867. if (!mdc800->download_urb)
  868. goto cleanup_on_fail;
  869. mdc800->write_urb=usb_alloc_urb (0, GFP_KERNEL);
  870. if (!mdc800->write_urb)
  871. goto cleanup_on_fail;
  872. /* Register the driver */
  873. retval = usb_register(&mdc800_usb_driver);
  874. if (retval)
  875. goto cleanup_on_fail;
  876. printk(KERN_INFO KBUILD_MODNAME ": " DRIVER_VERSION ":"
  877. DRIVER_DESC "\n");
  878. return 0;
  879. /* Clean driver up, when something fails */
  880. cleanup_on_fail:
  881. if (mdc800 != NULL)
  882. {
  883. printk(KERN_ERR "mdc800: can't alloc memory!\n");
  884. kfree(mdc800->download_urb_buffer);
  885. kfree(mdc800->write_urb_buffer);
  886. kfree(mdc800->irq_urb_buffer);
  887. usb_free_urb(mdc800->write_urb);
  888. usb_free_urb(mdc800->download_urb);
  889. usb_free_urb(mdc800->irq_urb);
  890. kfree (mdc800);
  891. }
  892. mdc800 = NULL;
  893. return retval;
  894. }
  895. static void __exit usb_mdc800_cleanup (void)
  896. {
  897. usb_deregister (&mdc800_usb_driver);
  898. usb_free_urb (mdc800->irq_urb);
  899. usb_free_urb (mdc800->download_urb);
  900. usb_free_urb (mdc800->write_urb);
  901. kfree (mdc800->irq_urb_buffer);
  902. kfree (mdc800->write_urb_buffer);
  903. kfree (mdc800->download_urb_buffer);
  904. kfree (mdc800);
  905. mdc800 = NULL;
  906. }
  907. module_init (usb_mdc800_init);
  908. module_exit (usb_mdc800_cleanup);
  909. MODULE_AUTHOR( DRIVER_AUTHOR );
  910. MODULE_DESCRIPTION( DRIVER_DESC );
  911. MODULE_LICENSE("GPL");