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

 
 
 
Reply to this topicStart new topic
> как разместить подпрограмму по заданному адресу
1921
сообщение Jul 25 2011, 07:23
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 56
Регистрация: 29-09-10
Пользователь №: 59 820



Почтенные гуру!
Вот выскочила проблемка, не подскажите ли: можно ли разместить подпрограммку по определённому адресу в flash?
Я уже делал такое с данными, прописав в линкере сегмент по определённому адресу:

#pragma constseg=MY_SEG;
<данные>
#pragma constseg=default

А можно ли такую же вещь сделать с подпрограммой? И как это сделать?

main();
{
prog1();
prog2(); - допустим, я хочу разместить эту программу по определённому адресу, а ещё лучше, в выделенном сегменте, в котором будет сидеть только она. Можно?
prog3();
}

Я сейчас полезу в первоисточники, но ваше направляющее воздействие позволит значительно облегчить мои метания. Если не трудно, поделитесь опытом!
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jul 25 2011, 07:31
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Почитайте про секции.
В GCC это будет __attribute__ ((section = "")), в IAR - #pragma location (емнип) или section (давно в руки не брал, забыл уже).

А для чего, если не секрет? Недавно тоже пробовали для неких целей.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
1921
сообщение Jul 25 2011, 10:54
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 56
Регистрация: 29-09-10
Пользователь №: 59 820



Цитата(MrYuran @ Jul 25 2011, 11:31) *
Почитайте про секции.
В GCC это будет __attribute__ ((section = "")), в IAR - #pragma location (емнип) или section (давно в руки не брал, забыл уже).

А для чего, если не секрет? Недавно тоже пробовали для неких целей.


Поясню. Возможно, придётся реализовывать перепрошивку блока по GPRS. Хотелось бы часть программ положить в отдельные сектора и не трогать ни при каких обстоятельствах (продпрограммы включения GSM, собственно, сама подпрограмма перепрошивки). Я бы выделил им свой сегмент, в который линкер бы больше не пытался что-то размещать, и больше не трогал эти адреса, а всё остальное - меняй на здоровье. Это, по моему разумению, гарантировало бы нахождение блока на связи при любых условиях, с возможностью отката до предыдущей версии ПО.
Go to the top of the page
 
+Quote Post
1921
сообщение Jul 25 2011, 12:20
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 56
Регистрация: 29-09-10
Пользователь №: 59 820



ГЫ!
Ничего не понял, потыкал, и всё получилось.

void myfunc (void) @"BLOCK2", где BLOCK2 - прописанный в линкере сегмент, типа:

.
.
.
// -------------------------------------
// Information memory
//

-Z(CONST)INFO=1800-19FF
-Z(CONST)INFOA=1980-19FF
-Z(CONST)INFOB=1900-197F
-Z(CONST)INFOC=1880-18FF
-Z(CONST)INFOD=1800-187F
// -------------------------------------
// Low memory 0-0FFFF
//
// ---------------------------
// Code
//
-Z(CODE)CSTART,ISR_CODE=6000-FF7F
// ---------------------------
// Constant data
//
-Z(CONST)DATA16_C,DATA16_ID,DIFUNCT,CHECKSUM=6000-FF7F
// -------------------------------------
// All memory 0-FFFFF
//
// ---------------------------
// Code
//
-P(CODE)CODE=6000-FF7F,10000-45BFF
-Z(CODE)CODE_ID
// ---------------------------
// Constant data
//
-Z(CONST)DATA20_C,DATA20_ID=6000-FF7F,10000-45BFF
//---------------------------------------
// Our segment 5C00..5FFF 1024 bytes
-Z(CODE)BLOCK1=5C00-5DFF
-Z(CODE)BLOCK2=5E00-5FFF
// -------------------------------------
// Interrupt vectors
//
-Z(CODE)INTVEC=FF80-FFFF
-Z(CODE)RESET=FFFE-FFFF

Модифицированный линкер надо подключить в настройках вместо стандартного.
При этом чётко кидает функцию по адресу 5E00, и больше ничего туда не пишет. Вах, как харашо!
У меня вопрос снят.
Go to the top of the page
 
+Quote Post
KARLSON
сообщение Aug 29 2011, 04:55
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 604
Регистрация: 5-05-06
Из: Нижегородская обл.
Пользователь №: 16 819



Спасибо, 1921, за способ. Мне это тоже актуально.
Но предположим мне надо несколько функций разместить по определённым адресам. Интересует несколько моментов:
1) как узнать размер функции?
2) как предотвратить наложение адресов при перепрограммировании, вдруг новая функция растолстела больше диапазона первоначального?
3) можно ли при перепрограммировании переложить функцию по другому адресу, где при этом прописать остальной программе, что перепрограммированная функция запускается по новому адресу?


