Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Kinetis E series
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
dimka76
Здравствуйте.

Разбираюсь с микроконтроллером 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
}


Что за дела ?
Нас обкрадывают ?
Как можно научить ликер также использовать память 0х00С0 - 0х03FF ?
ataradov
Странный подход они выбрали. Автоматом такое не сделать, GNU ld не умеет секции с разрывами.

Похожая проблема возникает на процах с 2 банками памяти, которые расположены не слитно в адресном пространстве.

"Решение" создать еще одну секцию .text и руками туда поместить некоторые функции. Скорее всего там места хватит только на заглушку для неиспользованных векторов, обработчик reset и еще всякую мелочь, которая меняется не часто.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.