189 похожих чатов

Всем привет! Знатоки, подскажите, балуюсь вторую неделю с bcm2835 чипом

на базе raspi zero, свою ОС реализовываю с нуля в целях близкого знакомства с arm инструкциями + базовым пониманием планирования потоков и т.д, всё круто, классно получается, столкнулся с непониманием одного вопроса, реализовал spinlock через SWP инструкцию, компилятор кидает предупреждения, что инструкция устарела. Предлагает LDREX/STREX, я пробовал, пробовал так же встроенные __atomic_test_and_set которые то же самое генерируют (на этих встроенных GCC функциях я и хотел бы остановиться). НО! инструкция LDREX перебрасывает процессор на reset handler. Что я упускаю?

3 ответов

8 просмотров

mmu включен? тип памяти какой? читай ARM ARM, там все написано

alexey ⚡️- Автор вопроса
Ivan
mmu включен? тип памяти какой? читай ARM ARM, там ...

mmu не включен, он мне пока не нужен. в этом причина?

Там у них в то время (ARMv6) была путаница и недосказанности в документации. Дело в том, что LDREX/STREX работают только с "Normal memory", работа с Device и Strongly-ordered приводила к непредсказуемым последствиям. Все это не очень сказано в доке к v6, но уже нормально освещено в доке к v7, если я правильно помню. Так вот ключевой вопрос для Вас: MMU включен? Если нет, то весь доступ к данным делается как Strongly-ordered.

Похожие вопросы

Обсуждают сегодня

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Какое виндузовое сообщение приходит TTabSheet, что риэлайняться контролы на нем, даже у которых парент другой? Ситуация: открываю форму - кнопок нет, перелистываю на другой т...
Катерина Свиридова
7
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
Карта сайта