--------------------
Кризис - это не отсутствие денег, а отсутствие идей! Учитесь и никаких кризисов не будет.
Go to the top of the page
 
+Quote Post
ih_
сообщение Sep 1 2011, 16:18
Сообщение #6


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

Группа: Свой
Сообщений: 77
Регистрация: 2-04-08
Из: Россия, Киров
Пользователь №: 36 422



Цитата(KARLSON @ Aug 29 2011, 08:55) *
...
1) как узнать размер функции?
Можно разместить ее в отдельном сегменте, и затем вычислять его адрес, через встроенные указатели начала и конца сегмента (__segment_begin("mySeg");__segment_end("meSeg");SFE("mySg");SFB("mySeg"))
Цитата
2) как предотвратить наложение адресов при перепрограммировании, вдруг новая функция растолстела больше диапазона первоначального?
Можно сделать запас.
Цитата
3) можно ли при перепрограммировании переложить функцию по другому адресу, где при этом прописать остальной программе, что перепрограммированная функция запускается по новому адресу?
Конечно можно. Как вариант, обращаться к функции через указатель на нее, который находится по фиксированному адресу.
Go to the top of the page
 
+Quote Post
rezident
сообщение Sep 1 2011, 17:39
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(KARLSON @ Aug 29 2011, 09:55) *
1) как узнать размер функции?
Сгенерить map-файл.
Цитата(KARLSON @ Aug 29 2011, 09:55) *
2) как предотвратить наложение адресов при перепрограммировании, вдруг новая функция растолстела больше диапазона первоначального?
Линковшик выдаст ошибку, если функция не помещается в выделенный для нее сегмент памяти.
Цитата(KARLSON @ Aug 29 2011, 09:55) *
3) можно ли при перепрограммировании переложить функцию по другому адресу, где при этом прописать остальной программе, что перепрограммированная функция запускается по новому адресу?
Можно сделать также, как это было в MSDOS. Чтобы была совместимость для программ, адреса вызова функций в этой ОС не менялись от версии к версии. Но по адресу вызова функции стоял JMP на ее реальный адрес, по которому она располагалась в памяти. Вам можно поступить так же, организовав таблицу переходов для вызова функций. Адреса функций в эту таблицу пускай заносит сам компилятор. Не барское это дело на ЯВУ вручную считать адреса и учитывать всякие смещения, чай не на ASMе программируете wink.gif
Go to the top of the page
 
+Quote Post
sergeeff
сообщение Sep 1 2011, 19:10
Сообщение #8


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

Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007



Коллеги! Поясните, пожалуйста, как вы потом планируете работать с такой программой? Распихали "постоянные" функции по конкретным фиксированным адресам. Понятно. Написали некую прикладную программу, которая содержит вызовы этих самых функций. И как линкеру сказать, что эти функции:

1. Определены.
2. Адреса их такие-то.

Непонятно.
Go to the top of the page
 
+Quote Post
rezident
сообщение Sep 1 2011, 21:31
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(sergeeff @ Sep 2 2011, 00:10) *
Коллеги! Поясните, пожалуйста, как вы потом планируете работать с такой программой?
Как будут использовать их вопрошающие, я не знаю. Обычно такие финты только для функций типа "самодельного" бутлоадера практикуются.
Цитата(sergeeff @ Sep 2 2011, 00:10) *
1. Определены.
Для компилятора достаточно прототипов функций, т.к. он проверяет соответствие типа и формата аргументов при вызове. Вызов функций возможен через указатель на нее.
Цитата(sergeeff @ Sep 2 2011, 00:10) *
2. Адреса их такие-то.
При таком раскладе возможна работа только с указателями на функции. Определяете указатель на функцию и загружаете его значением адреса функции, который вам известен заранее.
P.S. если это только не булоадер или какие-то подпрограммы с шифрованием данных, то такие заморочки с принудительным размещением функций могут свидетельствовать о привычках завсегдатая ассемблера, который совсем недавно перешел на Си. ИМХО конечно sm.gif
Go to the top of the page
 
+Quote Post
KARLSON
сообщение Sep 2 2011, 04:21
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 604
Регистрация: 5-05-06
Из: Нижегородская обл.
Пользователь №: 16 819



Цитата(sergeeff @ Sep 1 2011, 23:10) *
2. Адреса их такие-то.

Вот тут говорится как разместить функцию по определённому адресу.

Цитата(rezident @ Sep 2 2011, 01:31) *
P.S. если это только не булоадер или какие-то подпрограммы с шифрованием данных, то такие заморочки с принудительным размещением функций могут свидетельствовать о привычках завсегдатая ассемблера, который совсем недавно перешел на Си.

Конечно же это бутлоадер sm.gif.


--------------------
Кризис - это не отсутствие денег, а отсутствие идей! Учитесь и никаких кризисов не будет.
Go to the top of the page
 
+Quote Post

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

 


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


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