Разбираюсь с микроконтроллером Kinetis E-Series.
А точнее с MKE04Z8.
В datasheet есть такая картинка (ну и текстовое описание)
Нажмите для просмотра прикрепленного файла
Получается они внедрили ячейки защиты (Flash configuration field) в память программ. И причем не в начало или конец, а в
промежуточное место в памяти, а точнее по адресам 0x00400 - 0x0040F.
Так вот, выходит что в первом килобайте памяти можно разположить только векторы преравания, а их всего 196, а
остальная чать этого килобайта будет бесполезно пропадать.
А памяти всего-то 8 КБайт.
В Kinetis Design Studio IDE попробовал создать простой проект. Студия сгенерировала в том числе и скрипт линкера.
В нем тоже первый килобайт идет только под вектора прерываний.
Код
MEMORY {
m_interrupts (RX) : ORIGIN = 0x00000000, LENGTH = 0x000000C0
m_text (RX) : ORIGIN = 0x00000410, LENGTH = 0x00001BF0
m_data (RW) : ORIGIN = 0x1FFFFF00, LENGTH = 0x00000400
m_cfmprotrom (RX) : ORIGIN = 0x00000400, LENGTH = 0x00000010
}
m_interrupts (RX) : ORIGIN = 0x00000000, LENGTH = 0x000000C0
m_text (RX) : ORIGIN = 0x00000410, LENGTH = 0x00001BF0
m_data (RW) : ORIGIN = 0x1FFFFF00, LENGTH = 0x00000400
m_cfmprotrom (RX) : ORIGIN = 0x00000400, LENGTH = 0x00000010
}
Что за дела ?
Нас обкрадывают ?
Как можно научить ликер также использовать память 0х00С0 - 0х03FF ?