Приветсвую Вас коллеги!!!!

Начал осваивать контроллеры семейства Kinetis от Freescale.
Есть необходимость оюновления ПО в микроконтроллере, поэтому решил прибегнуть у разбиению памяти. Работаю в Keil uvision 4.73.

Столкнулся с такой проблемой что все мои инструкции по размещению либо не обрабатываются, либо обрабатываются как-то неправильно. Хочу часть функций разместить в секции work_rom, которую и буду в будущем перезаписывать.

Привожу распечатку scatter-файла
CODE

LR_IROM1 0x00000000 0x00040000 { ; load region size_region
ER_IROM1 0x00000000 0x00010000 { ; load address = execution address
*.o (RESET, +First)
*(InRoot$$Sections)
.ANY (+RO)
}

ER_IROM2 0x00010000 0x00030000 { ; load address = execution address
main.o (+RO)
* (work_rom)
}

RW_IRAM1 0x1FFF8000 0x00008000 { ; RW data
.ANY (+RW +ZI)
}
RW_IRAM2 0x20000000 0x00008000 {
.ANY (sram2)
}
}

LR_IROM2 0x10000000 0x00030000 { ; load region size_region
ER_IROM3 0x10000000 0x00030000 { ; load address = execution address
.ANY (work_rom2)
}
}


Линкер ошибок не выдает. В МАР-файле все пучком - все функции лежат по правильным секциям, НО в AXF-файле нет ничего что касается секции work_rom.
Более того, прямое размещение константы по указанному адресу дает тот же эффект. Самое интересное что ничего подобного при работе с контроллерами LPC2xxx я не видел.

Хотелось бы понять что я делаю неправильно???



Проблема решилась самостоятельно.
Надо было вынести раздел в отдельный загрузочный блок.

на всякий случай привожу текст рабочего scatter-файла
CODE

; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************

LR_IROM1 0x00000000 0x00010000 { ; load region size_region
ER_IROM1 0x00000000 0x00010000 { ; load address = execution address
*.o (RESET, +First)
*(InRoot$$Sections)
.ANY (+RO)
}

RW_IRAM1 0x1FFF8000 0x00008000 { ; RW data
.ANY (+RW +ZI)
}

RW_IRAM2 0x20000000 0x00008000 {
.ANY (sram2)
}
}

LR_IROM2 0x00010000 0x00030000 { ; load region size_region
ER_IROM2 0x00010000 0x00030000 { ; load address = execution address
main.o (+RO)
.ANY (work_rom)
}
}

LR_IROM3 0x10000000 0x00030000 { ; load region size_region
ER_IROM3 0x10000000 0x00030000 { ; load address = execution address
.ANY (work_rom2)
}
}