|
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 С/С++ подобного описания что-то не нахожу… Может кто подскажет, где это описано или приведет примеры.
|
|
|
|
2 страниц
< 1 2
|
 |
Ответов
(15 - 22)
|
Jun 20 2008, 12:13
|
Местный
  
Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377

|
Цитата(Kuzmi4 @ Jun 20 2008, 12:51)  2 Волощенко - не забудьте поделится результами - самому интересно  //Это описание переменных в ssramalt_u8 mm[16] __attribute__ ((section (".ssram.rwdata"))); // Это часть кода для вывода на консоль for (y=0;y<10;y++) mm[y]=y; for (y=0;y<10;y++) {printf(", mm=%04x\n", mm[y]);}; //а программа и все остальное onchip_memory
|
|
|
|
|
Jun 20 2008, 15:22
|
Местный
  
Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377

|
Цитата(Kuzmi4 @ Jun 20 2008, 15:23)  Вы этот сегмент как то описывали где то, или просто добавили в систему SSRAM и заюзали атрибут ? Я работаю с платформой DK-NIOS-2S60N, в ней SSRAM, Flash, DDRAM, а также память в FPGA. С помощью SOPC подключил SSRAM и Flash, надо же как-то их задействовать. Как назначить там переменные, см.предыдущий пост. В свойствах syslib по умолчанию для всех переменных задана onchip_memory что в FPGA, а атрибутами можно в нужном месте переназначать их локализацию. Подсказка дана id_gene, за что ему большое спасибо, а главная ссылка на Nios II Software Developer's Handbook, глава Memory Usage/Memory Sections.
|
|
|
|
|
Jul 22 2008, 09:32
|
Местный
  
Группа: Свой
Сообщений: 305
Регистрация: 22-06-07
Из: Санкт-Петербург
Пользователь №: 28 617

|
Цитата(Волощенко @ Jun 19 2008, 14:00)  Как средствами NiosII C/C++ отображается локализация данных в разных областях памяти есть пример на сайле альтеры tcm_vs_cache.cи Using Nios II Tightly Coupled Memory.pdf к ниму; там можно посмотреть инициализацию Tightly coupled memory / On-chip / SDRAM (и вообще интересный примерчик, о производительности)
|
|
|
|
|
Jul 23 2008, 16:37
|
Местный
  
Группа: Свой
Сообщений: 347
Регистрация: 16-02-06
Из: г.Николаев, Украина
Пользователь №: 14 377

|
Цитата(yura-w @ Jul 22 2008, 12:32)  есть пример на сайле альтеры и Using Nios II Tightly Coupled Memory.pdf Спасибо за новую информацию! По поводу главного вопроса топика, как уже писал, обошелся для размещения в ssram так: alt_u8 RsInp [32] __attribute__ ((section (".ssram.rwdata"))); alt_u8 RsOut [256] __attribute__ ((section (".ssram.rwdata"))); alt_u8 RsT, RsN, RsC, RsK __attribute__ ((section (".ssram.rwdata"))); alt_u8 *RsI, *RsO __attribute__ ((section (".ssram.rwdata"))); Если не добавить атрибутику типа __attribute__ ((section (".ssram.rwdata"))), то компилятор автоматически размещает переменные в onchip_memory..., т.к. в свойствах System Library для всех типов памяти у меня прописано onchip_memory. Вот еще вопрос: На моей платформе DK-NIOS-2S60N есть и DDRAM, там емкости немеряно... Пока не понял, как к ней подступиться. Похоже надо корку где-то искать, или самому синтезировать, видать, без нее не обойтись. Кто и как разрешил эту проблему? Поделитесь опытом!!!
|
|
|
|
|
Jul 24 2008, 07:35
|

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

|
Цитата(Волощенко @ Jul 23 2008, 23:37)  Вот еще вопрос: На моей платформе DK-NIOS-2S60N есть и DDRAM, там емкости немеряно... Пока не понял, как к ней подступиться. Похоже надо корку где-то искать, или самому синтезировать, видать, без нее не обойтись. Кто и как разрешил эту проблему? Поделитесь опытом!!! с месяц назад пробовал на циклон3-стартер-кит. основная проблема была-скомпилировать проект, для DDR нужно правильные констрейны на I/O навесить, иначе тупо не соберется. лучше всего взять пример с фтп альтеры или на ниосфоруме пошарить. корку я брал альтеровскую, но видел и примеры с опенкорками. время будет, вкорячу на эту плату линукс
|
|
|
|
3 чел. читают эту тему (гостей: 3, скрытых пользователей: 0)
Пользователей: 0
|
|
|