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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> IAR 5.11 для ARM, как быть с инициализированной константой по адресу?
LeshaL
сообщение Feb 22 2008, 11:29
Сообщение #1


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



В ИАР для АРМ версии 4.XX инициализированную константу, расположенную во флеш по определенному адресу я описывал как:

const unsigned char date_def @ 0x102 = DATE_;

В версиях 5.ХХ запретили инициализированным константам явно указывать адреса хранения. Т.е. транслятор ругается:

Error[Be022]: location address not allowed for initialized variables (writable variables without the __no_init attribute)...

Как это можно обойти в новом ИАРе?
Собственно, мне нужно чтобы в памяти программ по определенному адресу забить константу, к которой можно будет обращаться внутри программы.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 11:54
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Линкер этим занимается - создаете сегментик с переменной и линкуете его куда хотите.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
LeshaL
сообщение Feb 22 2008, 12:04
Сообщение #3


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



Цитата(zltigo @ Feb 22 2008, 16:54) *
Линкер этим занимается - создаете сегментик с переменной и линкуете его куда хотите.


У меня девять таких переменных. Для каждой переменной свой сегментик создавать?
Go to the top of the page
 
+Quote Post
KRS
сообщение Feb 22 2008, 12:29
Сообщение #4


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(LeshaL @ Feb 22 2008, 15:04) *
У меня девять таких переменных. Для каждой переменной свой сегментик создавать?

Только так!
Раньше просто компилер занимался подготовительной работой для штатной инициализации сегментов...
А теперь это делает линкер.
недавно как раз об еэтом написал.
http://electronix.ru/forum/index.php?showt...3554&st=115
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 22 2008, 14:41
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(LeshaL @ Feb 22 2008, 15:04) *
У меня девять таких переменных. Для каждой переменной свой сегментик создавать?

Ну если не хочется, то подумайте А ЗАЧЕМ ОНИ ВООБЩЕ НУЖНЫ?
Сможете ответить сами себе на этот вопрос? Я, могу ответить только по поводу одной единственной переменной для bootloader-а NXP. Все.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
LeshaL
сообщение Feb 26 2008, 05:04
Сообщение #6


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



Цитата(zltigo @ Feb 22 2008, 19:41) *
Ну если не хочется, то подумайте А ЗАЧЕМ ОНИ ВООБЩЕ НУЖНЫ?
Сможете ответить сами себе на этот вопрос? Я, могу ответить только по поводу одной единственной переменной для bootloader-а NXP. Все.


Ну нам, например, для своего программатора нужно хранить в бинарнике по определенному адресу тип прошивки, версию, дату. Т.е. чтобы программатор при загрузке бинарника выводил для пользователя эту информацию из прошивки.

Корявость какая-то в новом ИАРе делать это через линкер. В чем смысл?
Go to the top of the page
 
+Quote Post
VAI
сообщение Feb 26 2008, 06:30
Сообщение #7


Профессионал
*****

Группа: Модераторы
Сообщений: 1 120
Регистрация: 17-06-04
Пользователь №: 37



Цитата
У меня девять таких переменных. Для каждой переменной свой сегментик создавать?

объедините эти переменные в структуру и поместите её в свой сегмент.


--------------------
Если зайца бить, его можно и спички научить зажигать
Сколько дурака не бей - умнее не будет. Зато опытнее
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 26 2008, 07:30
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(LeshaL @ Feb 26 2008, 08:04) *
...нужно хранить в бинарнике по определенному адресу тип прошивки, версию, дату. Т.е. чтобы программатор при загрузке бинарника выводил для пользователя эту информацию из прошивки.

Для этого, совершенно незачем "по определенному адресу" - достаточно иметь сигнатуру после которой нужная информация идет, или, например использовать указатель на эту информацию расположенный в startup после таблицы(которая уже согласно ценых указаний линкеру размещается в фиксированном месте) векторов, или ....
Цитата
Корявость какая-то в новом ИАРе делать это через линкер. В чем смысл?

Это не корявость - этим действительно работа линкера. Вам уже обьясняли, что в старом IAR был сделан прибамбас скрывающий эту физическую сущность. При пререходе на унифицированные форматы объектых файлов с этим непонятным наворотом провоцирущим написание лобового, непереносимого и мешающего оптимальной линковке кода наворотом рассались. Если хотите, можете совершенно спокойно все Ваши цифирки поместить в один сегмент и сказать линкеру куда его залинковать.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
LeshaL
сообщение Feb 26 2008, 09:15
Сообщение #9


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



