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

 
 
> Tightly Coupled Memory
sifadin
сообщение Jul 1 2011, 09:47
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 443
Регистрация: 11-02-09
Пользователь №: 44 698



Есть программа размером под 2Мб, которая выполняется из SDRAM
Столкнулся с тем что вот такой кусок кода
col1=*videomem;

if ((col1 & 0xff000000)!=0) return 1;
if (1) {
if ((col1 & 0xff000000)==0)
offset1=X1;
offset1=offset1*1024;
offset1=offset1+Y1;
offset1=(offset1<<2);
}
выполняется 1,5 мкс при частоте 100МГц
Решил повысить быстродействие, введением Tightly Coupled Memory под инструкции
И сразу столкнулся с трудностью - как запихнуть нужную мне процедуру в эту память
При объявлении
void PP () __attribute__ ((section (".onchip_memory2_0_s2")));
компилятор выдает ошибку relocation truncated to fit
смысл ее мне не очень ясен но видимо линкер не может поместить ее в эту область потому что остальной код
в SDRAM
как быть? Весь код туда не влезет


Сообщение отредактировал sifadin - Jul 1 2011, 09:48
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
id_gene
сообщение Jul 5 2011, 08:03
Сообщение #2


carpe manana
***

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



+1 смотрите листинг. Можно промоделировать, если ресуры позволяют.

Поковырял свои старые коды, вот такая строчка у меня есть (переложил одну функцию во флешку)
void my_init (void) __attribute__ ((section (".cfi_flash_2.txt")));

Почему с txt - не помню wacko.gif
При этом строчка это в файле заголовков (при декларации), а не при описании функции.

Как называются секции в вашем случае можно посмотреть в _syslib/Release/system_description/generated.x

Но лучше, конечно, разобраться, почему так медленно.
Go to the top of the page
 
+Quote Post
sifadin
сообщение Jul 8 2011, 10:46
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 443
Регистрация: 11-02-09
Пользователь №: 44 698



с O3 время того куска составляет 100нс вроде это соответствует

А чем череват O3?

Go to the top of the page
 
+Quote Post
vadimuzzz
сообщение Jul 8 2011, 11:19
Сообщение #4


Гуру
******

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



Цитата(sifadin @ Jul 8 2011, 17:46) *
А чем череват O3?

есть риск получить нестабильную программу. имеет смысл только в приложении к какому-то конкретному коду, иначе все эти разговоры - сравнение теплого с мягким. на одних задачах может дать падение производительности, на других - прирост, на третьих - вообще глюки. т.е. для конкретной программы можно поиграться с флагами (-O* это еще не все), поглядеть на результат. еще это зависит от версии компилятора. вот на пальцах: http://www.insidepro.com/kk/231/231r.shtml
Go to the top of the page
 
+Quote Post
sifadin
сообщение Jul 8 2011, 12:28
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 443
Регистрация: 11-02-09
Пользователь №: 44 698



Цитата(vadimuzzz @ Jul 8 2011, 15:19) *
есть риск получить нестабильную программу. имеет смысл только в приложении к какому-то конкретному коду, иначе все эти разговоры - сравнение теплого с мягким. на одних задачах может дать падение производительности, на других - прирост, на третьих - вообще глюки. т.е. для конкретной программы можно поиграться с флагами (-O* это еще не все), поглядеть на результат. еще это зависит от версии компилятора. вот на пальцах: http://www.insidepro.com/kk/231/231r.shtml


Спасибо, посмотрю
Go to the top of the page
 
+Quote Post



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

 


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


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