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/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. printk(KERN_ERR "ezusb: %s - no physical device present, "
  26. "failing.\n", __func__);
  27. return -ENODEV;
  28. }
  29. transfer_buffer = kmemdup(data, length, GFP_KERNEL);
  30. if (!transfer_buffer) {
  31. dev_err(&dev->dev, "%s - kmalloc(%d) failed.\n",
  32. __func__, length);
  33. return -ENOMEM;
  34. }
  35. result = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), request,
  36. USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
  37. 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_device *dev, unsigned char reset_bit)
  43. {
  44. int response = ezusb_writememory(dev, CPUCS_REG, &reset_bit, 1, WRITE_INT_RAM);
  45. if (response < 0)
  46. dev_err(&dev->dev, "%s-%d failed: %d\n",
  47. __func__, reset_bit, response);
  48. return response;
  49. }
  50. EXPORT_SYMBOL_GPL(ezusb_set_reset);