STM32与机智云的连接详细步骤

一、创建产品

1.打开机智云官网

机智云|智能物联网操作系统机智云官网:机智云|智能物联网操作系统

2.找到开发者平台,创建个人账号

3.注册账号

登录

4、点击创建产品,创建一个新产品

下一步

 5、进入到新建产品中,根据自己想要的功能点击去编辑添加数据点(功能定义)

6、添加所需要数据点(添加功能)

本设计设置的数据点如下所示。

二、调试设备

1.返回开发者中心首页,点击“下载中心”

2.下载APP调试工具

3.下载完成后,打开虚拟设备调试

返回到虚拟设备调试中。

4.手机端调试APP扫描二维码绑定设备,并可以进行调试

三、刷入机智云固件

1.刷入机智云联网固件

下载中心里:Gizwits

下载完成后,进行解压缩

ESP8266-01s和CH340烧录机智云固件全解_机智云esp01s固件-CSDN博客ESP8266-01s和CH340烧录机智云固件详细介绍:ESP8266-01s和CH340烧录机智云固件全解_机智云esp01s固件-CSDN博客ESP8266-01s和CH340烧录机智云固件全解_机智云esp01s固件-CSDN博客

烧录软件在

固件烧录工具

开发工具清单 | 安信可科技   

ESP8266-01s和CH340烧录机智云固件全解_机智云esp01s固件-CSDN博客

解压后打开

等待烧录完成。

2.烧录过程中可能出现的问题

1.需要保证IO0接地,可以用烧录器的GND和其相连

2.把ESP8266的3V3快速断开后再相连,再点击烧录即可其相连

四、生成Gizwits代码,准备移植STM32中

1.返回机智云官网,生产代码

等待代码生成

下载完成后解压缩:

2.开始移植到STM32文件中

然后找到自己的32工程,复制到工程中

打开工程配置设备虚拟树

添加对应的文件

包含相关头文件路径

编写对应的USART代码 ---- 注意波特率必须为9600,本设计用的是stm32f103c8t6的串口3

void uart3_init(u32 bound)
{
	//GPIO端口设置
	GPIO_InitTypeDef GPIO_InitStructure;
	USART_InitTypeDef USART_InitStructure;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);//时钟GPIOB、USART3
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);
	
	//USART3_TX   PB10
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
	GPIO_Init(GPIOB, &GPIO_InitStructure);
	//USART3_RX	  PB11
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
	GPIO_Init(GPIOB, &GPIO_InitStructure);  
	//USART 初始化设置
	USART_InitStructure.USART_BaudRate = bound;//一般设置为9600;
	USART_InitStructure.USART_WordLength = USART_WordLength_8b;
	USART_InitStructure.USART_StopBits = USART_StopBits_1;
	USART_InitStructure.USART_Parity = USART_Parity_No;
	USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
	USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
	USART_Init(USART3, &USART_InitStructure);
	
	NVIC_InitTypeDef NVIC_InitStruct;
	NVIC_InitStruct.NVIC_IRQChannel = USART3_IRQn;
	NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;
	NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 2;
	NVIC_InitStruct.NVIC_IRQChannelSubPriority = 2;
	NVIC_Init(&NVIC_InitStruct);
	
	USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);//开启中断
	USART_Cmd(USART3, ENABLE);                    //使能串口 
}


void USART3_IRQHandler(void) 
{
	
	u8 data = 0;
	if(USART_GetITStatus(USART3,USART_IT_RXNE)!=RESET)//接收中断标志位拉高
	{
		USART_ClearITPendingBit(USART3,USART_IT_RXNE);
		data = USART_ReceiveData(USART3);
		gizPutData(&data,1);      //这段话不要忘记
		
	}
}

编写1ms定时器更新中断,作为心跳

#include "timer.h" 
#include "gizwits_protocol.h"
#include "gizwits_product.h"
//通用定时器4中断初始化
//这里时钟选择为APB1的2倍,而APB1为36M
//arr:自动重装值。
//psc:时钟预分频数
//这里使用的是定时器4!
void TIM4_Int_Init(void)
{
    TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
	NVIC_InitTypeDef NVIC_InitStructure;

	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE); //时钟使能
	
	//定时器TIM4初始化
	TIM_TimeBaseStructure.TIM_Period = 1000 - 1; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值	
	TIM_TimeBaseStructure.TIM_Prescaler =72 - 1; 72Mhz  T=1/f = 1000hz
	TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim
	TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式
	TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure); //根据指定的参数初始化TIMx的时间基数单位
 
	TIM_ITConfig(TIM4,TIM_IT_Update,ENABLE ); //使能指定的TIM4中断,允许更新中断

	//中断优先级NVIC设置
	NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;  //TIM4中断
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  //先占优先级0级
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;  //从优先级3级
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
	NVIC_Init(&NVIC_InitStructure);  //初始化NVIC寄存器


	TIM_Cmd(TIM4, ENABLE);  //使能TIMx					 
}
//定时器4中断服务程序
void TIM4_IRQHandler(void)   //TIM4中断
{
	if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)  //检查TIM4更新中断发生与否
		{
			TIM_ClearITPendingBit(TIM4, TIM_IT_Update );
			gizTimerMs();
		}
}

