Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

(+)

Отправлено DASM 15 мая 2008 г. 01:14
В ответ на: Опять спрошу- как выставить защиту кода в LPC213x через IAR отправлено колян безпарольный 15 мая 2008 г. 01:06

Для установки защиты необходимо по адресу 0x1FC Flash памяти разместить
специальный ключ, 32 битное слово 0x87654321. Однако сделать это прямо
в компиляторе вам не удастся, так как распределением занимается линкер.

Не поможет и указание компилятору специфичного для IAR расширения "@",
означающего размещение по фиксированному адресу, т.к. оно неприменимо
для инициализированных переменных и констант.

Выходом из положения является создание ассемблерного файла, определяющего
новый сегмент кода и размещающего в нем одно единственное слово 0x87654321.
А чтобы линкер поместил этот сегмент по нужному нам адресу 0x1FC немного
модифицируем XCL файл линкера.

Тестовый проект по ссылке.
Обратить внимание на файл prot.s79 и 123-ую строку flash.xcl

P.S. На мой взгляд, способ размещения через дополнительный сегмент
является более правильным, т.к. с незначительными изменениями может быть
использован в любых компиляторах. Однако для IAR есть способ проще -
разместить в любом из С файлов проекта строку
__root const unsigned int protectKey @ 0x1FC = 0x87654321;
DASM



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
при вычитании трёх из шести получится:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru