на базе raspi zero, свою ОС реализовываю с нуля в целях близкого знакомства с arm инструкциями + базовым пониманием планирования потоков и т.д, всё круто, классно получается, столкнулся с непониманием одного вопроса, реализовал spinlock через SWP инструкцию, компилятор кидает предупреждения, что инструкция устарела. Предлагает LDREX/STREX, я пробовал, пробовал так же встроенные __atomic_test_and_set которые то же самое генерируют (на этих встроенных GCC функциях я и хотел бы остановиться). НО! инструкция LDREX перебрасывает процессор на reset handler. Что я упускаю?
mmu включен? тип памяти какой? читай ARM ARM, там все написано
mmu не включен, он мне пока не нужен. в этом причина?
Там у них в то время (ARMv6) была путаница и недосказанности в документации. Дело в том, что LDREX/STREX работают только с "Normal memory", работа с Device и Strongly-ordered приводила к непредсказуемым последствиям. Все это не очень сказано в доке к v6, но уже нормально освещено в доке к v7, если я правильно помню. Так вот ключевой вопрос для Вас: MMU включен? Если нет, то весь доступ к данным делается как Strongly-ordered.
Обсуждают сегодня