drv_spi.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-06-16 bigmagic first version
  9. */
  10. #ifndef __DRV_SPI_H__
  11. #define __DRV_SPI_H__
  12. #include "drv_gpio.h"
  13. #define SPI_REG_CS(BASE) HWREG32(BASE + 0x00)
  14. #define SPI_REG_FIFO(BASE) HWREG32(BASE + 0x04)
  15. #define SPI_REG_CLK(BASE) HWREG32(BASE + 0x08)
  16. #define SPI_REG_DLEN(BASE) HWREG32(BASE + 0x0C)
  17. #define SPI_REG_LTOH(BASE) HWREG32(BASE + 0x10)
  18. #define SPI_REG_DC(BASE) HWREG32(BASE + 0x14)
  19. /* CS Register */
  20. #define SPI_CS_LOSSI_LONG_32BIT (1 << 25)
  21. #define SPI_CS_LOSSI_DMA_MODE (1 << 24)
  22. #define SPI_CS_CSPOL2 (1 << 23)
  23. #define SPI_CS_CSPOL1 (1 << 22)
  24. #define SPI_CS_CSPOL0 (1 << 21)
  25. #define SPI_CS_RX_FIFO_FULL (1 << 20)
  26. #define SPI_CS_RX_FIFO_3_QUARTER (1 << 19)
  27. #define SPI_CS_TX_DATA (1 << 18)
  28. #define SPI_CS_RX_DATA (1 << 17)
  29. #define SPI_CS_DONE (1 << 16)
  30. #define SPI_CS_LOSSI_EN (1 << 13)
  31. #define SPI_CS_READ_EN (1 << 12)
  32. #define SPI_CS_AUTO_CS (1 << 11)
  33. #define SPI_CS_INTR_RXR (1 << 10)
  34. #define SPI_CS_INTR_DONE (1 << 9)
  35. #define SPI_CS_DMA_EN (1 << 8)
  36. #define SPI_CS_TA (1 << 7)
  37. #define SPI_CS_CSPOL_HIGH (1 << 6)
  38. #define SPI_CS_CLEAR_RX (2 << 4)
  39. #define SPI_CS_CLEAR_TX (1 << 4)
  40. #define SPI_CS_CPOL (1 << 3)
  41. #define SPI_CS_CPHA (1 << 2)
  42. #define SPI_CS_CHIP_SELECT_2 (2 << 0)
  43. #define SPI_CS_CHIP_SELECT_1 (1 << 0)
  44. #define SPI_CS_CHIP_SELECT_0 (0 << 0)
  45. struct raspi_spi_hw_config
  46. {
  47. rt_uint8_t spi_num;
  48. GPIO_PIN sclk_pin;
  49. GPIO_FUNC sclk_mode;
  50. GPIO_PIN mosi_pin;
  51. GPIO_FUNC mosi_mode;
  52. GPIO_PIN miso_pin;
  53. GPIO_FUNC miso_mode;
  54. #if defined (BSP_USING_SPI0_DEVICE0) || defined (BSP_USING_SPI1_DEVICE0)
  55. GPIO_PIN ce0_pin;
  56. GPIO_FUNC ce0_mode;
  57. #endif
  58. #if defined (BSP_USING_SPI0_DEVICE1) || defined (BSP_USING_SPI1_DEVICE1)
  59. GPIO_PIN ce1_pin;
  60. GPIO_FUNC ce1_mode;
  61. #endif
  62. #if defined (BSP_USING_SPI1_DEVICE2)
  63. GPIO_PIN ce2_pin;
  64. GPIO_FUNC ce2_mode;
  65. #endif
  66. rt_ubase_t hw_base;
  67. };
  68. struct raspi_spi_device
  69. {
  70. char *device_name;
  71. struct rt_spi_bus *spi_bus;
  72. struct rt_spi_device *spi_device;
  73. struct raspi_spi_hw_config *spi_hw_config;
  74. GPIO_PIN cs_pin;
  75. };
  76. int rt_hw_spi_init(void);
  77. #endif