Данное устройство может быть выполнено на разной элементной базе включая микросхемы серии 155,176,561 также различные микропроцессорные комплекты 580,1816,1830 и на специализированных микросхемах например 1901 что предпочтительней с экономической точки зрения т.к в их состав входят контроллер клавиатуры и дисплея тактовый генератор, устройство управления, таймер и многое другое необходимое для электронных часов. В данной работе в учебных целях это устройство будет разработано на микроконтроллере PIC16F84
PIC16F84 относится к семейству КМОП микроконтроллеров. Отличается тем, что имеет внутреннее 1K x 14 бит EEPROM для программ, 8-битовые данные и 64байт EEPROM памяти данных. При этом отличаются низкой стоимостью и высокой производительностью. Все команды состоят из одного слова (14 бит шириной) и исполняются за один цикл (400 нс при 10 МГц), кроме команд перехода, которые выполняются за два цикла (800 нс). PIC16F84 имеет прерывание, срабатывающее от четырех источников, и восьмиуровневый аппаратный стек. Периферия включает в себя 8-битный таймер/счетчик с 8-битным программируемым предварительным делителем (фактически 16 - битный таймер) и 13 линий двунаправленного ввода/вывода. Высокая нагрузочная способность (25 мА макс. втекающий ток, 20 мА макс. вытекающий ток) линий ввода/вывода упрощают внешние драйверы и, тем самым, уменьшается общая стоимость системы. Разработки на базе контроллеров PIC16F84 поддерживается ассемблером.
Низкая цена, экономичность, быстродействие, простота использования и гибкость ввода/вывода делает PIC16F84 привлекательным даже в тех областях, где ранее не применялись микроконтроллеры. Структурная схема микроконтроллера приведена в приложении «номер» 1.
Архитектура основана на концепции раздельных шин и областей памяти для данных и для команд (Гарвардская архитектура). Шина данных и память данных (ОЗУ) - имеют ширину 8 бит, а программная шина и программная память (ПЗУ) имеют ширину 14 бит. Такая концепция обеспечивает простую, но мощную систему команд, разработанную так, что битовые, байтовые и регистровые операции работают с высокой скоростью и с перекрытием по времени выборок команд и циклов выполнения. 14- битовая ширина программной памяти обеспечивает выборку 14-битовой команды в один цикл. Двухступенчатый конвейер обеспечивает одновременную выборку и исполнение команды. Все команды выполняются за один цикл, исключая команды переходов. В PIC16F84 программная память объемом 1К х 14 расположена внутри кристалла. Исполняемая программа может находиться только во встроенном ПЗУ. Условно графическое обозначение микроконтроллера приведено на рис.2
Вход в режим SLEEP осуществляется командой SLEEP. По этой команде, если WDT разрешен, то он сбрасывается и начинает счет времени, бит "PD" в регистре статуса (f3) сбрасывается, бит "TO" устанавливается, а встроенный генератор выключается. Порты ввода/вывода сохраняют состояние, которое они имели до входа в режим SLEEP. Для снижения потребляемого тока в этом режиме, ножки на вывод должны иметь такие значения, чтобы не протекал ток между кристаллом и внешними цепями. Ножки на ввод должны быть соединены внешними резисторами с высоким или низким уровнем, чтобы избежать токов переключения, вызываемых плавающими высокоомными входами. То же и про RTCC. Ножка /MCLR должна быть под напряжением Vihmc.
Рисунок .2 Условно графическое изображение PIC16F84
Таблица 1. Обозначение шин микроконтроллера
Обозначение
Нормальный режим
Режим записи EEPROM
RA0 - RA3
Двунаправленные линии ввода/вывода.Входные уровни ТТЛ.
-
RA4/RTCC
Вход через триггер Шмитта. Ножка порта ввода/вывода с открытым стоком или вход частоты для таймера/счетчика RTCC
-
RB0/INT
Двунаправленная линия порта ввода/вывода или внешний вход прерывания. Уровни ТТЛ.
-
RB1 - RB5
Двунаправленные линии ввода/вывода. Уровни ТТЛ.
-
RB6
Двунаправленные линии ввода/вывода. Уровни ТТЛ.
Вход тактовой частоты для EEPROM
RB7
Двунаправленные линии ввода/вывода. Уровни ТТЛ.
Вход/выход EEPROM данных.
/MCLR/Vpp/
Низкий уровень на этом входе генерирует сигнал сброса для контроллера. Активный низкий. Сброс контроллера.
Для режима EEPROM - подать Vpp.
OSC1 /CLKIN
Для подключения кварца, RC или вход внешней тактовой частоты.
-
OSC2 /CLKOUT
Генератор, выход тактовой частоты в режиме RC генератора, в остальных случаях - для подкл.кварц
-
Vdd
Напряжение питания
Напряжение питания
Vss
Общий(земля)
Общий(земля)
В регистре статуса (03h) есть биты выбора страниц, которые позволяют обращаться к четырем страницам будущих модификаций этого кристалла. Однако для PIC16F84 память данных существует только до адреса 02Fh. Первые 12 адресов используются для размещения регистров специального назначения. Регистры с адресами 0Ch-2Fh могут быть использованы, как регистры общего назначения, которые представляют собой статическое ОЗУ. Некоторые регистры специального назначения продублированы на обеих страницах, а некотрые расположены на странице 1 отдельно. Когда установлена страница 1, то обращение к адресам 8Ch-AFh фактически адресует страницу 0. К регистрам можно адресоваться прямо или косвенно. В обоих случаях можно адресовать до 512 регистров.
Watchdog таймер представляет собой полностью независимый встроенный RC генератор, который не требует никаких внешних цепей. Он будет работать, даже если основной генератор остановлен, как это бывает при исполнении команды SLEEP. Таймер вырабатывает сигнал сброса. Выработка таких сбросов может быть запрещена путем записи нуля в специальный бит конфигурации WDTE. Эту операцию производят на этапе программирования микросхем.
Также в устройстве будет использован цифробуквенные индикаторы с высотой цифр 7,5 мм из семи сегментов с децимальной точкой АЛС324А, его графическое изображение приведено на рис. 3. Блок индикации, состоящий из 4-х индикаторов АЛС324А которые управляются микропроцессором через токоограничивающие резисторы R4...R10 номиналом 180 Ом. Индикация осуществляется динамическим способом т.е вывод осуществляется по порядку 1,2,3,4 - индикатор по 10мс на каждый индикатор. Схема подключения индикаторов показана в приложении 1
Рисунок . 3 Индикатор АЛС 324 А УГО
Ввод информации для управления электронными часами осуществляется через 2 кнопки, подключенных к портам RB0 и RA0 микроконтроллера. Схема подключения показана в приложении 2. Меры по предотвращению дребезга контактов могут реализоваться программным методом. Сопротивление резисторов выбирается из расчета протекания наименьшего тока необходимого для фиксации логической 1 на входах микроконтроллера при неактивных позициях кнопок и в данном случае составляют 10 Ком.
Кристаллы PIC16F84 могут работать с четырьмя типами встроенных генераторов. Пользователь может запрограммировать два конфигурационных бита (FOSC1 и FOSC0) для выбора одного из четырех режимов: RC, LP, XT, HS. Кристаллы PIC16... могут также тактироваться и от внешних источников. Генератор, построенный на кварцевых или керамических резонаторах, требует периода стабилизации после включения питания. Для этого, встроенный таймер запуска генератора держит устройство в состоянии сброса примерно 18 мс после того, как сигнал на /MCLR ножке кристалла достигнет уровня логической единицы. Таким образом, внешняя цепочка RC , связанная с ножкой /MCLR во многих случаях не требуется.
Встроенные генераторы работоспособны при определенных номиналах питающего напряжения:
Таблица 2 Параметры кварцевого резонатора
Vdd
OSC mode
Max Freq
2..3V
RC
2 MHz
LP
200 kHz
3..6V
RC, XT
4 MHz
LP
200 kHz
4,5..5,5
HS
10 MHz
При частотах ниже 500 кГц, внутренний генератор может генерировать сбойный импульс на гармониках, когда переключается бит 0 порта A. Этого не происходит при использовании внешнего генератора или при встроенном RC генераторе. PIC16F84-XT, -HS или -LP требуют подключения кварцевого или керамического резонатора к выводам OSC1 и OSC2. Маркировка следующая: XT - стандартный кварцевый генератор, HS - высокочастотный кварцевый генератор, LP - низкочастотный генератор для экономичных приложений. Резистор Rs может потребоваться для генератора "HS", особенно при частотах ниже 20 МГц для гашения гармоник. Он также может потребоваться в режиме XT с резонатором типа AT strip-cut. Необходимые значения конденсаторов для разных частот приведены в таблице.
Таблица 3 Выбор конденсатора для кварцевого генератора
Тип генератора
Частота
Конденсатор С1
Конденсатор С2
LP
32 КГц
30 пФ
30 - 50 пф
100 КГц
15 пф
15 пФ
200 КГц
0- 15 пФ
0 - 15 пФ
XT
100 КГц
15 - 30 пФ
200 - 300 пФ
200 КГц
15- 30 пФ
100 - 200 пФ
455 КГц
15 - 30 пФ
15 -100 пФ
1 МГц
15 - 30 пФ
15 - 30 пФ
2 МГц
15 пФ
15 пФ
4МГц
15 пФ
15 пФ
HS
4 МГц
15 пФ
15 пФ
10 МГц
15пФ
15 пФ
Более высокая емкость будет увеличивать стабильность генератора, но также будет увеличивать время запуска. В режимах HS и XT, чтобы избежать гармоник может потребоваться последовательный резистор Rs.
Выбираем 2 конденсатора К5-16 30 пф +\- 10%
Выбираем 2 резистора R1,R2 МЛТ 0,125 10 Ком +/- 10% и 8 резисторов R3-R10 МЛТ 0,125 180 ом +/- 10%