реклама на сайте
подробности

 
 
> МК не выполняет команды...
d7d1cd
сообщение Jul 10 2012, 17:13
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199



Привет всем! Ребята, подскажите как быть. Весь измучался уже...

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

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

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


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


Подскажите, почему не выполняется первая строка? Что я не так делаю?

Сообщение отредактировал d7d1cd - Jul 10 2012, 17:15
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
rezident
сообщение Jul 10 2012, 17:33
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Адрес 0xFE30 находится во Flash. Его содержимое одной командой изменить нельзя. Ибо Flash это ЭППЗУ. Измените адрес Flash на адрес ячейки в ОЗУ.
Go to the top of the page
 
+Quote Post
d7d1cd
сообщение Jul 10 2012, 17:58
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199



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



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



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

Пока меня больше всего и волнует то, что перестает работать стандартный обработчик прерывания... Завтра попробую инкрементировать слово в ОЗУ. Но я не знаю где там есть свободное место. Желательно бы как-то менять именно адрес FLASH. Или это недопустимо?
Go to the top of the page
 
+Quote Post
rx3apf
сообщение Jul 10 2012, 18:15
Сообщение #4


Гуру
******

Группа: Участник
Сообщений: 3 834
Регистрация: 14-06-06
Из: Moscow, Russia
Пользователь №: 18 047



Цитата(d7d1cd @ Jul 10 2012, 21:58) *
Желательно бы как-то менять именно адрес FLASH. Или это недопустимо?

Механизм изменения flash совершенно иной. И к тому же ресурс перезаписей весьма ограничен. Уж два байта оперативки наверняка можно где-то выскрести (а как вариант, какие-нибудь неиспользуемые регистры периферии, но тут надо осторожно и не забывать про разрядность). А почему не работает обработчик при таком варианте - можно только гадать. можно проверить, будет ли он работать, если команду add заменить на парочку nop, например. Т.е. надо найти причину...
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 30th July 2025 - 02:33
Рейтинг@Mail.ru


Страница сгенерированна за 0.01395 секунд с 7
ELECTRONIX ©2004-2016