ezusb.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * EZ-USB specific functions used by some of the USB to Serial drivers.
  3. *
  4. * Copyright (C) 1999 - 2002 Greg Kroah-Hartman (greg@kroah.com)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License version
  8. * 2 as published by the Free Software Foundation.
  9. */
  10. #include <linux/kernel.h>
  11. #include <linux/errno.h>
  12. #include <linux/init.h>
  13. #include <linux/slab.h>
  14. #include <linux/tty.h>
  15. #include <linux/module.h>
  16. #include <linux/usb.h>
  17. #include <linux/usb/serial.h>
  18. /* EZ-USB Control and Status Register. Bit 0 controls 8051 reset */
  19. #define CPUCS_REG 0x7F92
  20. int ezusb_writememory(struct usb_serial *serial, int address,
  21. unsigned char *data, int length, __u8 request)
  22. {
  23. int result;
  24. unsigned char *transfer_buffer;
  25. if (!serial->dev) {
  26. printk(KERN_ERR "ezusb: %s - no physical device present, "
  27. "failing.\n", __func__);
  28. return -ENODEV;
  29. }
  30. transfer_buffer = kmemdup(data, length, GFP_KERNEL);
  31. if (!transfer_buffer) {
  32. dev_err(&serial->dev->dev, "%s - kmalloc(%d) failed.\n",
  33. __func__, length);
  34. return -ENOMEM;
  35. }
  36. result = usb_control_msg(serial->dev, usb_sndctrlpipe(serial->dev, 0),
  37. request, 0x40, address, 0, transfer_buffer, length, 3000);
  38. kfree(transfer_buffer);
  39. return result;
  40. }
  41. EXPORT_SYMBOL_GPL(ezusb_writememory);
  42. int ezusb_set_reset(struct usb_serial *serial, unsigned char reset_bit)
  43. {
  44. int response;
  45. response = ezusb_writememory(serial, CPUCS_REG, &reset_bit, 1, 0xa0);
  46. if (response < 0)
  47. dev_err(&serial->dev->dev, "%s- %d failed\n",
  48. __func__, reset_bit);
  49. return response;
  50. }
  51. EXPORT_SYMBOL_GPL(ezusb_set_reset);