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

 
 
> Линукс на ARM, висим при старте
romez777
сообщение Jan 14 2009, 07:31
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 292
Регистрация: 9-11-04
Пользователь №: 1 077



Приветствую.

Начал эту тему в http://electronix.ru/forum/index.php?showtopic=57717 решил спросить здесь, думаю больше народу читают данный раздел. Собственно, по-прежнему ядро виснет, никакие кульбиты не помогают. После зависания, подключившись jtag-ом, посмотрел содержимое ядерного log_buffer, который был накоплен разной информацией, но не выведен на консоль: лог завершается строкой "Calibrating delay loop... " (это функция calibrate_delay() из $(linux)/init/calibrate.c), далее тишина.

Судя по исходникам, calibrate_delay() вызывается много позже console_init(), т.е. сообщения должны уже появляться на консоли, но их нет sad.gif (видимо висим в каком-то бесконечном цикле).

Подозреваю, что дело в криво настроенном MMU, и когда дело доходит до инициализации консоли, то используется "левый" base address серийного порта. Есть какие-то идеи/соображения, куда копать/смотреть?

Вопросы остались такие:
1) таки нужно ли делать ремап на АРМ платформе для успешного старта Линукса, или линукс может жить и без него? Сейчас я ремап не делаю.
2) как определяется параметр CONFIG_PAGE_OFFSET? Он используется для конфигуриирования MMU.

Спасибо!
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
amw
сообщение Jan 14 2009, 12:00
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 601
Регистрация: 22-09-05
Из: Kharkov
Пользователь №: 8 847



Цитата(romez777 @ Jan 14 2009, 09:31) *
Приветствую.

Начал эту тему в http://electronix.ru/forum/index.php?showtopic=57717 решил спросить здесь, думаю больше народу читают данный раздел. Собственно, по-прежнему ядро виснет, никакие кульбиты не помогают. После зависания, подключившись jtag-ом, посмотрел содержимое ядерного log_buffer, который был накоплен разной информацией, но не выведен на консоль: лог завершается строкой "Calibrating delay loop... " (это функция calibrate_delay() из $(linux)/init/calibrate.c), далее тишина.

Чуть раньше, в том же буффере должна быть строка вида
Код
console [tty0] enabled

Там правильный tty?
Цитата
Судя по исходникам, calibrate_delay() вызывается много позже console_init(), т.е. сообщения должны уже появляться на консоли, но их нет sad.gif (видимо висим в каком-то бесконечном цикле).

Примерно на ядре 2.6.12 была такая проблема.
Вроде ж ее давно пофиксили, но на всякий случай приведу методику поиска причин (к сожалению точный ответ с патчем затерялся за давностью лет, но патч был на arm.linux.org.uk в списках рассылки)
Суть была в том, что в linux/arch/arm/Makefile CPPFLAGS (или KBUILD_CPPFLAGS) для BE устанавливались неправильно (отсутствовал параметр -mbig-endian).
delay_loop расчитывается по jiffies, а это 64 бит значение, объявленное через макрос. Препроцессор (из-за отсутствия флага -mbig-endian неправильно его раскрывал, и в итоге в функции calibrate_delay() анализировался не младшее, а старшее 32бит слово.
Проверте, правильно ли у Вас он устанавливается.
Цитата
Подозреваю, что дело в криво настроенном MMU, и когда дело доходит до инициализации консоли, то используется "левый" base address серийного порта. Есть какие-то идеи/соображения, куда копать/смотреть?

Вопросы остались такие:
1) таки нужно ли делать ремап на АРМ платформе для успешного старта Линукса, или линукс может жить и без него? Сейчас я ремап не делаю.
2) как определяется параметр CONFIG_PAGE_OFFSET? Он используется для конфигуриирования MMU.

linux/Documentation/arm/ в частности linux/Documentation/arm/memory.txt

PS: Зря продублировали тему, ориентироваться сложно.


--------------------
- А мораль отсюда такова: всякому овощу свое время. Или, хочешь, я это сформулирую попроще: никогда не думай, что ты иная, чем могла бы быть иначе, чем будучи иной в тех случаях, когда иначе нельзя не быть.
© Lewis Carroll. Alice's adventures in wonderland.
Go to the top of the page
 
+Quote Post
romez777
сообщение Jan 15 2009, 01:53
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 292
Регистрация: 9-11-04
Пользователь №: 1 077



Цитата
Чуть раньше, в том же буффере должна быть строка вида
Код
console [tty0] enabled

Там правильный tty?

Да. Кроме того, в linux/arch/arm/Makefile все флаги для big endian установлены правильно, косяков не замечено.

Цитата
linux/Documentation/arm/ в частности linux/Documentation/arm/memory.txt

Здесь представлена карта виртуальной памяти. Она одинакова для обоих случаев remapped/unremapped RAM? Т.е. таки для arm платформы ремап _нужен_ ?
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 4th August 2025 - 22:55
Рейтинг@Mail.ru


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