AT45DBXXX_import.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. // Файл импорта внешних функций
  2. // v 1.1 от 20/07/15
  3. // Автор: Сычев А.
  4. // Драйвер управления AD45DB321D использует интерфейсные функции SSP и системного таймера
  5. // Для нормальной работы требуется, чтобы в системе присутствовали следующие функции:
  6. // * функция обмена по SSP/SPI (двустороннйий обмен)
  7. // * функции управления ChipSelect
  8. // * функции задержки на микросекунды и миллисекунды
  9. // * функция получения отметки времени (системный таймер) в миллисекундах
  10. // * функция отключения/включения питания чипа
  11. // * функции работы с памятью
  12. #ifdef AT45DBXXX_HAL_H
  13. #ifndef AT45DBXXX_IMPORT_H
  14. #define AT45DBXXX_IMPORT_H
  15. // переопределите макросы на ваши функции (имя внутреннего макроса менять не надо)
  16. #include "stm32l1xx_hal.h" // HAL_GetTick()
  17. #include "core/main.h" // HAL_Wait_us()
  18. #include "drivers/spi/spi.h" // SPIHandle
  19. #include "drivers/flash/config/at45db321d_conf.h"
  20. #include "drivers/extmem_flash/extmem_flash.h" // ExtMemPinsHandle
  21. #include <string.h>
  22. // Import SPI handle
  23. #define pSPIHandle (&SPIHandle)
  24. // Import External Memory Pins Handle
  25. #define pExtMemPinsHandle (&ExtMemPinsHandle)
  26. // внутренний макрос | ваша функция
  27. #define __imp_sys_delayus(_1us) HAL_Wait_us(_1us) // ожидание, в микросекундах
  28. #define __imp_sys_delayms(_1ms) HAL_Delay(_1ms) // ожидание, в миллисекундах
  29. #define __imp_sys_gettimer() HAL_GetTick() // возвращает количество тиков системы с момента старта системы
  30. #define __imp_ssp_cshi() pSPIHandle->SetNSS() // #CS в состояние 1 (HiLogicLevel)
  31. #define __imp_ssp_cslo() pSPIHandle->ClrNSS() // #CS в состояние 0 (LoLogicLevel)
  32. #define __imp_ssp_ro(r,c) pSPIHandle->Receive(r,c) // функция обмена по SSP / SPI
  33. #define __imp_ssp_wo(w,c) pSPIHandle->Transmit(w,c) // функция обмена по SSP / SPI
  34. // ------------------------------------------------------------------------------------
  35. // __imp_ssp_io - функция двунаправленного обмена - не требуется, если есть __imp_ssp_ro и __imp_ssp_wo
  36. //#define __imp_ssp_io(w,r,c) pSPIHandle->TransmitReceive(w,r,c) // функция обмена по SSP / SPI
  37. // ------------------------------------------------------------------------------------
  38. // __imp_ssp_io_rev - функция передачи данных по SPI в обратном порядке байт.
  39. // Создается для ускорения процесса обмена. Если такая функция отсутсвует в вашей системе,
  40. // не объявляйте макрос __imp_ssp_io_rev. При этом драйвер будет сам инвертировать порядок
  41. // байт в ущерб производительности.
  42. /*
  43. #define __imp_ssp_io_rev(w,r,c) ssp_ior(w,r,c) // функция обмена по SSP / SPI в обратном порядке байт
  44. */
  45. #if AT45DB321D_POWER_MANAGEMENT
  46. // Опция AT45DB321D_POWER_MANAGEMENT
  47. #define __imp_flash_poweron() pExtMemPinsHandle->SetPinPowerOn()
  48. #define __imp_flash_poweroff() pExtMemPinsHandle->SetPinPowerOff()
  49. #endif
  50. #if AT45DB321D_RESET_MANAGEMENT
  51. // Опция AT45DB321D_RESET_MANAGEMENT
  52. #define __imp_flash_reset_assert() pExtMemPinsHandle->ResetPinAssert()
  53. #define __imp_flash_reset_release() pExtMemPinsHandle->ResetPinRelease()
  54. #endif
  55. #if AT45DB321D_HW_WR_PROTECT
  56. // Опция AT45DB321D_HW_WR_PROTECT
  57. #define __imp_flash_hwwrprotect_assert() pExtMemPinsHandle->HwWrProtPinAssert()
  58. #define __imp_flash_hwwrprotect_release() pExtMemPinsHandle->HwWrProtPinRelease()
  59. #endif
  60. // ------------------------------------------------------------------------------------
  61. // __imp_flash_powercycle - перезапуск чипа по питанию.
  62. // нужна если требуется аппаратное конфигурирование чипа на размер 512 байт (одноразовое перепрограммирование)
  63. // Эта функция требуется ТОЛЬКО ЕСЛИ:
  64. // * 1) запрещено управление питанием (AT45DB321D_POWER_MANAGEMENT = 0); и
  65. // * 2) запрещены сервисные байты (включен AT45DB321D_PRM512); и
  66. // * 2) отключен режим эмуляции страниц 512 байт (отключен AT45DB321D_EMU512).
  67. // Если все эти условия выполняются, требуется такую функцию объявить и импортировать.
  68. // В остальных случаях она не требуется.
  69. // #define __imp_flash_powercycle() sys_flashpwrcycle() // отключение питания чипа
  70. // // Note: при остутствии возможности отключить питание чипа используйте
  71. // // данный вызов как callback-событие для того, чтобы пользователь сделал это.
  72. // ------------------------------------------------------------------------------------
  73. #define __imp_sys_memset(p,b,c) memset(p,b,c) // порт функции memset()
  74. #define __imp_sys_memzero(p,c) memset(p,0,c) // порт функции memset()
  75. #define __imp_sys_memcpy(d,s,c) memcpy(d,s,c) // порт функции memcpy()
  76. #define __imp_sys_memmove(d,s,c) memmove(d,s,c) // порт функции memmove()
  77. // ------------------------------------------------------------------------------------
  78. #define __imp_utl_mutex_lock() // блокировка доступа к устройству ч/з мютекс
  79. #define __imp_utl_mutex_unlock() // разблокировка доступа к устройству ч/з мютекс
  80. // Добавьте прототипы функций:
  81. /* функция системы */
  82. // void sys_delayus( unsigned int _1us );
  83. // void sys_delayms( unsigned int _1ms );
  84. // unsigned int sys_gettimer( void );
  85. /* функции работы с памятью */
  86. // void sys_memset(void*,int,unsigned int);
  87. // void sys_memcpy(void*,const void*,unsigned int);
  88. // void sys_memmove(void*,const void*,unsigned int);
  89. /* функции обмена по SSP */
  90. // void ssp_cshi();
  91. // void ssp_cslo();
  92. // void ssp_io(
  93. // __FLASH_BYTE* , // -- буфер на запись (может быть 0)
  94. // __FLASH_BYTE* , // -- буфер на чтение (может быть 0)
  95. // __FLASH_DWORD ) ; // -- количество байт
  96. //
  97. // void ssp_ior(
  98. // __FLASH_BYTE* , // -- буфер на запись (может быть 0)
  99. // __FLASH_BYTE* , // -- буфер на чтение (может быть 0)
  100. // __FLASH_DWORD ) ; // -- количество байт
  101. //
  102. #endif
  103. #endif