野火学习笔记(3) —— 使用寄存器点亮 LED 灯

2023-05-16

文章目录

  • 1. GPIO 简介
  • 2. GPIO 框图剖析
    • 2.1 基本结构分析
    • 2.2 GPIO 工作模式
  • 3. 实验:使用寄存器点亮 LED 灯
    • 3.1 硬件连接
    • 3.2 启动文件
    • 3.3 stm32f10x.h 文件
    • 3.4 main 文件




1. GPIO 简介

GPIO 是通用输入输出端口的简称,简单来说就是 STM32 可控制的引脚, STM32 芯片的 GPIO 引脚与外部设备连接起来,从而实现与外部通讯、控制以及数据采集的功能。STM32 芯片的 GPIO 被分成很多组,每组有 16 个引脚,如型号为 STM32F103VET6 型号的芯片有 GPIOA、 GPIOB、 GPIOC 至 GPIOE 共 5 组 GPIO,芯片一共 100 个引脚,其中 GPIO 就占了一大部分,所有的 GPIO 引脚都有基本的输入输出功能。

最基本的输出功能是由 STM32 控制引脚输出高、低电平,实现开关控制,如把 GPIO 引脚接入到 LED 灯,那就可以控制 LED 灯的亮灭,引脚接入到继电器或三极管,那就可以通过继电器或三极管控制外部大功率电路的通断。

最基本的输入功能是检测外部输入电平,如把 GPIO 引脚连接到按键,通过电平高低区分按键是否被按下。



2. GPIO 框图剖析

在这里插入图片描述


通过 GPIO 硬件结构框图,就可以从整体上深入了解 GPIO 外设及它的各种应用模式。该图从最右端看起,最右端就是代表 STM32 芯片引出的 GPIO 引脚,其余部件都位于芯片内部。



2.1 基本结构分析

下面我们按图中的编号对 GPIO 端口的结构部件进行说明。

① 保护二极管及上、下拉电阻
引脚的两个保护二级管可以防止引脚外部过高或过低的电压输入,当引脚电压高于 VDD 时, 上方的二极管导通,当引脚电压低于 VSS 时,下方的二极管导通,防止不正常电压引入芯片导致芯片烧毁。尽管有这样的保护,并不意味着 STM32 的引脚能直接外接大功率驱动器件,如直接驱动电机,强制驱动要么电机不转,要么导致芯片烧坏,必须要加大功率及隔离电路驱动。

② P-MOS 管和 N-MOS 管
GPIO 引脚线路经过两个保护二极管后,向上流向“输入模式”结构,向下流向“输出模式”结构。先看输出模式部分,线路经过一个由 P-MOS 和 N-MOS 管组成的单元电路。这个结构使 GPIO 具有了“推挽输出”和“开漏输出”两种模式。

所谓的推挽输出模式,是根据这两个 MOS 管的工作方式来命名的。在该结构中输入高电平时,经过反向后,上方的 P-MOS 导通,下方的 N-MOS 关闭,对外输出高电平;而在该结构中输入低电平时,经过反向后, N-MOS 管导通, P-MOS 关闭,对外输出低电平。当引脚高低电平切换时,两个管子轮流导通, P 管负责灌电流, N 管负责拉电流,使其负载能力和开关速度都比普通的方式有很大的提高。推挽输出的低电平为 0 伏,高电平为 3.3 伏,具体参考 图 8-2,它是推挽输出模式时的等效电路。


在这里插入图片描述图 8-2 推挽等效电路


而在开漏输出模式时,上方的 P-MOS 管完全不工作。如果我们控制输出为 0,低电平,则 P-MOS 管关闭, N-MOS 管导通,使输出接地,若控制输出为 1 (它无法直接输出高电平)时,则 P-MOS 管和 N-MOS 管都关闭,所以引脚既不输出高电平,也不输出低电平,为高阻态。为正常使用时必须外部接上拉电阻,参考 图 8-3 中等效电路。它具有“线与”特性,也就是说,若有很多个开漏模式引脚连接到一起时,只有当所有引脚都输出高阻态,才由上拉电阻提供高电平,此高电平的电压为外部上拉电阻所接的电源的电压。若其中一个引脚为低电平,那线路就相当于短路接地,使得整条线路都为低电平, 0 伏。

推挽输出模式一般应用在输出电平为 0 和 3.3 伏而且需要高速切换开关状态的场合。在 STM32 的应用中,除了必须用开漏模式的场合,我们都习惯使用推挽输出模式。


