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

 
 
> Выход из обработчика FIQ, AT91SAM7S64, Eclipse
transformator
сообщение Aug 28 2012, 07:41
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 13-12-06
Пользователь №: 23 466



Помогите разобраться.

В файле crt.s по адресу 0х1С стоит команда перехода на обработчик FIQ

_vec_fiq: LDR PC, [PC, # -0xF20]

Проблема в том, что при выходе из обработчика процессор остается в режиме FIQ_mode.

Где и что надо поправить?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 4)
_4afc_
сообщение Aug 28 2012, 08:44
Сообщение #2


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

Группа: Свой
Сообщений: 1 262
Регистрация: 13-10-05
Из: Санкт-Петербург
Пользователь №: 9 565



Цитата(transformator @ Aug 28 2012, 11:41) *
Помогите разобраться.
В файле crt.s по адресу 0х1С стоит команда перехода на обработчик FIQ

_vec_fiq: LDR PC, [PC, # -0xF20]

Проблема в том, что при выходе из обработчика процессор остается в режиме FIQ_mode.

Где и что надо поправить?


Добавить подтверждение прерывания в конце обработчика. Например для нулевого счётчика:
Код
    .equ AIC_ICCR,        (0x128)
FIQ_Exit:
                ldr        r8, [pc,#(FIQ_AIC-8-.)]
                mov        r9, #0x1000         //AT91C_ID_TC0
                str        r9, [r8, #AIC_ICCR]
                
                subs    pc, lr, #4

FIQ_AIC:        .word    0xFFFFF000

Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 28 2012, 11:42
Сообщение #3


Гуру
******

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



Цитата(transformator @ Aug 28 2012, 13:41) *
Проблема в том, что при выходе из обработчика процессор остается в режиме FIQ_mode.
А как выходите из ISR?
Go to the top of the page
 
+Quote Post
transformator
сообщение Aug 29 2012, 03:37
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 28
Регистрация: 13-12-06
Пользователь №: 23 466



Весь код написан на C.
На ассемблере - только переход _vec_fiq: LDR PC, [PC, # -0xF20].

Кажется, проблема решена путем добавления __atribute__ (interrupt("FIQ")) перед определением функции обработчика FIQ.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 29 2012, 06:46
Сообщение #5


Гуру
******

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



Цитата(transformator @ Aug 29 2012, 09:37) *
Кажется, проблема решена путем добавления __atribute__ (interrupt("FIQ")) перед определением функции обработчика FIQ.
Вот потому и спрашивал - на ARM7/ARM9 выход из ISR отличается от выхода из обычной функции необходимостью копирования SPSR в CPSR (в которых и хранится режим процессора). Когда вы определили функцию как interrupt("FIQ"), то соответственно изменились команды восстановления контекста по выходу.
Go to the top of the page
 
+Quote Post

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

 


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


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