Цитата(zltigo @ Feb 26 2008, 12:30) *
Для этого, совершенно незачем "по определенному адресу" - достаточно иметь сигнатуру после которой нужная информация идет, или, например использовать указатель на эту информацию расположенный в startup после таблицы(которая уже согласно ценых указаний линкеру размещается в фиксированном месте) векторов, или ....


Зачем создавать какую-то сигнатуру, если была возможность записать инициализированную константу по конкретному адресу? Тем более речь идет в моем конкретном случае о программе, которая постоянно разрабатывается и модифицируется на протяжении пяти лет, работающая по мере наращивания на процессорах от зайлога, атмеги128, атмеги256 до лпс2138 и менять достаточно удобный способ идентификации прошивок данными по конкретному адресу, который используется еще с первых прошивок никак не подходит. Потому как выпущено уже столько приборов и версий. А объяснять каждому, что наша программа не обновилась, потому что мы перешли на новую версию ИАРа, заказчиков мало колышит...

Ну да ладно... Это всле лирика.
Буду решать проблемы секциями по адресу. Спасибо всем за ответы и советы.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 26 2008, 09:23
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(LeshaL @ Feb 26 2008, 12:15) *
Зачем создавать какую-то сигнатуру, если была возможность записать инициализированную константу по конкретному адресу?

Она и сечас есть.
Цитата
Тем более речь идет в моем конкретном случае о программе...

К сожалению, производители компиляторов любят плодить сущности и закладывать ненужные собственные фичи, дабы подсадить определенный круг пользователей на свой конкретный компилятор sad.gif. Просто 5 лет назад, надо было подумать smile.gif и сделать независимо ни от фич компилятора ни от конкретного линкера.
Цитата
Буду решать проблемы секциями по адресу.

Да нет там в общем-то проблем.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
LeshaL
сообщение Feb 27 2008, 10:20
Сообщение #11


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



Цитата(zltigo @ Feb 26 2008, 14:23) *
К сожалению, производители компиляторов любят плодить сущности и закладывать ненужные собственные фичи, дабы подсадить определенный круг пользователей на свой конкретный компилятор sad.gif. Просто 5 лет назад, надо было подумать smile.gif и сделать независимо ни от фич компилятора ни от конкретного линкера.


Если все делать независимо от фич компилятора, линкера, то надо самому писать свой компилятор и линкер. А также еще желательно переписать все библиотечные функции под себя, чтобы не выплывало типа sprintf_P и т.п.

Зачем Вы ассемблерные тексты переделывали для IAR 5.10, а сразу не написали их так, чтобы через пять лет как появится IAR 5.10 Ваши тексты без исправлений на нем заработали? rolleyes.gif

Ну это снова на лирику скатились smile.gif
А по-существу проблема решилась созданием двух секций в *.icf. Благо в одной секции инициализированные константы должны были следовать одна за другой.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 27 2008, 11:04
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(LeshaL @ Feb 27 2008, 13:20) *
Зачем Вы ассемблерные тексты переделывали....

А я НЕ поминал ассемблерные тексты в качестве образца независимости и портируемости, так-что к чему все это?
Цитата
А по-существу проблема решилась ..

В том и дело, что проблемы-то и нет. Просто разобрались с ИНСТРУМЕНТОМ который для этой работы предназначен. При переходе на другой инструментарий надо будет с ними разбираться, НО НЕ с исходными текстами.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Ынжынэр
сообщение Apr 2 2008, 08:01
Сообщение #13





Группа: Новичок
Сообщений: 4
Регистрация: 24-08-06
Из: Минск
Пользователь №: 19 793



На эту ж тему позвольте вопросик.
Не могу из сишного кода в IAR 5.11 закинуть массив в созданную секцию.
В асме пишу так:

SECTION Signatura_section:CONST
DCB '1','2','3'
END

и все работает, а если в в main.c написать так:

#pragma section = "Signatura_section"
char const Signatura[] @ "Signatura_section" = "123";

линкер строку в упор не видит, даж секцию не создает.
Не подскажете в чем может быть дело?

Сообщение отредактировал Ынжынэр - Apr 2 2008, 08:03
Go to the top of the page
 
+Quote Post
KRS
сообщение Apr 2 2008, 10:45
Сообщение #14


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(Ынжынэр @ Apr 2 2008, 12:01) *
линкер строку в упор не видит, даж секцию не создает.

А ссылки на эту строку есть?
Go to the top of the page
 
+Quote Post
LeshaL
сообщение Apr 2 2008, 10:52
Сообщение #15


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

Группа: Свой
Сообщений: 166
Регистрация: 14-01-06
Пользователь №: 13 160



При оптимизации объявленный сегмент может быть выброшен. Попробуйте убрать оптимизацию чтобы это проверить.
Go to the top of the page
 
+Quote Post

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

 


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


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