基于STM32单片机光学指纹识别模块

发布者:dst2015最新更新时间:2016-03-04 来源: eefocus关键字:STM32  单片机  光学指纹识别 手机看文章 扫描二维码
随时随地手机看文章
1.平台
   首先我使用的是 奋斗 STM32 开发板 MINI板
   基于STM32单片机光学指纹识别模块(FPM10A)全教程

   光学指纹识别模块(FPM10A)淘宝网址是:http://item.taobao.com/item.htm?id=5380075198
   基于STM32单片机光学指纹识别模块(FPM10A)全教程
 
2.购买指纹模块,可以获得三份资料
  1.简要使用说明 2.使用指纹模块的功能函数 3.FPM10A用户手册.
 
3.硬件搭建
  根据使用说明:FPM 10A使用标准的串口与外界通信,默认的波特率为57600,可以与任何单片机,ARM,DSP等带串口的设备进行连接,请注意电平转换,连接电脑需要进行电平转换,比如MAX232电路。
FPM10A光学指纹模块共有5个管脚
        1 为 VCC     电源的正极接 3.6V – 5.5V的电压均可。
2 为 GND     电源的负极 接地。
3 为 TXD     串口的发送。
4 为 RXD     串口的接收。
5 为 NC      悬空不需要使用。
 
  奋斗板上已经有5V的管脚,可以直接供给指纹模块,
  这里需要注意的是,指纹模块主要通过串口进行控制,模块和STM32单片机连接的时候,需要进行电平转换,
    基于STM32单片机光学指纹识别模块(FPM10A)全教程


    这样只要把这个转接板插入STM32,接上5V的电,就可以工作了,将模块的发送端接转接板的接收端,接收端接转接板的发送端。
 这样,我们的硬件平台就搭建好了!
 
4.模块的测试工作
    模块成功上电后,指纹采集窗口会闪一下,表示自检正常,如果不闪,请仔细检查电源,是否接反,接错等。指纹模块使用120MHZ的DSP全速工作,工作时芯片有一些热,经过严格的测试,这是没有问题的可以放心使用,在不使用的时候可以关闭电源,以降低功耗。
 
5.现在我们要进入编程环节了
    指纹模块主要是通过串口进行控制,所以这里我们需要用到单片机的串口模块。
    我们需要用到两个关键函数
    1.使用串口发送一个字节的数据
    2.使用串口接收一个字节的数据
这里我使用的STM32单片,所以这两个程序如下:
// 从 USART1 发送一个字节
void USART1_SendByte(unsigned char temp)
{
    USART_SendData(USART1, temp);
    while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
}
// 从 USART1 读取一个字节
unsigned char USART1_ReceivByte()
{
    unsigned char recev;
 while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET);
    recev = USART_ReceiveData(USART1);
 return recev;
}
 
