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

 
 
> Знатокам 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
Ответов (1 - 8)
scifi
сообщение Jun 7 2007, 16:41
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



В режиме THUMB невозможно прочитать или записать CPSR. Надо переключаться в режим ARM.
Go to the top of the page
 
+Quote Post
abcdefg
сообщение Jun 8 2007, 06:47
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 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
zltigo
сообщение Jun 8 2007, 06:56
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(abcdefg @ Jun 8 2007, 09:47) *
Ок, а как бы переключится из user в supervisor,

Только SWI


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
VslavX
сообщение Jun 8 2007, 06:58
Сообщение #5


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
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 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
vet
сообщение Jun 8 2007, 09:16
Сообщение #7


Знающий
****

Группа: Свой
Сообщений: 550
Регистрация: 16-06-04
Из: Казань
Пользователь №: 32



а есть ли смысл блокировать программный FIFO?
в случае его реализации двумя указателями чтение модифицирует только указатель на хвост буфера, запись - только указатель на голову, т.е. чтение и запись друг другу не мешают.


--------------------
Главная линия этого опуса ясна мне насквозь!
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jun 8 2007, 09:18
Сообщение #8


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(abcdefg @ Jun 8 2007, 09:47) *
Ок, а как бы переключится из user в supervisor, чтобы изменить биты I & F ?
Другими словами, надо глобально включать/выключать прерывания в user mode
Из User Mode, как заметил zltigo, только SWI. Но если вам в User Mode все равно надо дергать CPSR, то может стоит работать не в User Mode, а в System Mode? В System Mode в режиме ARM доступен CPSR и вы можете включать/выключать прерывания следующим образом: командой BX переход из THUMB в ARM, в режиме ARM запрет/разрешение, командой BX переключение обратно в THUMB.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
abcdefg
сообщение Jun 8 2007, 09:39
Сообщение #9


Местный
***

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



Цитата(vet @ Jun 8 2007, 13:16) *
а есть ли смысл блокировать программный FIFO?
в случае его реализации двумя указателями чтение модифицирует только указатель на хвост буфера, запись - только указатель на голову, т.е. чтение и запись друг другу не мешают.


Эээ, чего то я перемудрил 07.gif
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 14:22
Рейтинг@Mail.ru


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