Интернет магазин китайских планшетных компьютеров



Компьютеры - Внутрисхемное программирование

23 января 2011





Внутрисхемное программирование — технология программирования электронных компонентов, позволяющая программировать компонент, уже установленный в устройство. До появления этой технологии компоненты программировались перед установкой в устройство, для их перепрограммирования требовалось их извлечение из устройства.

Главным преимуществом технологии является возможность объединения процесса программирования и тестирования при производстве, исключив отдельную фазу программирования компонентов перед окончательной сборкой. Технология также позволяет производителям устройств обойтись без закупки заранее запрограммированных компонентов, выполняя программирование прямо в процессе производства. Это позволяет снизить стоимость производства и вносить изменения в программируемую часть устройства без остановки производства.

Микросхемы, имеющие возможность внутрисхемного программирования, обычно имеют специальную схему, генерирующую напряжения, необходимые для программирования, из обычного напряжения питания, а также схему для коммуникации с программатором посредством последовательного интерфейса. Большинство микросхем используют вариации протокола JTAG.

Существуют два основных способа ISP: а) программатор работает с ПЗУ и EEPROM микроконтроллера как с внешней памятью, самостоятельно размещая байты прошивки по нужным адресам. Ядро МК при этом не задействовано, а выводы переведены в высокоимпедансное состояние; б) используется bootloader - небольшая программа, записанная, обычно, в конце ПЗУ МК. При этом сектор ПЗУ, отведёный под bootloader, должен быть отмечен тем или иным способом. Обычно, установкой fuse бит в состояние, указывающее на наличие bootloader-а и объём ПЗУ под него отведённый. В этом случае при старте МК управление передаётся сначала bootloader-у. Bootloader проверяет наличие заранее определённых условий и если условия не совпадает, передаёт управление основной программе. Если же условия совпадают, bootloader переходит в режим программирования, готовый принимать данные через любой, заранее определённый программистом, интерфейс и размещать их в ПЗУ. При этом МК программирует "сам себя".

Преимущество bootloader-а в том, что возможно программирование МК через любой имеющийся у него интерфейс любым удобным протоколом. Bootloader удобен при удалённом обновлении прошивки МК. Недостаток - часть ПЗУ недоступна для размещения основной программы.




Просмотров: 980


<<< Гарвардская архитектура