6.查看FPM10A用户手册 我们来实现比对一个指纹(我们这里假设指纹模块中已经存在指纹模板)
  首先我们需要让指纹模块检测是否有指纹输入(也就是是否有手指放在指纹模块上检测)
  我们来看手册上给的操作说明:
  基于STM32单片机光学指纹识别模块(FPM10A)全教程
  我们需要发送给定的数据包给模块,发送的数据已经给我们了,现在我们参看给我们的C例程
  //应答包数组
  unsigned char dat[18];
  //获得指纹图像
  unsigned char FP_Get_Img[6] ={0x01,0x00,0x03,0x01,0x0,0x05};
  //协议包头
  unsigned char FP_Pack_Head[6] = {0xEF,0x01,0xFF,0xFF,0xFF,0xFF};      
  //FINGERPRINT_获得指纹图像命令
  void FINGERPRINT_Cmd_Get_Img(void)
 {
    unsigned char i;
    for(i=0;i<6;i++) //发送包头
       USART1_SendByte(FP_Pack_Head[i]);
   
    for(i=0;i<6;i++) //发送命令 0x1d
       USART1_SendByte(FP_Get_Img[i]);
   
    for(i=0;i<12;i++)//读回应答信息
    dat[i]=USART1_ReceivByte();
   
 说明:这个函数就是检测是否有指纹输入的信息,根据用户手册,当确认码返回值为0时,表示成功录入,所以,我们可以有下面的函数:
//检测指纹模块录入指纹情况,返回00表示录入成功;02无手指;03录入失败
unsigned char test_fig()
{
 unsigned char fig_dat;
 FINGERPRINT_Cmd_Get_Img();
 Delay_ms1(20);
 fig_dat=dat[9];
 return(fig_dat);
}
因此,我们在主函数中可以这样调用:
void main
{
     if(test_fig()==0)
     {
        //do something
     }
}
 
7.如何录入一个新的指纹信息呢?
 步骤如下
  1.获得指纹图像
  2.检测是否成功的按了指纹 
  3.将图像转换成特征码存放在Buffer1中
  4.再次获得指纹图像
  5.将图像转换成特征码存放在Buffer2中
  6.转换成特征码
  7.存储到指定地址上
 
 同样的,根据用户手册,我们可以得到以下这样的模块:
 
 当调用的时候,你只要给这个函数附上两个值就可以了,例如:
 unsigned char FP_add_new_user(00,01);
 如果你下次再次写入这个地址,以前存储的指纹模板信息将被覆盖
 
//添加一个新的指纹
unsigned char FP_add_new_user(unsigned char ucH_user,unsigned char ucL_user)

  do
                   
     FINGERPRINT_Cmd_Get_Img();       //获得指纹图像
  } while ( dat[9]!=0x0 );            //检测是否成功的按了指纹 
 
  FINGERPRINT_Cmd_Img_To_Buffer1();   //将图像转换成特征码存放在Buffer1中
   
  do
  {
      FINGERPRINT_Cmd_Get_Img();      //获得指纹图像  
  } while( dat[9]!=0x0 );
 
  FINGERPRINT_Cmd_Img_To_Buffer2();   //将图像转换成特征码存放在Buffer2中
  
  FINGERPRINT_Cmd_Reg_Model();        //转换成特征码
 
  FINGERPRINT_Cmd_Save_Finger(ucH_user,ucL_user);                          
 
  return 0;
}
//存储模版到特定地址
void FINGERPRINT_Cmd_Save_Finger( unsigned char ucH_Char, unsigned char ucL_Char)
{
    unsigned long temp = 0;
    unsigned char i;
    FP_Save_Finger[5] = ucH_Char;
    FP_Save_Finger[6] = ucL_Char;
       
    for(i=0;i<7;i++)   //计算校验和
        temp = temp + FP_Save_Finger[i];
     
    FP_Save_Finger[7]=(temp & 0x00FF00) >> 8; //存放校验数据
    FP_Save_Finger[8]= temp & 0x0000FF;
    
    
    for(i=0;i<6;i++)   
        USART1_SendByte(FP_Pack_Head[i]);        //发送包头
    for(i=0;i<9;i++)  
      USART1_SendByte(FP_Save_Finger[i]) ;//发送命令将图像转换成特征码存放CHAR_buffer1
    
    for(i=0;i<12;i++)
         dat[i]=USART1_ReceivByte();
}
 
8.如何删除一个模板?
//删除所有指纹模版
void FINGERPRINT_Cmd_Delete_All_Model(void)
{
    unsigned char i;
    for(i=0;i<6;i++) //发送包头
       USART1_SendByte(FP_Pack_Head[i]);
   
    for(i=0;i<6;i++) //发送命令 0x1d
       USART1_SendByte(FP_Delet_All_Model[i]);
 
 for(i=0;i<12;i++)//读回应答信息
  dat[i]=USART1_ReceivByte();    
}
 
9.如何获取已经存取的指纹模板信息?
这个模块一共可以存储0~999枚指纹信息
//搜索全部用户999枚
void FINGERPRINT_Cmd_Search_Finger(void)
{
   unsigned char i;   
   //发送命令搜索指纹库
   for(i=0;i<6;i++)  
   {
    USART1_SendByte(FP_Pack_Head[i]);  
   }
   for(i=0;i<11;i++)
   {
    USART1_SendByte(FP_Search[i]);  
   }
  
   for(i=0;i<16;i++)
   {
  dat[i]=USART1_ReceivByte();
   }
}
根据用户手册,我们可以从应答包中得出模块中已经存在指纹数量的大小
 
这样,我们就轻松把指纹模块搞定!
 
