drv_io_config.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #include <rtthread.h>
  2. #include <fpioa.h>
  3. #include <drv_io_config.h>
  4. #include <sysctl.h>
  5. #define HS_GPIO(n) (FUNC_GPIOHS0 + n)
  6. static struct io_config
  7. {
  8. int io_num;
  9. fpioa_function_t func;
  10. } io_config[] =
  11. {
  12. #ifdef BSP_USING_LCD
  13. {BSP_LCD_CS_PIN, FUNC_SPI0_SS0}, /* LCD CS PIN */
  14. {BSP_LCD_WR_PIN, FUNC_SPI0_SCLK}, /* LCD WR PIN */
  15. {BSP_LCD_DC_PIN, HS_GPIO(LCD_DC_PIN)}, /* LCD DC PIN */
  16. #endif
  17. #ifdef BSP_USING_CAMERA
  18. {BSP_CAMERA_SCCB_SDA_PIN, FUNC_SCCB_SDA},
  19. {BSP_CAMERA_SCCB_SCLK_PIN, FUNC_SCCB_SCLK},
  20. {BSP_CAMERA_CMOS_RST_PIN, FUNC_CMOS_RST},
  21. {BSP_CAMERA_CMOS_VSYNC_PIN, FUNC_CMOS_VSYNC},
  22. {BSP_CAMERA_CMOS_PWDN_PIN, FUNC_CMOS_PWDN},
  23. {BSP_CAMERA_CMOS_XCLK_PIN, FUNC_CMOS_XCLK},
  24. {BSP_CAMERA_CMOS_PCLK_PIN, FUNC_CMOS_PCLK},
  25. {BSP_CAMERA_CMOS_PCLK_PIN, FUNC_CMOS_HREF},
  26. #endif
  27. #ifdef BSP_USING_SPI1
  28. {BSP_SPI1_CLK_PIN, FUNC_SPI1_SCLK},
  29. {BSP_SPI1_D0_PIN, FUNC_SPI1_D0},
  30. {BSP_SPI1_D1_PIN, FUNC_SPI1_D1},
  31. #ifdef BSP_USING_SPI1_AS_QSPI
  32. {BSP_SPI1_D2_PIN, FUNC_SPI1_D2},
  33. {BSP_SPI1_D3_PIN, FUNC_SPI1_D3},
  34. #endif
  35. #ifdef BSP_SPI1_USING_SS0
  36. {BSP_SPI1_SS0_PIN, HS_GPIO(SPI1_CS0_PIN)},
  37. #endif
  38. #ifdef BSP_SPI1_USING_SS1
  39. {BSP_SPI1_SS1_PIN, HS_GPIO(SPI1_CS1_PIN)},
  40. #endif
  41. #ifdef BSP_SPI1_USING_SS2
  42. {BSP_SPI1_SS2_PIN, HS_GPIO(SPI1_CS2_PIN)},
  43. #endif
  44. #ifdef BSP_SPI1_USING_SS3
  45. {BSP_SPI1_SS3_PIN, HS_GPIO(SPI1_CS3_PIN)},
  46. #endif
  47. #endif
  48. };
  49. int io_config_init(void)
  50. {
  51. int count = sizeof(io_config) / sizeof(io_config[0]);
  52. int i;
  53. sysctl_set_power_mode(SYSCTL_POWER_BANK0, SYSCTL_POWER_V18);
  54. sysctl_set_power_mode(SYSCTL_POWER_BANK1, SYSCTL_POWER_V18);
  55. sysctl_set_power_mode(SYSCTL_POWER_BANK2, SYSCTL_POWER_V18);
  56. for(i = 0; i < count; i++)
  57. {
  58. fpioa_set_function(io_config[i].io_num, io_config[i].func);
  59. }
  60. #if defined(BSP_USING_CAMERA) || defined(BSP_USING_LCD)
  61. sysctl_set_spi0_dvp_data(1);
  62. #endif
  63. }
  64. INIT_BOARD_EXPORT(io_config_init);