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

 
 
> Прошивание Spartan3 с помощью AVR
StanislavF
сообщение Jan 15 2010, 15:37
Сообщение #1





Группа: Участник
Сообщений: 9
Регистрация: 15-01-10
Пользователь №: 54 837



Здравствуйте.

На плате использую два Spartan3, которые прошиваются с помощью AVR Atmega2561, последовательно, один за другим. Использую WinAVR 2010****. В заголовочном файле в массиве размещаю сам код для ПЛИС. При компиляции кода компилятор ругается:
./sensor_part.h:4227: error: size of array is too large
В коде:
CODE
unsigned char xsf_buf0[] PROGMEM ={0xFF.......

Этот массив -- и есть прошивка для ПЛИС, файл bin.

Можно ли как-то по другому прошивать ПЛИС с помощью AVR? Возможно, без использования массивов.

Буду очень благодарен за советы и личный опыт.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
SysRq
сообщение Jan 15 2010, 16:43
Сообщение #2


Чайник, 1 литр
****

Группа: Свой
Сообщений: 655
Регистрация: 17-05-06
Из: Moscow
Пользователь №: 17 168



http://www.nongnu.org/avr-libc/user-manual...#faq_binarydata

--

Я делаю так (ПЛИС не помню, МК - ATMega128):

Файл *.cmd с командами на конвертирование исходного бинарного файла (у меня - fpga_zeroconfig.rbf, 77655 байт) в объектный (fpga_zeroconfig.o):
Код
@echo Creating relocatable object file with data for FPGA:

@avr-objcopy -v --rename-section .data=.progmem.data,contents,alloc,load,readonly,data -I binary -O elf32-avr fpga_zeroconfig.rbf fpga_zeroconfig.o
@avr-objdump -t fpga_zeroconfig.o
@avr-size fpga_zeroconfig.o

@pause

Далее я его тупо указываю линкеру в Makefile проекта:
Код
OBJ = $(SRC:%.c=$(OBJDIR)/%.o) $(CPPSRC:%.cpp=$(OBJDIR)/%.o) $(ASRC:%.S=$(OBJDIR)/%.o) fpga_zeroconfig.o

И использую где надо:
Код
extern PGM_P _binary_fpga_zeroconfig_rbf_start;
extern PGM_P _binary_fpga_zeroconfig_rbf_end;

//...

uint32_t sz = GET_FAR_ADDRESS(_binary_fpga_zeroconfig_rbf_end) - GET_FAR_ADDRESS(_binary_fpga_zeroconfig_rbf_start);

//...
for(uint32_t i = 0; i < sz; i++)
    {
        // = pgm_read_byte_far(GET_FAR_ADDRESS(_binary_fpga_zeroconfig_rbf_start) + i);        
    }

Макрос GET_FAR_ADDRESS взят на avrfreaks.
Go to the top of the page
 
+Quote Post
Student Pupkin
сообщение Jan 20 2010, 19:39
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 328
Регистрация: 23-05-08
Пользователь №: 37 760



Цитата(SysRq @ Jan 15 2010, 19:43) *
Я делаю так (ПЛИС не помню, МК - ATMega128):
Файл *.cmd с командами на конвертирование исходного бинарного файла

А вариант написать простенькую консольную програмку, конвертирующую файл прошивки в заголовочный h-файл не рассматривали?
Go to the top of the page
 
+Quote Post
defunct
сообщение Jan 21 2010, 18:12
Сообщение #4


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Цитата(Student Pupkin @ Jan 20 2010, 21:39) *
конвертирующую файл прошивки в заголовочный h-файл не рассматривали?

Вот чего не надо делать так это конвертировать бинарник в h-файл. Header файл не предназначен для того чтобы в нем хранить данные.
конвертировать надо в .c файл, и использовать по месту с помощью extern.

Цитата
В avr-gcc ограничение в 64к на размер массива,

ну так сделать два массива, простенькая консольная программа, думаю без труда сможет посчитать до 65535 и затем создать второй массив.
Go to the top of the page
 
+Quote Post



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

 


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


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