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

 
 
 
Reply to this topicStart new topic
> malloc в Xilinx SDK
Andrey Pesoshin
сообщение Nov 12 2011, 11:43
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 51
Регистрация: 5-07-10
Пользователь №: 58 297



EDK-проект для Xilinx Spartan 6.

В C++ коде часть классов/структур размещается в куче динамически через malloc(). Куча и стек лежат во внешней DDR2, код - в брамах (можно вынести тоже в оперативку).

Проблема в следующем:
После сброса системы (или нескольких) код выполняется с начала, однако вызовы malloc возвращают NULL.

Как вы это обычно лечите?
Go to the top of the page
 
+Quote Post
DevL
сообщение Nov 12 2011, 20:39
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 254
Регистрация: 23-10-10
Из: астрал
Пользователь №: 60 371



В С/С++ malloc определяется как
http://www.cplusplus.com/reference/clibrary/cstdlib/malloc/

и соответственно - если не получается ( в силу каких то причин - много запрошено памяти или просто нет доступной уже ) выделять запрошеный размер - возращается NULL

обычно, стоит проверить свой код, насчет malloc + free использования , а так же запрашиваемые размеры ...
Go to the top of the page
 
+Quote Post
AVR
сообщение Nov 12 2011, 20:50
Сообщение #3


фанат Linux'а
*****

Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008



Цитата(DevL @ Nov 13 2011, 00:39) *
и соответственно - если не получается ( в силу каких то причин - много запрошено памяти или просто нет доступной уже ) выделять запрошеный размер - возращается NULL
обычно, стоит проверить свой код, насчет malloc + free использования , а так же запрашиваемые размеры ...

но ведь система сбрасывается полностью, удивляет вообще теоретическая возможность что в памяти что-то не инициализируется при сбросе

а вдруг содержимое памяти после предыдущего цикла работы сохраняется, что если посмотреть адреса указатели стеков, heap и т.п.?


--------------------
Go to the top of the page
 
+Quote Post
Andrey Pesoshin
сообщение Nov 13 2011, 13:44
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 51
Регистрация: 5-07-10
Пользователь №: 58 297



Цитата(DevL @ Nov 13 2011, 00:39) *
В С/С++ malloc определяется как
http://www.cplusplus.com/reference/clibrary/cstdlib/malloc/

и соответственно - если не получается ( в силу каких то причин - много запрошено памяти или просто нет доступной уже ) выделять запрошеный размер - возращается NULL

обычно, стоит проверить свой код, насчет malloc + free использования , а так же запрашиваемые размеры ...

Это так и есть. Только я поясню еще раз - при включении питания схемы - код с malloc/free выполняется нормально, а после сброса - тот же самый код - запускается сначала и уже падает в местах вызова malloc (возвращает NULL). Linker-скриптом сегменты кода, стека и кучи распределяются по блочной памяти ПЛИС и внешней оперативной.

Следовательно это проблема не в коде, а где-то выше - на уровне bsp или драйверов Xilinx'а.
Xilinx вроде бы знает об этой проблеме http://www.xilinx.com/support/answers/30878.htm, только оба описанных метода выглядят как страшнейшие хаки. Потому и спрашиваю, можно ли это сделать как-то лучше.

AVR
Да, это очень похоже на правду. Как посмотреть, не подскажите?
Go to the top of the page
 
+Quote Post
AVR
сообщение Nov 13 2011, 15:47
Сообщение #5


фанат Linux'а
*****

Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008



AVRДа, это очень похоже на правду. Как посмотреть, не подскажите?[/quote]
просто printf адреса при malloc и printf адреса любой локальной переменной
если при каждом старте системы адреса отличаются - тут я бы насторожился


--------------------
Go to the top of the page
 
+Quote Post
Andrey Pesoshin
сообщение Nov 13 2011, 19:11
Сообщение #6


Участник
*

Группа: Участник
Сообщений: 51
Регистрация: 5-07-10
Пользователь №: 58 297



Цитата(AVR @ Nov 13 2011, 19:47) *
AVRДа, это очень похоже на правду. Как посмотреть, не подскажите?
просто printf адреса при malloc и printf адреса любой локальной переменной
если при каждом старте системы адреса отличаются - тут я бы насторожился

Так я уже и насторожился, посмотрите, об этом в ссылке приведенной написано
http://www.xilinx.com/support/answers/30878.htm
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 10:04
Рейтинг@Mail.ru


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