Библиотека файловой системы последовательного доступа AT45DB161
Краткое описание AT45DB161
AT45DB161 является Flash памятью
с последовательным интерфейсом, и идеально подходит для
широкого спектра цифровых голосовых приложений, приложений визуализации, и
приложений хранения программного кода и данных. 17 301 504 бит памяти данной
ИС организованы в 4096 страниц по 528 байт каждая. Кроме
памяти общего назначения ИС, также, имеет два SRAM буфера данных по 528 байт.
Буферы обеспечивают возможность приема данных в режиме
перепрограммирования страницы основной памяти, или считывание,
или запись непрерывных потоков данных. Режим эмуляции EEPROM
(с побитным или побайтным изменением) прост в применении, благодаря встроенной,
трехступенчатой системе команд Read - Modify - Write. В отличие от стандартных
типов Flash памяти, обращение к которым, происходит
произвольным образом в режиме многочисленных адресных строк и при помощи
параллельного интерфейса, память типа DataFlash использует
последовательный интерфейс для обращения к своим данным в
режиме последовательного доступа. ИС поддерживает SPI - режимы типа 0 и 3.
Простой последовательный интерфейс облегчает разводку
платы, увеличивает отказоустойчивость системы,
минимизирует коммутационные шумы, а также, уменьшает размер
корпуса и число необходимых активных выводов. ИС оптимизирована для
использования в широком круге коммерческих и индустриальных приложений, для
которых существенную роль играют высокая плотность
размещения, малое число выводов, низкое напряжение питания, и низкое
энергопотребление. ИС функционирует с тактовыми частотами,
вплоть до 20 МГц при типовом потребляемом токе в режиме
активного чтения 4 мА.
Для обеспечения удобства внутрисистемного перепрограммирования, ИС AT45DB161 не
требует высоких входных напряжений в режиме программирования.
ИС питается от однополярного источника с напряжением от 2.5 В
до 3.6 В, или от 2.7 В до 3.6 В, как в режиме программирования, так и в режиме
чтения. Выборка ИС AT45DB161 производится по входу CS
(активный низкий), а доступ к ИС обеспечивается посредством 3-х проводного
последовательного интерфейса, состоящего из сигнала
последовательного входа (SI), последовательного выхода (SO) и последовательного
тактового сигнала (SCK).
Все циклы программирования имеют встроенный контроль временных характеристик, а
для проведения программирования предварительный цикл стирания не требуется. При
поставке ИС от Atmel, старшая значащая страница массива памяти может не быть
чистой. Другими словами, содержимое последней страницы
может быть заполнено содержимым, отличным от FFH.
Отличительные особенности:
Библиотека последовательного доступа для AT45DB161.
При разработке микроконтроллерных устройств с внешней памятью типа AT45DBxx приходится сталкиваться с ситуацией когда блоки данных (файлы) записываются редко, обычно при обновлении ПО устройства, а иногда вообще только один раз - при изготовлении устройства. В таких случаях нет необходимости в использовании файловой системы дискового типа таких как FAT. Проще и эффективнее использовать файловую систему последовательного доступа, наподобие ленточной. При этом файлы вместо названия имеют только индексы - последовательный номер файла на устройстве. Данные файла при записи записываются в конец свободного адресного пространства устройства, в этом случае при закрытии файла ему назначается уникальный номер (индекс). Доступ к файлу при чтении происходит по его индексу. На устройстве может находится не более 62 записанных файлов. Рассматриваемая библиотека организует такую файловую систему для микросхемы AT45DB161, порт CodeVision. Листинги библиотеки подробно прокомментированны. Так, что при желании не потребуется больших усилий для портирования на другой компилятор и для внесения изменений с целью применения для другого типа микросхем серии AT45DBxx.
Структура файловой системы.
Первая страница (528 байт) отводится для хранения системной информации о файловой структуре устройства.
Первые 11 байт это строка - *AT45DB161#.
Строка является идентификационной записью, которая показывает,
что устройство отформатированно и готово к работе.
В 12-ом байте содержиться число, показывающее количество файлов на устройстве.
Далее идут 8-ми байтовые структуры, выполняющие
функцию описателей файлов:
В первых 2-х байтах адрес 1-ой страницы файла.
Следующие 2 байта содержат количество страниц в файле.
Последние
4 байта структуры - размер файла в байтах.
Функции библиотеки.
1. Инициализация файловой системы AT45DB161.
unsigned char InitialFlash();
Возвращает значения:
0 - инициализированно.
1 - ус-во отсутствует в системе.
2 - ус-во не форматированно.
3. Закрыть файл.
void CloseFile();
4. Открыть файл.
unsigned char OpenFile(char mode, unsigned char nfile);
Параметр mode:
r - Открыть файл в режиме чтения.
w - Открыть файл в режиме записи.
Параметр nfile:
В режиме чтения указывает индекс (номер) файла.
В режиме записи не имеет значения, следует указать 0.
Возвращает значения:
0 - ошибка при открытии файла.
N(1...62) - индекс успешно открытого файла..
После успешного открытия файла будут доступны глобальные переменные статуса файла:
// Переменные описывающие состояние рабочего
файла.
// Состояние файла.
/*
0 - Файл закрыт
1 - Файл открыт в режиме записи
2 - Файл открыт в режиме чтения
*/
unsigned char at45_file_mode = 0;
// Счетчик страниц при записи.
unsigned int at45_cpwrite = 0;
// Номер текущей страницы.
unsigned int at45_npage = 0;
// Индекс открытого файла.
unsigned char at45_currfile = 0;
// Размер открытого файла/счетчик байт открытого файла при записи.
unsigned long at45_cbfile = 0;
// Счетчик байт открытого файла при чтении.
unsigned long at45_countb = 0;
// К-во страниц в файле.
unsigned int at45_kpage = 0;
// Счетчик байт записанных/считанных в/из буфер.
unsigned int at45_buffer_counter = 0;
5. Считать из файла count байт в буфер dest.
unsigned int ReadFile(char * dest, unsigned int count);
dest - Указатель на буфер чтения.
count - Количество байт для считывания.
Возвращает значения:
N - количество считанных байт.
6. Записать в файл count байт из буфера source.
unsigned int WriteFile(char * source, unsigned int count);
source - Указатель на буфер записи.
count - Количество байт для записи.
7. Читать файл побайтно.
unsigned char ReadByte(unsigned char * flag);
Схема подключения.
Несмотря на то, что напряжение питания микросхемы AT45DB161 указано от 2.7 до 3.6 В., микросхема нормально работает при напряжении 5 В. В реальном проекте используется питание 3 В.
Внимание! При 6 В. быстро выгорает, по крайней мере так было у меня.
Поэтому подключил AT45DB161 на свою макетницу с микроконтроллером ATMega162 с 5-ти вольтовым питанием. Все тесты прошли исключительно хорошо, от самых простых до более сложных - воспроизведение звука с использованием ШИМ-модуляции. Микросхема AT45DB161 использовалась в корпусе SOIC в котором отсутствует отдельный вывод BYSE, что видно на схеме и было учтено при написании библиотеки.
Применение библиотеки.
Для того, чтобы использовать библиотеку в проект ПО следует включить файлы - at45db161.c и at45db161.h.
В файле at45db161.h следует скорректировать 2 настройки:
Первая:
В строке 7 указать бит порта вывода который Вы будете
использовать в качестве сигнала CS микросхемы
AT45DB161.
// DataFlash chip
select
// Здесь следует определить пин порта мк. для CS AT45DB161!!!
#define DF_CHIP_SELECT PORTC.0
// Здесь следует определить
настройки SPI!!!
// Включить SPI.
// SPI initialization
// SPI Type: Master
// SPI Clock Rate: 4000.000 kHz
// SPI Clock Phase: Cycle Start
// SPI Clock Polarity: High
// SPI Data Order: MSB First
#define SPI_ON SPCR=0x5c
Простой пример применения библиотеки:
unsigned char temp;
temp = InitialFlash();
if(temp) {
if(temp == 1) {
// И зацикливаемся - ус-во не обнаружено в системе.
while(1);
}
// ИНАЧЕ УСТРОЙСТВО ОБНАРУЖЕНО НО НЕ ФОРМАТИРОВАННО!
// ФОРМАТИРУЕМ FLASH.
FormatFlash();
}
//Записали первый файл:
OpenFile('w', 0);
memset(Buff, 0, 128);
for(ic = 0;ic<256;ic++) Buff[ic] = ic;
WriteFile(Buff, 256);
WriteFile(Buff, 256);
WriteFile(Buff, 256);
WriteFile(Buff, 256);
WriteFile(Buff, 256);
CloseFile();
//Записали второй файл:
OpenFile('w', 0);
memset(Buff, 2, 128);
//for(ic = 0;ic<256;ic++) Buff[ic] = ic;
WriteFile(Buff, 128);
WriteFile(Buff, 55);
CloseFile();
//Записали третий файл:
OpenFile('w', 0);
memset(Buff, 3, 128);
//for(ic = 0;ic<256;ic++) Buff[ic] = ic;
WriteFile(Buff, 128);
WriteFile(Buff, 23);
CloseFile();
//Считали третий файл:
if(OpenFile('r', 3)) {
do {
memset(Buff, 0, 528);
ic = ReadFile(Buff, 64);
} while(ic);
CloseFile();
}
//Считали первый файл:
if(OpenFile('r', 1)) {
memset(Buff, 0, 528);
do {
ic = ReadFile(Buff, 64);
} while(ic);
CloseFile();
}
Замечание - при считывании последнего блока данных в
файле в буфер заносится действительное оставшиеся количество байтов, их
количество указывается в возвращаемом функцией значении.
Ссылка на скачивание библиотеки: LIB_AT45.rar
Пример: проект для микроконтроллера ATMega162 - загрузка файлов в AT45DB161 - AT45LOAD.rar
Пример: проект для ПК (Builder C++ 6). - Программа которая умеет открывать файлы мультимедиа типа wav, идентифицировать их, на соответствии требованиям закачки (частота дискретизации, к-во каналов и т.д.) и пересылать их в микроконтроллерную систему - LoadAT45DB.rar.