ezusb.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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/init.h>
  12. #include <linux/slab.h>
  13. #include <linux/module.h>
  14. #include <linux/usb.h>
  15. /* EZ-USB Control and Status Register. Bit 0 controls 8051 reset */
  16. #define CPUCS_REG 0x7F92
  17. /* Command for writing to internal memory */
  18. #define WRITE_INT_RAM 0xA0
  19. int ezusb_writememory(struct usb_device *dev, int address,
  20. unsigned char *data, int length, __u8 request)
  21. {
  22. int result;
  23. unsigned char *transfer_buffer;
  24. if (!dev)
  25. return -ENODEV;
  26. transfer_buffer = kmemdup(data, length, GFP_KERNEL);
  27. if (!transfer_buffer) {
  28. dev_err(&dev->dev, "%s - kmalloc(%d) failed.\n",
  29. __func__, length);
  30. return -ENOMEM;
  31. }
  32. result = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), request,
  33. USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  34. address, 0, transfer_buffer, length, 3000);
  35. kfree(transfer_buffer);
  36. return result;
  37. }
  38. EXPORT_SYMBOL_GPL(ezusb_writememory);
  39. int ezusb_set_reset(struct usb_device *dev, unsigned char reset_bit)
  40. {
  41. int response = ezusb_writememory(dev, CPUCS_REG, &reset_bit, 1, WRITE_INT_RAM);
  42. if (response < 0)
  43. dev_err(&dev->dev, "%s-%d failed: %d\n",
  44. __func__, reset_bit, response);
  45. return response;
  46. }
  47. EXPORT_SYMBOL_GPL(ezusb_set_reset);