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

 
 
 
Reply to this topicStart new topic
> Опять о критических секциях, sam7x
xelax
сообщение Mar 28 2008, 06:45
Сообщение #1


Местный
***

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



На досуге ещё раз покурил даташит, особенно раздел о контроллере прерываний AIC. И нашёл парочку интересных регистров, которым раньше не придавал особого значения.

1. Debug Control register.
2. Core Interrupt status register.

Получается, что с помощью них можно реализовать критические секции. Примерно так:
Код
AT91C_BASE_AIC->AIC_DCR |= AT91C_AIC_DCR_GMSK;
while(AT91C_BASE_AIC->AIC_CISR & (AT91C_AIC_NFIQ | AT91C_AIC_NIRQ));

................  /* critical time code */


AT91C_BASE_AIC->AIC_DCR &= ~AT91C_AIC_DCR_GMSK;


Если это верно, то получается ненадо писать ассемблерные вставки, где идёт обращение к cspr и т.д.

Что скажут знатоки армов? Можно ли организовать критические секции посредством контроллера прерываний? Или где то здесь засада, которую я пока не осознал? 05.gif
Go to the top of the page
 
+Quote Post
_dem
сообщение Mar 28 2008, 08:32
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 263
Регистрация: 2-02-07
Из: CN, Ukraine
Пользователь №: 24 970



Стоп, а после выхода из критической секции кто будет обрабатывать произошедшие во время ее выполнения прерывания ?
Go to the top of the page
 
+Quote Post
xelax
сообщение Mar 28 2008, 08:57
Сообщение #3


Местный
***

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



Цитата(_dem @ Mar 28 2008, 11:32) *
Стоп, а после выхода из критической секции кто будет обрабатывать произошедшие во время ее выполнения прерывания ?


Ну так я понимаю, AIC только отключает свои линии IRQ и FIQ от аналогичных линий ядра. Прерывания накапливаются в AIC. А когда AICу обратно устанавливаешь флаг GMSK, то в ядро пойдут все накопившиеся запросы на обработку прерываний согласно приоритету.

Если я неправ поправте.
Go to the top of the page
 
+Quote Post
_dem
сообщение Mar 28 2008, 09:36
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 263
Регистрация: 2-02-07
Из: CN, Ukraine
Пользователь №: 24 970



Учитывая

Код
This function facilitates synchronizing the processor on a next event
and, as soon as the event occurs, performs subsequent operations without having to handle an
interrupt. It is strongly recommended to use this mask with caution.


я так понимаю, что "without having to handle" означает, что AIC самостоятельно сбрасывает линии, не дожидаясь реакции проца. Хм, вообще интересно, вечером проверю.
Go to the top of the page
 
+Quote Post

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

 


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


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