| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- // Файл импорта внешних функций
- // v 1.1 от 20/07/15
- // Автор: Сычев А.
- // Драйвер управления AD45DB321D использует интерфейсные функции SSP и системного таймера
- // Для нормальной работы требуется, чтобы в системе присутствовали следующие функции:
- // * функция обмена по SSP/SPI (двустороннйий обмен)
- // * функции управления ChipSelect
- // * функции задержки на микросекунды и миллисекунды
- // * функция получения отметки времени (системный таймер) в миллисекундах
- // * функция отключения/включения питания чипа
- // * функции работы с памятью
- #ifdef AT45DBXXX_HAL_H
- #ifndef AT45DBXXX_IMPORT_H
- #define AT45DBXXX_IMPORT_H
- // переопределите макросы на ваши функции (имя внутреннего макроса менять не надо)
- #include "stm32l1xx_hal.h" // HAL_GetTick()
- #include "core/main.h" // HAL_Wait_us()
- #include "drivers/spi/spi.h" // SPIHandle
- #include "drivers/flash/config/at45db321d_conf.h"
- #include "drivers/extmem_flash/extmem_flash.h" // ExtMemPinsHandle
- #include <string.h>
- // Import SPI handle
- #define pSPIHandle (&SPIHandle)
- // Import External Memory Pins Handle
- #define pExtMemPinsHandle (&ExtMemPinsHandle)
-
- // внутренний макрос | ваша функция
- #define __imp_sys_delayus(_1us) HAL_Wait_us(_1us) // ожидание, в микросекундах
- #define __imp_sys_delayms(_1ms) HAL_Delay(_1ms) // ожидание, в миллисекундах
- #define __imp_sys_gettimer() HAL_GetTick() // возвращает количество тиков системы с момента старта системы
- #define __imp_ssp_cshi() pSPIHandle->SetNSS() // #CS в состояние 1 (HiLogicLevel)
- #define __imp_ssp_cslo() pSPIHandle->ClrNSS() // #CS в состояние 0 (LoLogicLevel)
- #define __imp_ssp_ro(r,c) pSPIHandle->Receive(r,c) // функция обмена по SSP / SPI
- #define __imp_ssp_wo(w,c) pSPIHandle->Transmit(w,c) // функция обмена по SSP / SPI
- // ------------------------------------------------------------------------------------
- // __imp_ssp_io - функция двунаправленного обмена - не требуется, если есть __imp_ssp_ro и __imp_ssp_wo
- //#define __imp_ssp_io(w,r,c) pSPIHandle->TransmitReceive(w,r,c) // функция обмена по SSP / SPI
- // ------------------------------------------------------------------------------------
- // __imp_ssp_io_rev - функция передачи данных по SPI в обратном порядке байт.
- // Создается для ускорения процесса обмена. Если такая функция отсутсвует в вашей системе,
- // не объявляйте макрос __imp_ssp_io_rev. При этом драйвер будет сам инвертировать порядок
- // байт в ущерб производительности.
- /*
- #define __imp_ssp_io_rev(w,r,c) ssp_ior(w,r,c) // функция обмена по SSP / SPI в обратном порядке байт
- */
- #if AT45DB321D_POWER_MANAGEMENT
- // Опция AT45DB321D_POWER_MANAGEMENT
- #define __imp_flash_poweron() pExtMemPinsHandle->SetPinPowerOn()
- #define __imp_flash_poweroff() pExtMemPinsHandle->SetPinPowerOff()
- #endif
-
- #if AT45DB321D_RESET_MANAGEMENT
- // Опция AT45DB321D_RESET_MANAGEMENT
- #define __imp_flash_reset_assert() pExtMemPinsHandle->ResetPinAssert()
- #define __imp_flash_reset_release() pExtMemPinsHandle->ResetPinRelease()
- #endif
- #if AT45DB321D_HW_WR_PROTECT
- // Опция AT45DB321D_HW_WR_PROTECT
- #define __imp_flash_hwwrprotect_assert() pExtMemPinsHandle->HwWrProtPinAssert()
- #define __imp_flash_hwwrprotect_release() pExtMemPinsHandle->HwWrProtPinRelease()
- #endif
- // ------------------------------------------------------------------------------------
- // __imp_flash_powercycle - перезапуск чипа по питанию.
- // нужна если требуется аппаратное конфигурирование чипа на размер 512 байт (одноразовое перепрограммирование)
- // Эта функция требуется ТОЛЬКО ЕСЛИ:
- // * 1) запрещено управление питанием (AT45DB321D_POWER_MANAGEMENT = 0); и
- // * 2) запрещены сервисные байты (включен AT45DB321D_PRM512); и
- // * 2) отключен режим эмуляции страниц 512 байт (отключен AT45DB321D_EMU512).
- // Если все эти условия выполняются, требуется такую функцию объявить и импортировать.
- // В остальных случаях она не требуется.
- // #define __imp_flash_powercycle() sys_flashpwrcycle() // отключение питания чипа
- // // Note: при остутствии возможности отключить питание чипа используйте
- // // данный вызов как callback-событие для того, чтобы пользователь сделал это.
- // ------------------------------------------------------------------------------------
- #define __imp_sys_memset(p,b,c) memset(p,b,c) // порт функции memset()
- #define __imp_sys_memzero(p,c) memset(p,0,c) // порт функции memset()
- #define __imp_sys_memcpy(d,s,c) memcpy(d,s,c) // порт функции memcpy()
- #define __imp_sys_memmove(d,s,c) memmove(d,s,c) // порт функции memmove()
- // ------------------------------------------------------------------------------------
- #define __imp_utl_mutex_lock() // блокировка доступа к устройству ч/з мютекс
- #define __imp_utl_mutex_unlock() // разблокировка доступа к устройству ч/з мютекс
-
- // Добавьте прототипы функций:
- /* функция системы */
- // void sys_delayus( unsigned int _1us );
- // void sys_delayms( unsigned int _1ms );
- // unsigned int sys_gettimer( void );
- /* функции работы с памятью */
- // void sys_memset(void*,int,unsigned int);
- // void sys_memcpy(void*,const void*,unsigned int);
- // void sys_memmove(void*,const void*,unsigned int);
-
- /* функции обмена по SSP */
- // void ssp_cshi();
- // void ssp_cslo();
- // void ssp_io(
- // __FLASH_BYTE* , // -- буфер на запись (может быть 0)
- // __FLASH_BYTE* , // -- буфер на чтение (может быть 0)
- // __FLASH_DWORD ) ; // -- количество байт
- //
- // void ssp_ior(
- // __FLASH_BYTE* , // -- буфер на запись (может быть 0)
- // __FLASH_BYTE* , // -- буфер на чтение (может быть 0)
- // __FLASH_DWORD ) ; // -- количество байт
- //
- #endif
- #endif
|