下面我附上基于STM32单片机光学指纹识别模块(FPM10A)打包好的函数库
第一个是 FPM10A.c
#include "stm32f10x.h"
#include "stm32f10x_usart.h"
#include "misc.h"
unsigned char dat[18];
//FINGERPRINT通信协议定义
unsigned char FP_Pack_Head[6] = {0xEF,0x01,0xFF,0xFF,0xFF,0xFF};                    //协议包头
unsigned char FP_Get_Img[6] = {0x01,0x00,0x03,0x01,0x0,0x05};                       //获得指纹图像
unsigned char FP_Templete_Num[6] ={0x01,0x00,0x03,0x1D,0x00,0x21 };                 //获得模版总数
unsigned char FP_Search[11]={0x01,0x0,0x08,0x04,0x01,0x0,0x0,0x03,0xA1,0x0,0xB2};   //搜索指纹搜索范围0 - 929
unsigned char FP_Search_0_9[11]={0x01,0x0,0x08,0x04,0x01,0x0,0x0,0x0,0x13,0x0,0x21};//搜索0-9号指纹
unsigned char FP_Img_To_Buffer1[7]={0x01,0x0,0x04,0x02,0x01,0x0,0x08};     //将图像放入到BUFFER1
unsigned char FP_Img_To_Buffer2[7]={0x01,0x0,0x04,0x02,0x02,0x0,0x09};     //将图像放入到BUFFER2
unsigned char FP_Reg_Model[6]={0x01,0x0,0x03,0x05,0x0,0x09};       //将BUFFER1跟BUFFER2合成特征模版
unsigned char FP_Delet_All_Model[6]={0x01,0x0,0x03,0x0d,0x00,0x11};     //删除指纹模块里所有的模版
unsigned char FP_Save_Finger[9]={0x01,0x00,0x06,0x06,0x01,0x00,0x0B,0x00,0x19};  //将BUFFER1中的特征码存放到指定的位置
unsigned char FP_Delete_Model[10]={0x01,0x00,0x07,0x0C,0x0,0x0,0x0,0x1,0x0,0x0};  //删除指定的模版