五、机智云相关代码开始移植

相关移植步骤

1.实现与模组通信串口驱动
2.实现串口打印函数printf();
3.实现1ms定时器,gizTimerMs()维护系统时间 (提供时基)
4.实现MCU复位函数,模组可请求MCU复位
5.实现配置入网功能,调用gizwitsSetMode()函数实现模组配网功能
6.实现userHandle()数据的采集(上行逻辑) 
7.实现 gizwitsEventProcess()控制命令的具体执行(下行逻辑)

1.WIFI串口接收数据写入缓冲区

串口包含这个机智云的头文件

2.实现uartWrite()串口发送数据

在该文件中找到uartWrite()这个函数,并在给文件上方添加所用串口的.h文件

该函数修改为

int32_t uartWrite(uint8_t *buf, uint32_t len)
{
    uint32_t i = 0;
    
    if(NULL == buf)
    {
        return -1;
    }
    
       #ifdef PROTOCOL_DEBUG
//    GIZWITS_LOG("MCU2WiFi[%4d:%4d]: ", gizGetTimerCount(), len);
    for(i=0; i<len; i++)
    {
//        GIZWITS_LOG("%02x ", buf[i]);
    }
//    GIZWITS_LOG("\n");
    #endif

    for(i=0; i<len; i++)
    {
        USART_SendData(USART3, buf[i]);//STM32 test demo
				while (USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);
        //Serial port to achieve the function, the buf[i] sent to the module
        if(i >=2 && buf[i] == 0xFF)
        {
					USART_SendData(USART3,0x55);
					while (USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);
          //Serial port to achieve the function, the 0x55 sent to the module
          //USART_SendData(UART, 0x55);//STM32 test demo
        }
    }
    


    
    return len;
}

3.实现毫秒定时

对于使用的定时器4,中断里添加相应代码

//定时器4中断服务程序
void TIM4_IRQHandler(void)   //TIM4中断
{
	if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)  //检查TIM4更新中断发生与否
		{
			TIM_ClearITPendingBit(TIM4, TIM_FLAG_Update );
			gizTimerMs();
		}
}

编译会出现警告,找不到该函数,gizTimerMs();函数没有定义,在gizwits_product.h文件中进行定义

4.实现芯片复位函数

修改该函数在gizwits_product.h文件中

改为下边的代码

void mcuRestart(void)
{
	__set_FAULTMASK(1);
	NVIC_SystemReset();
}

5.实现配置入网

 模组支持 SoftAp 和 AirLink 两种方式配置入网, 相应接口为 gizwitsSetMode(), 三种模式如下:

WIFI_RESET_MODE                恢复默认出厂设置

WIFI_SOFTAP_MODE            热点配网

WIFI_AIRLINK_MODE            手机广播配网

在此之前主函数中添加头文件

以及初始化

添加机智云初始化代码,本次选择了airlink配网模式

userInit();
	
  gizwitsInit();
//	Delay_ms(500); 
	gizwitsSetMode(WIFI_AIRLINK_MODE);
	
	gizwitsSetMode(WIFI_RESET_MODE);

6.协议处理

根据采集到的数据,然后调用函数 gizwitsHandle()、userHandle()上报,函数位置在gizwits_protocol.c文件中,该函数主要完成协议数据的处理及数据主动上报的相关操作

在main.c进行外部声明

/** Current datapoint */
extern dataPoint_t currentDataPoint;

在while(1)调用gizwitsHandle()和userHandle()上报数据


gizwitsHandle(&currentDataPoint);
userHandle();

 到这一步,配网就结束了,接下来开始配置自己需要传输的数据

7.数据上下发配置

上发数据用到的函数为userHandle(),这个函数是在gizwits_protocol.c中

如图,本设计一开始将参数都初始化为0

采集数据的函数

该函数中内容作为机智云app下发数据

六、至此,完成所有步骤,实验现象如下:

七、WIFI连接出现的问题

出现timeout超时,可能原因是主函数中给了延时函数,可以尝试屏蔽掉。如果出现连接数据传输不稳定,WIFI连接容易掉,可以尝试一下。

注释掉箭头指向的这三行

并且把这个语句能搜索到的全部注释掉,可以ctrl+f 搜索都在这两个文件中

这个主要是串口1打印内容(gizwits_product.c,gizwits_protocol.c)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值