|
|
  |
как разместить подпрограмму по заданному адресу |
|
|
|
Jul 25 2011, 10:54
|
Участник

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

|
Цитата(MrYuran @ Jul 25 2011, 11:31)  Почитайте про секции. В GCC это будет __attribute__ ((section = "")), в IAR - #pragma location (емнип) или section (давно в руки не брал, забыл уже).
А для чего, если не секрет? Недавно тоже пробовали для неких целей. Поясню. Возможно, придётся реализовывать перепрошивку блока по GPRS. Хотелось бы часть программ положить в отдельные сектора и не трогать ни при каких обстоятельствах (продпрограммы включения GSM, собственно, сама подпрограмма перепрошивки). Я бы выделил им свой сегмент, в который линкер бы больше не пытался что-то размещать, и больше не трогал эти адреса, а всё остальное - меняй на здоровье. Это, по моему разумению, гарантировало бы нахождение блока на связи при любых условиях, с возможностью отката до предыдущей версии ПО.
|
|
|
|
|
Jul 25 2011, 12:20
|
Участник

Группа: Участник
Сообщений: 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, и больше ничего туда не пишет. Вах, как харашо! У меня вопрос снят.
|
|
|
|
|
Sep 1 2011, 16:18
|
Частый гость
 
Группа: Свой
Сообщений: 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) можно ли при перепрограммировании переложить функцию по другому адресу, где при этом прописать остальной программе, что перепрограммированная функция запускается по новому адресу? Конечно можно. Как вариант, обращаться к функции через указатель на нее, который находится по фиксированному адресу.
|
|
|
|
|
Sep 1 2011, 17:39
|
Гуру
     
Группа: Свой
Сообщений: 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е программируете
|
|
|
|
|
Sep 1 2011, 21:31
|
Гуру
     
Группа: Свой
Сообщений: 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. если это только не булоадер или какие-то подпрограммы с шифрованием данных, то такие заморочки с принудительным размещением функций могут свидетельствовать о привычках завсегдатая ассемблера, который совсем недавно перешел на Си. ИМХО конечно
|
|
|
|
|
Sep 2 2011, 04:21
|

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

|
Цитата(sergeeff @ Sep 1 2011, 23:10)  2. Адреса их такие-то. Вот тут говорится как разместить функцию по определённому адресу. Цитата(rezident @ Sep 2 2011, 01:31)  P.S. если это только не булоадер или какие-то подпрограммы с шифрованием данных, то такие заморочки с принудительным размещением функций могут свидетельствовать о привычках завсегдатая ассемблера, который совсем недавно перешел на Си. Конечно же это бутлоадер  .
--------------------
Кризис - это не отсутствие денег, а отсутствие идей! Учитесь и никаких кризисов не будет.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|