| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- // Файл с прототипами низкоуровневых комманд для AT45DB321D.
- // v 1.12 от 21/07/15
- // Автор: Сычев А.
- #ifdef AT45DB321D_H
- #if defined(AT45DB321D_LOWLEVEL) || defined(AT45DB321D_APILEVEL)
- // №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№
- // №№№№№№№№№№№№№№№№№№№№№№ НИЗКОУРОВНЕВЫЕ НЕБЕЗОПАСНЫЕ ФУНКЦИИ №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№
- // №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№
- //
- // подробнее см. AT45DBXXX_LL.c
- //
- // __flash_hal__statusread - чтение регистра статуса
- void __flash_hal__statusread( __flash_status_t * pcReadRegister // буфер для чтения статус-регистра
- );
- // __flash_hal__page_read - чтение одной страницы
- void __flash_hal__page_read( __FLASH_WORD wPageNum, // номер страницы для чтения
- __FLASH_WORD wPageOfs, // адрес начала чтения в странице
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__array_read - последовательное чтение (массив)
- // * недоступна в режиме программной эмуляции 512-байтных страниц (AT45DB321D_EMU512)
- void __flash_hal__array_read ( __FLASH_WORD wPageNum, // номер начальной страницы для чтения
- __FLASH_WORD wPageOfs, // адрес начала чтения в начальной странице
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__use512page - сконфигурировать чип на работу со стандартной страницей 512 байт
- // # НАВСЕГДА изменяет размер страницы!
- // * недоступна в режиме программной эмуляции 512-байтных страниц (AT45DB321D_EMU512)
- void __flash_hal__use512page();
- // __flash_hal__buffer1_read - чтение буфера 1 (up to 66 MHz)
- void __flash_hal__buffer1_read( __FLASH_WORD wBuffOfs, // адрес начала чтения в буфере
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__buffer2_read - чтение буфера 2 (up to 66 MHz)
- void __flash_hal__buffer2_read( __FLASH_WORD wBuffOfs, // адрес начала чтения в буфере
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__buffer1_read_slow - чтение буфера 1 (up to 33 MHz)
- void __flash_hal__buffer1_read_slow( __FLASH_WORD wBuffOfs, // адрес начала чтения в буфере
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__buffer2_read_slow - чтение буфера 2 (up to 33 MHz)
- void __flash_hal__buffer2_read_slow( __FLASH_WORD wBuffOfs, // адрес начала чтения в буфере
- __FLASH_BYTE * pDataRead, // указатель на буфер-приемник данных
- __FLASH_WORD wCntToRead ); // количество данных на чтение
- // __flash_hal__buffer1_write - запись буфера 1
- void __flash_hal__buffer1_write( __FLASH_WORD wBuffOfs, // адрес начала записи в буфере-приемнике (чип)
- __FLASH_BYTE * pDataWrite, // указатель на буфер-источник данных
- __FLASH_WORD wCntToWrite ); // количество данных на запись
- // __flash_hal__buffer2_write - запись буфера 2
- void __flash_hal__buffer2_write( __FLASH_WORD wBuffOfs, // адрес начала записи в буфере-приемнике (чип)
- __FLASH_BYTE * pDataWrite, // указатель на буфер-источник данных
- __FLASH_WORD wCntToWrite ); // количество данных на запись
- // __flash_hal__buffer1_program - программирование буфера 1 в страницу со стиранием
- void __flash_hal__buffer1_program( __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__buffer2_program - программирование буфера 2 в страницу со стиранием
- void __flash_hal__buffer2_program( __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__buffer1_program_wo_erase - программирование буфера 1 в страницу без стирания
- void __flash_hal__buffer1_program_wo_erase( __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__buffer2_program_wo_erase - программирование буфера 2 в страницу без стирания
- void __flash_hal__buffer2_program_wo_erase( __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__page_erase - стирание страницы
- void __flash_hal__page_erase( __FLASH_WORD wPageNum // номер стираемой страницы
- );
- // __flash_hal__block_erase - стирание блока
- void __flash_hal__block_erase( __FLASH_WORD wBlockNum // номер стираемого блока
- );
- // __flash_hal__sector0_erase - стирание секторов 0a и 0b
- void __flash_hal__sector0_erase( __FLASH_WORD wSubSector // номер подсектора 0 или 1
- );
- // __flash_hal__sector_erase - стирание секторов с номером 1 и выше
- void __flash_hal__sector_erase( __FLASH_WORD wSector // номер сектора 1-63
- );
- // __flash_hal__page_write_via_buffer1 - запись страницы через буфер 1
- void __flash_hal__page_write_via_buffer1( __FLASH_WORD wBuffOfs, // адрес начала записи в буфере-приемнике (чип)
- __FLASH_BYTE * pDataWrite, // указатель на буфер-источник данных
- __FLASH_WORD wCntToWrite, // количество данных на запись
- __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__page_write_via_buffer2 - запись страницы через буфер 2
- void __flash_hal__page_write_via_buffer2( __FLASH_WORD wBuffOfs, // адрес начала записи в буфере-приемнике (чип)
- __FLASH_BYTE * pDataWrite, // указатель на буфер-источник данных
- __FLASH_WORD wCntToWrite, // количество данных на запись
- __FLASH_WORD wPageNum // номер страницы, куда произвести программирование
- );
- // __flash_hal__pagetobuffer1 - загрузка содержимого страницы в буфер 1
- void __flash_hal__pagetobuffer1( __FLASH_WORD wPageNum // номер страницы для загрузки
- );
- // __flash_hal__pagetobuffer2 - загрузка содержимого страницы в буфер 2
- void __flash_hal__pagetobuffer2( __FLASH_WORD wPageNum // номер страницы для загрузки
- );
- // __flash_hal__pagetobuffer1 - сравнение содержимого страницы с буфером 1
- void __flash_hal__buffer1_compare( __FLASH_WORD wPageNum // номер страницы для сравнения
- );
- // __flash_hal__pagetobuffer2 - сравнение содержимого страницы с буфером 2
- void __flash_hal__buffer2_compare( __FLASH_WORD wPageNum // номер страницы для сравнения
- );
- // __flash_hal__autopagerewrite - обновление страницы через буфер 1
- void __flash_hal__autopagerewrite1( __FLASH_WORD wPageNum // номер обновляемой страницы
- );
- // __flash_hal__autopagerewrite - обновление страницы через буфер 2
- void __flash_hal__autopagerewrite2( __FLASH_WORD wPageNum // номер обновляемой страницы
- );
- // __flash_hal__sleepmode - переход в режим пониженного энергопотребления
- // # переводит устройство в режим, когда все команды, кроме __flash_hal__wakeup игнорируются
- void __flash_hal__sleepmode();
- // __flash_hal__wakeup - выход из режима пониженного энергопотребления
- // # выводит устройство из режима, когда все команды, кроме __flash_hal__wakeup игнорируются
- void __flash_hal__wakeup();
- // __flash_hal__manufactureridread - чтение идентификатора производителя
- // * возвращаемое значение - первые 4 байта структуры __flash_id_t
- __FLASH_DWORD __flash_hal__manufactureridread( __flash_id_t * pManufacturerID // необязательный параметр-буфер для приема расширенной информации
- );
- // __flash_hal__writeprotect_enable - включить программную защиту от записи/стирания
- void __flash_hal__writeprotect_enable();
- // __flash_hal__writeprotect_disable - выключить программную защиту от записи/стирания
- void __flash_hal__writeprotect_disable();
- // __flash_hal__protectregister_erase - стирает регистр защиты, помечая ВСЕ сектора как защищенные
- // # если включена программная защита от записи, все операции стирания/записи для всех секторов будут заблокированы до ее отключения
- void __flash_hal__protectregister_erase();
- // __flash_hal__protectregister_write - записывает регистр защиты
- void __flash_hal__protectregister_write( __flash_protectionregister_t * contents // содержимое регистра защиты для записи
- );
- // __flash_hal__protectregister_read - прочитывает регистр защиты
- void __flash_hal__protectregister_read( __flash_protectionregister_t * contents // буфер-приемник содержимого регистра защиты
- );
- // __flash_hal__sectorlockdown - постоянная блокировка сектора от записи/стирания
- void __flash_hal__sectorlockdown( __FLASH_DWORD address // адрес внутри блокируемого сектора
- );
- // __flash_hal__lockdownregister_read - прочитывает регистр блокировки
- void __flash_hal__lockdownregister_read( __flash_lockdownregister_t * contents // буфер-приемник содержимого регистра блокировки
- );
- // __flash_hal__securityregister_write - записывает регистр безопасности
- // * записывает только ПОЛЬЗОВАТЕЛЬСКУЮ часть
- // # РЕГИСТР БЕЗОПАСНОСТИ МОЖЕТ БЫТЬ ЗАПИСАН ТОЛЬКО ОДИН РАЗ!
- void __flash_hal__securityregister_write( __flash_usersecurityregister_t * contents // содержимое регистра безопасности (часть, доступная для записи пользователю)
- );
- // __flash_hal__securityregister_read - прочитывает регистр безопасности
- void __flash_hal__securityregister_read( __flash_securityregister_t * contents // буфер-приемник содержимого регистра блокировки
- );
- // __flash_hal__securityregister_validate - прочитывает регистр безопасности и выполняет
- // проверку осмысленности прочитанного заводского идентификатора.
- bool __flash_hal__securityregister_validate( __flash_securityregister_t * contents // буфер-приемник содержимого регистра блокировки
- );
- // __flash_hal__getprotectstate - получение состояния общего бита защиты
- flash_err_t __flash_hal__getprotectstate( );
-
- // __flash_hal__getreadyfast - проверка занятости без ожидания
- flash_err_t __flash_hal__getreadyfast( );
- // __flash_hal__getcompareresult - проверка результата сравнения (бит COMP / bMismatch)
- flash_err_t __flash_hal__getcompareresult( );
-
- // __flash_hal__initialize - Низкоуровневая инициализация флешпамяти );
- // # возвращает 0, если все успешно, или код ошибки
- flash_err_t __flash_hal__initialize();
- // __flash_hal__detect - Низкоуровневое определение наличия чипа (доступности)
- // Используется во время первичной инициализации в flash_initialize().
- flash_err_t __flash_hal__detect();
- // служебные функции доступа к памяти драйвера
- //
- __flash_protectionregister_t * __flash_internal_getbuffer_protect();
- __FLASH_BYTE * __flash_internal_getbuffer_page();
- // служебная функция для проверки готовности чипа
- int __flash_smart_waitms( __FLASH_WORD wTimems );
-
-
- #if AT45DB321D_POWER_MANAGEMENT > 0
- // __flash_hal__power_on - реализует управление питанием микросхемы памяти (подает питание)
- void __flash_hal__power_on();
-
- // __flash_hal__power_off - реализует управление питанием микросхемы памяти (снимает питание)
- void __flash_hal__power_off();
- // __flash_hal__power_pulse - реализует управление питанием микросхемы - формирует импульс перезагрузки
- void __flash_hal__power_pulse( __FLASH_WORD nCooldownTime_ms, __FLASH_WORD nStartupTime_ms );
- #endif
- #if AT45DB321D_RESET_MANAGEMENT > 0
- // __flash_hal__reset_assert - реализует управление сигналом сброса микросхемы памяти (устанавливает сигнал сброса)
- void __flash_hal__reset_assert();
-
- // __flash_hal__reset_release - реализует управление сигналом сброса микросхемы памяти (снимает сигнал сброса)
- void __flash_hal__reset_release();
- // __flash_hal__reset_pulse - реализует управление сигналом сброса микросхемы памяти (подает законченный импульс сброса)
- void __flash_hal__reset_pulse();
- #endif
- // __flash_hal__finalize_prepare - Низкоуровневая функция для подготовки флешпамяти к деинициализации драйвера
- flash_err_t __flash_hal__finalize_prepare();
-
- #else
- #error FLASH HAL: вы подключили заголовочный файл для низкоуровневых операций.
- #error FLASH HAL: используйте файл AT45DB321_API.h
- #endif
- #else
- #error FLASH HAL: подключите сначала заголовочный файл AT45DB321.h
- #endif
-
|