//从 USART1 发送一个字节
void USART1_SendByte(unsigned char temp)
{
    USART_SendData(USART1, temp);
    while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
}
//从 USART1 读取一个字节
unsigned char USART1_ReceivByte()
{
    unsigned char recev;
 while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET);
    recev = USART_ReceiveData(USART1);
 return recev;
}
//FINGERPRINT命令字
//FINGERPRINT_获得指纹图像命令
void FINGERPRINT_Cmd_Get_Img(void)
{
    unsigned char i;
    for(i=0;i<6;i++) //发送包头
       USART1_SendByte(FP_Pack_Head[i]);
   
    for(i=0;i<6;i++) //发送命令 0x1d
       USART1_SendByte(FP_Get_Img[i]);
   
 for(i=0;i<12;i++)//读回应答信息
  dat[i]=USART1_ReceivByte();
}
//删除所有指纹模版
void FINGERPRINT_Cmd_Delete_All_Model(void)
{
    unsigned char i;
    for(i=0;i<6;i++) //发送包头
       USART1_SendByte(FP_Pack_Head[i]);
   
    for(i=0;i<6;i++) //发送命令 0x1d
       USART1_SendByte(FP_Delet_All_Model[i]);
 
 for(i=0;i<12;i++)//读回应答信息
  dat[i]=USART1_ReceivByte();    
}
//讲图像转换成特征码存放在Buffer1中
void FINGERPRINT_Cmd_Img_To_Buffer1(void)
{
    unsigned char i;
    for(i=0;i<6;i++)    //发送包头
    {
        USART1_SendByte(FP_Pack_Head[i]);  
    }
    for(i=0;i<7;i++)   //发送命令 将图像转换成 特征码 存放在 CHAR_buffer1
    {
        USART1_SendByte(FP_Img_To_Buffer1[i]);
    }
 for(i=0;i<12;i++)//读应答信息
 {
   dat[i]=USART1_ReceivByte();//把应答数据存放到缓冲区
 }
}
//将图像转换成特征码存放在Buffer2中
void FINGERPRINT_Cmd_Img_To_Buffer2(void)
{
     unsigned char i;
     for(i=0;i<6;i++)    //发送包头
     {
       USART1_SendByte(FP_Pack_Head[i]);  
     }
  
     for(i=0;i<7;i++)   //发送命令 将图像转换成 特征码 存放在 CHAR_buffer1
     {
    USART1_SendByte(FP_Img_To_Buffer2[i]);
     }
  for(i=0;i<12;i++)
  {
  dat[i]=USART1_ReceivByte();//读回应答信息
     }
}
//将BUFFER1 跟 BUFFER2 中的特征码合并成指纹模版
void FINGERPRINT_Cmd_Reg_Model(void)
{
    unsigned char i;   
    for(i=0;i<6;i++) //包头
    {
      USART1_SendByte(FP_Pack_Head[i]);  
    }
    for(i=0;i<6;i++) //命令合并指纹模版
    {
      USART1_SendByte(FP_Reg_Model[i]);  
    }
 
 for(i=0;i<12;i++)
 {
  dat[i]=USART1_ReceivByte();
 }
}
//存储模版到特定地址
void FINGERPRINT_Cmd_Save_Finger( unsigned char ucH_Char, unsigned char ucL_Char)
{
       unsigned long temp = 0;
    unsigned char i;
       FP_Save_Finger[5] = ucH_Char;
       FP_Save_Finger[6] = ucL_Char;
   
      
    for(i=0;i<7;i++)   //计算校验和
        temp = temp + FP_Save_Finger[i];
     
    FP_Save_Finger[7]=(temp & 0x00FF00) >> 8; //存放校验数据
    FP_Save_Finger[8]= temp & 0x0000FF;
   
   
       for(i=0;i<6;i++)   
        USART1_SendByte(FP_Pack_Head[i]);        //发送包头
       for(i=0;i<9;i++) 
       USART1_SendByte(FP_Save_Finger[i]);      //发送命令 将图像转换成 特征码 存放在 CHAR_buffer1
    
    for(i=0;i<12;i++)
          dat[i]=USART1_ReceivByte();
}
//获得指纹模板数量
void FINGERPRINT_Cmd_Get_Templete_Num(void)

   unsigned int i;
   for(i=0;i<6;i++) //包头
      USART1_SendByte(FP_Pack_Head[i]);
   //发送命令 0x1d
   for(i=0;i<6;i++)
     USART1_SendByte(FP_Templete_Num[i]);
 
   for(i=0;i<12;i++)
        dat[i]=USART1_ReceivByte();
}
//搜索全部用户999枚
void FINGERPRINT_Cmd_Search_Finger(void)
{
   unsigned char i;   
   //发送命令搜索指纹库
   for(i=0;i<6;i++)  
   {
    USART1_SendByte(FP_Pack_Head[i]);  
   }
   for(i=0;i<11;i++)
   {
    USART1_SendByte(FP_Search[i]);  
   }
  
   for(i=0;i<16;i++)
   {
  dat[i]=USART1_ReceivByte();
   }
}
//搜索用户0~9枚
void FINGERPRINT_Cmd_Search_Finger_Admin(void)
{
   unsigned char i;   
   for(i=0;i<6;i++)   //发送命令搜索指纹库
   {
    USART1_SendByte(FP_Pack_Head[i]);  
   }
   for(i=0;i<11;i++)
   {
    USART1_SendByte(FP_Search_0_9[i]);  
   }
  
   for(i=0;i<12;i++)
        dat[i]=USART1_ReceivByte();
}
//添加一个新的指纹
unsigned char FP_add_new_user(unsigned char ucH_user,unsigned char ucL_user)

  do
                   
     FINGERPRINT_Cmd_Get_Img();       //获得指纹图像
  } while ( dat[9]!=0x0 );            //检测是否成功的按了指纹 
 
  FINGERPRINT_Cmd_Img_To_Buffer1();   //将图像转换成特征码存放在Buffer1中
   
  do
  {
      FINGERPRINT_Cmd_Get_Img();      //获得指纹图像  
  } while( dat[9]!=0x0 );
 
  FINGERPRINT_Cmd_Img_To_Buffer2();   //将图像转换成特征码存放在Buffer2中
  
  FINGERPRINT_Cmd_Reg_Model();        //转换成特征码
 
  FINGERPRINT_Cmd_Save_Finger(ucH_user,ucL_user);                          
 
  return 0;
}
第2个 FPM10A.h
#ifndef _FPM10A_H
#define _FPM10A_H
#include  
extern unsigned char dat[18];
extern void FINGERPRINT_Cmd_Get_Img();
extern void FINGERPRINT_Cmd_Img_To_Buffer1();
extern void FINGERPRINT_Cmd_Img_To_Buffer2();
extern void FINGERPRINT_Cmd_Reg_Model();
extern void FINGERPRINT_Cmd_Delete_All_Model(void);
extern void FINGERPRINT_Cmd_Search_Finger(void);
extern void FINGERPRINT_Cmd_Get_Templete_Num(void);
extern void FINGERPRINT_Cmd_Search_Finger_Admin(void);
extern void FINGERPRINT_Cmd_Save_Finger( unsigned char ucH_Char, unsigned char ucL_Char);
extern unsigned char FP_add_new_user(unsigned char ucH_user,unsigned char ucL_user);

