|
NiosII, C/C++., Локализация данных в пространстве адресов. |
|
|
|
Jun 19 2008, 10:00
|
Местный
  
Группа: Свой
Сообщений: 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 С/С++ подобного описания что-то не нахожу… Может кто подскажет, где это описано или приведет примеры.
|
|
|
|
|
Jun 19 2008, 10:43
|

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

|
Попробуйте поискать в направлении сегменотв памяти: сегмент кода (.text) сегмент инициализируемых данных (.rodata) сегмент неинициализируемых данных (.rwdata) сегмент стека (.stack) - до кучи  В принципе, это общепринятая концепция для 32-разрядных процессоров.
--------------------
Чтобы слова не расходились с делом, нужно молчать и ничего не делать...
|
|
|
|
|
Jun 19 2008, 12:39
|
Местный
  
Группа: Свой
Сообщений: 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/С++...
|
|
|
|
|
Jun 19 2008, 16:55
|
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;
|
|
|
|
|
Jun 19 2008, 17:47
|
Частый гость
 
Группа: Свой
Сообщений: 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 разместил код или стек?
|
|
|
|
|
Jun 20 2008, 00:15
|

Гуру
     
Группа: Свой
Сообщений: 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.
|
|
|
|
|
Jun 20 2008, 07:46
|
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. Можно ли управлять таким же образом массивами данных?
|
|
|
|
|
Jun 20 2008, 11:51
|
Участник

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

|
Да, уточните...
Сообщение отредактировал 608 - Jun 20 2008, 11:52
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|