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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> TI AM1808 Program Reset, Как реализовать программный сброс процессора?
doom13
сообщение Nov 17 2014, 14:58
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Приветствую!
Хочу реализовать программный сброс процессора, но не могу подобрать нужную команду.

Можно сделать что-то типа:
Код
asm(" .ref Entry");
asm(" b Entry");

программа должна перезапуститься, но в моём случае не работает (только перейдёт на Entry и куда-то улетит), как понимаю надо ещё что-то почистить или сбросить, сделать аналог "System Reset" из CCS и перезапустить программу.

А как сделать, чтобы программа перешла на адреса встроенного ROM загрузчика и уже в соответствии с выбранным режимом загрузки перезагрузила прошивку и стартанула её?
Пока что-то не получаетсяsad.gif
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 18 2014, 03:39
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Используйте встроенный сторожевик для сброса.
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 06:25
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(jcxz @ Nov 18 2014, 06:39) *
Используйте встроенный сторожевик для сброса.

Это можно, но хочется чтобы была команда, которая приходит, например, по ethernet. Как-то ведь можно, используя ассм, это сделать (всегда делал для других процов от TI). Нужно только описать переход на адрес, думаю, адрес ROM загрузчика 0xFFFD0000 должен подойти, но пока не могу разобраться, какую команду (или несколько команд) использовать.
Например для с28346 было:
Код
int restart()
{
    DINT;

    asm(" .ref _c_int00\n\t LB _c_int00");

    return 0;
}

int reset()
{
    DINT;
    PieCtrlRegs.PIECTRL.bit.ENPIE = 0;

    asm(" LB 0x003FFFC0");

    return 0;
}

Вопрос, как сделать для данного процессора нечто подобное?
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 18 2014, 08:27
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(doom13 @ Nov 18 2014, 12:25) *
Это можно, но хочется чтобы была команда, которая приходит, например, по ethernet. Как-то ведь можно

Пришла команда - пишете в WD недопустимую последовательность - сразу получаете аппаратный RESET.
В чём проблема?
Обратите внимание на выделенное жирным. Это в 100 раз надёжнее и достовернее любых программных рестартов, так как заведомо переводит весь МК в начальное состояние.
Чего Вы своим программным переходом не делаете.
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 08:55
Сообщение #5


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(jcxz @ Nov 18 2014, 11:27) *
Пришла команда - пишете в WD недопустимую последовательность - сразу получаете аппаратный RESET.
В чём проблема?
Обратите внимание на выделенное жирным. Это в 100 раз надёжнее и достовернее любых программных рестартов, так как заведомо переводит весь МК в начальное состояние.
Чего Вы своим программным переходом не делаете.

Попробую такой вариант, спасибо, но всё же интересно, как ассмом можно его перенаправить на ROM загрузчик?
Пока делаю так:
Код
// reset.c
int reset()
{
    asm(" .ref RstHandler");
    asm(" b RstHandler");
    return 0;
}

попадаем:
Код
;reset.asm
    .global RstHandler
    .global ADDR_BOOTROM

ADDR_BOOTROM .word 0xFFFD0000

RstHandler:
;    LDR      r0, ADDR_BOOTROM
;    LDR      r1, [r0]
;    LDR      pc, [r0]

Как правильно написать то, что после RstHandler: ?

Да, мне кажется (возможно ошибаюсь), если перейти на код и заставить выполниться встроенный ROM-загрузчик, то это и будет аналог аппаратного сброса???
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 18 2014, 09:07
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(doom13 @ Nov 18 2014, 14:55) *
Попробую такой вариант, спасибо, но всё же интересно, как ассмом можно его перенаправить на ROM загрузчик?

Восстановить состояние регистров управления процессором в исходное состояние (такое, какое должно быть после подачи сигнала RESET).
Восстановить состояние периферии на исходное (прерывание, управление питанием, PLL, MPU/MMU, кеши и т.п.).
...(что-то ещё восстановить).
И только после этого можно делать RESET.

