Электронный замок с ключами iButton

Некоторое время тому назад появился проект «ИМИТАТОР TOUCH-MEMORY DS1990A», т.е. отмычка. Теперь Вашему вниманию предлагается замок к этой отмычке. Замок имеет простую конструкцию и предназначен в основном для индивидуального использования. Замок работает с любыми типами ключей iButton, поэтому можно применять уже имеющиеся ключи, предназначенные для других целей. Всего в память может быть записано до 9 ключей, хотя это количество можно легко увеличить. Для авторизации процесса программирования используется мастер-ключ, код которого занесен в ПЗУ и не может быть стерт или изменен обычной процедурой программирования замка.

В последнее время широкое распространение получили замки, ключом к которым является электронная таблетка iButton (или touch memory) фирмы Dallas Semiconductor. Такие замки часто используются на дверях подъездов, а также внутри многих учреждений. Кроме того, ключи iButton часто применяются для расчетов на автозаправочных станциях и в других местах. Таким образом, у многих уже есть ключи iButton от чего-либо. Потому при проектировании самодельного замка рационально использовать в нем уже имеющиеся у пользователя ключи. Именно так и сделано в предлагаемом замке: с ним могут работать любые типы ключей, потому что используется лишь записанный в ПЗУ iButton серийный номер, который есть в любом их типе. К тому же, команда чтения этого номера одна и та же для всех типов ключей (33H). Код семейства, который различается у разных типов, может быть любым. Он воспринимается как ещё одна цифра сериального номера. Нужно отметить, что самым дешевым типом ключей является DS1990A.

Замок проектировался для индивидуального использования и имеет предельно простую конструкцию. На входной двери снаружи располагается лишь панелька для iButton и светодиод открывания дверей. Открывание дверей изнутри осуществляется с помощью кнопки. В качестве исполнительного механизма используется стандартная защелка с электромагнитом, который рассчитан на напряжение 12В. Коды ключей хранятся в энергонезависимой памяти и могут стираться и добавляться пользователем. Для защиты от несанкционированного перепрограммирования замка используется мастер-ключ. Всего в память можно записать 9 ключей. Это количество продиктовано возможностями 1-разрядного индикатора номера программируемого ключа. Если задействовать ещё и буквы, можно увеличить суммарное количество ключей до 15. Это делается путем замены значения константы MAXK в программе. Таким же способом можно и уменьшить максимальное количество ключей.


Рис. 1. Принципиальная схема замка

Принципиальная схема замка показана на рисунке 1. Основой конструкции является микроконтроллер U1 типа AT89C2051 фирмы Atmel. К порту P1 подключен 7-сегментный индикатор, который используется при программировании ключей. Для этих же целей предназначена и кнопка SB1, подключенная к порту P3.7. Хранение серийных номеров ключей осуществляется в микросхеме EEPROM U3 типа 24C02, подключенной к портам P3.4 (SDA) и P3.5 (SCL). Внешняя панелька для iButton подключается к порту P3.3 через разъем XP2 и элементы защиты VD4, R3, VD5 и VD6. Подтягивающий резистор R4 выбран согласно спецификации однопроводной шины. Параллельно внешней панельке подключена ещё и внутренняя панелька XS1, которая используется для программирования ключей. Кнопка открывания двери подключена к порту P3.2 через разъем XP1 и такие же элементы защиты, как и для iButton. Исполнительным устройством замка является электромагнит, подключенный через терминал XT1. Электомагнитом управляет ключ VT3, в качестве которого используется мощный МОП-транзистор типа IRF540. Диод VD7 защищает от выбросов самоиндукции. Ключом VT3 управляет транзистор VT2, который инвертирует сигнал, поступающий с порта P3.0 и обеспечивает управляющие уровни 0/12В на затворе VT3. Инверсия нужна для того, чтобы исполнительное устройство не срабатывало во время сброса микроконтроллера, когда на порту присутствует уровень логической единицы. 12-вольтовые управляющие уровни позволили применить обычный МОП-транзистор вместо более дефицитного низкопорогового (logick level). Для индикации открытия замка используется светодиод, который управляется тем же портом, что и электромагнит, но через транзисторный ключ VT1. Светодиод подключается через тот же разъем, что и iButton. Поскольку устройство должно работать круглосуточно без обслуживания, для повышения надежности установлен супервизор U2 типа ADM1232. Он имеет встроенный сторожевой таймер и монитор питания. На порту P3.1 микроконтроллер формирует периодические импульсы для сброса сторожевого таймера.