(PS:个人理解)
{
推挽输出与开漏输出的区别:
推挽输出 PMOS、NMOS 都工作;
开漏输出只有 NMOS 工作。


推挽输出输出高电平时,上方的 P-MOS 导通,下方的 N-MOS 关闭;
开漏输出输出高电平时,因为只有 NMOS 工作,所以只能输出高阻态(即不输出高电平,也不输出低电平),需要外接一个上拉电阻才可以输出高电平。


推挽输出输出高电平,取决于芯片的 VDD ;
开漏输出输出高电平,取决于外部上拉电阻接的电压。


推挽输出比开漏输出驱动能力强。


推挽输出与开漏输出输出低电平原理差不多一致, P-MOS 管关闭, N-MOS 管导通,使输出接地。
}


开漏输出一般应用在 I2C、 SMBUS 通讯等需要“线与”功能的总线电路中。除此之外,还用在电平不匹配的场合,如需要输出 5 伏的高电平,就可以在外部接一个上拉电阻, 上拉电源为 5 伏, 并且把 GPIO 设置为开漏模式,当输出高阻态时,由上拉电阻和电源向外输出 5 伏的电平,具体见 图 8-4。


在这里插入图片描述
图 8-3 开漏电路


在这里插入图片描述图 8-4 STM32 IO 对外输出 5V 电平


③ 输出数据寄存器
前面提到的 双 MOS 管结构电路的输入信号,是由 GPIO “输出数据寄存 器 GPIOx_ODR” 提供的,因此我们通过修改输出数据寄存器的值就可以修改 GPIO 引脚的输出电平。而“置位/复位寄存器 GPIOx_BSRR” 可以通过修改输出数据寄存器的值从而影响电路的输出。

④ 复用功能输出
“复用功能输出”中的“复用”是指 STM32 的其它片上外设对 GPIO 引脚进行控制,此时 GPIO 引脚用作该外设功能的一部分,算是第二用途。从其它外设引出来的“复用功能输出信号”与 GPIO 本身的数据据寄存器都连接到双 MOS 管结构的输入中,通过图中的梯形结构作为开关切换选择。

例如我们使用 USART 串口通讯时,需要用到某个 GPIO 引脚作为通讯发送引脚,这个时候就可以把该 GPIO 引脚配置成 USART 串口复用功能,由串口外设控制该引脚,发送数据。

// GPIOB 16 个 IO 全部输出 0XFF
GPIOB->ODR = 0XFF;

⑤ 输入数据寄存器
看 GPIO 结构框图的上半部分, GPIO 引脚经过内部的上、下拉电阻, 可以配置成上/下拉输入,然后再连接到施密特触发器,信号经过触发器后,模拟信号转化为 0、 1 的数字信号,然后存储在“输入数据寄存器 GPIOx_IDR” 中,通过读取该寄存器就可以了解 GPIO 引脚的电平状态。

// 读取 GPIOB 端口的 16 位数据值
uint16_t temp;
temp = GPIOB->IDR;

⑥ 复用功能输入
与“复用功能输出”模式类似,在“复用功能输入模式”时, GPIO 引脚的信号传输到 STM32 其它片上外设,由该外设读取引脚状态。

同样,如我们使用 USART 串口通讯时,需要用到某个 GPIO 引脚作为通讯接收引脚,这个时候就可以把该 GPIO 引脚配置成 USART 串口复用功能,使 USART 可以通过该通讯引脚的接收远端数据。


⑦ 模拟输入输出
当 GPIO 引脚用于 ADC 采集电压的输入通道时,用作“模拟输入”功能,此时信号是不经过施密特触发器的,因为经过施密特触发器后信号只有 0、 1 两种状态,所以 ADC 外设要采集到原始的模拟信号, 信号源输入必须在施密特触发器之前。类似地,当 GPIO 引脚用于 DAC 作为模拟电压输出通道时,此时作为“模拟输出”功能, DAC 的模拟信号输出就不经过双 MOS 管结构,模拟信号直接输出到引脚。


2.2 GPIO 工作模式

总结一下,由 GPIO 的结构决定了 GPIO 可以配置成以下模式:


代码 8-1 GPIO 8 种工作模式

typedef enum
{
    GPIO_Mode_AIN = 0x00, 			// 模拟输入
    GPIO_Mode_IN_FLOATING = 0x04, 	// 浮空输入
    GPIO_Mode_IPD = 0x28, 			// 下拉输入
    GPIO_Mode_IPU = 0x48, 			// 上拉输入
    GPIO_Mode_Out_OD = 0x14, 		// 开漏输出
    GPIO_Mode_Out_PP = 0x10, 		// 推挽输出
    GPIO_Mode_AF_OD = 0x1C, 		// 复用开漏输出
    GPIO_Mode_AF_PP = 0x18 			// 复用推挽输出
} GPIOMode_TypeDef;

在固件库中, GPIO 总共有 8 种细分的工作模式,稍加整理可以大致归类为以下三类:

