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

 
 
> Опять о критических секциях, 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



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

 


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


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