Я уже Вам написал что это в 100 раз сложнее чем 2 строчки которые у Вас, а Вы не верите....
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 09:16
Сообщение #7


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(jcxz @ Nov 18 2014, 12:07) *
Восстановить состояние регистров управления процессором в исходное состояние (такое, какое должно быть после подачи сигнала RESET).
Восстановить состояние периферии на исходное (прерывание, управление питанием, PLL, MPU/MMU, кеши и т.п.).
И только после этого можно делать RESET.

Тут понятно, что это должно быть сделано. Поэтому мой переход на Entry и не запускается, что что-то там (всё) не очищено и не сброшено в начальное состояние.

Цитата(jcxz @ Nov 18 2014, 12:07) *
Я уже Вам написал что это в 100 раз сложнее чем 2 строчки которые у Вас, а Вы не верите....

Тут я понял, что использовать WD - это проще, но вот пока ещё хочется понять как его загнать на адреса встроенного загрузчика.
Две строчки - это рестарт того, что уже лежит в RAM, а вот две строчки, которые перенаправят его на встроенный загрузчик, думаю, спасли бы ситуацию, но пока не пойму какие команды и как использовать.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 18 2014, 09:34
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(doom13 @ Nov 18 2014, 15:16) *
Тут я понял, что использовать WD - это проще, но вот пока ещё хочется понять как его загнать на адреса встроенного загрузчика.

Это несложно.
Для Thumb-2 системы команд (Cortex-M):
Код
typedef void (* EntryTyp)();
#define Entry ((EntryTyp)0xFFFD0001)  
Entry();

Для ARM-системы команд - с ноликом в мл. бите.
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 11:17
Сообщение #9


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(jcxz @ Nov 18 2014, 12:34) *

Спасибо, то что надо. Это работает (прошивку перезаливает), но надо ему ещё что-то "обнулить", а то не стартанёт нормально загруженную прошивку. Не подскажете, что конкретно?


Нашёл кусок кода, что ему мешает после перезагрузки прошивки с внешней SPI-флэшки нормально работать. Проблема старая (спрашивал тут(сообщение №69), но никто не ответил), во всём оказывается виноват McBSP и его прерывания. Пробовал чистить все его регистры (McBSP), но не помогает, ещё что-то надо стереть. Что? Если убрать настройку прерываний от McBSP, то приведённый выше код перезальёт прошивку и она нормально запустится.

Ещё хочу спросить, что неправильно в моём коде и почему он не хочет компилиться?
Выше приводил переход на RstHandler: , это работает. Далее пытался сделать:
Код
RstHandler:
    B    0xFFFD0000

, но это компилиться не хочет, пишет
Цитата
Illegal operand
B 0xFFFD0000
.
Почему так? Если нажму кнопку Reset на плате, процессор станет на адрес 0xFFFF0000.
Смотрю дизассм и вижу:
Цитата
ffff0000: EAFF7FFE B 0xFFFD0000

, т.е. что я и пытался сделать, используется та же инструкция, почему в моём случае не захотело компилиться?
Если далее нажму "F5" в CCS, то перейдёт на адрес 0xFFFD0000, где ещё один бранч на следующий адрес.
Где может быть проблема?
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 18 2014, 11:31
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



B - это прямой переход. В команде адрес назначения кодируется как смещение к PC.
А Вам нужен косвенный (BX):
LDR R0, p1
BX R0

для IAR:
p1 DC32 0xFFFD0000
для CCS:
p1 .long 0xFFFD0000
(если Thumb-2 - не забываем про мл. бит)

PS: Что ещё надо проинитить я не знаю. Не знаком с данным МК.
Go to the top of the page
 
+Quote Post
SM
сообщение Nov 18 2014, 11:33
Сообщение #11


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



Цитата(doom13 @ Nov 18 2014, 14:17) *
Где может быть проблема?


Проблема в расстоянии от команды перехода до точки назначения. Для далеких переходов следует использовать нечто типа:

LDR PC, JmpAddr

JmpAddr: .word 0xFFFD0000

или, если предполагается переключение ARM <=> THUMB, то

LDR R0, JmpAddr
BX R0
JmpAddr: .word 0xFFFD0000



