Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: МК не выполняет команды...
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > MSP430
d7d1cd
Привет всем! Ребята, подскажите как быть. Весь измучался уже...

У меня есть устройство на MSP430F149 и прошивка от этого МК. Устройство по оптопорту принимает данные и отправляет ответ. Мне необходимо поставить счетчик принятых байт. Так как исходника у меня нет, то используя прошивку и дизассемблер я сделал ассемблерную вставку кода в незанятое программой место МК. Адрес вектора сброса USART0 (по нему происходит "общение" с прибором) я изменил на адрес начала моей вставки. Сама вставка выглядит так:

Код
ADD #1, &FE30        ;Увеличиваем счетчик принятых байт

BR #B91E        ;Переходим к истинной процедуре обработки прерывания


Однако, после заливки такой модифицированной прошивки, устройство вообще перестало отвечать на запросы. Пробовал после запросов прочитать адрес FE30 - его значение так и осталось неизменным. Если адрес вектора сброса установить так, чтобы он указывал сразу на вторую строку вставки, то все работает как и до изменения прошивки.


Подскажите, почему не выполняется первая строка? Что я не так делаю?
rezident
Адрес 0xFE30 находится во Flash. Его содержимое одной командой изменить нельзя. Ибо Flash это ЭППЗУ. Измените адрес Flash на адрес ячейки в ОЗУ.
rx3apf
Цитата(d7d1cd @ Jul 10 2012, 21:13) *
Пробовал после запросов прочитать адрес FE30 - его значение так и осталось неизменным. Если адрес вектора сброса установить так, чтобы он указывал сразу на вторую строку вставки, то все работает как и до изменения прошивки.
Подскажите, почему не выполняется первая строка? Что я не так делаю?


Может я чего не понимаю, но FE30 - это же область flash-памяти, таким способом она никак не может меняться. Правда, это не объясняет, почему нет реакции на запросы, попытка записи не должна никак влиять на работу процессора. Попробуйте инкрементировать какой-нибудь свободный регистр (если есть) или укажите адрес в свободной области RAM.
d7d1cd
Цитата(rezident @ Jul 10 2012, 21:33) *
Адрес 0xFE30 находится во Flash. Его содержимое одной командой изменить нельзя. Ибо Flash это ЭППЗУ. Измените адрес Flash на адрес ячейки в ОЗУ.



Спасибо за разъяснения. Вы говорите, что " Его содержимое одной командой изменить нельзя". А вообще можно как-то изменить содержимое по этому адресу (в частности)?



Цитата(rx3apf @ Jul 10 2012, 21:35) *
Может я чего не понимаю, но FE30 - это же область flash-памяти, таким способом она никак не может меняться. Правда, это не объясняет, почему нет реакции на запросы, попытка записи не должна никак влиять на работу процессора. Попробуйте инкрементировать какой-нибудь свободный регистр (если есть) или укажите адрес в свободной области RAM.

Пока меня больше всего и волнует то, что перестает работать стандартный обработчик прерывания... Завтра попробую инкрементировать слово в ОЗУ. Но я не знаю где там есть свободное место. Желательно бы как-то менять именно адрес FLASH. Или это недопустимо?
rx3apf
Цитата(d7d1cd @ Jul 10 2012, 21:58) *
Желательно бы как-то менять именно адрес FLASH. Или это недопустимо?

Механизм изменения flash совершенно иной. И к тому же ресурс перезаписей весьма ограничен. Уж два байта оперативки наверняка можно где-то выскрести (а как вариант, какие-нибудь неиспользуемые регистры периферии, но тут надо осторожно и не забывать про разрядность). А почему не работает обработчик при таком варианте - можно только гадать. можно проверить, будет ли он работать, если команду add заменить на парочку nop, например. Т.е. надо найти причину...
rezident
Цитата(d7d1cd @ Jul 10 2012, 22:58) *
Спасибо за разъяснения. Вы говорите, что " Его содержимое одной командой изменить нельзя". А вообще можно как-то изменить содержимое по этому адресу (в частности)?
Можно (читайте раздел Chapter 5. Flash Memory Controller в MSP430x1xx Family User's Guide), но не нужно - во-первых, число перезаписей ячейки Flash весьма ограничено, во-вторых, запись одной ячейки требует предварительного стирания всего сегмента Flash (512 байт) в котором она расположена, в-третьих, запись одной ячейки задерживает выполнение программы из Flash на время записи (около 10мс).
Цитата(d7d1cd @ Jul 10 2012, 22:58) *
Пока меня больше всего и волнует то, что перестает работать стандартный обработчик прерывания...
Ничего удивительного, срабатывает встроенная защита от несанкционированной записи Flash (access violation to the flash memory), которая вызывает немаскируемое прерывание и рестарт программы.
Цитата(d7d1cd @ Jul 10 2012, 22:58) *
Завтра попробую инкрементировать слово в ОЗУ. Но я не знаю где там есть свободное место.
Найдите в самом начале программы команду инициализации стека и измените (сдвиньте на одно слово) начальное значение указателя стека. В освободившуюся ячейку памяти ОЗУ (2 байта) будете писать свой счетчик.
Цитата(d7d1cd @ Jul 10 2012, 22:58) *
Желательно бы как-то менять именно адрес FLASH. Или это недопустимо?
См. выше.
d7d1cd
Спасибо всем за помощь! Пока буду пробовать писать в ОЗУ.
d7d1cd
Ребят, есть вопрос: возможно ли выполнить запись в информационную память без использования контроллера Flash памяти? Если возможно, то какой ресурс перезаписей у этой памяти?
И еще: допустимо ли осуществлять чтение слова по нечетному адресу? Допустим, я хочу хранить слово по адресу 0x0301.
d7d1cd
rezident, спасибо за помощь! Сдвинул вершину стека на слово назад и сделал счетчик в образовавшейся "пустоте". Все работает как и задумано! Но вопросы остались: возможно ли выполнить запись в информационную память без использования контроллера Flash памяти? Если возможно, то какой ресурс перезаписей у этой памяти?
И еще: допустимо ли осуществлять чтение слова по нечетному адресу? Допустим, я хочу хранить слово по адресу 0x0301.
rezident
Цитата(d7d1cd @ Jul 11 2012, 22:28) *
возможно ли выполнить запись в информационную память без использования контроллера Flash памяти?
Вы упорно не желаете самостоятельно изучать документацию? Ведь ссылку на User's Guide я вам как минимум уже три раза давал! Ну тогда я пожалуй и не буду потакать вашей лени.
Цитата(d7d1cd @ Jul 11 2012, 22:28) *
Если возможно, то какой ресурс перезаписей у этой памяти?
Datasheet MSP430F149 (rev.F), стр. 39, таблица Flash Memory, значение параметра Program/Erase endurance.
Цитата(d7d1cd @ Jul 11 2012, 22:28) *
И еще: допустимо ли осуществлять чтение слова по нечетному адресу?
16-и разрядного слова - нет. К нечетным адресам можно обращаться только побайтно. См. (даю ссылку в 4-й раз) MSP430x1xx Family User's Guide (Rev.F), стр. 16, первый параграф главы 1.4 Address Space.
d7d1cd
Спасибо, rezident! Руководство, кстати, я читаю. Не в оригинале, конечно, в переводе, но хотя бы так... Задуманное получилось. Сегодня все протестировал. Спасибо еще раз всем за помощь!
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.