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

 
 
 
Reply to this topicStart new topic
> PPC(V4Fx)+LinkerScript
tolik1
сообщение Jun 15 2009, 06:33
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 199
Регистрация: 2-03-05
Из: МОСКВА
Пользователь №: 3 016



Делаю проект с PPC на Virtex4.(ISE+EDK 9.2) Делаю память для процессора 32К (PlbBram) При генерации LinkerScript получаю ошибку, что секция VECTORS должна быть выровнена по 64К. Пытаюсь удалить эту секцию(прерывания я не использую) - не получается. Как мне быть? Борюсь за блочную память....
Заранее спасибо.
Go to the top of the page
 
+Quote Post
Cont
сообщение Jun 15 2009, 08:20
Сообщение #2


Частый гость
**

Группа: Участник
Сообщений: 112
Регистрация: 10-11-06
Из: Москва
Пользователь №: 22 176



Добрый день! Если у Вас появилась эта секция, то скорее всего у Вас в системе есть контроллер прерываний. Решить проблему можно разными способами. Убрать контроллер, либо создать проект вручную и самому написать makefile и LinkerScript и назначить эту секцию например во внешнюю память или попробовать уменьшить ее.
Go to the top of the page
 
+Quote Post
DmitryR
сообщение Jun 15 2009, 08:40
Сообщение #3


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

Группа: Свой
Сообщений: 1 535
Регистрация: 20-02-05
Из: Siegen
Пользователь №: 2 770



Цитата(Cont @ Jun 15 2009, 12:20) *
Добрый день! Если у Вас появилась эта секция, то скорее всего у Вас в системе есть контроллер прерываний.

IMHO это вовсе необязательно, как минимум там всегда будет vector_reset. Но выйти из этой ситуации можно легко, написав самостоятельно устройство памяти на шине, которое будет занимать последние 64K но откликаться только на адрес 0xFFFFFFFC инструкцией безусловного перехода на -4 (bootloop).
Go to the top of the page
 
+Quote Post
Cont
сообщение Jun 15 2009, 12:35
Сообщение #4


Частый гость
**

Группа: Участник
Сообщений: 112
Регистрация: 10-11-06
Из: Москва
Пользователь №: 22 176



У меня не было ситуации, чтобы без контроллера прерываний я не мог задать bram блок размера < 64 kb.

Сообщение отредактировал Cont - Jun 15 2009, 12:37
Go to the top of the page
 
+Quote Post
tolik1
сообщение Jun 16 2009, 06:15
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 199
Регистрация: 2-03-05
Из: МОСКВА
Пользователь №: 3 016



Цитата(Cont @ Jun 15 2009, 12:20) *
Добрый день! Если у Вас появилась эта секция, то скорее всего у Вас в системе есть контроллер прерываний. Решить проблему можно разными способами. Убрать контроллер, либо создать проект вручную и самому написать makefile и LinkerScript и назначить эту секцию например во внешнюю память или попробовать уменьшить ее.

Контроллера прерываний нет. И внешней памяти тоже.

Цитата(DmitryR @ Jun 15 2009, 12:40) *
IMHO это вовсе необязательно, как минимум там всегда будет vector_reset. Но выйти из этой ситуации можно легко, написав самостоятельно устройство памяти на шине, которое будет занимать последние 64K но откликаться только на адрес 0xFFFFFFFC инструкцией безусловного перехода на -4 (bootloop).

А можно подробнее. Как занять 64К а откликаться тока на вектор сброса? Заранее спасибо.
Go to the top of the page
 
+Quote Post
Cont
сообщение Jun 16 2009, 10:48
Сообщение #6


Частый гость
**

Группа: Участник
Сообщений: 112
Регистрация: 10-11-06
Из: Москва
Пользователь №: 22 176



Записать в регистр инструкцию перехода, а параметрах BASEADDR, HIGHADDR пользовательского ядра указать диапазон в 64k.

Сообщение отредактировал Cont - Jun 16 2009, 10:58
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 28th June 2025 - 11:57
Рейтинг@Mail.ru


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