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

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

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

3 ответов

11 просмотров

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

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

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

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта