Страница 14 из 399
Добавлено: Ср мар 25, 2009 08:00:25
BerZerK-ku
Igor писал(а):Люди, подскажите пожалста. Программку пишу и захотел сделать сохранение данные в ЕЕПРОМ. Программа данные туда успешно записывает, но вот считывает почему-то все нули. Уже пробую просто вывести в порт, на котором весят светодиоды то что прочтено из ЕЕПРОМ. Результат аналогичен

Подскажите в каком месте криво сделано
А вы уверены что у вас что-то записывает? Что за биты EEPE и ЕЕMPE? что за контроллер, что за среда программирования? Вот пример записи в ЕЕПРОМ из ДШ.
Код: Выделить всё
EEPROM_write:
; Wait for completion of previous write
sbic EECR,EEWE
rjmp EEPROM_write
; Set up address (r18:r17) in address register
out EEARH, r18
out EEARL, r17
; Write data (r16) to data register
out EEDR,r16
; Write logical one to EEMWE
sbi EECR,EEMWE
; Start eeprom write by setting EEWE
sbi EECR,EEWE
ret
[/code]
Добавлено: Ср мар 25, 2009 12:25:34
Igor
Да, что записывает это 100%. Потому что при считывании памяти программатором там есть данные. Контроллер Attiny2313. Среда - AVR Studio4.16. Бит EEPE разрешает программирование ЕЕПРОМ, EEMPE разрешает работу предыдущего бита.
Вот пример записи в ЕЕПРОМ из ДШ.
Этот код я и использовал при написании программы. В протеусе работает замечательно, но вот в МК нивкакую

Есть еще идеи?
Добавлено: Чт мар 26, 2009 12:45:06
BerZerK-ku
Идей нет

В AVR Studio читает, а вот писать отказывается категорически и хз с чем это связано.
Добавлено: Чт мар 26, 2009 13:36:55
Igor
Вот и я уже не знаю в чем дело. Думал микросхема испорчена, купил нову - таже песня. Попробую еще на меге8. Если будет тоже самое, то я в ауте.....
Добавлено: Пт мар 27, 2009 13:00:02
BerZerK-ku
Igor писал(а):Люди, подскажите пожалста. Программку пишу и захотел сделать сохранение данные в ЕЕПРОМ. Программа данные туда успешно записывает, но вот считывает почему-то все нули. Уже пробую просто вывести в порт, на котором весят светодиоды то что прочтено из ЕЕПРОМ. Результат аналогичен

Подскажите в каком месте криво сделано
Есть еще 1 вариант, в вашем "tn2313def.inc" стоит неправильное значение RamEnd и потому программа после каждого rcall EEPROM_write начинается с 0. Попробуйте заменить RamEnd на 0хDF.
Проверьте fuse-биты, может у вас включен WD и постоянно перезагружает контроллер? Может что-то не так с reset?
Чудес не бывает. Программа рабочая

Добавлено: Пт мар 27, 2009 15:18:23
Alexeus
Igor писал(а):Люди, подскажите пожалста. Программку пишу и захотел сделать сохранение данные в ЕЕПРОМ. Программа данные туда успешно записывает, но вот считывает почему-то все нули.
Попробуй адрес записи поменять, возми что нть из последних- где то читал, что начальные адреса еепром могут глючить и не писаться...
Что за регистр
может
Добавлено: Пн мар 30, 2009 12:08:18
Igor
Всё, разобрался:) Почему-то ЕЕПРОМ читает всякую ерунду если включен делитель частоты тактовой на 8. Убрал, всё стало очень замечательно

Добавлено: Вт апр 07, 2009 02:09:27
Negor
нужно красиво написать на асме но ника не уловлю "нить красоты". Наверно потому что 2 ночи на дворе
Алгоритм такой
Код: Выделить всё
Если бит 0 в регистре установлен, то
Если бит 1 в регистре установлен, то
rjmp end
иначе
sbr r16, (1<<7)
rjmp l2_end
иначе
если бит 1 в регистре установлен, то
cbr r16, (1<<7)
rjmp l2_end
иначе
rjmp end
в условиях работа с регистром r0. сам пытаюсь построить конструкцию из sbrc, sbrs но получается дофига меток.
Добавлено: Вт апр 07, 2009 08:38:25
GP1
Попробуйте сначало на бумаге нарисовать алгоритм переходов, к сожалению без кучи меток не обойтись - это все-таки ASM.
1) со своей стороны я бы порекомендовал как-нибудь обзывать биты, очень удобно если надо к примеру поменять ногу на процике, да и наглядней чем просто цифра.
2) ИМХО не используйте R0 для хранения переменных, он используется для многих операций типа косвенного чтения, работы с EEPROM и т.п., очень легко допустить ошибку.
Добавлено: Вт апр 07, 2009 09:08:20
Negor
ну по поводу битов и r0 - это я так, для примера. А по поводу бумаги - я уже её стока замарал, что коту хватит на целый год... Эх... ну раз куча меток значит куча меток

