Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Аналог __SWP для Cortex
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
Alechek
У себя в проекте использовал __SWP внутреннюю функцию IAR

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

Как быть?
esaulenka
В 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'е реализовано, не понял, возможно, что-то подключить надо. В кейле встроенные интрисинки переопределяются.
Alechek
Вопрос возникает дальше....
Можно ли все таки заменить 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. Регистр периферии - это ячейка памяти в данном случае? Сможет ли ядро отследить изменение в регистре?
AHTOXA
Вот статья, где всё хорошо объясняется: ARM Synchronization Primitives.
Alechek
AHTOXA, спасибо, доходчиво разъяснено. Но вот по п.2 правда, остался вопрос.
В общем стоит задача, не останавливая таймер (счетчик), прочитать значение и обнулить. Ранее делал с помощью SWP, полагая, что раз операция атомарная, то значение не может изменится во время операции чтения-записи.
scifi
Цитата(Alechek @ Mar 29 2011, 09:17) *
В общем стоит задача, не останавливая таймер (счетчик), прочитать значение и обнулить. Ранее делал с помощью SWP, полагая, что раз операция атомарная, то значение не может изменится во время операции чтения-записи.

Сомнительный способ. "Операция атомарная" - то есть никто другой не влезет в данную ячейку памяти во время операции. Но вот входит ли аппаратный таймер в категорию "никто другой" - сильно сомневаюсь на этот счёт. Регистр счётчика может быть реализован самыми разными способами, и на SWP я бы не рассчитывал.
Добавление:
Смотря чего Вы хотите добиться, конечно. Если прочитать значение счётчика, обнулить его и быть уверенным, что между чтением и обнулением счётчик не получал приращения, то, боюсь, SWP не сможет этого гарантировать.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.