hwio.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Low-level I/O functions.
  4. *
  5. * Copyright (c) 2017-2020, Silicon Laboratories, Inc.
  6. * Copyright (c) 2010, ST-Ericsson
  7. */
  8. #ifndef WFX_HWIO_H
  9. #define WFX_HWIO_H
  10. #include <linux/types.h>
  11. struct wfx_dev;
  12. /* Caution: in the functions below, 'buf' will used with a DMA. So, it must be kmalloc'd (do not use
  13. * stack allocated buffers). In doubt, enable CONFIG_DEBUG_SG to detect badly located buffer.
  14. */
  15. int wfx_data_read(struct wfx_dev *wdev, void *buf, size_t buf_len);
  16. int wfx_data_write(struct wfx_dev *wdev, const void *buf, size_t buf_len);
  17. int wfx_sram_buf_read(struct wfx_dev *wdev, u32 addr, void *buf, size_t len);
  18. int wfx_sram_buf_write(struct wfx_dev *wdev, u32 addr, const void *buf, size_t len);
  19. int wfx_ahb_buf_read(struct wfx_dev *wdev, u32 addr, void *buf, size_t len);
  20. int wfx_ahb_buf_write(struct wfx_dev *wdev, u32 addr, const void *buf, size_t len);
  21. int wfx_sram_reg_read(struct wfx_dev *wdev, u32 addr, u32 *val);
  22. int wfx_sram_reg_write(struct wfx_dev *wdev, u32 addr, u32 val);
  23. int wfx_ahb_reg_read(struct wfx_dev *wdev, u32 addr, u32 *val);
  24. int wfx_ahb_reg_write(struct wfx_dev *wdev, u32 addr, u32 val);
  25. #define CFG_ERR_SPI_FRAME 0x00000001 /* only with SPI */
  26. #define CFG_ERR_SDIO_BUF_MISMATCH 0x00000001 /* only with SDIO */
  27. #define CFG_ERR_BUF_UNDERRUN 0x00000002
  28. #define CFG_ERR_DATA_IN_TOO_LARGE 0x00000004
  29. #define CFG_ERR_HOST_NO_OUT_QUEUE 0x00000008
  30. #define CFG_ERR_BUF_OVERRUN 0x00000010
  31. #define CFG_ERR_DATA_OUT_TOO_LARGE 0x00000020
  32. #define CFG_ERR_HOST_NO_IN_QUEUE 0x00000040
  33. #define CFG_ERR_HOST_CRC_MISS 0x00000080 /* only with SDIO */
  34. #define CFG_SPI_IGNORE_CS 0x00000080 /* only with SPI */
  35. #define CFG_BYTE_ORDER_MASK 0x00000300 /* only writable with SPI */
  36. #define CFG_BYTE_ORDER_BADC 0x00000000
  37. #define CFG_BYTE_ORDER_DCBA 0x00000100
  38. #define CFG_BYTE_ORDER_ABCD 0x00000200 /* SDIO always use this value */
  39. #define CFG_DIRECT_ACCESS_MODE 0x00000400
  40. #define CFG_PREFETCH_AHB 0x00000800
  41. #define CFG_DISABLE_CPU_CLK 0x00001000
  42. #define CFG_PREFETCH_SRAM 0x00002000
  43. #define CFG_CPU_RESET 0x00004000
  44. #define CFG_SDIO_DISABLE_IRQ 0x00008000 /* only with SDIO */
  45. #define CFG_IRQ_ENABLE_DATA 0x00010000
  46. #define CFG_IRQ_ENABLE_WRDY 0x00020000
  47. #define CFG_CLK_RISE_EDGE 0x00040000
  48. #define CFG_SDIO_DISABLE_CRC_CHK 0x00080000 /* only with SDIO */
  49. #define CFG_RESERVED 0x00F00000
  50. #define CFG_DEVICE_ID_MAJOR 0x07000000
  51. #define CFG_DEVICE_ID_RESERVED 0x78000000
  52. #define CFG_DEVICE_ID_TYPE 0x80000000
  53. int wfx_config_reg_read(struct wfx_dev *wdev, u32 *val);
  54. int wfx_config_reg_write(struct wfx_dev *wdev, u32 val);
  55. int wfx_config_reg_write_bits(struct wfx_dev *wdev, u32 mask, u32 val);
  56. #define CTRL_NEXT_LEN_MASK 0x00000FFF
  57. #define CTRL_WLAN_WAKEUP 0x00001000
  58. #define CTRL_WLAN_READY 0x00002000
  59. int wfx_control_reg_read(struct wfx_dev *wdev, u32 *val);
  60. int wfx_control_reg_write(struct wfx_dev *wdev, u32 val);
  61. int wfx_control_reg_write_bits(struct wfx_dev *wdev, u32 mask, u32 val);
  62. #define IGPR_RW 0x80000000
  63. #define IGPR_INDEX 0x7F000000
  64. #define IGPR_VALUE 0x00FFFFFF
  65. int wfx_igpr_reg_read(struct wfx_dev *wdev, int index, u32 *val);
  66. int wfx_igpr_reg_write(struct wfx_dev *wdev, int index, u32 val);
  67. #endif