|
ATxMEGA и EERPOM |
|
|
|
Oct 13 2011, 11:47
|
Частый гость
 
Группа: Участник
Сообщений: 105
Регистрация: 9-09-11
Пользователь №: 67 080

|
Пытаюсь написать подпрограммы записи и чтения внутренней EEPROM на асме Нифига не получается, не могу понять почему. Вот что сказано в даташите: 30.11.5.1. Загрузка страничного буфера EEPROM
Данная команда предназначена для записи одного байта в страничный буфер EEPROM.
Запишите в регистр NVM CMD команду загрузки страничного буфера EEPROM Запишите в регистр NVM ADDR0 адрес, по которому выполняется запись. Запишите в регистр NVM DATA0 данные, подлежащие записи. Это приведет к запуску исполнения команды.
30.11.5.4. Запись страницы EEPROM
Данная команда предназначена для записи загруженного страничного буфера EEPROM в одну страницу EEPROM. Запись выполняется только тех ячеек, которые предварительно были загружены в страничный буфер EEPROM.
Запишите в регистр NVM CMD команду записи страницы EEPROM. Запишите в регистр NVM ADDR адрес подлежащей записи страницы EEPROM. Установите бит CMDEX в регистре NVM CTRLA с использованием привязанной ко времени последовательности CCP.
Флаг BUSY регистра NVM STATUS равен единице вплоть до завершения операции.И вот что я нагородил : Код .macro stsi ; Запись в порт IO ldi r16,@1 sts @0,r16 .endm
stsi NVM_CMD,0x33 stsi NVM_ADDR0,0 stsi NVM_DATA0,0b10101010
stsi NVM_ADDR0,0 stsi NVM_CMD,0x34 stsi CPU_CCP,0xD8 stsi NVM_CTRLA,1 после этого устанавливается флаг NVMBUSY, когда он снимается жму ALT+6 смотрю на EEPROM и DATA MAPPED_EEPROM, там везде FF. Че не так делаю ?
|
|
|
|
|
Oct 13 2011, 13:05
|
Участник

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272