① 输入模式(模拟/浮空/上拉/下拉)
在输入模式时, 施密特触发器打开, 输出被禁止,可通过输入数据寄存器 GPIOx_IDR 读取 I/O 状态。 其中输入模式,可设置为上拉、下拉、 浮空和模拟输入四种。 上拉和下拉输入很好理解, 默认的电平由上拉或者下拉决定。浮空输入的电平是不确定的,完全由外部的输入决定,一般接按键的时候用的是这个模式。模拟输入则用于 ADC 采集。

② 输出模式(推挽/开漏)
在输出模式中, 推挽模式时双 MOS 管以轮流方式工作,输出数据寄存器 GPIOx_ODR 可控制 I/O 输出高低电平。开漏模式时,只有 N-MOS 管工作,输出数据寄存器可控制 I/O 输出高阻态或低电平。 输出速度可配置,有 2MHz\10MHz\50MHz 的选项。此处的输出速度即 I/O 支持的高低电平状态最高切换频率,支持的频率越高,功耗越大,如果功耗要求不严格,把速度设置成最大即可。

在输出模式时施密特触发器是打开的,即输入可用,通过输入数据寄存器 GPIOx_IDR 可读取 I/O 的实际状态。

③ 复用功能(推挽/开漏)
复用功能模式中,输出使能,输出速度可配置,可工作在开漏及推挽模式,但是输出信号源于其它外设,输出数据寄存器 GPIOx_ODR 无效;输入可用,通过输入数据寄存器可获取 I/O 实际状态,但一般直接用外设的寄存器来获取该数据信号。

通过对 GPIO 寄存器写入不同的参数,就可以改变 GPIO 的工作模式,再强调一下,要了解具体寄存器时一定要查阅《STM32F10X-中文参考手册》中对应外设的寄存器说明。在 GPIO 外设中, 控制端口高低控制寄存器 CRH 和 CRL 可以配置每个 GPIO 的工作模式和工作的速度, 每 4 个位控制一个 IO, CRH 控制端口的高八位, CRL 控制端口的低 8 位,具体的看 CRH 和 CRL 的寄存器描述。


在这里插入图片描述
图 8-5 GPIO 端口配置低寄存器


在这里插入图片描述图 8-6 GPIO 端口配置高寄存器



3. 实验:使用寄存器点亮 LED 灯

3.1 硬件连接

在本教程中 STM32 芯片与 LED 灯的连接见 图 8-8,这是一个 RGB 灯,里面由红蓝绿三个小灯构成, 使用 PWM 控制时可以混合成 256 不同的颜色。


在这里插入图片描述
图 8-8 LED 灯电路连接图


图中从 3 个 LED 灯的阳极引出连接到 3.3V 电源,阴极各经过 1 个限流电阻引入至 STM32 的 3 个 GPIO 引脚中,所以我们只要控制这三个引脚输出高低电平,即可控制其所连接 LED 灯的亮灭。如果您的实验板 STM32 连接到 LED 灯的引脚或极性不一样,只需要修改程序到对应的 GPIO 引脚即可,工作原理都是一样的。

我们的目标是把 GPIO 的引脚设置成推挽输出模式并且默认下拉,输出低电平,这样就能让 LED 灯亮起来了。


3.2 启动文件

启动文件在这里只是简要的介绍下,关于这个文件的详解请参考后面的《启动文件详解》章节。

名为 “ startup_stm32f10x_hd.s” 的文件,它里边使用汇编语言写好了基本程序,当 STM32 芯片上电启动的时候,首先会执行这里的汇编程序,从而建立起 C 语言的运行环境,所以我们把这个文件称为启动文件。该文件使用的汇编指令是 Cortex-M3 内核支持的指令,可参考《Cortex-M3 权威指南》 中指令集章节。

startup_stm32f10x_hd.s 文件由官方提供,一般有需要也是在官方的基础上修改,不会自己完全重写。 该文件从 ST 固件库里面找到,找到该文件后把启动文件添加到工程里面即可。不同型号的芯片以及不同编译环境下使用的汇编文件是不一样的,但功能相同。

对于启动文件这部分我们主要总结它的功能,不详解讲解里面的代码,其功能如下:

  • 初始化堆栈指针 SP;
  • 初始化程序计数器指针 PC;
  • 设置堆、栈的大小;
  • 初始化中断向量表;
  • 配置外部 SRAM 作为数据存储器(这个由用户配置,一般的开发板可没有外部 SRAM) ;
  • 调用 SystemIni() 函数配置 STM32 的系统时钟。
  • 设置 C 库的分支入口“__main”(最终用来调用 main 函数);