extern void USART1_SendByte(unsigned char temp);
extern unsigned char USART1_ReceivByte();
extern void Delay_ms1(uint32_t nCount);
void Delay_nus1(uint32_t nCount)
{
 uint32_t j;
 while(nCount--)
 {
    j=8;
    while(j--);
 }
}
void Delay_ms1(uint32_t nCount)
{
    while(nCount--)
    Delay_nus1(1100);
}
unsigned char test_fig()//检测指纹模块录入指纹情况,返回00表示录入成功;02无手指;03录入失败
{
 unsigned char fig_dat;
 FINGERPRINT_Cmd_Get_Img();
 Delay_ms1(20);
 fig_dat=dat[9];
 return(fig_dat);
}
#endif

有了这两个东西,加入到你的工程中,就可以直接调用啦!
关键字:STM32  单片机  光学指纹识别 引用地址:基于STM32单片机光学指纹识别模块

上一篇:ARM汇编中的标号
下一篇:基于STM32处理器 定时器比较输出测试程序

推荐阅读最新更新时间:2024-03-16 14:46

单片机MCS-51系列指令快速记忆法(学习单片机编程的好资料)
随着微电子技术和超大规模集成电路技术的发展,单片微型计算机以其体积小、性价比高、功能强、可靠性高等独有的特点,在各个领域(如工业控制、家电产品、汽车电子、通信、智能仪器仪表)得到了广泛的应用。学习、使用单片机的人越来越多,而生产单片机的厂家很多,单片机种类繁杂,不知如何选择。据统计,八位单片机占全球单片机销量的65%。在八位单片机中,Intel公司的8051单片机内核已成为8位单片机事实上的标准。因此,对初学者而言,选择8051单片机来学习不失为明智的选择。 学习单片机,除了搞清单片机内部功能、存储空间分配及I/O接口外,还应掌握其指令系统。MCS-51共有111条指令,现介绍我们总结出的快速记忆MCS-51指令的方法,供大
[工业控制]
基于SPMC75F2413A单片机的步进电机加减速控制
步进电机(脉冲电动机)是一种将电脉冲转化为角位移的执行机构,是数字控制的一种执行元件,其可以通过控制脉冲频率来控制电机转动的速度和加速度,从而达到调速的目的。步进电机具有转矩大、惯性小、响应频率高等优点,因此具有瞬间启动与急速停止的优越特性。步进电机在各种应用场合下最大的优势是:可以开环方式控制而无需反馈就能对位置和速度进行控制,但也正是因为负载位置对控制电路没有反馈,步进电机就必须正确响应每次励磁变化。如果励磁频率选择不当,电机不能够移到新的位置,那么实际的负载位置相对控制器所期待的位置出现永久误差,即发生失步现象或过冲现象。因此步进电机开环控制系统中,如何防止失步和过冲是开环控制系统能否正常运行的关键。 本设计使用SP
[单片机]
基于SPMC75F2413A<font color='red'>单片机</font>的步进电机加减速控制
基于单片机的OLED显示器的应用
   1  前言   有机发光显示器(Organic Light Emitting Display,OLED)是一种新型发光和显示器件。OLED实质上是一个薄膜器件,它的发光层是有机材料层,当有电流通过时,这些有机材料就会发光。与传统的液晶显示器(LCD)相比,除了无需背光源外,OLED显示屏可实现低于1mm的厚度,这为实现软体显示提供了可能,此外可视角度更大,亮度更高,色彩更加丰富。OLED可广泛应用于手持设备、通信终端、仪器仪表等领域。   2  模块结构   下面以维信诺VGG12864E-S001模块为例,介绍OLED的模块结构。   2.1  模块框图   VGG12864E-S001 模块的OLED 显示屏为