|
Делаю так : (предварительно включаю отображение EEPROM на пространство памяти) Код void x_EEPROM_Write_Byte(unsigned char * adr, unsigned char data) { asm volatile("cli\n\t"::); while ((NVM.STATUS & NVM_NVMBUSY_bm) == NVM_NVMBUSY_bm); *(unsigned char*)((unsigned int)adr+EEPROM_START_ADR)=data; NVM.CMD=0x35; // NVM.ADDR0=adr; NVM.ADDR1=((unsigned int)adr)>>8; NVM.ADDR2=0; CPU_CCP=0xd8; // NVM.CTRLA=0x01; // CMDEX while ((NVM.STATUS & NVM_NVMBUSY_bm) == NVM_NVMBUSY_bm); NVM.CMD=0x00; asm volatile("sei\n\t"::); }
Сообщение отредактировал Юрий_СВ - Oct 13 2011, 13:07
|
|
|
|
|
Oct 13 2011, 13:22
|
Частый гость
 
Группа: Участник
Сообщений: 105
Регистрация: 9-09-11
Пользователь №: 67 080

|
Цитата(Юрий_СВ @ Oct 13 2011, 17:05)  Делаю так : (предварительно включаю отображение EEPROM на пространство памяти) Это как ? где ? в АВР студио 5 ? посмотрел ваш код (не пробовал). Вы используете команду 0х35 -стирание и запись страницы, а что он записывает ? регистры DATA ? или буфер, который хз где.
|
|
|
|
|
Oct 13 2011, 13:44
|
Участник

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272

|
Цитата(Navovvol @ Oct 13 2011, 16:22)  Это как ? где ? в АВР студио 5 ? NVM.CTRLB=0x0b; (влияет только на способ чтения/записи данных - через регистр DATA или через запись по адресу памяти) Цитата(Navovvol @ Oct 13 2011, 16:22)  Вы используете команду 0х35 -стирание и запись страницы, а что он записывает ? регистры DATA ? или буфер, который хз где. Он записывает только ту часть буфера, которая была изменена. Цитата EEPROM page buffer locations that are loaded will get tagged by the NVM Controller. During a page write or page erase, only target locations will be written or erased. Locations that are not target, will not be written or erased, and the corresponding EEPROM location will remain unchanged. This means that also before an EEPROM page erase, data must be loaded to the selected page buffer location to tag them. If the data in the page buffer is not going to be written afterword, the actual values in the buffer does matter.
Сообщение отредактировал Юрий_СВ - Oct 13 2011, 13:48
|
|
|
|
|
Oct 13 2011, 14:13
|
Участник

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272

|
Цитата(_Артём_ @ Oct 13 2011, 16:56)  Проблема может ещё быть в ревизии кристала: у первых версий были проблемы с записью в EEPROM и FLASH - запись организовывалась с использованием прерываний и sleep-а. Не знаю, в Errata ничего подобного нет. Моя функция на хМега32А работает. Единственное умоминание про EEPROM в Errata : (у моей функции не должно с этим возникнуть трудностей) Цитата 15. EEPROM page buffer always written when NVM DATA0 is written If the EEPROM is memory mapped, writing to NVM DATA0 will corrupt data in the EEPROM page buffer. Problem fix/Workaround Before writing to NVM DATA0, for example when doing software CRC or flash page buffer write, check if EEPROM page buffer active loading flag (EELOAD) is set. Do not write NVM DATA0 when EELOAD is set.
|
|
|
|
|
Oct 13 2011, 15:22
|
Участник

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272

|
Цитата(_Артём_ @ Oct 13 2011, 18:11)  Из datasheet rev. B XMega128/192/...A3: Ага, спасибо. В историю не заглядывал...
|
|
|
|
|
Oct 13 2011, 20:17
|
Участник

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272

|
Цитата(Navovvol @ Oct 13 2011, 19:53)  Я запускал только в симуляторе. Всё это дело пишется для AtXMEGA128A1. Буфер EEPROM - это "DATA MAPPED_EEPROM" ? По идее, "DATA MAPPED_EEPROM" - это EEPROM режиме отображения на пространство памяти.
|
|
|
|
|
Oct 14 2011, 05:44
|
Частый гость
 
Группа: Участник
Сообщений: 105
Регистрация: 9-09-11
Пользователь №: 67 080

|
Цитата(_Артём_ @ Oct 13 2011, 17:56)  Проблема может ещё быть в ревизии кристала: у первых версий были проблемы с записью в EEPROM и FLASH - запись организовывалась с использованием прерываний и sleep-а. В даташите, errata на две ревизии rev.H и rev.G На контроллере, который я использую rev.A, а где для него errata? всё облазил, нигде не нашел.
|
|
|
|
|
Oct 14 2011, 11:55
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(Navovvol @ Oct 14 2011, 08:44)  В даташите, errata на две ревизии rev.H и rev.G На контроллере, который я использую rev.A, а где для него errata? всё облазил, нигде не нашел. Посмотрел datasheet. Действительно для A1 только равизии H и G. Вы уверенны, что правильно ревизию определили? Цитата А в симуляторе AVR Studio 5 для AtXmega вообще возможно посмотреть содержимое EEPROM ? или там всегда FF ? И нет в проекте файла .eep ,так должно быть ? На данный момент в симуляторе не удается ни прочитать, ни записать. Не пойму, что не так. В симуляторе EEPROM показывает. FF не всегда(значит незапрограммирована) Цитата На данный момент в симуляторе не удается ни прочитать, ни записать. Не пойму, что не так. В симуляторе всё работало. Проверял по соотв. AppN.
|
|
|
|
|
Oct 14 2011, 12:17
|
Частый гость
 
Группа: Участник
Сообщений: 105
Регистрация: 9-09-11
Пользователь №: 67 080

|
Цитата(_Артём_ @ Oct 14 2011, 15:55)  Посмотрел datasheet. Действительно для A1 только равизии H и G. Вы уверенны, что правильно ревизию определили? Olimex'овская плата, на ней так и написано rev.A Цитата В симуляторе всё работало. Проверял по соотв. AppN. AVR1315 ?
|
|
|
|
|
Oct 14 2011, 12:40
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(Navovvol @ Oct 14 2011, 15:17)  Olimex'овская плата, на ней так и написано rev.A Это типа как на заборе... Ревизия платы или Меги? Цитата(Navovvol @ Oct 14 2011, 15:17)  AVR1315 ? Да, оно самое.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|