Главная страница
Навигация по странице:

  • Таблица 5.6. Назначение бит регистра EECON1 (адреса 88h).

  • 1)

  • 3)

  • Таблица 5.7. Состояние регистров МК после сброса. Регистр Адрес

  • Таблица 5.8. Назначение бит конфигурации МК PIC16CR83 и PIC16CR84.

  • Таблица 5.9. Назначение бит конфигурации МК PIC15F83 и PIC16F84.

  • КУРС ЛЕКЦИЙ ПО МИКРОПРОЦЕССОРНОЙ ТЕХНИКЕ. Курс лекций по микропроцессорной технике. Введение


    Скачать 1.34 Mb.
    НазваниеКурс лекций по микропроцессорной технике. Введение
    АнкорКУРС ЛЕКЦИЙ ПО МИКРОПРОЦЕССОРНОЙ ТЕХНИКЕ.doc
    Дата16.03.2017
    Размер1.34 Mb.
    Формат файлаdoc
    Имя файлаКУРС ЛЕКЦИЙ ПО МИКРОПРОЦЕССОРНОЙ ТЕХНИКЕ.doc
    ТипКурс лекций
    #3832
    страница17 из 22
    1   ...   14   15   16   17   18   19   20   21   22

    5.2.7. Счетчик команд


    Счетчик команд PCL и PCLATH имеет разрядность 13 бит. Младший байт счетчика (PCL) доступен для чтения и записи и находится в регистре   02h. Старший байт счетчика команд не может быть напрямую записан или считан и берется из регистра   PCLATH (PC latch high), адрес которого 0Ah. Содержимое PCLATH передается в старший байт счетчика команд, когда он загружается новым значением.

    В зависимости от того, загружается ли в счетчик команд новое значение во время выполнения команд CALL, GOTO, или в младший байт счетчика команд (PCL) производится запись, – старшие биты счетчика команд загружаются из PCLATH разными способами, как показано на рис. 5.6.


    Рис. 5.6.  Загрузка старших бит счетчика команд.

    Команды CALL и GOTO оперируют 11-разрядным адресным диапазоном, достаточным для смещения в пределах страницы программной памяти объемом 2К слов. Для МК подгруппы PIC16F8X этого хватает. С целью обеспечения возможности расширения памяти команд для будущих моделей МК предусмотрена загрузка двух старших бит счетчика команд из регистра   PCLATH<4:3>. При использовании команд CALL и GOTO пользователь должен убедиться в том, что эти страничные биты запрограммированы для выхода на нужную страницу. При выполнении команды CALL или выполнении прерывания весь 13-битный счетчик команд помещается в стек, поэтому для возвращения из подпрограммы не нужны манипуляции с разрядами PCLATH<4:3>.

    Микроконтроллеры подгруппы PIC16F8X игнорируют значения бит PCLATH<4:3>, которые используются для обращения к страницам 1, 2 и 3 программной памяти. Однако применять биты PCLATH<4:3> в качестве ячеек памяти общего назначения не рекомендуется, так как это может повлиять на совместимость с будущими поколениями изделий.

    Возможность выполнять арифметические операции непосредственно над счетчиком команд позволяет очень быстро и эффективно осуществлять табличные преобразования в PIC-контроллерах.

    Микроконтроллеры подгруппы PIC16F8X имеют восьмиуровневый аппаратный стек шириной 13 бит (см. рис. 5.4). Область стека не принадлежит ни к программной области, ни к области данных, а указатель стека пользователю недоступен. Текущее значение счетчика команд посылается в стек, когда выполняется команда CALL или производится обработка прерывания. При выполнении процедуры возврата из подпрограммы (команды RETLW, RETFIE или RETURN) содержимое счетчика команд восстанавливается из стека. Регистр   PCLATH при операциях со стеком не изменяется.

    Стек работает как циклический буфер. Следовательно, после того как стек был загружен 8 раз, девятая загрузка перепишет значение первой. Десятая загрузка перепишет вторую и т.д. Если стек был выгружен 9 раз, счетчик команд становится таким же, как после первой выгрузки.

    Признаков положения стека в контроллере не предусмотрено, поэтому пользователь должен самостоятельно следить за уровнем вложения подпрограмм.

    5.2.8. Прямая и косвенная адресации


    Когда производится прямая 9-битная адресация, младшие 7 бит берутся как прямой адрес из кода операции, а два бита указателя страниц (RP1, RP0) из регистра статуса, как показано на рис. 5.7.


    Рис. 5.7.  Методы адресации данных.

    Признаком косвенной адресации является обращение к регистру   INDF. Любая команда, которая использует INDF (адрес 00h) в качестве регистра фактически обращается к указателю, который хранится в FSR (адрес 04h). Чтение косвенным образом самого регистра   INDF даст результат 00h. Запись в регистр   INDF косвенным образом будет выглядеть как NOP, но биты статуса могут быть изменены. Необходимый 9-битный адрес формируется объединением содержимого 8-битного FSR   регистра и бита IRP из регистра статуса (см. рис. 5.7).

    Обратите внимание, что некоторые регистры специальных функций располагаются в банке 1. Чтобы адресоваться к ним, нужно дополнительно установить в единицу бит RP0 в регистре статуса.

    5.2.9. Порты ввода/вывода


    Контроллеры подгруппы PIC16F8X имеют два порта: PORTA (5 бит) и PORTB (8 бит) с побитовой индивидуальной настройкой на ввод или на вывод.

    Порт   A (PORTA) представляет собой 5-битовый фиксатор, соответствующий выводам контроллера RA<4:0>. Линия RA4 имеет вход триггера Шмитта и выход с открытым стоком. Все остальные линии порта имеют ТТЛ входные уровни и КМОП выходные буферы. Адрес регистра порта   А – 05h.

    Каждой линии порта поставлен в соответствие бит направления передачи данных, который хранится в управляющем регистре   TRISA, расположенном по адресу 85h. Если бит управляющего TRISA   регистра имеет значение 1, то соответствующая линия будет устанавливаться на ввод. Ноль переключает линию на вывод и одновременно выводит на нее содержимое соответствующего регистра-фиксатора порта. При включении питания все линии порта по умолчанию настроены на ввод.

    На рис. 5.8 дана схема линий RA<3:0>   порта   A.


    Рис. 5.8.  Схема линий RA <3:0> порта А. Выводы порта имеют защитные диоды к Vdd и Vss.

    Операция чтения порта   А считывает состояние выводов порта, в то время как запись в него изменяет состояние триггеров порта. Все операции с портом являются операциями типа «чтение-модификация-запись». Поэтому запись в порт предполагает, что состояние выводов порта вначале считывается, затем модифицируется и записывается в триггер-фиксатор. Вывод RA4 мультиплексирован с тактовым входом таймера   TMR0. Схема линии RA4   порта   А приведена на рис. 5.9.

    Порт   В (PORTB) – это двунаправленный 8-битовый порт, соответствующий выводам RB<7:0> контроллера и расположенный по адресу 06h. Относящийся к порту В управляющий регистр   TRISB расположен на первой странице регистров по адресу 86h. Если бит управляющего TRISB   регистра имеет значение 1, то соответствующая линия будет устанавливаться на ввод. Ноль переключает линию на вывод и одновременно выводит на нее содержимое соответствующего регистра защелки. При включении питания все линии порта по умолчанию настроены на ввод.


    Рис. 5.9.  Схема линии RA4 порта А. Вывод порта имеет защитный диод только к Vss.

    У каждой ножки порта   В имеется небольшая активная нагрузка (около 100мкА) на линию питания (pull-up). Она автоматически отключается, если эта ножка запрограммирована как вывод. Более того, управляющий бит /RBPU   регистра   OPTION<7> может отключить (при RBPU=1) все нагрузки. Сброс при включении питания также отключает все нагрузки.

    Четыре линии порта   В (RB<7:4>) могут вызвать прерывание при изменении значения сигнала на любой из них. Если эти линии настроены на ввод, то они опрашиваются и защелкиваются в цикле чтения Q1. Новая величина входного сигнала сравнивается со старой в каждом командном цикле. При несовпадении значения сигнала на ножке и в фиксаторе генерируется высокий уровень. Выходы детекторов «несовпадений» RB4, RB5, RB6, RB7 объединяются по ИЛИ и генерируют прерывание   RBIF (запоминаемое в регистре   INTCON<0>). Любая линия, настроенная как вывод, в этом сравнении не участвует. Прерывание может вывести кристалл из режима SLEEP. В подпрограмме обработки прерывания следует сбросить запрос прерывания одним из следующих способов:

    • прочитать (или записать в) порт   В. Это завершит состояние сравнения;

    • обнулить бит RBIF   регистра   INTCON<0>.

    При этом необходимо иметь в виду, что условие «несовпадения» будет продолжать устанавливать признак RBIF. Только чтение порта   В может устранить «несовпадение» и позволит обнулить бит RBIF.

    Прерывание по несовпадению и программно устанавливаемые внутренние активные нагрузки на этих четырех линиях могут обеспечить простой интерфейс, например, с клавиатурой, с выходом из режима SLEEP по нажатию клавиш.

    Схемы линий порта   B приведены на рис. 5.10 и 5.11.


    Рис. 5.10.  Схема линий RB <7:4> порта B. Выводы порта имеют защитные диоды к Vdd и Vss.


    Рис. 5.11.  Схема линий RB <3:0> порта B. Выводы порта имеют защитные диоды к Vdd и Vss.

    При организации двунаправленных портов необходимо учитывать особенности организации ввода/вывода данных МК. Любая команда, которая осуществляет запись, выполняет ее внутри как «чтение-модификация-запись». Например, команды BCF и BSF считывают порт целиком, модифицируют один бит и выводят результат обратно. Здесь необходима осторожность. В частности, команда BSF PORTB, 5 (установить в единицу бит 5 порта   B) сначала считывает все реальные значения сигналов, присутствующие в данный момент на выводах порта. Затем выполняются действия над битом 5, и новое значение байта целиком записывается в выходные фиксаторы. Если другой бит регистра   PORTB используется в качестве двунаправленного ввода/вывода (скажем, бит 0), и в данный момент он определен как входной, то входной сигнал на этом выводе будет считан и записан обратно в выходной триггер-фиксатор этого же вывода, стирая предыдущее состояние. До тех пор, пока эта ножка остается в режиме ввода, никаких проблем не возникает. Однако если позднее линия 0 переключи тся в режим вывода, ее состояние будет неопределенным.

    На ножку, работающую в режиме вывода, не должны нагружаться внешние источники токов («монтажное И», «монтажное ИЛИ»). Большие результирующие токи могут повредить кристалл.

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

    5.2.10. Модуль таймера и регистр таймера


    Структура модуля таймера/счетчика TIMER0 и его взаимосвязь с регистрами   TMR0 и OPTION показаны на рис. 5.12. TIMER0 является программируемым модулем и содержит следующие компоненты:

    • 8-разрядный таймер/счетчик TMR0 с возможностью чтения и записи как регистр;

    • 8-разрядный программно управляемый предварительный делитель (пределитель);

    • мультиплексор входного сигнала для выбора внутреннего или внешнего тактового сигнала;

    • схему выбора фронта внешнего тактового сигнала;

    • формирователь запроса прерывания по переполнению регистра   TMR0 с FFh до 00h.

    Режим таймера выбирается путем сбрасывания в ноль бита T0CS   регистра   OPTION <5>. В режиме таймера   TMR0 инкрементируется каждый командный цикл (без пределителя). После записи информации в TMR0 инкрементирование его начнется после двух командных циклов. Это происходит со всеми командами, которые производят запись или чтение-модификацию-запись TMR0 (например, MOVF TMR0, CLRF TMR0). Избежать этого можно при помощи записи в TMR0 скорректированного значения. Если TMR0 нужно проверить на равенство нулю без останова счета, следует использовать инструкцию MOVF TMR0,W.

    Режим счетчика выбирается путем установки в единицу бита T0CS   регистра   OPTION<5>. В этом режиме регистр   TMR0 будет инкрементироваться либо нарастающим, либо спадающим фронтом на выводе RA4/T0CKI от внешних событий. Направление фронта определяется управляющим битом T0SE в регистре   OPTION<4>. При T0SE = 0 будет выбран нарастающий фронт.

    Пределитель может использоваться или совместно с TMR0, или со сторожевым (Watchdog) таймером. Вариант подключения делителя контролируется битом PSA регистра   OPTION<3>. При PSA=0 делитель будет подсоединен к TMR0. Содержимое делителя программе недоступно. Коэффициент деления пределителя программируется битами PS2…PS0   регистра   OPTION<2:0>.


    Рис. 5.12.  Структурная схема таймера/счетчика TMR0.

    Прерывание по TMR0 вырабатывается тогда, когда происходит переполнение регистра   таймера/счетчика при переходе от FFh к 00h. Тогда устанавливается бит запроса T0IF в регистре   INTCON<2>. Данное прерывание можно замаскировать битом T0IE в регистре   INTCON<5>. Бит запроса T0IF должен быть сброшен программно при обработке прерывания. Прерывание по TMR0 не может вывести процессор из режима SLEEP потому, что таймер в этом режиме не функционирует.

    При PSA=1 делитель будет подсоединен к сторожевому таймеру как постделитель (делитель на выходе). Возможные варианты использования пределителя показаны на рис. 5.13.

    При использовании пределителя совместно с TMR0, все команды, изменяющие содержимое TMR0, обнуляют пределитель. Если пределитель используется совместно с WDT, команда CLRWDT обнуляет содержимое пределителя вместе с WDT.

    При использовании модуля TIMER0 в режиме счетчика внешних событий необходимо учитывать то, что внешний тактовый сигнал синхронизируется внутренней частотой Fosc. Это приводит к появлению задержки во времени фактического инкрементирования содержимого TMR0.

    Синхронизация происходит по окончании 2-го и 4-го тактов работы МК, поэтому, если пределитель не используется, то для фиксации входного события необходимо, чтобы длительности высокого и низкого состояний сигнала на входе RA4/T0CKI были бы не менее 2 периодов тактовой частоты Tosc плюс некоторая задержка ( 20 нс).

    Если модуль TIMER0 используется совместно с пределителем, то частота входного сигнала делится асинхронным счетчиком так, что сигнал на выходе пределителя становится симметричным. При этом необходимо, чтобы длительности высокого и низкого уровней сигнала на входе RA4/T0CKI были бы не менее 10 нс. Синхронизация сигнала происходит на выходе пределителя, поэтому существует небольшая задержка между фронтом внешнего сигнала и временем фактического инкремента таймера/счетчика. Эта задержка находится в диапазоне от 3 до 7 периодов колебаний тактового генератора. Таким образом, измерение интервала между событиями будет выполнено с точностью ±4 · Tosc.


    Рис. 5.13.  Структура и возможные варианты использования пределителя.

    5.2.11. Память данных в РПЗУ (EEPROM)


    Микроконтроллеры подгруппы PIC6F8X имеют энергонезависимую память данных 64х8 EEPROM бит, которая допускает запись и чтение во время нормальной работы (во всем диапазоне питающих напряжений). Эта память не принадлежит области регистровой памяти ОЗУ. Доступ к ней осуществляется посредством косвенной адресации через регистры специальных функций: EEDATA <08h>, который содержит 8-битовые данные для чтения/записи и EEADR <09h>, включающий адрес ячейки, к которой идет обращение. Для управления процессом чтения/записи используются два регистра: EECON1 <88h> и EECON2 <89h>.

    При записи байта автоматически стирается предыдущее значение, и записываются новые данные (стирание перед записью). Все эти операции производит встроенный автомат записи EEPROM. Содержимое ячеек этой памяти при выключении питания сохраняется.

    Регистр   EEADR может адресовать до 256 байт данных EEPROM. В МК подгруппы PIC6F8X используются только первые 64 байта, адресуемые шестью младшими битами EEADR<5:0>. Однако старшие два бита также декодируются. Поэтому эти два бита должны быть установлены в ‘0’, чтобы адрес попал в доступные 64 бита адресного пространства.

    Назначение бит регистра   EECON1 приведено в табл. 5.6.

    Таблица 5.6. Назначение бит регистра EECON1 (адреса 88h).

    U

    U

    U

    R/W-0

    R/W-x

    R/W-0

    R/S-0

    R/S-x

    -

    -

    -

    EEIF

    WRERR

    WREN

    WR

    RD

    Бит 7

    Бит 6

    Бит 5

    Бит 4

    Бит 3

    Бит 2

    Бит 1

    Бит 0

    Биты 7:5 не используются (читаются как ‘0’)

    Бит 4: EEIF: бит запроса прерывания по записи в EEPROM

    0 = операция записи не завершена или не начиналась

    1 = операция записи завершена (должен быть сброшен программно)

    Бит 3: WRERR: бит признака ошибки записи в EEPROM

    0 = операция записи завершена

    1 = операция записи прервана преждевременно (сбросом по /MCLR или сбросом от WDT)

    Бит 2: WREN: бит разрешения записи в EEPROM

    0 = запрещена запись в EEPROM

    1 = разрешены циклы записи

    Бит 1: WR: бит управления записью

    0 = цикл записи данных в EEPROM завершен

    1 = инициирует цикл записи (сбрасывается аппаратно по завершении записи. Бит WR может быть только установлен (но не сброшен) программно)

    Бит 0: RD: бит управления чтением

    0 = чтение данных EEPROM не инициировано

    1 = инициирует чтение данных EEPROM (чтение занимает один цикл. Бит RD сбрасывается аппаратно. Бит RD может быть только установлен (но не сброшен) программно)

    Регистр   EECON2 не является физическим регистром. Он используется исключительно при организации записи данных в EEPROM. Чтение регистра   EECON2 дает нули.

    При считывании данных из памяти EEPROM необходимо записать нужный адрес в EEADR   регистр и затем установить бит RD EECON1<0> в единицу. Данные появятся в следующем командном цикле в регистре   EEDATA и могут быть прочитаны. Данные в регистре   EEDATA фиксируются.

    При записи в память EEPROM необходимо сначала записать адрес в EEADR-регистр и данные в EEDATA-регистр. Затем следует выполнить специальную последовательность команд, производящую непосредственную запись:

    movlw 55h

    movwf EECON2

    movlw AAh

    movwf EECON2

    bsf EECON1,WR;установить WR бит, начать запись

    Во время выполнения этого участка программы все прерывания должны быть запрещены, для точного выполнения временной диаграммы. Время записи – примерно 10 мс. Фактическое время записи может изменяться в зависимости от напряжения, температуры и индивидуальных свойств кристалла. В конце записи бит WR автоматически обнуляется, а флаг завершения записи EEIF, он же запрос на прерывание, устанавливается.

    Для предотвращения случайных записей в память данных предусмотрен специальный бит WREN в регистре   EECON1. Рекомендуется держать бит WREN выключенным, кроме тех случаев, когда нужно обновить память данных. Более того, кодовые сегменты, которые устанавливают бит WREN, и те, которые выполняют запись, следует хранить на различных адресах, чтобы избежать случайного выполнения их обоих при сбое программы.

    5.2.12. Организация прерываний


    МК подгруппы PIC16F8X имеют четыре источника прерываний:

    • внешнее прерывание с вывода RB0/INT;

    • прерывание от переполнения счетчика/таймера   TMR0;

    • прерывание от изменения сигналов на линиях порта   RB<7:4>;

    • прерывание по окончании записи данных в EEPROM.

    Все прерывания имеют один и тот же вектор/адрес – 0004h. Однако в управляющем регистре   прерываний   INTCON соответствующим битом-признаком записывается, от какого именно источника поступил запрос прерывания. Исключение составляет прерывание по завершении записи в EEPROM, признак которого находится в регистре   EECON1.

    Бит общего разрешения/запрещения прерывания   GIE (INTCON <7>) разрешает (если = 1) все индивидуально незамаскированные прерывания или запрещает их (если = 0). Каждое прерывание в отдельности может быть дополнительно разрешено/запрещено установкой/сбросом соответствующего бита в регистре   INTCON.

    Бит GIE при сбросе обнуляется. Когда начинает обрабатываться прерывание, бит GIE обнуляется, чтобы запретить дальнейшие прерывания, адрес возврата посылается в стек, а в программный счетчик загружается адрес 0004h. Время реакции на прерывание для внешних событий, таких как прерывание от ножки INT или порта   B, составляет приблизительно пять циклов. Это на один цикл меньше, чем для внутренних событий, таких как прерывание по переполнению от таймера   TMR0. Время реакции всегда одинаковое.

    В подпрограмме обработки прерывания источник прерывания может быть определен по соответствующему биту в регистре признаков. Этот флаг-признак должен быть программно сброшен внутри подпрограммы. Признаки запросов прерываний не зависят от соответствующих маскирующих битов и бита общего маскирования GIE.

    Команда возврата из прерывания   RETFIE завершает прерывающую подпрограмму и устанавливает бит GIE, чтобы опять разрешить прерывания.

    Логика прерываний контроллера изображена на рис. 5.14.


    Рис. 5.14.  Логика прерываний микроконтроллера.

    Внешнее прерывание на ножке RB0/INT осуществляется по фронту: либо по нарастающему (если в регистре   OPTION бит INTEDG=1), либо по спадающему (если INTEDG=0). Когда фронт обнаруживается на ножке INT, бит запроса INTF устанавливается в единицу (INTCON <1>). Это прерывание может быть замаскировано сбросом управляющего бита INTE в ноль (INTCON <4>). Бит запроса INTF необходимо очистить прерывающей программой перед тем, как опять разрешить это прерывание. Прерывание   INT может вывести процессор из режима SLEEP, если перед входом в этот режим бит INTE был установлен в единицу. Состояние бита GIE также определяет, будет ли процессор переходить на подпрограмму прерывания после выхода из режима SLEEP.

    Переполнение счетчика TMR0 (FFh->00h) устанавливает в единицу бит запроса T0IF (INTCON<2>). Это прерывание может быть разрешено/запрещено установкой/сбросом бита маски T0IE (INTCON<5>). Сброс запроса T0IF – дело программы обработки.

    Любое изменение сигнала на одном из четырех входов порта   RB<7:4> устанавливает в единицу бит RBIF (INTCON<0>). Это прерывание может быть разрешено/запрещено установкой/сбросом бита маски RBIE (INTCON<3>). Сброс запроса RBIF – дело программы обработки.

    Признак запроса прерывания по завершении записи в EEPROM, EEIF (EECON1<4>) устанавливается в единицу по окончании автоматической записи данных в EEPROM. Это прерывание может быть замаскировано сбросом бита EEIE (INTCON<6>). Сброс запроса EEIF – дело программы обработки.
      1)   Этот буфер имеет вход триггера Шмитта, когда конфигурируется в режиме RC-генератора и КМОП-вход в остальных случаях.
      2)   Этот буфер имеет вход триггера Шмитта, когда конфигурируется в качестве входа внешнего прерывания.
      3)   Этот буфер имеет вход триггера Шмитта, когда используется в режиме последовательного программирования.
      4)   Этот буфер имеет вход триггера Шмитта, когда используется в режиме последовательного программирования.

    5.2.13. Специальные функции


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

    • сброс;

    • сторожевой таймер (WDT);

    • режим пониженного энергопотребления (SLEEP);

    • выбор типа генератора;

    • защита кода от считывания;

    • биты идентификации;

    • последовательное программирование в составе схемы.

    В PIC16F8X существуют различия между вариантами сбросов:

    • сброс по включению питания;

    • сброс по внешнему сигналу /MCLR при нормальной работе;

    • сброс по внешнему сигналу /MCLR в режиме SLEEP;

    • сброс по окончании задержки таймера WDT при нормальной работе;

    • сброс по окончании задержки таймера WDT в режиме SLEEP.

    Для реализации сброса по включению питания в МК подгруппы PIC16F8X предусмотрен встроенный детектор включения питания. Таймер установления питания (PWRT) начинает отсчет времени после того, как напряжение питания пересекает уровень около 1,2…1,8 Вольт. По истечении выдержки около 72мс считается, что напряжение достигло номинала и запускается другой таймер – таймер запуска генератора (OST), формирующий выдержку на стабилизацию кварцевого генератора. Программируемый бит конфигурации позволяет разрешать или запрещать выдержку от встроенного таймера установления питания. Выдержка запуска меняется в зависимости от экземпляров кристалла, от питания и температуры. Таймер на стабилизацию генератора отсчитывает 1024 импульса от начавшего работу генератора. Считается, что кварцевый генератор за это время выходит на режим. При использовании RC   генераторов выдержка на стабилизацию не производится.

    Если сигнал /MCLR удерживается в низком состоянии достаточно долго (дольше времени всех задержек), тогда после перехода /MCLR в высокое состояние программа начнет выполняться немедленно. Это необходимо в тех случаях, когда требуется синхронно запустить в работу несколько PIC-контроллеров через общий для всех сигнал /MCLR.

    Микроконтроллеры подгруппы PIC16F8X имеют встроенный сторожевой таймер   WDT. Для большей надежности он работает от собственного внутреннего RC-генератора и продолжает функционировать, даже если основной генератор остановлен, как это бывает при исполнении команды SLEEP. Таймер вырабатывает сигнал сброса. Выработка таких сбросов может быть запрещена путем записи нуля в специальный бит конфигурации   WDTE. Эту операцию производят на этапе прожига микросхем.

    Номинальная выдержка WDT составляет 18 мс (без использования делителя). Она зависит от температуры, напряжения питания, особенностей типов микросхем. Если требуются большие задержки, то к WDT может быть подключен встроенный пределитель с коэффициентом деления до 1:128, который программируется битами PS2:PS0 в регистре OPTION. В результате могут быть реализованы выдержки до 2,3 секунд.

    Команды «CLRWDT» и «SLEEP» обнуляют WDT и пределитель, если он подключен к WDT. Это запускает выдержку времени сначала и предотвращает на некоторое время выработку сигнала сброса. Если сигнал сброса от WDT все же произошел, то одновременно обнуляется бит /TO в регистре статуса. В приложениях с высоким уровнем помех содержимое регистра OPTION подвержено сбою. Поэтому регистр OPTION должен обновляться через равные промежутки времени.

    Состояние регистров МК после сброса представлено в табл. 5.7.

    Некоторые из специальных регистров при сбросе не инициализируются. Они имеют случайное состояние при включении питания и не изменяются при иных видах сброса. Другая часть специальных регистров инициализируется в «состояние сброса» при всех видах сброса, кроме сброса по окончанию задержки таймера WDT в режиме SLEEP. Просто этот сброс рассматривается как временная задержка в нормальной работе. Есть еще несколько исключений. Счетчик команд всегда сбрасывается в ноль (0000h). Биты регистра статуса /TO и /PD устанавливаются или сбрасываются в зависимости от варианта сброса. Эти биты используются программой для определения природы сброса (см. табл. 5.3).

    Таблица 5.7. Состояние регистров МК после сброса.

    Регистр

    Адрес

    Сброс по включению

    Другие виды питания сброса

    W

    -

    xxxx xxxx

    uuuu uuuu

    INDF

    00h

    —— ——

    —— ——

    TMR0

    01h

    xxxx xxxx

    uuuu uuuu

    PCL

    02h

    0000 0000

    0000 0000

    STATUS

    03h

    0001 1xxx

    000q quuu

    FSR

    04h

    xxxx xxxx

    uuuu uuuu

    PORT A

    05h

    —x xxxx

    —u uuuu

    PORT B

    06h

    xxxx xxxx

    uuuu uuuu

    TRIS A

    85h

    —1 1111

    —1 1111

    TRIS B

    86h

    1111 1111

    1111 1111

    OPTION

    81h

    1111 1111

    1111 1111

    EEDATA

    08h

    xxxx xxxx

    uuuu uuuu

    EEADR

    09h

    xxxx xxxx

    uuuu uuuu

    EECON1

    88h

    —0 0000

    —0 q000

    EECON2

    89h

    —— ——

    —— ——

    PCLATH

    0Ah

    —0 0000

    —0 0000

    INTCON

    0Bh

    0000 000x

    0000 000u

    Здесь: x — неизвестное значение; u — неизменяемый бит; «–» — неиспользуемый бит (читается как «0»); q — значение бита зависит от условий сброса.

    Режим пониженного энергопотребления SLEEP предназначен для обеспечения очень малого тока потребления в ожидании (менее 1 мкА при выключенном сторожевом таймере). Выход из режима SLEEP возможен по внешнему сигналу сброса или по окончании выдержки сторожевого таймера.

    Кристаллы PIC16F8X могут работать с четырьмя типами встроенных генераторов. Пользователь может запрограммировать два конфигурационных бита (FOSC1 и FOSC0) для выбора одного из четырех режимов: RC, LP, XT, HS. Здесь XT – стандартный кварцевый генератор, HS – высокочастотный кварцевый генератор, LP – низкочастотный генератор для экономичных приложений. Микроконтроллеры PIC16F8X могут тактироваться и от внешних источников.

    Генератор, построенный на кварцевых или керамических резонаторах, требует периода стабилизации после включения питания. Для этого встроенный таймер запуска генератора держит устройство в состоянии сброса примерно 18 мс после того, как сигнал на /MCLR ножке кристалла достигнет уровня логической единицы.

    Возможность выбора типа генератора позволяет эффективно использовать микроконтроллеры семейства в различных приложениях. Применение RC   генератора позволяет уменьшить стоимость системы, а низкочастотный LP-генератор сокращает энергопотребление.

    Программный код, который записан в кристалл, может быть защищен от считывания при помощи установки бита защиты (CP) в слове конфигурации в ноль. Содержимое программы не может быть прочитано так, чтобы с ним можно было работать. Кроме того, при установленном бите защиты невозможно изменять программу. То же относится и к содержимому памяти данных EEPROM.

    Если установлена защита, то бит CP можно стереть только вместе с содержимым кристалла. Сначала будет стерта EEPROM программная память и память данных, и в последнюю очередь – бит защиты кода CP. При считывании защищенного кристалла чтение любого адреса памяти даст результат вида 0000000XXXXXXX(двоичный код), где X – это 0 или 1.

    Память данных EEPROM невозможно проверить после установки бита защиты.

    Для выбора различных режимов работы используются биты конфигурации. Микроконтроллеры подгруппы PIC16F8X имеют 5 или 6 бит конфигурации, которые хранятся в EEPROM и устанавливаются на этапе программирования кристалла. Эти биты могут быть запрограммированы (читается как «0») или оставлены незапрограммированными (читается «1«) для выбора подходящего варианта конфигурации устройства. Они расположены в EEPROM-памяти по адресу 2007h. Пользователю следует помнить, что этот адрес находится ниже области кодов и недоступен программе.

    Назначение бит конфигурации МК PIC16CR83 и PIC16CR84 приведено в табл. 5.8.

    Таблица 5.8. Назначение бит конфигурации МК PIC16CR83 и PIC16CR84.

    R-u

    R/P-u

    R-u

    R-u

    R-u

    R-u

    R-u

    CP

    DP

    CP

    /PWRTE

    WDTE

    FOSC1

    FOSC0

    Бит 13:8

    Бит 7

    Бит 6:4

    Бит 3

    Бит 2

    Бит 1

    Бит 0

    Биты 13:8 CP: бит защиты памяти программ

    0 = память программ защищена

    1 = защита отсутствует

    Бит 7 DP: бит защиты памяти данных

    0 = память данных защищена

    1 = защита отсутствует

    Биты 6:4 CP: бит защиты памяти программ

    0 = память программ защищена

    1 = защита отсутствует

    Бит 3 /PWRTE: бит использования таймера по включению питания

    0 = таймер используется (есть задержка)

    1 = таймер не используется

    Бит 2: WDTE: бит использования сторожевого таймера

    0 = WDT не используется

    1 = WDT используется

    Биты 1:0 FOSC1:FOSC0: бит выбора типа генератора

    11 = генератор RC

    10 = генератор HS

    01 = генератор XT

    00 = генератор LP

    Здесь: P — программируемый бит; – n = значение по сбросу после включения питания.

    Назначение бит конфигурации МК PIC16F83 и PIC16F84 приведено в табл. 5.9.

    Таблица 5.9. Назначение бит конфигурации МК PIC15F83 и PIC16F84.

    R-u

    R-u

    R-u

    R-u

    R-u

    CP

    /PWRTE

    WDTE

    FOSC1

    FOSC0

    Бит 13:4

    Бит 3

    Бит 2

    Бит 1

    Бит 0

    Биты 13:4 CP: бит защиты памяти программ

    0 = память программ защищена

    1 = защита отсутствует

    Бит 3 /PWRTE: бит использования таймера по включению питания

    0 = таймер используется (есть задержка)

    1 = таймер не используется

    Бит 2: WDTE: бит использования сторожевого таймера

    0 = WDT не используется

    1 = WDT используется

    Биты 1:0 FOSC1:FOSC0: бит выбора типа генератора

    11 = генератор RC

    10 = генератор HS

    01 = генератор XT

    00 = генератор LP

    Четыре слова памяти, расположенные по адресам 2000h-2003h, предназначены для хранения идентификационного кода (ID) пользователя, контрольной суммы или другой информации. Как и слово конфигурации, они могут быть прочитаны или записаны только с помощью программатора. Доступа из программы к ним нет.

    Микроконтроллеры подгруппы PIC16F8X могут быть запрограммированы последовательным способом в составе устройства. Для этого используется всего пять линий: две для данных и тактового сигнала и три для земли, напряжения питания и программирующего напряжения. Разработчик может создать и смакетировать устройство с незапрограммированным прибором, а перед использованием ввести в него программу.
    1   ...   14   15   16   17   18   19   20   21   22


    написать администратору сайта