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

 
 
> Две таблицы векторов в одном софте, xmega
xelax
сообщение Apr 20 2011, 08:58
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 370
Регистрация: 7-11-06
Пользователь №: 22 035



Привет всем!

Тут некоторых коллег посетила нездоровая идея иметь два вектора прерывания на одну периферию (NVM eeprom и flash).
Одна таблица в application другая в bootloader секции. И всё это должно жить в одной программе. В возможности иметь две таблице векторов прерывания для xmegа я не вижу никаких технических препятствий, то как это реализовать в одном софте средствами компилятора и линкера пока не понимаю. Не могу же я иметь две функции
Код
ISR(NVM_EE_vect)


Пока не вижу другого способа кроме как для application секции формировать таблицу посредством макросов ISR, а для bootloader формировать её в рукопашную, размещая jmp на обработчики по фиксированным адресам из bootloader и добавляя в функции обработки рукописные прологи и эпилоги.

Но уж очень этот вариант на камасутру похож. Может кто-то знает более красивые варианты решения?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
xelax
сообщение Apr 20 2011, 09:19
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 370
Регистрация: 7-11-06
Пользователь №: 22 035



Так камни с ядром avr имеют гарвардскую архитектуру и умеют исполнять код только из FLASH области, к сожалению это не cortex crying.gif .
Go to the top of the page
 
+Quote Post
defunct
сообщение May 19 2011, 15:32
Сообщение #3


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Цитата(xelax @ Apr 20 2011, 12:19) *
Так камни с ядром avr имеют гарвардскую архитектуру и умеют исполнять код только из FLASH области, к сожалению это не cortex crying.gif .

И что с того?
В ОЗУ для каждого вектора пусть лежит адрес обработчика, а по реальному вектору прерывания во флеш пусть лежит буквально следующий код:
Код
lds zh, high( vector_i )
lds zl, low( vector_i)
ijmp

Где vector_i - переменная в ОЗУ.

Если с асмом туго, переместите все вектора в область бутлоадера, и состряпайте Сишные wrapper'ы:

Код
ISR( vect_xxx)
{
     if (handlers[ vect_xxx ])
         handlers[ vect_xxx ]();
}


где "handlers" массив в ОЗУ, где каждый элемент - адрес обработчика.

Цитата(V_G @ May 11 2011, 16:04) *
Но не думаю, что IAR C умеет ее использовать для целей, потребных топикстартеру.
Все-таки 2 отдельных проекта реальнее, чем так извращаться на Си

Toolchain от IAR включает еще и транслятор Asm'а. Создаете .s файл, пишете в нем код таблицы векторов, и линкером кладете в секцию таблицы векторов вот и всего делов.


Цитата(vvppvv @ May 13 2011, 16:00) *
__interrupt __raw void irqUSART0_RXC (void)
{
interrupt_entry ();
(* Ufunc_ptr)();
interrupt_exit ();
}

Не вижу смысла в ручных entry / exit.
Надо просто тупо вызвать функцию.
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 27th June 2025 - 16:45
Рейтинг@Mail.ru


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