chip.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2021 pureLiFi
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/errno.h>
  7. #include "chip.h"
  8. #include "mac.h"
  9. #include "usb.h"
  10. void plfxlc_chip_init(struct plfxlc_chip *chip,
  11. struct ieee80211_hw *hw,
  12. struct usb_interface *intf)
  13. {
  14. memset(chip, 0, sizeof(*chip));
  15. mutex_init(&chip->mutex);
  16. plfxlc_usb_init(&chip->usb, hw, intf);
  17. }
  18. void plfxlc_chip_release(struct plfxlc_chip *chip)
  19. {
  20. plfxlc_usb_release(&chip->usb);
  21. mutex_destroy(&chip->mutex);
  22. }
  23. int plfxlc_set_beacon_interval(struct plfxlc_chip *chip, u16 interval,
  24. u8 dtim_period, int type)
  25. {
  26. if (!interval ||
  27. (chip->beacon_set && chip->beacon_interval == interval))
  28. return 0;
  29. chip->beacon_interval = interval;
  30. chip->beacon_set = true;
  31. return plfxlc_usb_wreq(chip->usb.ez_usb,
  32. &chip->beacon_interval,
  33. sizeof(chip->beacon_interval),
  34. USB_REQ_BEACON_INTERVAL_WR);
  35. }
  36. int plfxlc_chip_init_hw(struct plfxlc_chip *chip)
  37. {
  38. unsigned char *addr = plfxlc_mac_get_perm_addr(plfxlc_chip_to_mac(chip));
  39. struct usb_device *udev = interface_to_usbdev(chip->usb.intf);
  40. pr_info("plfxlc chip %04x:%04x v%02x %pM %s\n",
  41. le16_to_cpu(udev->descriptor.idVendor),
  42. le16_to_cpu(udev->descriptor.idProduct),
  43. le16_to_cpu(udev->descriptor.bcdDevice),
  44. addr,
  45. plfxlc_speed(udev->speed));
  46. return plfxlc_set_beacon_interval(chip, 100, 0, 0);
  47. }
  48. int plfxlc_chip_switch_radio(struct plfxlc_chip *chip, u16 value)
  49. {
  50. int r;
  51. __le16 radio_on = cpu_to_le16(value);
  52. r = plfxlc_usb_wreq(chip->usb.ez_usb, &radio_on,
  53. sizeof(value), USB_REQ_POWER_WR);
  54. if (r)
  55. dev_err(plfxlc_chip_dev(chip), "POWER_WR failed (%d)\n", r);
  56. return r;
  57. }
  58. int plfxlc_chip_enable_rxtx(struct plfxlc_chip *chip)
  59. {
  60. plfxlc_usb_enable_tx(&chip->usb);
  61. return plfxlc_usb_enable_rx(&chip->usb);
  62. }
  63. void plfxlc_chip_disable_rxtx(struct plfxlc_chip *chip)
  64. {
  65. u8 value = 0;
  66. plfxlc_usb_wreq(chip->usb.ez_usb,
  67. &value, sizeof(value), USB_REQ_RXTX_WR);
  68. plfxlc_usb_disable_rx(&chip->usb);
  69. plfxlc_usb_disable_tx(&chip->usb);
  70. }
  71. int plfxlc_chip_set_rate(struct plfxlc_chip *chip, u8 rate)
  72. {
  73. int r;
  74. if (!chip)
  75. return -EINVAL;
  76. r = plfxlc_usb_wreq(chip->usb.ez_usb,
  77. &rate, sizeof(rate), USB_REQ_RATE_WR);
  78. if (r)
  79. dev_err(plfxlc_chip_dev(chip), "RATE_WR failed (%d)\n", r);
  80. return r;
  81. }