先去除繁枝细节,挑重点的讲,主要理解最后两点,在启动文件中有一段复位后立即执行的程序,代码见 代码清单 8-1。在实际工程中阅读时,可使用编辑器的搜索 (Ctrl+F) 功能查找这段代码在文件中的位置,搜索 Reset_Handler 即可找到。


代码清单 8-1 复位后执行的程序

;Reset handler
Reset_Handler 	PROC
    			EXPORT Reset_Handler [WEAK]
    			IMPORT SystemInit
    			IMPORT __main
    
    			LDR R0, =SystemInit
    			BLX R0
    			LDR R0, =__main
    			BX R0
    			ENDP

开头 的是程序注释,在汇编里面注释用的是 “;” ,相当于 C 语言的 “//” 注释符

第二行 是定义了一个子程序: Reset_Handler。 PROC 是子程序定义伪指令。这里就相当于 C 语言里定义了一个函数,函数名为 Reset_Handler。

第三行 EXPORT 表示 Reset_Handler 这个子程序可供其他模块调用。 相当于 C 语言的函数声明。关键字 [WEAK] 表示弱定义,如果编译器发现在别处定义了同名的函数,则在链接时用别处的地址进行链接,如果其它地方没有定义,编译器也不报错,以此处地址进行链接。

第四行和第五行 IMPORT 说明 SystemInit 和__main 这两个标号在其他文件,在链接的时候需要到其他文件去寻找。相当于 C 语言中,从其它文件引入函数声明。以便下面对外部函数进行调用。

SystemInit 需要由我们自己实现,即我们要编写一个具有该名称的函数,用来初始化 STM32 芯片的时钟,一般包括初始化 AHB、 APB 等各总线的时钟,需要经过一系列的配置 STM32 才能达到稳定运行的状态。 其实这个函数在固件库里面有提供,官方已经为我们写好。

__main 其实不是我们定义的(不要与 C 语言中的 main 函数混淆), 这是一个 C 库函数,当编译器编译时,只要遇到这个标号就会定义这个函数,该函数的主要功能是:负责初始化栈、堆,配置系统环境, 并在函数的最后调用用户编写的 main 函数,从此来到 C 的世界。

第六行 把 SystemInit 的地址加载到寄存器 R0。

第七行 程序跳转到 R0 中的地址执行程序,即执行 SystemInit 函数的内容。

第八行 把 __main 的地址加载到寄存器 R0。

第九行 程序跳转到 R0 中的地址执行程序,即执行 __main 函数,执行完毕之后就去到我们熟知的 C 世界,进入 main 函数。

第十行 表示子程序的结束。

总之,看完这段代码后,了解到如下内容即可:我们需要在外部定义一个 SystemInit 函数设置 STM32 的时钟; STM32 上电后,会执行 SystemInit 函数,最后执行我们 C 语言中的 main 函数。


3.3 stm32f10x.h 文件

看完启动文件,那我们立即写 SystemInit 和 main 函数吧 ?别着急,定义好了 SystemInit 函数和 main 我们又能写什么内容?连接 LED 灯的 GPIO 引脚,是要通过读写寄存器来控制的,就这样空着手,如何控制寄存器。 我们知道寄存器就是给一个已经分配好地址的特殊的内存空间取的一个别名, 这个特殊的内存空间可以通过指针来操作。在编程之前我们要先实现寄存器映射,有关寄存器映射的代码都统一写在 stm32f10x.h 文件中,见 代码清单 8-2。


代码清单 8-2 外设地址定义

/*片上外设基地址 */
#define PERIPH_BASE 	((unsigned int)0x40000000)

/*总线基地址, GPIO 都挂载到 APB2 上 */
#define APB2PERIPH_BASE (PERIPH_BASE + 0x10000)

/*GPIOB 外设基地址*/
#define GPIOB_BASE 		(APB2PERIPH_BASE + 0x0C00)

/* GPIOB 寄存器地址,强制转换成指针 */
#define GPIOB_CRL 		*(unsigned int*)(GPIOB_BASE+0x00)
#define GPIOB_CRH 		*(unsigned int*)(GPIOB_BASE+0x04)
#define GPIOB_IDR 		*(unsigned int*)(GPIOB_BASE+0x08)
#define GPIOB_ODR 		*(unsigned int*)(GPIOB_BASE+0x0C)
#define GPIOB_BSRR 		*(unsigned int*)(GPIOB_BASE+0x10)
#define GPIOB_BRR 		*(unsigned int*)(GPIOB_BASE+0x14)
#define GPIOB_LCKR 		*(unsigned int*)(GPIOB_BASE+0x18)

/*RCC 外设基地址*/
#define RCC_BASE 		(AHBPERIPH_BASE + 0x1000)
/*RCC 的 AHB1 时钟使能寄存器地址,强制转换成指针*/
#define RCC_APB2ENR 	*(unsigned int*)(RCC_BASE+0x18)

GPIO 外设的地址跟前面章节讲解的相同,不过此处把寄存器的地址值都直接强制转换成了指针,方便使用。代码的最后两段是 RCC 外设寄存器的地址定义, RCC 外设是用来设置时钟的,以后我们会详细分析,本实验中只要了解到使用 GPIO 外设必须开启它的时钟即可。


3.4 main 文件

现在就可以开始编写程序,在 main 文件中先编写一个 main 函数,里面什么都没有,暂时为空。

int main (void)
{
    
}

此时直接编译的话,会出现如下错误:

“Error: L6218E: Undefined symbol SystemInit (referred from startup_stm32f10x.o)” 

错误提示 SystemInit 没有定义。从分析启动文件时我们知道, Reset_Handler 调用了该函数用来初始化 SMT32 系统时钟,为了简单起见,我们在 main 文件里面定义一个 SystemInit 空函数,什么也不做,为的是骗过编译器,把这个错误去掉。关于配置系统时钟我们在后面再写。当我们不配置系统时钟时, STM32 会把 HSI 当作系统时钟, HSI=8M,由芯片内部的振荡器提供。我们在 main 中添加如下函数:

// 函数为空,目的是为了骗过编译器不报错
void SystemInit(void)
{
    
}

这时再编译就没有错了,完美解决。还有一个方法就是在启动文件中把有关 SystemInit 的代码注释掉也可以,见 代码清单 8-3。


代码清单 8-3 注释掉启动文件中调用 SystemInit 的代码

; Reset handler
Reset_Handler 	PROC
    			EXPORT Reset_Handler [WEAK]
    			;IMPORT SystemInit
                IMPORT __main
                    
                ;LDR R0, =SystemInit
                ;BLX R0
                LDR R0, =__main
                BX R0
                ENDP    

接下来在 main 函数中添加代码, 实现我们的点灯之旅。


① GPIO 模式
首先我们把连接到 LED 灯的 GPIO 引脚 PB0 配置成输出模式,即配置 GPIO 的端口配置低寄存器 CRL,见 图 8-9。 CRL 中包含 0-7 号引脚,每个引脚占用 4 个寄存器位。MODE 位用来配置输出的速度, CNF 位用来配置各种输入输出模式。在这里我们把 PB0 配置为通用推挽输出,输出的速度为 10M, 具体见 代码清单 8-4。


代码清单 8-4 配置输出模式

// 清空控制 PB0 的端口位
GPIOB_CRL &= ~( 0x0F<< (4*0));
// 配置 PB0 为通用推挽输出,速度为 10M
GPIOB_CRL |= (1<<4*0);

在这里插入图片描述
图 8-9 GPIO 端口控制低寄存器 CRL


在代码中,我们先把控制 PB0 的端口位清 0,然后再向它赋值 “0001 b” ,从而使 GPIOB0 引脚设置成输出模式,速度为 10M。

代码中使用了 “&=~”、 “|=” 这种操作方法是为了避免影响到寄存器中的其它位,因为寄存器不能按位读写,假如我们直接给 CRL 寄存器赋值:

GPIOB_CRL = 0x0000001;

这时 CRL 的的低 4 位被设置成 “0001” 输出模式,但其它 GPIO 引脚就有意见了,因为其它引脚的 MODER 位都已被设置成输入模式。


② 控制引脚输出电平
在输出模式时,对端口位设置/清除寄存器 BSRR 寄存器、端口位清除寄存器 BRR 和 ODR 寄存器写入参数即可控制引脚的电平状态,其中操作 BSRR 和 BRR 最终影响的都是 ODR 寄存器,然后再通过 ODR 寄存器的输出来控制 GPIO。为了一步到位,我们在这里直接操作 ODR 寄存器来控制 GPIO 的电平。具体见 代码清单 8-5。


代码清单 8-5 控制引脚输出电平

// PB0 输出低电平
GPIOB_ODR &= ~(1<<0);

在这里插入图片描述


③ 开启外设时钟
设置完 GPIO 的引脚,控制电平输出,以为现在总算可以点亮 LED 了吧,其实还差最后一步。 由于 STM32 的外设很多,为了降低功耗,每个外设都对应着一个时钟,在芯片刚上电的时候这些时钟都是被关闭的,如果想要外设工作,必须把相应的时钟打开。

STM32 的所有外设的时钟由一个专门的外设来管理,叫 RCC(reset and clockcontrol),RCC 在《 STM32 中文参考手册》的第六章。 关于 RCC 外设中的时钟部分,我们在后面的章节《RCC—使用 HSE/HIS 配置》中有详细的讲解,这里我们暂时先了解下。

所有的 GPIO 都挂载到 APB2 总线上,具体的时钟由 APB2 外设时钟使能寄存器 (RCC_APB2ENR) 来控制,具体见 代码清单 8-6。


代码清单 8-6 开启端口时钟

// 开启 GPIOB 端口 时钟
RCC_APB2ENR |= (1<<3);

在这里插入图片描述


④ 水到渠成
开启时钟,配置引脚模式,控制电平,经过这三步,我们总算可以控制一个 LED 了。现在我们完整组织下用 STM32 控制一个 LED 的代码,见 代码清单 8-7。


代码清单 8-7 main 文件中控制 LED 灯的代码

/*
	*工程模板(寄存器版本)
*/
#include "stm32f10x.h" 


/*
  *   主函数
*/
int main(void)
{	
	// 开启GPIOB 端口时钟
	RCC_APB2ENR |= (1<<3);

	//清空控制PB0的端口位
	GPIOB_CRL &= ~( 0x0F<< (4*0));	
	// 配置PB0为通用推挽输出,速度为10M
	GPIOB_CRL |= (1<<4*0);

	// PB0 输出 低电平
	GPIOB_ODR &= ~(1<<0);
	
	while(1);
}



// 函数为空,目的是为了骗过编译器不报错
void SystemInit(void)
{	
}

摘抄自:
[野火EmbedFire]《STM32库开发实战指南——基于野火霸道开发板》.pdf

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

野火学习笔记(3) —— 使用寄存器点亮 LED 灯 的相关文章

  • 串灯控制盒去掉怎么接_我家的LED串灯的线路出问题了,每隔一个都不亮

    我家的LED串灯的线路出问题了 每隔一个都不亮 串灯分成两组 xff0c 其中一组坏了 xff0c 看看坏的那组的第一个灯泡是不是坏了 2020 08 30 大厅的吸顶LED灯时亮时不亮怎么办是不是震流器出问题了 可能是驱动器坏了 xff0
  • 无线gprs控制卡服务器,无线LED控制卡/GPRS无线控制卡

    名称 xff1a gprs无线控制卡 型号 xff1a lztd02 控制范围 xff1a 1024 64 xff0c 1024 48 xff0c 1024 32 xff0c 2048 16 xff0c 双色减半 接口类型 xff1a 4个
  • 用Keil-MDK开发TQ2440裸机程序入门教程——LED流水灯实现

    觉得此编文章很详实 xff0c 故转载之 xff0c 来自http www amobbs com thread 5281512 1 1 html 开发板也差不多买了半年了 以前照着教程用的是软件是ADS 在win7下老是崩溃 后来才知道AD
  • s3c2440之点亮led

    原理是操作led 与 CPU 相连管脚的GPIO xff0c 具体操作哪个GPIO xff0c 需要查看原理图 将对应GPIO配置为输出模式 xff0c 并设置GPIO的对应位为低电平即可点亮led xff0c 相反 xff0c 设置对应位
  • 使用STM32点亮LED

    多学多练 一 题目描述二 设计思路三 寄存器实现01 时钟配置02 模式设置03 代码编写04 创建工程文件 四 HAL库实现01 安装 STM32CubeMX02 安装HAL库03 新建工程04 Keil仿真调试 五 硬件连接六 逻辑仿真
  • insmod: can't insert 'led.ko': invalid module format详细解释

    insmod can 39 t insert 39 led ko 39 invalid module format 之前在Imx257学习版固件编写的驱动想直接移植imx257核心板的开发板上 以为2个板子的源码的引脚定义一样就没什么问题了
  • LED的使用纯汇编和C语言的点亮

    概述 我们通过观察原理图可以发现LED灯有四个分别连接在GPM4 1 GPM4 2 GPM4 3 GPM4 4上面 xff0c 这时候我们去查询我们板子4412的说明书 xff0c 去寻址寄存器的配置 初始化的时候我们需要将他配置为输出模式
  • STM32按键外部中断控制LED流水灯-HAL库

    续上一篇 基于HAL库的32流水灯 http t csdn cn 30QT4 一 硬件选用上 xff0c 我们增加一个四角按键 二 原理图设计 xff0c 上也增加一个开关 LED0 LED2 gt PA0 PA2引脚 KEY1 gt PA
  • LED恒流驱动IC汇总

    这几天在找LED恒流驱动芯片 xff0c 无意间在LED网论坛上发现这个帖子 xff0c 分享给大家 xff01 LED恒流IC芯片大盘点 韩国LDT LD1016 16位最大90mA LED屏幕 护栏灯管恒流驱动IC LD1048 48位
  • LED驱动IC厂家

    厂家芯片类别 世微半导体 英飞凌Infineon 壹芯半导体科技 xff08 深圳 xff09 有限公司 欧司朗OSRAM xff1a 汽车照明 深圳天微电子有限公司 中铭电子 深圳市华芯光电有限公司 宁波欧特电子科技有限公司 芯片介绍 l
  • imx6ull 正点原子设备树适配韦东山的开发板 (一)顺利启动,配置led,button

    设备树在公司经常用到 有时候很多驱动编写也就是替换设备树 所以拿韦老师的板子练手设备树 这次尝试直接拿正点的设备书改成韦老师的板子能用 对比 正点原子的设备树结构图 韦东山的设备树结构图 从因为蓝色的是开发板厂商对开发板自己的优化 所以我们
  • Android手机控制ZigBee板上LED

    环境 xff1a Windows 编译器 xff1a IAREW8051 8 1 硬件 xff1a CC2530 协议栈 xff1a ZStack CC2530 2 3 0 1 4 0 手机 xff1a Android4 1 2 又重新开始
  • LED数码管结构与工作原理

    一 xff0e 什么是数码管 LED数码管 xff08 LED Segment Displays xff09 是由8个发光二极管构成 xff0c 并按照一定的图形及排列封转在一起的显示器件 其中7个LED构成7笔字形 xff0c 1个LED
  • 驱动框架入门之LED-linux驱动开发第4部分-朱有鹏-专题视频课程

    驱动框架入门之LED linux驱动开发第4部分 5199人已学习 课程介绍 本课程是linux驱动开发的第4个课程 xff0c 主要内容是驱动框架的引入 通过led驱动框架和gpiolib的这两个框架的详细解释 xff0c 让大家学习内核
  • RK3308 按键Key与LED灯

    硬件原理图 LED指示灯 麦克风阵列子板上使用12颗RGB灯作为效果指示灯 用户可以通过I2C总线配置LED灯驱动IC来是实现不同场景下的灯效 按键Key 麦克风阵列子板上集成五个控制按键 xff0c 分别为 xff1a 控制音量增减的VO
  • ..\OBJ\LED.axf: Error: L6218E: Undefined symbol xTaskGetSchedulerState (referred from delay.o).

    文章目录 前言解决办法 前言 在学习FreeRTOS移植后 xff0c 编译出现 OBJ LED axf Error L6218E Undefined symbol xTaskGetSchedulerState referred from
  • 野火学习笔记(13) —— USART —串口通讯

    文章目录 1 串口通讯协议简介1 1 物理层1 1 1 电平标准1 1 2 RS 232 信号线 1 2 协议层1 2 1 波特率1 2 2 通讯的起始和停止信号1 2 3 有效数据1 2 4 数据校验 2 STM32 的 USART 简介
  • STM32以中断的方式点亮LED小灯(标准库)

    STM32以中断的方式点亮LED小灯 xff08 标准库 xff09 文章目录 STM32以中断的方式点亮LED小灯 xff08 标准库 xff09 一 认识中断1 中断优先级 xff1a 2 中断嵌套 xff1a 3 中断执行流程4 中断
  • LED点阵

    本周的学习内容是LED点阵的使用 其实LED点阵与动态数码管的原理非常相似 xff0c 都是通过扫描和视觉暂停现象来实现多个LED同时点亮的视觉效果 不同的是 xff0c 点阵可以通过74HC595来实现三根线串行输入多根线并行输出的效果
  • LED驱动IC TM1616,TM1650,TM1651替代兼容型号(VK,AIP)

    产品型号 xff1a VK1650 产品品牌 xff1a VINKA 永嘉微电 永嘉微 封装形式 xff1a SOP16 概述 VK1650 是一种带键盘扫描电路接口的 LED 驱动控制专用电路 内部集成有 MCU 输入输出控制数字 接口

随机推荐

  • 开源时序建模框架Kats

    KATS简介 时间序列分析建模是数据科学和机器学习的一个重要的领域 xff0c 在电子商务 金融 供应链管理 医学 气象 能源 天文等诸多领域有着广泛的应用 目前时间序列分析以及建模的技术非常多 xff0c 但相对散乱 Facebook开源
  • 包含动画的PPT转为PDF

    目的 xff1a 带动画的PPT转化为PDF xff0c PDF的每一页是动画的一个步骤 方法 xff1a 使用 宏 参考链接 xff1a https www codercto com a 70548 html 具体方法 xff08 win
  • windows中docker编写一个dockerfile文件

    Dockerfile文件描述了当我们启动镜像的时候需要哪些软件元素 除了软件元素之外 xff0c Dockerfile 还能够让我们能够在启动镜像的时候在容器中运行一些命令或者指明我们使用什么样的环境 使用虚拟机中的vim命令编写docke
  • spyder增加模块代码提示功能

    最近在配置tensorflow xff0c 可是发现使用spyder的时候无法加载tensorflow的代码提示 xff0c 需要自己输入完整的函数名称 xff0c 十分不方便 xff0c 于是从网上找了一些资料 xff0c 来解决spyd
  • conda activate报错:gbk相关错误

    使用conda create n 建立新的虚拟环境后 xff0c 使用activate无法进入虚拟环境 xff0c 报了一个和gbk相关的错误 xff0c 后来经排查发现 xff0c 是系统环境变量中包含中文字符 xff0c 把系统变量中所
  • scanf源码分析

    本文分析的是glibc2 31中的scanf相关源码 xff0c 目的不是研究scanf的算法 xff0c 而是说明scanf在IO attack中的利用方法 xff0c 属于CTF的范畴 scanf c 其实就是对 vscanf inte
  • windows建立定时任务执行bat脚本

    在Linux中我们可以通过crontab来定时执行脚本 xff0c 那么windows中如何执行呢 xff1f 为了避免分支冲突 xff0c 准备在每天上班的时候自动将git远程仓库的最新版本pull下来 xff0c 然后在下班时间自动将重
  • 需账号密码登陆的网页爬虫

    对于普通网页的爬取十分简单 xff0c 如果网站没有任何反爬机制 xff0c 只要以下代码就可以实现对于网页的爬取 span class token keyword import span requests html span class
  • sqlserver通过OPENJSON转换 json数据

    OPENJSON 行集函数可将 JSON 文本转换为一组行和列 使用 OPENJSON 将 JSON 集合转换为行集后 xff0c 可以在返回的数据上运行任意 SQL 查询或将其插入到 SQL Server 表中 OPENJSON 函数采用
  • [linux]armbian修改为清华源

    查看系统发行版本 命令lsb release a 本机为基于Debian的armbian buster 所以用清华Debian源 修改apt为清华软件源 备份原文件 sudo cp etc apt sources list etc apt
  • 基础的三角函数,反三角函数,双曲函数的图形绘制(matlab)

    matlab基本图形绘制 基础的三角函数 xff0c 反三角函数 xff0c 双曲函数的图形绘制 xff1b 在此过程 xff0c 可以熟悉基础的matlab指令 xff1b 三角函数 y1 61 sin x y2 61 cos x y3
  • tkinter实现带背景图片的登录窗口

    实现功能 xff1a 打开系统登录窗口 xff0c 输入用户名密码 xff0c 点击登录后跳转到程序主界面 xff0c 用户名密码在程序代码里 xff0c 注意运行时需要自己准备一张背景图片back png 主要代码 xff1a self
  • CCF 201809-3 2018年9月第三题元素选择器(python 100分题解)

    问题描述 试题编号 xff1a 3试题名称 xff1a 元素选择器时间限制 xff1a 10 0s内存限制 xff1a 512 0MB问题描述 xff1a 提交后100分代码 xff1a 注意标签选择器大小写不敏感 xff0c 匹配时都转成
  • GitHub项目徽章的添加和设置

    原文出处 xff1a https lpd ios github io 2017 05 03 GitHub Badge Introduction 许多同学在 GitHub 上发布了自己的开源项目 xff0c 有辛苦开发的实用工具 构思巧妙的开
  • 【C++】买鸡问题练手题

    C 43 43 买鸡问题 公鸡 5 元 1 只 xff0c 母鸡 3 元 1 只 xff0c 小鸡 1 元 3 只 xff0c 花了 100 元钱买 100 只鸡 xff0c 问公鸡 母鸡 小鸡各多少只 xff1f include lt i
  • 关于Vue中的axios数据异步 获取后,更改数据,页面没有更新

    更改axios数据后 xff0c 页面没有更新解决办法 列子解决 列子 span class token comment 页面视图HTML span span class token operator lt span span span c
  • C# ToString()方法一些特殊用法

    转帖 http hi baidu com crp8 blog item d19ab0cc131b8f1300e92869 html 一 取中文日期显示 1 年月日时分 currentTime ToString 34 f 34 不显示秒 2
  • 树莓派3B+ 搭建 esp32开发环境

    目前来说esp32的整体开发体验还是不错的 xff0c 关于esp32开发环境的搭建官方也有给出指导文档 xff08 https docs espressif com projects esp idf zh CN latest esp32
  • printf源代码的分析

    1 常见的格式 span class hljs built in printf span xff08 span class hljs string 34 show int d char s 34 span span class hljs k
  • 野火学习笔记(3) —— 使用寄存器点亮 LED 灯

    文章目录 1 GPIO 简介2 GPIO 框图剖析2 1 基本结构分析2 2 GPIO 工作模式 3 实验 xff1a 使用寄存器点亮 LED 灯3 1 硬件连接3 2 启动文件3 3 stm32f10x h 文件3 4 main 文件 1