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

 
 
 
Reply to this topicStart new topic
> Про HardFault
Vladimir_T
сообщение Jun 29 2018, 12:47
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Здравствуйте, уважаемые программисты, подскажите где мне искать решение? Как написано в описании STM32F410R8 программно абсолютно совместим с STM32F405RGT8, на котором успешно работает проект. Но когда этот же проект из Keil 4.70 загружаю d STM32F410, после запуска процессор улетает на HardFault из Startup. Все проверил карты памяти одинаковы, стеки настроены. В отладчике ловлю-ловлю вижу, что LR = 0xFFFFFFF9, почему так?
Может для STM32F410 нужен другой Startup, тогда где его взять?

Go to the top of the page
 
+Quote Post
Forger
сообщение Jun 29 2018, 13:56
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831



Цитата(Vladimir_T @ Jun 29 2018, 15:47) *
подскажите где мне искать решение?
Экстрасенсы в отпуске, поэтому пока что можно дать только "стандартный" ответ: ищите проблемы в своем коде, сверяясь с даташитами.

Цитата
Все проверил карты памяти одинаковы
Этого недостаточно. Внутри МК есть не только память, но и куча различной периферии, набор который может значительно отличаться.

Цитата
В отладчике ловлю-ловлю...
fman.gif cool.gif


--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jun 29 2018, 15:19
Сообщение #3


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



QUOTE (Vladimir_T @ Jun 29 2018, 15:47) *
В отладчике ловлю-ловлю вижу, что LR = 0xFFFFFFF9, почему так?
Тут есть два решения: простое и быстрое.
Простое: наставить в startup-коде точек останова. После вылета перенести те точки, до которых не дошли и те, которые прошли, в промежуток между последней отработавшей точкой и первой не отработавшей. Так, постепенно, найдете команду, на которой происходит вылет. Дальше разбираться, почему у этой команды оказались такие параметры, которые вызывают вылет.
Быстрое: делаете обработчик HardFault с таким кодом:
CODE
{
    volatile int i = 0;
    while(i==0)
     ;
}
Попав в этот обработчик, устанавливаем отладчиком i = 1 и выходим из обработчика по шагам в дизассемблированном коде. Сразу после выхода попадем на следующую после проблемной команду. И снова думаем, что же процессору на этой команде не понравилось.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
adnega
сообщение Jun 29 2018, 15:54
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702



Цитата(Vladimir_T @ Jun 29 2018, 15:47) *
программно абсолютно совместим

STM32F405RGT8 - 192кБ ОЗУ, а у STM32F410 всего 32 кБ. Вангую проблему со стеком.
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Jul 2 2018, 07:00
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Спасибо Всем за помощь! Дело было в настройках размеров ОЗУ. Scatter load пытал инициализировать массив, размер которого для 405 был уже предельным, а для 410 совсем запредельный!
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 18th July 2025 - 18:02
Рейтинг@Mail.ru


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