UPD:
А вообще, я бы покопал на тему захода в SwRstDisable ARM-а (PSC0/LPSC14) - это было бы пожестче, если реализуемо.
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 12:04
Сообщение #12


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(jcxz @ Nov 18 2014, 14:31) *
B - это прямой переход. В команде адрес назначения кодируется как смещение к PC.
А Вам нужен косвенный (BX):
LDR R0, p1
BX R0

для IAR:
p1 DC32 0xFFFD0000
для CCS:
p1 .long 0xFFFD0000
(если Thumb-2 - не забываем про мл. бит)

PS: Что ещё надо проинитить я не знаю. Не знаком с данным МК.


Спасибо, почитал, кто такой
Цитата
BX{cond} Rm
, получается - это и есть переход на адрес, который содержится в Rm (затупил, несколько раз просматривал все бранчи, но не нашёл нужную инструкцию).
Тогда не понимаю почему после ресета по адресу 0xFFFF0000 лежит просто
Цитата
B 0xFFFD0000
(согласно дизассму CCS), ведь это НЕПРАВИЛЬНАЯ инструкция!!?? Ведь B - это переход на label, а константа 0xFFFD0000 и будет для него illegal operand??? Или здесь он уже пересчитал адрес label и показал куда будет переходить?

Остаётся "старый" вопрос, что нужно почистить/занулить/сбросить, чтобы программа нормально стартовала после перезагрузки? Пытаюсь разобраться, если кто подскажет, буду благодарен.
Go to the top of the page
 
+Quote Post
SM
сообщение Nov 18 2014, 12:31
Сообщение #13


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



Цитата(doom13 @ Nov 18 2014, 15:04) *
Ведь B - это переход на label, а константа 0xFFFD0000 и будет для него illegal operand???

Я выше написал - весь вопрос в расстоянии от команды перехода до точки, куда переходить. На "короткие" расстояния - дотягивает команда B/BX label. На длинные - уже B/BX Rx нужна, или LDR PC,xxxx
Go to the top of the page
 
+Quote Post
doom13
сообщение Nov 18 2014, 13:08
Сообщение #14


Профессионал
*****

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Цитата(SM @ Nov 18 2014, 15:31) *

Не заметил Ваш пост выше
Цитата(SM @ Nov 18 2014, 14:33) *
Проблема в расстоянии от команды перехода до точки назначения. Для далеких переходов следует использовать нечто типа:

LDR PC, JmpAddr

JmpAddr: .word 0xFFFD0000

или, если предполагается переключение ARM <=> THUMB, то

LDR R0, JmpAddr
BX R0
JmpAddr: .word 0xFFFD0000



UPD:
А вообще, я бы покопал на тему захода в SwRstDisable ARM-а (PSC0/LPSC14) - это было бы пожестче, если реализуемо.

Это тоже работает, спасибо, не мог понять, как в программный счётчик запихнуть адрес 0xFFFD0000, пробовал почти то что и надо LDR PC, 0xFFFD0000, но немного не то sad.gif

Цитата(SM @ Nov 18 2014, 15:31) *
весь вопрос в расстоянии от команды перехода до точки, куда переходить. На "короткие" расстояния - дотягивает команда B/BX label. На длинные - уже B/BX Rx нужна, или LDR PC,xxxx

Тут что-то не понимаю, как оно может скомпилить код B 0xFFFD0000? Или это только то что я вижу в CCS Disassembly, на самом деле было что-то типа:

Код
boot_label:
...
   B boot_label
...

, где boot_label = 0xFFFD0000?
Go to the top of the page
 
+Quote Post
SM
сообщение Nov 18 2014, 13:16
Сообщение #15


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



Цитата(doom13 @ Nov 18 2014, 16:08) *
, где boot_label = 0xFFFD0000?


любая метка есть символьное обозначение какого-то, вполне определенного, числа... Это эквивалентно, что метку поставить, что метку определить через .set, что число указать. Однако, если комипилятор видит, что инструкция "не дотянется" до адреса, он ее и обругает.

А LDR можно еще написать как

LDR PC, =0xFFFD0000

компилятор должен сам это переделать в

LDR PC,label

[.....]
label: .word 0xFFFD0000
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 20:44
Рейтинг@Mail.ru


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