Питание устройства осуществляется от встроенного блока питания, содержащего трансформатор T1, выпрямительный мост VD9-VD12 и интегральный стабилизатор U4. В качестве резервного источника питания используется батарея BT1-BT10 из 10-ти NiMH-аккумуляторов типоразмера AA емкостью 800мА/Ч. При питании устройства от сети батарея аккумуляторов заряжается через резистор R10 током примерно 20мА, что составляет 0.025C. Режим зарядки малым током называют капельным (trickle charge). В таком режиме аккумуляторы могут находится сколь угодно долго, контроль конца процесса зарядки не требуется. Когда аккумуляторы оказываются полностью заряженными, забираемая ими от источника питания энергия превращается в тепло. Но поскольку ток зарядки очень маленький, выделяемое тепло рассеивается в окружающее пространство без сколько-нибудь заметного увеличения температуры аккумуляторов.

Конструктивно устройство выполнено в корпусе размером 150х100х60мм. Большинство элементов, включая трансформатор питания, смонтировано на печатной плате. Аккумуляторы размещаются в стандартных пластмассовых держателях, которые закреплены внутри корпуса рядом с платой. В принципе, можно использовать и другие типы аккумуляторов, например 12-вольтовую кислотную необслуживаемую батарею, применяющуюся в охранных системах. Для подключения исполнительного устройства на плате имеются терминалы типа TB-2, все остальные внешние цепи подключаются через малогабаритные разъемы с шагом контактов 2.54мм. Разъемы расположены на печатной плате и снаружи корпуса недоступны. Провода выходят из корпуса через резиновые уплотнители. Поскольку индикатор HG1, кнопка SB1 и панелька для iButton XS1 используются лишь во время программирования, они размещены на плате внутри устройства. Это упрощает конструкцию корпуса и делает его более защищенным от внешних воздействий. На боковой панели корпуса размещен лишь светодиод индикации включения VD13. Схема внешних соединений показана на рис. 2.


Рис. 2. Схема внешних соединений

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

Замок может иметь максимум 9 ключей, плюс один мастер-ключ. Коды ключей заносятся в энергонезависимую память под номерами от 1 до 9. Код мастер-ключа занесен в ПЗУ микроконтроллера и не может быть изменен. Программирование новых ключей или стирание старых может быть произведено лишь при наличии мастер-ключа. Как и другие ключи, мастер-ключ может использоваться для открывания замка.

Для программирования нового ключа нужно проделать следующие действия:

1. Нажать кнопку программирования.
2. На индикаторе появится буква «P», что означает вход в режим программирования.
3. Коснуться мастер-ключом панельки.
4. На индикаторе появится цифра «1», которая обозначает номер программируемого ключа.
5. Кнопкой выбрать нужный номер.
6. Коснуться любым ключом панельки.
7. Цифра на индикаторе начнет мигать, что говорит о готовности к программированию.
8. Коснуться панельки тем ключом, код которого требуется занести в память.
9. В случае успешного программирования цифра на индикаторе перестанет мигать и начнет гореть постоянно.
10. Для выхода из режима программирования нужно просто подождать 5 секунд, после чего индикатор погаснет.

Схематически процесс программирования нового ключа показан на рис. 3.


Рис. 3. Программирование нового ключа

Если нужно запрограммировать несколько ключей, то можно сразу перейти от пункта 9 к пункту 5 и повторить пункты 5 – 9 необходимое число раз.

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

Для стирания из памяти лишнего ключа последовательность действий остается такой же, как и при программировании, лишь все действия производятся мастер-ключом. Т.е. процесс стирания фактически является записью кода мастер-ключа на неиспользуемые номера.
Схематически процесс стирание лишнего ключа показан на рис. 4.


Рис. 4. Стирание лишнего ключа

