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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> NiosII, C/C++., Локализация данных в пространстве адресов.
Волощенко
сообщение Jun 19 2008, 10:00
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377



Всем привет!
В NiosII используется Avalon Memory-Mapped (Avalon-MM) interfaces, как я понимаю, основанный на архитектуре с общим пространством адресов. В это пространство может включаться SRAM, DRAM, Flash, Onchip_Memory и периферия, начальные адреса, которых определены в system.h.
Вопрос такой: Как средствами NiosII C/C++ отображается локализация данных в разных областях памяти? Например, один массив переменных нужно разместить в SRAM, другой массив констант во Flash и т.п., а обращаться к этим данным через указатели.
Работая с компиляторами для микроконтроллеров архитектур 51, 196 и AVR, заметил, что для каждого описаны свои способы локализации, а для NiosII С/С++ подобного описания что-то не нахожу… Может кто подскажет, где это описано или приведет примеры.
Go to the top of the page
 
+Quote Post
Stewart Little
сообщение Jun 19 2008, 10:43
Сообщение #2


Лентяй
******

Группа: Свой
Сообщений: 2 203
Регистрация: 11-10-04
Из: Санкт-Петербург
Пользователь №: 843



Попробуйте поискать в направлении сегменотв памяти:
сегмент кода (.text)
сегмент инициализируемых данных (.rodata)
сегмент неинициализируемых данных (.rwdata)
сегмент стека (.stack) - до кучи smile.gif

В принципе, это общепринятая концепция для 32-разрядных процессоров.


--------------------
Чтобы слова не расходились с делом, нужно молчать и ничего не делать...
Go to the top of the page
 
+Quote Post
Kuzmi4
сообщение Jun 19 2008, 11:50
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 3 304
Регистрация: 13-02-07
Из: 55°55′5″ 37°52′16″
Пользователь №: 25 329



2 Волощенко - а не проще ли наваять на асме свою процедрку начального переброса и обращения и использовать их ?

Хотя реализация средствами GNU тоже интересна..
Go to the top of the page
 
+Quote Post
Волощенко
сообщение Jun 19 2008, 12:39
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377



Вот, например, в Keil C51 есть такие виды памяти: data, xdata, bdata, sbit, pdata. И есть возможность разместить данные по своему желанию (ниже отрывки кода):
data byte RiT, RoT;
xdata byte Ri[32],Ro[260]; // --- Block for RS-232 communication ---
bdata Flags;
sbit MainLoop = Flags^0; //Flag for Main loop
*((char pdata *)Rx)=*(pEthPcm++);

аналогичная ситуация в IAR для AVR
word wa, wb, wc, wd, w0;
byte FlagTIMER0;
__eeprom byte IEEE_addresse[6];
__flash byte CLC1 []={0x01, 0x64, 0x89, 0x00};


Понятно, что это другой дивизион... Но хотелось бы видеть что-то аналогичное и в NiosII C/C++. Поэтому вопрос остается прежним: кто и как в таких ситуациях поступает (см. первый пост). Ведь данные, иногда, надо размещать по разным адресам.

to Kuzmi4. К асму в крайнем случае перейти можно, но хотелось бы разобраться с C/С++...
Go to the top of the page
 
+Quote Post
cms
сообщение Jun 19 2008, 12:58
Сообщение #5


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

Группа: Свой
Сообщений: 168
Регистрация: 6-07-04
Пользователь №: 266



каждому сегменту памяти типа .text/.data/.code можно выбирать компонент памяти, в котором он размещается. если работаете с NIOSII IDE, то посмотрите на property SystemLibrary - там в комбо-боксах выпадают списки всех сгенеренных в SOPC Builder в компонент памяти.

если работаете скриптами - то там эти проперти прописываются при вызове bsp-билдера в tcl-скрипте
Go to the top of the page
 
+Quote Post
id_gene
сообщение Jun 19 2008, 16:55
Сообщение #6


carpe manana
***

Группа: Свой
Сообщений: 321
Регистрация: 2-06-05
Пользователь №: 5 659



Почему бы не сделать просто:
Код
#include <system.h>

char *foo_CONST = DDR_BASE;
unsigned int *foo_data = ONCHIP_BASE;

foo_CONST[0] = 0x0;
foo_CONST[3] = 0x3;

foo_data [0] = 0x1234;
foo_data [123] = 0xABCD;
Go to the top of the page
 
+Quote Post
cms
сообщение Jun 19 2008, 17:47
Сообщение #7


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

Группа: Свой
Сообщений: 168
Регистрация: 6-07-04
Пользователь №: 266



Цитата(id_gene @ Jun 19 2008, 20:55) *
Почему бы не сделать просто:
Код
#include <system.h>

char *foo_CONST = DDR_BASE;
unsigned int *foo_data = ONCHIP_BASE;

foo_CONST[0] = 0x0;
foo_CONST[3] = 0x3;

foo_data [0] = 0x1234;
foo_data [123] = 0xABCD;


