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

 
 
 
Reply to this topicStart new topic
> Аналог __SWP для Cortex, чем заменить в IAR?
Alechek
сообщение Feb 17 2011, 08:26
Сообщение #1


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



У себя в проекте использовал __SWP внутреннюю функцию IAR

В букварях нашел, что в кортексах инструкция SWP заменена на LDREX и STREX.
IAR вроде как о них не знает. Покрайней мере из под Си напрямую не нашел как к ним достучатся.

Как быть?
Go to the top of the page
 
+Quote Post
esaulenka
сообщение Feb 17 2011, 09:08
Сообщение #2


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

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



В CMSIS есть функции
extern uint8_t __LDREXB(uint8_t *addr);
extern uint16_t __LDREXH(uint16_t *addr);
extern uint32_t __LDREXW(uint32_t *addr);

Подробности - в core_cm3.h

Как оно в IAR'е реализовано, не понял, возможно, что-то подключить надо. В кейле встроенные интрисинки переопределяются.


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post
Alechek
сообщение Mar 28 2011, 13:42
Сообщение #3


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



Вопрос возникает дальше....
Можно ли все таки заменить SWP инструкцию на пару LDREX - STREX?

Букварь говорит, что мониторится ячейка памяти на экслюзивный доступ.
Сразу возникают вопросы
1. Мониторится только одна пара LDREX/STREX? Выполнится ли корректно вложенный доступ, типа
Код
LDREX R1, [R0, #0]
LDREX R2, [R0, #4]
STREX R5, R1, [R0, #4]
STREX R6, R2, [R0, #0]

2. Регистр периферии - это ячейка памяти в данном случае? Сможет ли ядро отследить изменение в регистре?
Go to the top of the page
 
+Quote Post
AHTOXA
сообщение Mar 28 2011, 14:49
Сообщение #4


фанат дивана
******

Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684



Вот статья, где всё хорошо объясняется: ARM Synchronization Primitives.


--------------------
Если бы я знал, что такое электричество...
Go to the top of the page
 
+Quote Post
Alechek
сообщение Mar 29 2011, 06:17
Сообщение #5


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

Группа: Свой
Сообщений: 1 241
Регистрация: 15-11-05
Из: Челябинск
Пользователь №: 10 882



AHTOXA, спасибо, доходчиво разъяснено. Но вот по п.2 правда, остался вопрос.
В общем стоит задача, не останавливая таймер (счетчик), прочитать значение и обнулить. Ранее делал с помощью SWP, полагая, что раз операция атомарная, то значение не может изменится во время операции чтения-записи.
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 29 2011, 07:12
Сообщение #6


Гуру
******

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



Цитата(Alechek @ Mar 29 2011, 09:17) *
В общем стоит задача, не останавливая таймер (счетчик), прочитать значение и обнулить. Ранее делал с помощью SWP, полагая, что раз операция атомарная, то значение не может изменится во время операции чтения-записи.

Сомнительный способ. "Операция атомарная" - то есть никто другой не влезет в данную ячейку памяти во время операции. Но вот входит ли аппаратный таймер в категорию "никто другой" - сильно сомневаюсь на этот счёт. Регистр счётчика может быть реализован самыми разными способами, и на SWP я бы не рассчитывал.
Добавление:
Смотря чего Вы хотите добиться, конечно. Если прочитать значение счётчика, обнулить его и быть уверенным, что между чтением и обнулением счётчик не получал приращения, то, боюсь, SWP не сможет этого гарантировать.
Go to the top of the page
 
+Quote Post

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

 


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


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