drv_ebi.c 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /**************************************************************************//**
  2. *
  3. * @copyright (C) 2020 Nuvoton Technology Corp. All rights reserved.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0
  6. *
  7. * Change Logs:
  8. * Date Author Notes
  9. * 2020-12-12 Wayne First version
  10. *
  11. ******************************************************************************/
  12. #include <drv_ebi.h>
  13. #include <drv_sys.h>
  14. #if defined(BSP_USING_EBI)
  15. /* Private variables ------------------------------------------------------------*/
  16. static uint8_t nu_ebi_bank_mask = 0;
  17. /* Public functions -------------------------------------------------------------*/
  18. rt_err_t nu_ebi_init(uint32_t u32Bank, uint32_t u32DataWidth, uint32_t u32TimingClass, uint32_t u32BusMode, uint32_t u32CSActiveLevel)
  19. {
  20. if (u32Bank > MAX_BANK)
  21. return -(RT_ERROR);
  22. /* Check this bank is not used */
  23. if ((1 << u32Bank) & nu_ebi_bank_mask)
  24. return -(RT_ERROR);
  25. if (!nu_ebi_bank_mask)
  26. {
  27. nu_sys_ipclk_enable(EBICKEN);
  28. nu_sys_ip_reset(EBIRST);
  29. }
  30. /* Initialize EBI */
  31. EBI_Open(u32Bank, u32DataWidth, u32TimingClass, u32BusMode, u32CSActiveLevel);
  32. nu_ebi_bank_mask |= (1 << u32Bank);
  33. return RT_EOK;
  34. }
  35. #endif //BSP_USING_EBI