A а если bsp builder по ONCHIP_BASE разместил код или стек?
Go to the top of the page
 
+Quote Post
torik
сообщение Jun 19 2008, 17:50
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 2 113
Регистрация: 1-11-05
Пользователь №: 10 359



А что, указать локализацию в свойствах проекта не хватает, не?


--------------------
Быть. torizin-liteha@yandex.ru
Go to the top of the page
 
+Quote Post
vadimuzzz
сообщение Jun 20 2008, 00:15
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 2 291
Регистрация: 21-07-05
Пользователь №: 6 988



все компоненты системы на базе ниоса memory-mapped, т.е. достаточно знать нужный адрес.
а потом IOWR(address,data) или IORD(address)
если это устройство(любое), то смотрим в файл system.h + файл описания регистров устройства.
если это память, то еще проще: IOWR(address,data) или IORD(address).
насчет разделения памяти на сегменты-это удобно, если есть RO-данные (их во флеш), остальные в RAM.
если флеш - CFI, то вообще сказка, работа с RAM и ROM осуществляется одними и теми же макросами IORD,IOWR.
если EPCS-то посложнее, но ненамного.
если мне не изменяет склероз, то квалификатор типа const в языке C как раз и указывает компилятору,
что переменную надо кинуть в секцию rodata.
Go to the top of the page
 
+Quote Post
Kuzmi4
сообщение Jun 20 2008, 07:03
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 3 304
Регистрация: 13-02-07
Из: 55°55′5″ 37°52′16″
Пользователь №: 25 329



2 vadimuzzz - это я собсно и имелл ввиду.

2 Волощенко - тут на ум пришло - в GCC есть понятие секций - там в WinAVR`е помню можно было атрибутами указать, что писать надо в еепром, например, а потом в линкере если что подредактить - может стоит в эту сторону покопать ??
Go to the top of the page
 
+Quote Post
Harbour
сообщение Jun 20 2008, 07:13
Сообщение #11


Местами Гуру
*****

Группа: Validating
Сообщений: 1 103
Регистрация: 5-12-04
Пользователь №: 1 323



Стандартная тема, на форуме сплошь и рядом обсуждается. Вкратце - память проекта состоит из разных "секций", нменованных по умолчанию (.text/.data/.bss) и заданных разработчиком в линкер-файле. Разработчик составляет карту памяти (on-chip-ram/ext-ram/flash), именует секции и определяет в какой области памяти оные будут размещены. Далее в программе указывает (в gcc это делается с помошью attribute section) в какой секции размещать указаные переменные. При генерации прошивки создаются (objcopy) бинарные файлы соответствующие кажной секции. Но это идеальная картина - для корректной работы программы необходимо чтобы данные оказались по нужным адресам в флеше/озу/etc. после ресета. Тут вступает в дело startup-code, который выполняется перед main - обычно подходит тот что предлагается фирмой по умолчанию, но иногда для удобственности можно написать свой - задача этого code именно и состоит в приведении устройств памяти в изначальное состояние так необходимое для работы программы. В embedded вариантах этот код еще может заниматься инициализацией BSP. например заполнение irq table, обнуление static vars, вызов конструкторов (c++) и т.д.
Чем хорош gcc/gas - не нужно парится по изучению 20 линкеров и способов передачи ему параметров из программ - выучил один и пошел пить пиво wink.gif
Go to the top of the page
 
+Quote Post
id_gene
сообщение Jun 20 2008, 07:46
Сообщение #12


carpe manana
***

Группа: Свой
Сообщений: 321
Регистрация: 2-06-05
Пользователь №: 5 659



Цитата(cms @ Jun 19 2008, 21:47) *
A а если bsp builder по ONCHIP_BASE разместил код или стек?
Ну я, естественно, имел ввиду, что разработчик знает, где у него что лежит и хочет положить свой массив данных в конкретную пустую область конкретной памяти.

Как располагать функции в нужных секциях написано в Sw developer book в главе Memory Usage/Memory Sections.
Можно ли управлять таким же образом массивами данных?
Go to the top of the page
 
+Quote Post
Волощенко
сообщение Jun 20 2008, 08:35
Сообщение #13


Местный
***

Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377



Спасибо всем за ответы, стало понятней.
Go to the top of the page
 
+Quote Post
Kuzmi4
сообщение Jun 20 2008, 09:51
Сообщение #14


Гуру
******

Группа: Свой
Сообщений: 3 304
Регистрация: 13-02-07
Из: 55°55′5″ 37°52′16″
Пользователь №: 25 329



2 Волощенко - не забудьте поделится результами - самому интересно
smile.gif
Go to the top of the page
 
+Quote Post
608
сообщение Jun 20 2008, 11:51
Сообщение #15


Участник
*

Группа: Участник
Сообщений: 70
Регистрация: 8-05-07
Пользователь №: 27 604



Да, уточните...

Сообщение отредактировал 608 - Jun 20 2008, 11:52
Go to the top of the page
 
+Quote Post

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

 


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


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