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

 
 
> Знатокам asm'а: в thumb'е можно как-нибудь "ручками" изменить биты в cpsr I & F?
abcdefg
сообщение Jun 7 2007, 16:23
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 23-01-06
Из: Msk
Пользователь №: 13 490



В arm-режиме есть соответствующие команды, а в thumb'е ничего не нашел... sad.gif
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
abcdefg
сообщение Jun 8 2007, 06:47
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 23-01-06
Из: Msk
Пользователь №: 13 490



Цитата(abcdefg @ Jun 7 2007, 20:23) *
В arm-режиме есть соответствующие команды, а в thumb'е ничего не нашел... sad.gif


Ок, а как бы переключится из user в supervisor, чтобы изменить биты I & F ?
Другими словами, надо глобально включать/выключать прерывания в user mode
Go to the top of the page
 
+Quote Post
VslavX
сообщение Jun 8 2007, 06:58
Сообщение #3


embarrassed systems engineer
*****

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



Цитата(abcdefg @ Jun 8 2007, 09:47) *
Ок, а как бы переключится из user в supervisor, чтобы изменить биты I & F ?
Другими словами, надо глобально включать/выключать прерывания в user mode

Из user в supervisor - средствами только процессора - никак. Это и есть основополагающий принцип разделения привилегий. Если код исполняется в режиме user, то это предполагает наличие операционной системы или хотя бы некоторого управляющего монитора. Эти компоненты должны предоставлять хотя бы минимальные сервисы синхронизации - их и следует использовать вместо запрещения прерываний "напрямую".
Go to the top of the page
 
+Quote Post
abcdefg
сообщение Jun 8 2007, 09:05
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 23-01-06
Из: Msk
Пользователь №: 13 490



Цитата(VslavX @ Jun 8 2007, 10:58) *
Это и есть основополагающий принцип разделения привилегий.


Красиво, как в книжке smile.gif
Подскажите тогда как по-правильному сделать семафор для программного FIFO, который заполняется из FIFO UART'а. Uart висит на irq
Задача: блокировать прерывание на время доступа к soft FIFO.
Как было сделано ранее: отлючение битов разрешения прерывания U0IER
Проблема: во время блокировки могут возникнуть другие прерывания irq, и пока контроллер их обрабатывает аппаратный fifo переполняется (16 байт на 115200 ~ 1.3мс)

Сейчас Uart перекинул на fiq (звучит!), но есть какой-то осадок, что "не айс"

Принимаю предложения
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 18:29
Рейтинг@Mail.ru


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