Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Linker script XPS9.2
Форум разработчиков электроники ELECTRONIX.ru > Программируемая логика ПЛИС (FPGA,CPLD, PLD) > Системы на ПЛИС - System on a Programmable Chip (SoPC)
tolik1
Есть проект ISE - XPS9.2. До некоторого момента все шло хорошо. Но однажды при увеличении программного кода (добавление С функций) компилятор стал выдавать ошибку:
/TestApp_Memory/src/TestApp_Memory_LinkScr.ld:225 cannot move location counter backwards (from fffffc70 to 00000070)
collect2: ld returned 1 exit status
make: *** [TestApp_Memory/executable.elf] Error 1
Done!
В программу пытаюсь добавить код под прерывание. Хотя подобная ошибка появлялась и ранее, при добавлении обычных функций, но тогда просто перегенерил Linker script и всё ушло. В этот раз и так и эдак и всё никак.
Память 64к 0хFFFF0000 - 0xFFFFFFFFF
Вопрос:
1. Что и куда он пытается двинуть.?
2. Почему не может?
3. Как ему помочь?
Дмитрий Мазунин
Скорее всего, мало памяти.
Когда генерите Linker script, посмотрите размеры сегментов - входят ли они все в Ваши 64К...

Как помочь -
1) увеличить размер блока памяти.
проанализировав размеры сегментов:
2) уменьшить код - например, пользуйтесь xil_printf, если что-то печатаете, printf очень велик.
3) также удалить ненужные массивы-переменные, если это возможно, также хип/стек.
tolik1
Цитата(Дмитрий Мазунин @ Jun 2 2008, 15:17) *
Скорее всего, мало памяти.
Когда генерите Linker script, посмотрите размеры сегментов - входят ли они все в Ваши 64К...

Как помочь -
1) увеличить размер блока памяти.
проанализировав размеры сегментов:
2) уменьшить код - например, пользуйтесь xil_printf, если что-то печатаете, printf очень велик.
3) также удалить ненужные массивы-переменные, если это возможно, также хип/стек.

Памяти достаточно (размер программы - смехотворный). С linker scriptом сложнее он ведь показывает размеры секций в режиме Readonly Править в диалоге можно только размер стека и кучи. Размер памяти конечно увеличивал - не помогло help.gif
Дмитрий Мазунин
Размеры секций Вы править, конечно, не можете - они зависят от Вашей программы и данных.
Я говорил - ПОСМОТРЕТЬ размеры, просуммировать их все - входят ли в память, какие из них (возможно) слишком большие ?
Правильно ли расположен сегмент .vectors (выровнен согласно требованиям Вашего процессора), сегмент .boot ?

PS Какой у Вас процессор ?
PPS Работаем в ЕДК (PowerPC) 2 года, собирали самые разные аппаратные платформы и программы, проблем на было...
tolik1
Цитата(Дмитрий Мазунин @ Jun 2 2008, 16:12) *
Размеры секций Вы править, конечно, не можете - они зависят от Вашей программы и данных.
Я говорил - ПОСМОТРЕТЬ размеры, просуммировать их все - входят ли в память, какие из них (возможно) слишком большие ?
Правильно ли расположен сегмент .vectors (выровнен согласно требованиям Вашего процессора), сегмент .boot ?

PS Какой у Вас процессор ?
PPS Работаем в ЕДК (PowerPC) 2 года, собирали самые разные аппаратные платформы и программы, проблем на было...

Размеры секций показываютя на основе ELF файла. А его-то получить не получается.

Цитата(tolik1 @ Jun 2 2008, 17:53) *
Размеры секций показываютя на основе ELF файла. А его-то получить не получается.

Вы были правы насчет размера памяти сделал 128К начал компилиться. Однако начались другие чудеса. При включении в функции main процедур инициализации прерывания
XExc_Init
XExc_RegisterHandler
XExc_mEnableExceptions программа на кристале перестает грузиться вообще. Как только я их(вызовы) коментирую - работает
Дмитрий Мазунин
Правильную настройку системы прерываний смотрите в примерах ЕДК EDK\sw\XilinxProcessorIPLib\drivers\intc_v1_10_c\examples\xintc_example.c

Также теперь для обработки прерывания Вам может не хватать размера стека - увеличьте его.

Далее, работоспособность Вашей программы может зависеть от характера прерывания (уровень или фронт), а также от устройства, генерирующего прерывание - возможно, устройство требует подтверждения для снятия прерывания.
tolik1
Цитата(Дмитрий Мазунин @ Jun 3 2008, 10:25) *
Правильную настройку системы прерываний смотрите в примерах ЕДК EDK\sw\XilinxProcessorIPLib\drivers\intc_v1_10_c\examples\xintc_example.c

Также теперь для обработки прерывания Вам может не хватать размера стека - увеличьте его.

Далее, работоспособность Вашей программы может зависеть от характера прерывания (уровень или фронт), а также от устройства, генерирующего прерывание - возможно, устройство требует подтверждения для снятия прерывания.

Огромное СПАСИБО за ответы. Похоже разрулил. cheers.gif
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.