|
IAR + SAM7S, Как узнать размер свободной SRAM? |
|
|
|
 |
Ответов
|
Nov 12 2007, 13:36
|

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

|
Цитата(KAlex @ Nov 12 2007, 15:27)  А как сказать IAR-у, что этот массив надо линковать последним. Явно указав его имя в списке для линкера последним. Конкретика зависит от версии IAR - у 4.x и 5.x линкеры разные. Если 4.x то например в XCL файле добавляем: Код -D_HEAP_RTOS_SIZE=1000 // 4Kb - Dummy minimal space for My Memory Manager -Z(DATA)HEAP_RTOS+_HEAP_RTOS_SIZE=RAMSTART-RAMEND // For My memory manager Ну а дальше: Код extern ulong RAMEND; extern ulong RAMSTART; #pragma segment="HEAP_RTOS"
printf( "\tRAM use:%lu Heap:%8X Size:%lu\r", (ulong)(__segment_begin( "HEAP_RTOS" ))-(ulong)&RAMSTART, __segment_begin( "HEAP_RTOS" ), (ulong)&RAMEND - (ulong)(__segment_begin( "HEAP_RTOS" )) + 1 );
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Nov 18 2007, 12:34
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(Kitsok @ Nov 18 2007, 10:16)  копируем прошивку в heap, в heap-же копируем функцию записи во флеш, делаем необходимые проверки и передаем управление на эту функцию. И незадолго до конца работы этой функции пропадает питание. Устройство можно возвращать изготовителю. Было несколько обсуждений на эту тему. Вкратце - загрузчик должен находиться в том же сегменте, что и вектора и получать управление при включении питания. А дальше решать - передавать управление основной программе или делать апгрейд.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 18 2007, 19:32
|
Местный
  
Группа: Свой
Сообщений: 211
Регистрация: 9-11-06
Пользователь №: 22 136

|
Цитата(Сергей Борщ @ Nov 18 2007, 15:34)  И незадолго до конца работы этой функции пропадает питание. Устройство можно возвращать изготовителю. Было несколько обсуждений на эту тему. Вкратце - загрузчик должен находиться в том же сегменте, что и вектора и получать управление при включении питания. А дальше решать - передавать управление основной программе или делать апгрейд. Спасибо за ссылку, почитаю. С опасением полностью согласен. Причина, по которой я не горю желанием писать полноценный бутлоадер (для поиска: загрузчик, bootloader, бутлодырь  ) - необходимо реализовать весь стек USB - других интерфейсов у устройства попросту нет...
|
|
|
|
|
Nov 19 2007, 13:13
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(Kitsok @ Nov 18 2007, 21:32)  необходимо реализовать весь стек USB - других интерфейсов у устройства попросту нет... А ОЗУ внешнее? Внутреннего-то не хватит, чтобы всю прошивку в heap поместить. Для прошивки достаточно держать в ОЗУ функцию из нескольких команд Код __ramfunc __arm void FlashCommand_RAM(uint32_t command) { AT91C_BASE_MC->MC_FCR = command; while(!(AT91C_BASE_MC->MC_FSR & AT91C_MC_FRDY)); } Возможно имеет смысл ее держать в ОЗУ постоянно. Все остальное может жить в защищенном от стирания секторе флеш. Может имеет смысл при приеме прошивки складывать ее в свободную область флеш, а загрузчик будет копировать из этой области в рабочие адреса? Тогда сбои питания не страшны - одна из копий прошивки всегда будет целой, а сам копировщик вообще нестираемым.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 20 2007, 10:52
|
Местный
  
Группа: Свой
Сообщений: 211
Регистрация: 9-11-06
Пользователь №: 22 136

|
Цитата(Сергей Борщ @ Nov 19 2007, 16:13)  А ОЗУ внешнее? Внутреннего-то не хватит, чтобы всю прошивку в heap поместить. Для прошивки достаточно держать в ОЗУ функцию из нескольких команд Код __ramfunc __arm void FlashCommand_RAM(uint32_t command) { AT91C_BASE_MC->MC_FCR = command; while(!(AT91C_BASE_MC->MC_FSR & AT91C_MC_FRDY)); } Возможно имеет смысл ее держать в ОЗУ постоянно. Все остальное может жить в защищенном от стирания секторе флеш. Может имеет смысл при приеме прошивки складывать ее в свободную область флеш, а загрузчик будет копировать из этой области в рабочие адреса? Тогда сбои питания не страшны - одна из копий прошивки всегда будет целой, а сам копировщик вообще нестираемым. ОЗУ встроенное, SAM7S256, но прошивка ограничивается размером в 16 кб, больше мне и не надо. Рассматриваю возможность дописывания аппликухи и организации dual firmware. А вот глупый вопрос - можно ли работая из флеша писать другие сектора этого флеша, или обязательно копировать себя в RAM и запускаться оттуда? Потому как если можно, то изменения будут касаться исключительно проверки версии и CRC с дальнейшей передачей управления. Хотя криво это все, по-хорошему, надо бутлоадер писать а-ля SAM-BA и не выпендриваться.
|
|
|
|
|
Nov 20 2007, 12:30
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(Kitsok @ Nov 20 2007, 12:52)  А вот глупый вопрос - можно ли работая из флеша писать другие сектора этого флеша, или обязательно копировать себя в RAM и запускаться оттуда? Все, кроме приведенной мной выше функции может работать из флеша. На время выполнения этой функции флеш блокируется (поэтому либо запрещайте прерывания, либо переносите обработчики и вектора в ОЗУ). Цитата(Kitsok @ Nov 20 2007, 12:52)  Хотя криво это все, по-хорошему, надо бутлоадер писать а-ля SAM-BA и не выпендриваться. Тем более что в USB есть (специальный класс?) возможность загрузки firmware. У атмела в апликухах кажется что-то было. Может и не так страшно?
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
Сообщений в этой теме
KAlex IAR + SAM7S Nov 12 2007, 12:07     KAlex Спасибо. То что надо. Nov 13 2007, 08:31           Kitsok Цитата(Сергей Борщ @ Nov 20 2007, 15:30) ... Nov 20 2007, 13:52 _dem имхо, имелось в виду немного не то :
Так как флеш... Nov 20 2007, 21:21 Kitsok Цитата(_dem @ Nov 21 2007, 00:21) Учитыва... Nov 21 2007, 12:22  Сергей Борщ Цитата(Kitsok @ Nov 21 2007, 14:22) Ресет... Nov 21 2007, 14:20   Kitsok Цитата(Сергей Борщ @ Nov 21 2007, 17:20) ... Nov 21 2007, 14:43    Kitsok Цитата(Kitsok @ Nov 21 2007, 17:43) Похож... Nov 21 2007, 22:55     Сергей Борщ Цитата(Kitsok @ Nov 22 2007, 00:55) ... н... Nov 22 2007, 11:35      Kitsok Цитата(Сергей Борщ @ Nov 22 2007, 14:35) ... Nov 22 2007, 12:05
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|