ebook img

Программирование микроконтроллеров AVR (Atmel) PDF

50 Pages·2008·21.358 MB·Russian
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Программирование микроконтроллеров AVR (Atmel)

МОСКОВСКИЙ АВТОМОБИЛЬНО.ДОРОЖНЫЙ ИНСТИТУТ (ГОСУДАРСТВЕННЫЙ ТЕХНИЧЕСКИЙ УНИВЕРСИТЕТ) Кафедра автоматизированных систем управления А.М. 8аськовский, О.И. Максимычев, д.Б. Маврин, Л.д. Литвинов ПРОГРАММИРОВАНИЕМИКРОКОНТРОЛЛЕРОВ AVR (ATMEL) УЧЕБНОЕ ПОСОБИЕ Москва 2008 3 УДК 32.96:32.97 С78 ББК 681.58:681.32 1. МИКРОКОНТРОЛЛЕРЫ С АРХИТЕКТУРОЙ AVR Под общей маркой AVR объединены 8-разрядныэ высокопроиз­ А.М. Васьковский, о.и. Максимычев, А.Б. Маврин, ЛА Литвинов. водительные RISC (Reduced Instruction Set Computer) микроконтрол­ леры (МК) общего назначения фирмы Atmel Согр. Выпуск AVR Программирование микроконтроллеров AVR (Atmel): Учебное начался в 1996 г., в настоящее время в серийном производстве пособие / МАДи (ГГУ). - М.: 2008. находятся три семейства - «Tiny», «Classic» и «Mega». На настоящий момент по соотношению «цена - производитель­ Рассмотрены вопросы, связанные с программированием ность _ энергопотребление» AVR является одним из лучших на однокристальных микроЭВМ (микроконтроллеров), г:рименяемых в мировом рынке 8-разрядных Мк. Можно считать, что AVR постепен­ промышленных системах автоматического управления. но становится еще одним индустриальным стандартом среди МК Пособие предназначено для студентов, обучающихся по спе­ общего назначения. циальностям 220200 «Автоматизированные системы обработки ин­ Области применения AVR многогранны. Для семейства «Tiny» формации и управления», 210200 «Автоматизированные техноло­ это интеллеl\Гуальные автомобильные устройства самого разного гии и производства», 1808000 «Электрооборудование автомобилей назначения, игрушки, игровые приставки, материнские платы персо­ и TpaI\ГOpoB», может быть использовано инженерами и аспиранта­ нальных компьютеров, защита доступа в мобильных телефонах, ми, занимаЮЩИМ~1СЯ вопросами проеl\Гирования микропроцессор- зарядные устройства, дeTel\ГOpы дыма и пламени, бытовая техника, ных систем. пульты дистанционного управления. Для семейства «Classic» это модемы различных типов, изделия класса Smaгt Cards и устройства чтения для них, спутниковые навигационные системы для опреде­ ления местоположения автомобилей на трассе, сложная бытовая техника, сетевые карты, материнские платы компьютеров, сотовые телефоны, разнообразные промышленные системы контроля и уп­ равления. Для «Mega» AVR это аналоговые (NMT, ETACS, AMPS) и цифровые (GSM, СОМА) мобильные телефоны, принтеры и ключе­ вые контроллеры для них, МК аппаратов факсимильной связи и ксероксов, современных дисковых накопителей, CO-ROM и т. д. © Московский автомобильно-дорожный институт (Государственный технический университет), 2008 5 4 Internal RC - наличие внутренней RС-цепочки для автоном­ 2. АППАРАТНЫЕ ОСОБЕННОСТИ МК AVR ной работы МК (без внешнего источника опорной частоты); Объемы массивов Flash-, EEPROM- и SRAM- памяти, набор WDT - сторожевой таймер; периферийных узлов и построение схемы тактирования существен­ но различаются как между семействами, так и между МК внутри ВОС - аппаратный программируемый блок защиты от сбоев каждого семейства. Поэтому конкретные детали и полные описания, при внезапном (в том числе и кратковременном) отключении особенности построения и функционирования всех периферийных питания МК; блоков можно найти в оригинальной технической документации UART асинхронный последовательный приемопередат- Atmel [1]. чик; Условные обозначения: SPI - синхронный трехпроводной последовательный интер- Flash ROM - объем энергонезависимой памяти программ (в фейс; килобайтах); 12С - двухпроводной последовательный интерфейс; EEPROM - объем энергонезависимой памяти данных (в RTC - система реального времени (Real Time Сопtгоl); байтах); PWM (channels) - количество независимых каналов ШИМ; ММ - объем статической памяти данных (в байтах); Command Set - набор инструкций в системе команд. External ММ - возможность подключения к микроконтрол­ Все AVR имеют Flаsh-память программ, которая может быть леру дополнительной микросхемы внешней статической памяти загружена как с помощью обычного программатора, так и с помо­ данных (килобайт); щью SРI-интерфейса, в том числе непосредственно на целевой ISP - программирование МК в системе; плате. Количество циклов перезаписи не менее 1000. Версии крис­ SPM - функция самопрограммирования Flash RoM-памяти таллов семейства «Mega» имеют возможность самопрограммирова­ МК в системе (без внешнего программатора); ния, то есть самостоятельно изменять заложенные в них программы и алгоритмы функционирования, и далее работать уже по новой JTAG - встроенный JТAG - интерфейс; программе или измененному алгоритму. 1/0 (pins) - максимальное количество доступных линий Например, можно сохранить несколько версий программы для ввода / вывода; конкретного приложения во внешней энергонезависимой памяти Timer(s) 8/16 bit - количество и разрядность таймеров/счет- (DataFlash, SEEPROM и т. п.), а затем, по мере необходимости или чиков; по реакции на какие-нибудь внешние или внутренние логические USI - универсальный коммуникационный интерфейс; условия, перегружать рабочие программы в тот же самый МК без извлечения его из печатной платы. Для этого весь массив памяти АС - аналоговый компаратор; программ подразделяется на две неравные по объему области: АDС (channels) - количество каналов АЦП; блок загрузчика (программа, управляющая перезаписью Flash- 6 7 памяти программ) и блок для размещения рабочего программного генератор, работающий на частоте примерно 1 МГц (в основном его кода, причем свободная память в области загрузчика может быть частота зависит от напряжения питания и температуры). использована в качестве дополнительного пространства для рабо­ WАТСНDОG-таймер снабжен своим собственным предвари­ чего кода. тельным делителем входной частоты с программируемым коэффи­ Программа-загрузчик создается самим разработчиком и долж­ циентом деления, что позволяет подстраивать временной интервал на быть запрограммирована внешним программатором. переполнения таймера и сброса мк. WАТСНDОG-таймер может Все AVR имеют также блок энергонезависимой электрически быть отключен программным путем во время работы, как в стираемой памяти данных EEPROM. Этот тип памяти, доступный активном, так и в любом из режимов пониженнога энергопотреб­ ления. В последнем случае это приводит к значительному снижению программе микроконтроллера непосредственно в ходе ее выполне­ потребляемого тока. ния, удобен для хранения промежуточных данных, различных конс­ тант, таблиц перекодировок, калибровочных коэффициентов. Порты ввода/вывода AVR имеют от 3 до 53 независимых линий «Вход/Выход», каждый разряд порта может быть запрограм­ EEPROM может быть также загружена извне - как через SPI мирован на ввод или вывод информации. интерфейс, так и с помощью обычного программатора. Два програм­ мируемых бита секретности позволяют защитить память программ и Интересная архитектурная особенность портов ввода/вывода энергонезависимую память данных EEPROM от несанкционирован­ у А VR: для каждого физического вывода существует 3 бита контро­ нога считывания. Чтение и запись ячеек EEPROM выполняются ля/управления, а не 2, как у распространенных 8-разрядных МК - через регистры ввода/вывода EEAR (регистр адреса), EEDR (ре­ Iпtеl, Microchip, Motorola. гистр данных) и EECR (регистр управления). DDRx в данном случае - бит контроля направления передачи Внутренняя оперативная память SRAM имеется у всех AVR данных и при вязки вывода к шине питания (VCC), PORTx - бит семейств «Classic», «Mega» и у одного из «Тiпу» (AТtiny26/L); для привязки вывода к VCC и бит выходных данных, PINx - бит для некоторых возможна организация подключения внешней памяти отображения логического уровня сигнала на физическом выводе данных объемом до 64 К слов. микросхемы. Внутренний тактовый генератор AVR может запускаться от Естественный вопрос: для чего необходимо наличие именно различных источников опорной частоты (внешний генератор, внеш­ трех битов? Дело в том, что использование только двух битов конт­ ний кварцевый резонатор, внутренняя или внешняя RС-цепочка). роля/управления пораждает ряд проблем при операциях типа «чте­ Так как AVR - полностью статические МК, то значение рабочей ние-модификация-запись» . Например, если имеют место две после­ частоты снизу не ограничено, вплоть до пошагавого режима. Макси­ довательные операции такого рода, то 1-й результат может быть безвозвратно потерян, если вывод порта работает на емкостную мальная рабочая частота определяется конкретным типом мк. нагрузку и требуется некоторое время для стабилизации уровня сиг­ Сторожевой (WATCHDOG) таймер предназначен для защиты нала на внешнем МК от сбоев в процессе работы; в нем имеется собственный RC- Выводе микросхемы. Трехбитовая архитектура портов ПОзволяет полностью контролировать процесс ввода/вы- вода. 8 9 Если необходимо получить реальное значение сигнала на Время преобразования выбирается программным путем - с физическом выводе МК, то содержимое бита читается по адресу помощью установки коэффициента деления частоты специального PINx. Если требуется обновить выходы, то сначала следует считать предварительного делителя, входящего в состав блока АЦП, и PORTx-защелку, а затем модифицировать данные. Это избавляет равно 70 - 280 мкс дляАТmеgа10З и 65 - 260 мкс для всех от необходимости иметь копию содержимого порта в памяти для остальных МК. безопасности и повышает скорость работы МК при работе с внешни­ Важной особенностью АЦП является наличие функции подав­ ми устройствами. Особую значимость данная архитектура приобре-' ления шума. Пользователь имеет возможность, выполнив короткий тает для реализации систем, работающих в условиях электрических ряд программных операций, запустить АЦП в то время, когда помех. центральный процессор находится в одном из режимов понижен­ Аналоговый компаратор входит в состав большинства МК ного энергопотребления. При этом помехи, возникающие при работе AVR. Типовое напряжение смещения равно 1О мВ,· время задержки процессорного ядра, не будут оказывать влияние на точность прео­ распространения составляет 500 нс и зависит от напряжения пита­ бразования. ния. Например, при напряжении 2,7 В оно равно 750 нс. Аналоговый МК AVR могут быть переведены в один из L'Jести режимов компаратор имеет свой собственный вектор прерывания в общей пониженного энергопотребления программным путем. Для разных системе прерываний МК, при этом тип перепада, вызывающий семейств AVR и разных МК в пределах каждого семейства изме­ запрос на прерывание при срабатывании компаратора, может быть няются сочетания доступных режимов пониженного энергопотребле­ запрограммирован пользователем как фронт, срез или переключе­ ния (соответствующую информацию можно найти в документации ние. Логический выход компаратора может быть программным Atmel [1]). способом подключен к входу одного из 16-разрядных таймеров/счет­ 2.1. Основные технические характеристики чиков, работающих в режиме захвата, что дает возможность изме­ рять длительность аналоговых сигналов, а также достаточно просто AVR представляет собой 8-разрядный МК типа RISC, имею­ реализовывать АЦП (см. ниже) двухтактного интегрирования. щий «быстрый» Гарвардский процессор, память программ, память данных, порты ввода/вывода, схемы интерфейса. Структура МК Аналого-цифровой преобразователь (АЦП) построен по приведена на РИС.1. классической схеме последовательных приближений, с устройством выборки/хранения (УВХ). Каждый из аналоговых входов АЦП может Гаrвардская архитектура AVR реализует полное логическое и быть соединен с входом УВХ через аналоговый мультиплексор. физическое разделение не только адресных пространств, но и информационных шин для обращения к памяти программ и памяти В УВХ имеется свой собственный усилитель, гарантирующий данных, причем способы адресации и доступа к этим массивам стабильность измеряемого аналогового сигнала в течение всего памяти также различны. С памятью программ и с памятью данных времени преобразования. Разрядность АЦП составляет 1О бит при центральный процессор работает одновременно; разрядность шины нормируемой погрешности ± 2 разряда. АЦП может работать в двух памяти программ расширена до 16 бит. режимах - однократного преобразования по любому выбранному каналу и последовательного циклического опроса всех каналов. 10 11 Оа1а Bus в..ыt Следующим шагом на пути повышения быстродействия явля­ ется использование технологИИ конвейеризации, благодаря которой заметно сокращается цикл «выборка - исполнение» команды». Под конвейеризацией в данном' случае подразумевается возможность выбора из памяти и дешифрации программного кода следующей команды во время исполнения текущей. Для сравнения: у МК семейства MCS-51 выборка кода коман­ ды и ее исполнение осуществляются последовательно, что зани­ Control Lines мает один машинный цикл, который длится 12 периодов кварцевого резонатора. 128 х 8 Dala В случае использования конвейера приведенную длитель­ SRAM ность машинного цикла можно сократить, например, у МК PIC фир­ мы Microchip за счет использования конвейера удалось уменьшить 128 х 8 EEPROM длительность машинного цикла до 4 периодов кварцевого резона­ тора. Длительность же машинного цикла AVR составляет один период кварцевого резонатора, таким образом, заданная произво­ дительность AVR обеспечивается при более низкой тактовой РИС.1. Структура AVR А T90S23 13 частоте. Именно эта особенность архитектуры и позволяет улуч­ Основную идею всех RISС-архитектур представляет возмож­ шить соотношение энергопотребление/производительность, кото­ ность увеличения быстродействия за счет сокращения количества рые для КМОП-микросхем определяются их рабочей частотой. Для операций обмена с памятью программ. Для этого каждую команду сравнения на РИС.2 приведены временные диаграммы выполнения стремятся уместить в одну ячейку памяти программ, что при ограни­ типовой команды при различных платформах мк. ченной разрядности ячейки неизбежно приводит к сокращению набора команд мк. UUUUUUUUUUUUUUUUUUUUUUUUU в соответствии с этим принципом В одной ячейке памяти :! " 1: i i . .! : . ~ i i ! ! !: AV~one! ' ; ;' , ., , , '. I ' программ размещаются практически все команды, исключая лишь I ! !. !'! i i! те, у которых одним из операндов является 16-разрядный адрес. Но plc) 11 Х2 УОопе! ! i это сделано не за счет сокращения количества команд процессора, HCO~~r 1- ' ------____Х '-:2:- Т: --~-----':-'--ХГО-оп-е!- -.:..-.---,i- --'' ------,--'--- а путем расширения ячейки памяти программ до 16 разрядов, что и является причиной увеличенной системы команд AVR по сравне­ 'csiX..:1..: -:---;-~--;---~_~~--,X2! . ~one! I нию с другими RISC-MK. , I ! РИС.2. Сравнительньrе _ характеристики МК по быстродеиствию 12 13 Следующая отличительная черта архитектуры AVR - n<>I-IАГ''Т'_ ие» и является еще одной отличительной контекстное переключен ~ ровый файл быстрого доступа, структура которого показана особенностью архитект уры AVR ' повышающеи эффективность рис.3. Использование трех 16-битных указателей (Х, У и Z Poi работы и производительность. существенно повышает скорость пересылки данных при б аметно данное преимущество при реализации про- Осо енно з прикладной программы. й 16-битной арифметики, многократных пересы­ цедур целочисленно O между РазличныМИ ячейками памяти в ALU. ~R1 лок данных R2 З. АССЕМБЛЕР ДЛЯ AVR RЗ ----- Рассмотрим особенности программирования МК семейства AT90Sxxxx на ассемблере: в данном случае имеется в виду язык XL Х Pointeг хн программирования (под «ассемблером» также подразумевают ком­ YL УН У Pointeг пилятор с языка ассемблер в машинный код). ZL ZH Z Pointeг 3.1. Структура программы Рис. 3. Регистровый файл Программу можно условно подразделить на следующие сос- Каждый из 32 регистров общего назначения длиной 1 байт тавные части: непосредственно связан с арифметико-логическим устройством 1) Подключение заголовочных файлов; (АЛУ) процессора. Другими словами, в AVR используются 32 ре­ 2) объявление констант; гистра-аккумулятора, что позволяет в сочетании с конвейерной 3) объявление имён регистров; обработкой выполнять одну операцию в АЛУ за один машинный цикл, в течение которого из регистрового файла извлекаются два 4) сегменты программы; операнда, выполняется команда и результат записывается обратно 5) комментарии. в регистровый фаЙл. Минимальная программа может содержать только сегмент При косвенной адресации данных 6 из 32 регистров файла кода, однако гораздо удобнее подключить и заголовочный файл для могут использоваться как три 16-разрядных указателя адреса, один заданн го контроллера. Программа физически хранится в текстовом из которых (Z Pointer) при меняется также для доступа к данным, файле, имеющем расширение *.asm. записанным в памяти программ МК. Заголовочные файлы Регистровый файл занимает младшие 32 байта в общем Формат заголовочных файлов, как и файлов программы, текс­ адресном пространстве SRAM AVR. Такое архитектурное решение товый, расширение *.inc. В заголовочных файлах содержатся позволяет получать доступ к быстрой «регистровой» оперативной константы, задающие символьные имена всем устройствам МК. Это памяти МК непосредственной адресацией в коде команды к любой позволяет, например, обращаться к порту В по имени PORTB и ячейке или другими способами адресации ячеек SRAM. Это избежать использования его номера $18. Кроме того, заголовочный полезное свойство носит в документации Atme/ название «быстрое 14 15 файл содержит директиву .device, которая указывает Сегменты программы используемого мк. Как любые программы, написанные для эвм Фон Нейманов­ Объявление констант ской архитектуры, программы для данного МК (построенного в соот­ ветствии с Гарвардскими гiринципами) состоят из сегментов кода, В дополнение к константам, объявленным данных и стека. В связи с тем, что МК содержит также энерго­ файле, можно задавать собственные константы, независимую память EEPROM, в программу добавляется допол­ конкретной задаче. С помощью констант удобно задавать маски нительный сегмент, позволяющий обеспечить доступ и к ней. доступа к портам, граничные значения счётчиков и т. п. Для .jClI1Clt-IИЯ констант следует использовать директиву .equ с форматом записи: Однако архитектура МК накладывает некоторые ограничения .equ на доступ к этим сегментам. Например, сегмент кода, как правило, <имя константы> =<значение константы> доступен только для чтения, причем командами, отличными от При необходимости значение константы может быть задано команд чтения данных из ОЗУ. Сегмент, описывающий содержимое шестнадцатеричной форме, для этого перед числом надо поста EEPROM, вообще недоступен для чтения-записи стандартными знак «$». Кроме того, допускается запись чисел, аналогичная прин командами (доступ к нему обеспечивается через порты ввода/выво­ той в языке «Си»: ОхЧисло. да). Сегмент стека в программе не описывается, однако, для досту­ Константа может быть представлена па к нему предусмотрены традиционные команды push/pop. выражением Физически сегменты располагаются следующим образом: сег­ = .equ MASK 1« PIN6 мент кода во Flаsh-памяти, сегмент энергонезависимой памяти - в Объявление имен регистров ЕЕРRОМ-памяти, сегмент данных и сегмент стека - в RAM. Данный МК имеет 32 регистра, для доступа к которым следует Начало сегмента кода отмечается директивой .CSEG, сегмент использовать имена RO - R31, на практике удобне~ использовать данных - .DSEG, сегмент EEPROM - .ESEG. для регистров символьные имена. Чтобы задать такое имя, следует Сегмент кода воспользоваться директивой .def. Формат записи директивы: Сегмент кода состоит из набора инструкций, которые должны .def <имя регистра> =<регистр> быть выполнены МК в процессе работы программы. Инструкции записыоаются следующим образом: В качестве имени регистра может использоваться произволь­ ная строка символов, записанная по тем же правилам, что и имена [<метка:>] <инструкция> <операнды> переменных в языке «Си»: строка может состоять из букв, цифр и Сегмент данных знака подчеркивания, первым знаком может быть либо буква, либо Сегмент данных традиционно используется для хранения знак подчеркивания. В качестве регистра может использоваться лю­ переменных. Для объявления переменных следует воспользоваться бой регистр в диапазоне RO - R31. Пример использования: директивой .ВУТЕ. = .def cnt RO Один и тот же регистр может иметь несколько имён. 16 17 <имя переменной>: .ВУТЕ 1 анном случае он имеет имя SPL. При мер битовом регистре, в Д Последняя цифра указывает реальное количество инициализации стека для данного МК: ных, под которые выделяется место. В случае если Idi temp, low(RAMEND) отличается от 1, переменная является массивом. out SPL,temp Примечание: МК имеет общее адресное пространство Сегмент EEPROM регистров, портов ввода/вывода и ОЗУ, которое начиная с адреса Ох60, поэтому при написании программ, К'""",,,. . ,,, Используется ДЛЯ хранения данных, которые не теряются при обращаются к ОЗУ, следует учитывать это смещение. При выключении питания (примеры приводились выше). зовании переменных, которые объявляются в программе Хранимые переменные могут иметь размер слова или байта. показано выше), смещение вычисляется ассемблером, ДлЯ объявления следует воспользоваться директивой db. Формат учитывать его не требуется. записи директивы Сегмент стека <имя>: .db <список значений> Сегмент стека в программе не представлен, Пример использования директивы для описания таблицы корректной работы программы, в частности, для инструкций перекодировки цифры в код семисегментного индикатора: push/pop/call/ret, а также для работы прерываний 0123456789Е настроить указатель стека. Обычно он устанавливается области памяти RAM следующими командами: , digits: .db ОхЕЕ, Ох60, Ox2F, Ох6D, ОхЕ1, ОхСD, OxCF, ОхЕ8, OxEF, ОхЕD, Ox8F Idi temp, high(RAMEND) Комментарии out SPH, temp Комментарии могут располагаться в любом месте программы: Idi temp, low(RAMEND) 1-й символ - точка с запятой, последующие символы ассемблером out SPL, temp не обрабатываются. Комментарий действует до конца строки, В данном примере temp - это имя произвольного BoellllelfiH()ro способ использования полностью совпадает с однострочными регистра, объявленного директивой .def. комментариями в языке Си, которые начинаются с символов: 11. Численное значение константы RAMEND может превышать 255, Пример программы при этом для её хранения требуется более одного байта и Пример программы, демонстрирующий порядок описания в используются директивы low и high, которые позволяют получить ней элементов, перечисленных выше. значения младшего и старшего байтов константы. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;,',',',',' .................... 111""'''''1111111' в случае использования МК AT90S2313 размер ОЗУ ; Пример программы для МК АТ90S231З. всего лишь 128 байт, и для обращения к памяти нужен ; Подключение заголовочного файла: пределах О - 127. Такой адрес можно хранить в одном восьм 18 19 емые при вычислениях, следует хранить .iпсludе "2З1 Зdеf.iпс" жуточные данные, использу ; Указание символьных имён регистров: в регистрах. 3.2. Система команд .def temp =R17 МК AVR весьма развита и насчитывает до ; Указание значений используемых констант: Система команд - М - В последниХ версиях семеиства « ega» 1 ЗЗ различных инструкции. .equ btп_mаsk =ОхОЗ аппаратного умножения, что придает им еще реализована функция ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"111 большую универсальность. ; Начало сегмента кода: Все команды (инструкции) можно разделить на следующие .CSEG группы: ; Инструкции сегмента кода: 1 ) Арифметико-логические; Idi temp, btп_mаsk 2) битовые; out PORTB, temp З) сравнения и условного перехода; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 4) безусловного перехода; ; Начало сегмента данных: 5) вызова подпрограмм; 6) пересылки данных; .DSEG 7) ввода/вывода; vaг: .ВУТЕ 1 ; объявили переменную vaг ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;".1.1...'.11.1.1.1.1.1.1..1.1.1.1.1.1.."." ,1. 8) специальные; 9) комбинированные. Примечание: В оригинальной технической документации Atmel [1] Использование регистров перечислено пять групп; дополнительные добавлены авторами для В соответствии с Гарвардской архитектурой мк содержит упрощения изложения. большое количество регистров (<<регистровый файл»), которые мож­ По разнообразию и количеству реализованных инструкций но использовать для хранения переменных, что позволяет сокра­ AVR больше похожи на CISC, чем на RISС-процессоры. Например, тить количество обращений к ОЗУ и ускорить ВЫПОЛ:-fение програм­ у РIС-контроллеров система команд насчитывает до 75 различных мы или вообще отказаться от использования ОЗУ (как в МК инструкций, а у MCS51 их число 111. В целом прогрессивная RISC AT90S1200). архитектура AVR в сочета~:ии с наличием регистрового файла и Все арифметико-логические инструкции предназначены для ра­ расширенной системы команд позволяет в короткие сроки созда­ боты с регистрами. Для работы с памятью предусмотрены лишь вать работоспособные программы с кодом, более эффективным как команды пересылки: регистр <-> память, в связи с этим все проме- по ко пактности реализации, так и по скорости выполнения.

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.