本项目为RT-Thread嵌入式大赛获奖作品,基于恩智浦MCXA156系列微控制器构建了一款多功能智能门锁控制系统。目前,恩智浦已有多款产品对RT-Thread完成了适配。近期,MCX A 系列产品的重要成员,FRDM-MCXA346也完成了适配,并在社区开发者的协作下完成了电子书《恩智浦FRDM-MCX A346开发实践指南》
(https://www.rt-thread.org/document/site/#/rt-thread-version/rt-thread-standard/tutorial/make-bsp/MCX-A346/%E6%81%A9%E6%99%BA%E6%B5%A6FRDM-MCXA346%E5%AE%9E%E8%B7%B5%E6%8C%87%E5%8D%97)
(文末查看贡献名单以及开发板详情↓)
目录
项目概述
硬件选型与连接
软件架构设计
核心模块实现
多开锁模式扩展
项目优化与改进方向
项目源码
1 项目概述
本项目基于MCXA156系列微控制器构建了一款多功能智能门锁控制系统,整合了密码、指纹、射频卡三种开锁方式,配备 OLED 本地显示与声光反馈机制,通过 EEPROM 实现密钥持久化存储,构成了一套兼顾安全性与便捷性的嵌入式解决方案。系统支持本地密钥修改、开锁状态实时反馈、错误报警等核心功能,可广泛应用于家庭、办公场所等场景的门禁控制。
设计思路方案

系统运行流程图

项目核心功能
多模式开锁:支持 6 位数字密码、FPM383C 指纹识别、RC522 射频卡三种开锁方式,满足不同使用场景需求。
密钥管理:通过 24CXX 系列 EEPROM 实现开锁密钥的持久化存储,支持本地按键修改密钥,修改后自动同步存储。
状态可视化:借助 SSD1306 OLED 显示屏实时显示当前界面状态、输入密码位数、开锁结果等信息;
声光反馈:开锁成功时 LED 点亮 + 图标提示,密码错误时蜂鸣器报警 + 图标闪烁,提升用户交互体验;
多任务并发:基于裸机编程实现传感器扫描、按键处理、显示更新、报警控制等任务的并发执行,确保系统响应实时性。
本文将详细拆解系统的硬件选型、软件架构、核心逻辑实现及开发过程中的关键细节,为嵌入式门禁系统开发提供实践参考。
视频演示:[智能门锁演示视频]【智能门锁MCXA156】
2 硬件选型与连接
核心控制器:FRDM-MCXA156
选用 FRDM-MCXA156微控制器作为核心控制单元,其优势如下:
性能:搭载ARM Cortex-M 系列内核,具备高效的指令执行能力,可满足多外设并发控制与算法处理需求,丰富的I2C、SPI、UART、PWM、GPIO 等接口,无需扩展板即可直接连接所有功能模块。
各模块功能

各协议通信流程图

硬件连接详情

3 软件架构设计
本项目软件基于RT-Thread-5.2.1官方demo开发,将系统功能拆解为多个独立模块,通过全局变量实现模块间数据交互,确保代码的可维护性与扩展性。
整体架构
系统软件主要包含五大核心模块,各模块功能独立、协同工作:
外设驱动模块:负责各硬件外设的初始化与底层操作(如UART、I2C、SPI、PWM、GPIO 等)。
核心控制模块:实现开锁逻辑判断、密钥验证、状态管理等核心功能。
输入处理模块:处理按键输入、指纹识别结果、射频卡读取数据。
显示控制模块:管理 OLED 屏幕的界面刷新与信息显示。
反馈模块:通过 LED、蜂鸣器实现开锁成功、错误报警等状态反馈。
工作流程详解
系统初始化阶段:
启动后依次完成中断优先级配置、串口初始化、各外设(指纹模块、RC522、OLED、按键EEPROM、PWM)初始化。
检测 EEPROM 是否正常工作,若异常则通过 LED 闪烁提示,从 EEPROM 中读取预存储的 6 位开锁密钥,存入全局变量open_lock_key。
主循环任务(无限循环执行):
传感器扫描:持续调用fpm383c_Scan()(指纹扫描)、RC522_Scan()(射频卡扫描),等待识别结果,通过key_Scan()检测按键输入,处理数字输入、密码确认、删除、界面切换等操作,输入 6 位密码后,与存储的开锁密钥比对,匹配则触发开锁,不匹配则启动报警,根据开锁结果、错误状态,控制 LED 亮灭与蜂鸣器发声,同步更新 OLED 显示。
线程间通信:通过全局变量(如open_door_type开锁状态、open_door_alert报警状态、interface_num界面标识)实现各模块间数据交互,简化通信逻辑,确保系统响应实时性。
4 核心模块实现
EEPROM 密钥存储与读取
采用 24CXX EEPROM 实现密钥的持久化存储,确保掉电后密钥不丢失。
初始化:调用AT24CXX_Init()初始化 I2C 总线与 EEPROM 设备,通过AT24CXX_Check()检测设备是否正常。
密钥读取:系统启动时,通过循环读取 EEPROM 的 0-5 地址数据,存入open_lock_key数组。
密钥修改:在修改界面(interface_num=2)确认后,将临时密钥open_lock_key_temp写入 EEPROM 对应地址,并重新读取同步至open_lock_key。
评论区
登录后即可参与讨论
立即登录