Добавлено: Вт апр 07, 2009 09:45:09
GP1
А кому сейчас легко
Бывает на бумаге все красиво, начинаешь писать..., и приходится опять рисовать исправлять, менять BRLO на BRSH, BRPL на BRMI и т.д. и так по кругу пока не получится "красиво"

Добавлено: Вт апр 07, 2009 14:07:30
YurkaM
Negor писал(а):нужно красиво написать на асме.......но получается дофига меток.
Вот накорябал вариант..
Код: Выделить всё
bst r0,0
brts _M1
sbrs r0,1
rjmp _l2_end
_BitChange: bld r16,7
rjmp _l2_end
_M1: sbrs r0,1
rjmp _BitChange
rjmp _end
Вроде алгоритму соответствует.
Регистровые пары
Добавлено: Ср май 06, 2009 19:17:49
edm2007
Доброго времени суток. Недавно начал изучать асм, добрел до массивов и вот не могу понять. Загружаю адрес массива в регистровую пару Z и далее командой lpm гружу данные в регистр R0. Это касаемо пары Z. А если, например, используется пара X?
Re: Регистровые пары
Добавлено: Ср май 06, 2009 20:27:04
smac
edm2007 писал(а):Доброго времени суток. Недавно начал изучать асм, добрел до массивов и вот не могу понять. Загружаю адрес массива в регистровую пару Z и далее командой lpm гружу данные в регистр R0. Это касаемо пары Z. А если, например, используется пара X?
Из памяти программ можно считать данные только по указателю Z, правда есть варианты
Код: Выделить всё
lpm rd, Z; загрузить в rd данные по указателю Z rd - от r0 до r31
lpm rd, Z+ ;загрузить в rd данные по указателю Z с постинкрементом Z rd - от r0 до r29
Если r30 или r31 в варианте с постинкрементом использовать, то результат неопределен, ибо это и есть пара Z.
Re: Регистровые пары
Добавлено: Ср май 06, 2009 20:38:50
edm2007
smac писал(а):Из памяти программ можно считать данные только по указателю Z, правда есть варианты
Код: Выделить всё
lpm rd, Z; загрузить в rd данные по указателю Z
lpm rd, Z+ ;загрузить в rd данные по указателю Z с постинкрементом Z
lpm rd, -Z ;загрузить в rd данные по указателю Z с предекрементом Z
Да, спасибо. Нашел я такую информацию.
Re: Регистровые пары
Добавлено: Ср май 06, 2009 21:05:13
edm2007
smac писал(а):
Код: Выделить всё
lpm rd, Z; загрузить в rd данные по указателю Z rd - от r0 до r31
lpm rd, Z+ ;загрузить в rd данные по указателю Z с постинкрементом Z rd - от r0 до r29
А с LD разница есть?
Добавлено: Чт май 07, 2009 08:37:32
GP1
Вся разница в том что команды LD-ST работают с памятью данных и могут адресоваться через регистровые пары X,Y,Z
в том числе и с регистрам R0-R31 и служебными регистрами
Массивы
Добавлено: Чт май 07, 2009 19:57:13
edm2007
Я снова к вам и снова с той же темой. Не могу я разобраться с массивом, а дальше идти не хочу. Я понимаю что
Код: Выделить всё
ldi ZH, high (Array*2)
ldi ZL, low (Array*2)
загружает в старшую и младшую часть пары соответственно старшую и младшую часть адреса.
Но как LPM загружает данные из пары Z в R0 понять не могу. Адрес-то 16-ти битный. Вероятнее всего я глупость спрашиваю, но разобраться хочу.
Добавлено: Чт май 07, 2009 22:48:22
GP1
Что именно Вам не понятно?
Загрузка high:low характерна для старших кристалов семейства с большим объемом памяти, а для =128= и =256= серии еще один регистр нужен.
множитель (хххх*2) нужен из-за того что память программ имеет словную организацию
зы: врядли вы найдете описание того как конкретно по указателю Z данные из памяти попадают в R0. если вам так интересен механизм данного процесса ищите описание старых ЭВМ у которых ЦПУ собрано на логических элементах. (в свое время изучал СМ1480 он же PDP-11 там в мануале все процессы были расписаны по тактам

)
Добавлено: Чт май 07, 2009 22:57:24
edm2007
GP1 писал(а):Что именно Вам не понятно?
Загрузка high:low характерна для старших кристалов семейства с большим объемом памяти, а для =128= и =256= серии еще один регистр нужен.
множитель (хххх*2) нужен из-за того что память программ имеет словную организацию
Про множитель понятно, и про загрузку в регистровую пару тоже. Адрес ПЗУ 16-ти битный, так? И все это в пару грузится нормально (два регистра). А вот как этот адрес в R0 загружается я не понимаю.