[应用]
基于at89c51单片机的最基础流水灯Proteus仿真图含代码
#include reg51.h #include stdio.h void delay(void) { unsigned int i,j; for(i=500;i 0;i--) for(j=115;j 0;j--); } void main(void) { // Write your code here unsigned char led ,a ,b ;//定义三个变量 led=0xfe; //led=1111 1110,P0。0亮 while (1) { P0=led; //将led的状态赋给P0寄存器 a=led 7; //将led最高位赋给a最低位,其
[单片机]
基于at89c51<font color='red'>单片机</font>的最基础流水灯Proteus仿真图含代码
基于单片机的智能家居电子密码锁系统电路设计
  电子密码锁是一种以高强度密码序列为基础,在单片机上实现的密码开关。它以无线电作为信息媒体,从而实现了遥控,也可以配备一个结构简单的接触式通讯接口,坚固并且防损。该锁具有使用方便、操作简单、价格低廉等特点。与传统的锁防盗效果相比,它避免了因为机械部分被破坏而导致开锁功能失常,大大增加了密码锁得防盗功能。同时因为电子密码锁不需要携带钥匙,弥补了钥匙极易丢失和仿造的缺陷,方便了锁具的使用特别适用于那些正常人体不宜接近的特殊场合,比如高辐射区、高传染区等。基于单片机的家居电子密码锁设计,不仅可以提高人们的生活效率,节约生活资源,而且十分安全可靠。并将以此为起点,构造一个更加舒适和人性化的生活环境。    电源设计   本系统设计为
[单片机]
基于<font color='red'>单片机</font>的智能家居电子密码锁系统电路设计
单片机大功率太阳能LED路灯电路设计与仿真解析
   1、引言    LED 作为第四代 照明 光源,正以其独有的优越性在城市美化、道路照明、庭院照明、 室内照明 以及其他各领域中得到越来越广的应用。尤其在偏远无电地区,太阳能照明灯具以其不可阻挡的优势得到迅速的推广应用。某作者对LED灯中的太阳能电池板的安装、控制器的功能、铅蓄电池的安置和恒流驱动电路等进行了探讨,但没有给出控制器等关键电路的设计和仿真。另一些作者从光源设计、驱动电路设计和散热设计3方面说明了LED路灯设计中应遵循的原则,但使用的电路没有实现智能化,无法进行程序控制。   本文设计和仿真了一基于AT89C52单片机智能控制的,功率约为40W太阳能LED路灯。它采用了双电源供电模式,具备光控和时控功能,抗干扰能
[电源管理]
<font color='red'>单片机</font>大功率太阳能LED路灯电路设计与仿真解析
STM32 SDIO详解
1、SDIO简介 SDIO,全称:Secure Digital Input and Output,即安全数字输入输出接口。它是在SD卡接口的基础上发展而来,它可以兼容之前的SD卡,并可以连接SDIO接口设备,比如:蓝牙、WIFI、照相机等。 SDIO和SD卡规范间的一个重要区别是增加了低速标准。低速卡的目标应用是以最小的硬件开支支持低速I/O能力。低速卡支持类似调制解调器、条码扫描仪和GPS接收器等应用。 STM32的SDIO控制器支持多媒体卡(MMC卡)、SD存储卡、SDI/O卡和CE-ATA设备。 SDIO框图 复位后SDIO_D0用于数据传输。初始化后主机可以改变数据总线的宽度(通过ACMD6命令设置) 如果一个多媒体卡
[单片机]
<font color='red'>STM32</font> SDIO详解
STMCU应用过程中与电源相关的案例分享
我们在从事STM32单片机的应用开发及调试过程中,往往会碰到各类异常。其中有不少比例的问题跟电源有关。对于一个电子产品而言,电源部分很关键、很重要,但在实际开发调试中,我们偶尔会有意无意的忽视它。这里分享几个实际案例,以加强刺激,加深印象。 毕竟因为电源问题可能导致的异常很多很多,这里分享几个案例算是抛砖引玉,希望大家在调试中对电源方面加以重视。个人认为,往往电源出问题时导致的异常时并不太好分析。多数时候异常表现得更为诡异或没章法。 注:下面提到的案例中异常原因都与电源有关,但并不是说出现类似异常时一定是电源的原因。 下面主要分享五个基于STM32应用的案例。 案例1:STM32芯片的PLL无法正常工作。 有人使用STM3
[单片机]
STMCU应用过程中与电源相关的案例分享
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved