stm32-esp8266驱动程序

本文详细介绍了ESP8266 WiFi模块的初始化过程及透传模式的设置方法,通过一系列AT指令配置,实现了模块与服务器的TCP连接,并提供了透传模式下的数据收发流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

esp8266模块是串口通讯,通讯的协议是AT指令,要正确的配置对应的AT指令模块才可以工作,这里就需要知道AT指令有没有配置成功,这个比较容易实现,一般发送AT指令配置成功的话,芯片都会返回至少一个OK,当然还有其它数据,我们只需要去解析有没有接收到OK就知道指令发送是否成功了。我这里是作为TCP客服端,所以只需要以下一些指令即可:

1>>	发送		AT\r\n			返回 	"OK"
	以上操作确保芯片连接正常,工作正常

2>>	发送 		ATE0\r\n		返回	"OK"
	关闭回显

3>>	发送 	AT+CWMODE=1\r\n		返回	"OK"
	设置成客服端模式


4>>	发送   	AT+CIPSTATUS		返回	"2 3 4 5"	2 3为连接
	确保连接到路由器

5>>	发送 	AT+CWJAP="HES_WIFI","wifi_pass"	返回 	"OK"
													返回	"FAIL"
	连接到路由器

6>>		发送 	AT+CWAUTOCONN=1		返回	"OK"
	开机自动连接

7>>		发送 	AT+CIPSTART="TCP","192.168.0.105",8888		返回	"OK"
	连接到服务器

8>>		发送 	AT+CIPCLOSE		返回	"OK"
	关闭服务器连接

8>>		发送    AT+CIPMODE=1 	返回	"OK"
	设置透传模式1
9>>		发送    AT+CIPSEND		返回	">"
	进入透传
10>>	发送 	+++				返回	无

程序驱动也会按照这个流程来实现;

大概框架如下

esp8266wifi.c文件主要是AT指令配置

serial_config.c文件主要用于解析返回的数据,例如OK,>等

uart.c是串口的应用协议

1-先看看esp8266wifi的内容

#define FANHUI_V		"OK"		//普通指令返回值

extern u8 wifi_name[20];		//路由器名字
extern u8 wifi_pass[20];		//路由器密码

extern u8 wifi_ip[32];			//服务器ip
extern u8 wifi_port[6];		//服务器端口

static u8 wifi_work_mode;		//wifi模块的工作模式,1为配置模式,2为透传模式

#define _WIFI_TRAN_MODE 		2
#define _WIFI_CONFIG_MODE 	1
	
/*模块初始化
	
	1.测试AT命令,保证芯片工作正常
	2.关闭回显
	3.设置成客服端模式
	4.连接到路由器
	5.连接到服务器
	6.设置透传模式1
	7.开始透传
	
	8.关闭透传


*/
u8 esp8266_init(void);

//测试AT指令,确保连接和芯片正常
u8 test_at(void);

//关闭回显
u8 close_huixian(void);

//设置成客户端
u8 set_client(void);

//判断是否连接路由器
u8 is_connect_ap(void);

//连接到路由器
u8 connect_ap(void);

//设置自动连接路由器
u8 aotu_connect_ap(void);

//连接到服务器
u8 connect_server(void);

//断开服务器
u8 disconnect_server(void);

//设置透传模式
u8 set_mode1(void);

//开始透传
u8 start_tran(void);

//关闭透传
u8 close_tran(void);

//设置为透传模式
void set_tran_mode(void);

//设置成配置模式
void set_config_mode(void);

//获取工作模式
u8 get_work_mode(void);


//发送命令和等待时间
u8 send_cmd_wait(u8 *str,u8 len,u32 d_ms);



#endif

这里主要介绍一下

//发送命令和等待时间
u8 send_cmd_wait(u8 *str,u8 len,u32 d_ms);

这个函数比较重要,主要功能还是发生一个AT指令,等待nms后检测是否收到OK,下面是实现

//发送命令和等待时间
u8 send_cmd_wait(u8 *str,u8 len,u32 d_ms)
{

	serial2_sned_buff(str,len);
	
	delay_ms(d_ms);

	if(find_quq_del(OK))	//查找串口数据缓存是否OK
	{
		
		return 1;
	}
	return 0;
}

关闭透传也比较特殊,实现如下

//关闭透传
u8 close_tran()
{
	serial2_sned_buff((u8*)"+++",3);
	delay_ms(20);
	serial2_sned_buff((u8*)"+++",3);
	delay_ms(20);
	serial2_sned_buff((u8*)"\r\n",2);
	delay_ms(20);
	
	return 1;
}

所有函数太多,只介绍几个关键的,其它的可以在后面下载源码。

接下来是serial_config文件

这个文件主要实现1-串口缓冲区添加数据(数据要在串口中断添加),2-解析是否存在相应指令

#define MES_LEN 200


//command
#define OK	(char*)"OK"
#define AP2	(char*)"2\r\n"
#define AP3	(char*)"3\r\n"
#define OFF (char*)"off"
#define ON (char*)"on"
#define STATE (char*)"state"

//Log Switch
#define ERIAL_CONFIG_LOG 0


static	int num;
static	char mes_buf[MES_LEN];		//串口队列长度


	//寻找子并移除子串

int find_str_del(char *mes,char *str);
	//寻找命令
	//参数:命令
	//查找到命令返回1,否则0
int find_quq_del(char *str);
	//添加数据到队列
void add_mes_buf(char ch);
	

#endif

uart.c应用协议是自己定义的,和模块没有关系,其实以上2个文件已经看正常的初始化esp8266了。

初始化函数:

u8 esp8266_init()
{
	
	//设置成配置模式
	set_config_mode();
	
	//测试AT
	if(test_at())
	{
		#if ESP8266_LOG
		printf("esp8266硬件 正常\r\n");
		#endif
	}
	else
	{
		#if ESP8266_LOG
		printf("esp8266硬件 异常\r\n");
		printf("尝试关闭透传...\r\n");
		#endif
		
		close_tran();
		
	}
	//关回显
	if(close_huixian())
	{
		#if ESP8266_LOG
		printf("关闭esp8266回显 正常\r\n");
		#endif
	}
	else
	{
		#if ESP8266_LOG
		printf("关闭esp8266回显 异常\r\n");
		#endif
	}
	//设置成客户端
	if(set_client())
	{
		#if ESP8266_LOG
		printf("设置成客户端 正常\r\n");
		#endif
	}
	else
	{
		#if ESP8266_LOG
		printf("设置成客户端 异常\r\n");
		#endif
	}
	//判断是否连接到路由器	is_connect_ap
	if(is_connect_ap())
	{
		#if ESP8266_LOG
		printf("连接路由器 正常\r\n");
		#endif
	}
	else	//如果没有连接路由器,则去连接
	{
		#if ESP8266_LOG
		printf("连接路由器 异常\r\n");
		printf("尝试连接路由器...\r\n");
		#endif
		
		if(connect_ap())
		{
			#if ESP8266_LOG
			printf("连接路由器 正常\r\n");
			#endif
			aotu_connect_ap();
		}
		else
		{
			#if ESP8266_LOG
			printf("连接路由器 异常\r\n");
			#endif
		}
		
	}
	
	
	
	//连接到服务器
	if(connect_server())
	{
		#if ESP8266_LOG
		printf("连接服务器 正常\r\n");
		#endif
	}
	else
	{
		#if ESP8266_LOG
		printf("连接服务器 异常\r\n");
		printf("尝试关闭连接服务器,重新连接...\r\n");
		#endif
		
		if(disconnect_server())
		{
			#if ESP8266_LOG
			printf("关闭连接服务器 正常\r\n");
			#endif
				//连接到服务器
			if(connect_server())
			{
				#if ESP8266_LOG
				printf("重新连接服务器 正常\r\n");
				#endif
			}
			else
			{
				#if ESP8266_LOG
				printf("连接服务器 异常\r\n");
				#endif
			}
		}
		else
		{
			#if ESP8266_LOG
			printf("关闭连接服务器 异常\r\n");
			#endif
		}
		
		
	}
	//设置透传模式1
	if(set_mode1())
	{
		#if ESP8266_LOG
		printf("设置透传模式1 正常\r\n");
		#endif
	}
	else
	{
		#if ESP8266_LOG
		printf("设置透传模式1 异常\r\n");
		#endif
	}		
	//开始透传
	if(start_tran())
	{
		#if ESP8266_LOG
		printf("开始透传 正常\r\n");
		#endif
		
		//设置成配置模式
		set_tran_mode();
		
	}
	else
	{
		#if ESP8266_LOG
		printf("开始透传 异常\r\n");
		#endif
		
		return 0;
		
	}	
	
	return 1;
}

整体使用的过程。

1,主函数必须初始化串口,esp8266_init()

2,while(1)里面实现如下,

//任务2函数
void task2_func(void *param)
{

	u8 data_count_time=0;	
	int j=1;
	
	while(1)
	{
		
		if(get_work_mode()==_WIFI_TRAN_MODE)	//判断是否是透传模式
		{
			
			//检查wifi数据
			check_wifi_data();
			
			if(wifi_mes.recv_len>0)
			{
				printf("%dwifi:%s\r\n",j++,wifi_mes.recv_data);
			}
			else
			{
				data_count_time++;
				if(data_count_time==5)		//如果很久没有接到数据
				{
					clear_wifi_buf();		//清空缓存
				}
			}
			
			//serial2_sned_buff((u8*)"hello world\r\n",13);
		}
		task_delay(1);

	}
	
}

串口中断实现如下:如果是配置模式,把数据放到命令解析的缓存里,如果是透传模式,把数据放到应用协议的缓存里

void USART2_IRQHandler(void)
{

	   USART_ClearFlag(USART2,USART_FLAG_TC);  
    if(USART_GetITStatus(USART2,USART_IT_RXNE)!=Bit_RESET)//检查指定的USART中断发生与否  
    {  
   
			u8  k=USART_ReceiveData(USART2);  
				
			if(get_work_mode()==_WIFI_CONFIG_MODE)	//如果是配置模式
			{
				add_mes_buf(k);
			
			}else
			{
				
				wifi_buf_add(k);
				//printf("%x ",k);
				
			}
 
      
    }  

	
}

整体测试下来,效果还是很不错的,一晚上通讯没有死机掉线。用的是TCP工具,没有自己写socket

代码量还是比较多的,不能一一讲解,可以下载源码学习,看部分代码可以知道注释是很足的。

https://download.csdn.net/download/hes_c/10678168

<think>好的,用户想了解基于STM32驱动ESP8266-01S的引脚图。首先,我需要确认ESP8266-01S的引脚定义,以及STM32的常见连接方式。ESP8266-01S通常有8个引脚,但有些可能被内部使用,用户需要的主要是VCC、GND、TX、RX、CH_PD和GPIO0。STM32方面,需要选择对应的UART接口,比如USART2或USART3,同时注意电平转换的问题,因为ESP8266是3.3V的。 接下来要考虑用户的可能应用场景,比如他们可能在做物联网项目,需要Wi-Fi连接。用户可能不太熟悉硬件连接中的电平匹配,或者如何配置STM32的串口。需要提醒他们使用3.3V电源,避免烧坏模块,同时注意GPIO0的状态,确保模块处于正常工作模式而非烧录模式。 另外,用户可能没有提到但需要注意的问题包括:上拉电阻是否需要,固件版本是否需要更新,AT指令的使用方法。虽然用户直接问的是引脚图,但在回答中适当提及这些关键点会有帮助,避免他们后续遇到问题。 结构方面,先给出引脚定义,再说明连接方法,最后补充注意事项,这样逻辑清晰。需要确保使用正确的LaTeX格式,比如变量用$V_{CC}$,同时避免使用任何Markdown,只用中文和合适的标点。还要检查是否有遗漏的引脚,比如RST脚的处理,是否需要接高电平或者STM32控制复位。 最后,确保语言通俗易懂,避免过于专业的术语,但必要的术语如UART、GPIO仍需保留,并适当解释。比如,解释CH_PD是使能脚,需要接高电平。这样用户即使初学者也能理解连接方式。</think>我将分步骤说明STM32ESP8266-01S的硬件连接方法及引脚对应关系: 一、ESP8266-01S模块引脚定义(8-pin版本) $$ \begin{array}{|c|c|} \hline \text{引脚编号} & \text{功能描述} \\ \hline 1 & V_{CC} (3.3V电源输入) \\ 2 & GPIO2 (通用IO) \\ 3 & GPIO0 (工作模式选择) \\ 4 & GND (接地) \\ 5 & TXD (UART发送端) \\ 6 & RXD (UART接收端) \\ 7 & CH\_PD (芯片使能,高电平有效) \\ 8 & RST (复位,低电平有效) \\ \hline \end{array} $$ 二、STM32最小系统连接方案 1. 电源连接: - ESP8266的$V_{CC}$(1脚) → STM32的3.3V输出 - ESP8266的$GND$(4脚) → STM32的GND 2. 串口通信连接: - ESP8266的$TXD$(5脚) → STM32的UART$RXD$(如PA3/USART2_RX) - ESP8266的$RXD$(6脚) → STM32的UART$TXD$(如PA2/USART2_TX) 3. 控制信号连接: - ESP8266的$CH\_PD$(7脚) → 接10kΩ上拉电阻至3.3V - ESP8266的$GPIO0$(3脚) → 接10kΩ下拉电阻至GND(正常模式) - ESP8266的$RST$(8脚) → 接10kΩ上拉电阻至3.3V 三、关键注意事项 1. 电平匹配:必须使用3.3V电平通信,STM32的IO口应配置为开漏模式(若STM32使用3.3V供电可不需电平转换) 2. 工作模式: - 当$GPIO0=0$时:进入固件烧录模式 - 当$GPIO0=1$时:进入正常工作模式 3. 电流要求:建议为ESP8266单独配置500mA以上的3.3V电源,避免射频工作时电压跌落 四、典型硬件连接示意图 ``` STM32F103C8T6 ESP8266-01S 3.3V ----------- VCC(1) GND ----------- GND(4) PA3 ----------- TXD(5) PA2 ----------- RXD(6) 3.3V --[10k]---- CH_PD(7) GND --[10k]---- GPIO0(3) ``` 五、软件配置要点 1. 初始化UART参数: - 波特率:115200(默认) - 数据位:8位 - 停止位:1位 - 无校验 2. AT指令示例: $$ AT+CWMODE=1 \quad // 设置STA模式 $$ $$ AT+CWJAP="SSID","password" \quad // 连接WiFi $$ 建议实际接线时增加0.1μF去耦电容,并在RXD/TXD线上串联100Ω电阻以提高抗干扰能力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值