В процессе программирования открыть дверь кнопкой можно, а вот открывание с помощью iButton заблокировано. Поскольку внутренняя и внешняя панельки соединены параллельно, нужно следить, чтобы во время программирования никто не касался внешней панельки никакими ключами.

Код мастер-ключа записывается в ПЗУ программ микроконтроллера, начиная с адреса 2FDH. Длина кода составляет 8 байт. Последовательность цифр должна быть такая же, как и на корпусе touch-memory, читать нужно слева направо. Т.е. по адресу 2FDH заносится значение контрольной суммы, далее по адресам 2FEH – 303H шесть байт серийного номера, начиная со старшего байта, и, наконец, по адресу 304H – код семейства. К примеру, код в целом может выглядеть так: 67 00 00 02 D6 85 26 01.

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


Рис. 5. Блок-схема основного цикла программы

Для обработки событий, связанных с программированием, имеются две подпрограммы: PROGT и PROGS, блок-схемы которых приведены на рис. 6. Первая вызывается при считывании кода ключа в режиме программирования, вторая – при нажатии кнопки программирования (NUMBER). Процесс программирования разбит на 3 фазы. При нажатии кнопки NUMBER осуществляется вход в программирование, т.е. переход к фазе 1. При этом на индикатор выводится буква «P». Считываемые после этого коды ключей проверяются на совпадение с кодом мастер-ключа, потому что лишь он может позволить продолжить программирование. Если такое совпадение произошло, то осуществляется переход к фазе 2. На индикатор выводится номер текущего ключа, который кнопка NUMBER может изменять. Если снова будет зарегистрировано касание ключа, то произойдет переход к фазе 3. Ещё одно касание ключа приведет к запоминанию его кода и к возврату к фазе 2. Нажатием кнопки NUMBER тоже можно вернуться к фазе 2, но без изменения содержимого памяти. Любое действие в режиме программирования вызывает перезагрузку таймера возврата, который имеет интервал 5 секунд и проверяется в основном цикле. Если будет обнаружено обнуление этого таймера, то происходит выход из режима программирования.


Рис. 6. Блок-схемы подпрограмм, используемых при программировании кода ключа

Приведенные на рис. 5 и 6 блок-схемы являются сильно упрощенными, однако общую логику построения программы они понять позволяют.

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

Файлы:
lock.asm — исходный текст программы замка.
lock.bin — оттранслированная программа.

Список радиоэлементовОбозначение
Тип
Номинал
Количество
ПримечаниеМагазинМой блокнот

U1
МК AVR 8-битAT89C20511
U2
Супервизор питанияTC12321
U3
EEPROM24C021
U4
Линейный регуляторLM78051
VT1
ТранзисторКТ3129А1
VT2
Биполярный транзисторКТ3130А91
VT3
MOSFET-транзисторIRF5401
VD1, VD4
СтабилитронBZV55-B5V62
VD2, VD3, VD5, VD6
Выпрямительный диод1N41484
VD7, VD8
Выпрямительный диодFR3072
VD9-VD12
Диодный мостKBU4051
С1, С2
Конденсатор33 пФ2
С3
Конденсатор0.1 мкФ1
С4
Электролитический конденсатор33 мкФ1
С5
Электролитический конденсатор10000 мкФ 16 В1
R1, R3
Резистор330 Ом2
R2, R4
Резистор4.7 кОм2
R5, R6, R8, R9
Резистор47 кОм4
R7, R19
Резистор220 Ом2
R10
Резистор100 Ом1
1 ВтR11-R18
Резистор470 Ом8

Светодиод1
ZQ1
Кварц10 МГц1
HG1
ИндикаторLTS6660E1
T1
Трансформатор1
FU1
Предохранитель1 А1
FU2
Предохранитель3 А1
BT1-BT10
АКБAA NiMH10
SB1
Кнопка1
XS1
РазъемTOUCH MEMORY1
XT1
Разъем1
XP1
Разъем2 выв.1
XP2
Разъем3 выв.1

Вилка сетевая1
Добавить все

Скачать список элементов (PDF)

Прикрепленные файлы:

Добавить комментарий

Ваш адрес email не будет опубликован.