Files
TC264_300W_Power/libraries/zf_device/zf_device_wifi_spi.h
2025-10-15 00:22:56 +08:00

153 lines
8.0 KiB
C
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*********************************************************************************************************************
* TC264 Opensourec Library 即TC264 开源库)是一个基于官方 SDK 接口的第三方开源库
* Copyright (c) 2022 SEEKFREE 逐飞科技
*
* 本文件是 TC264 开源库的一部分
*
* TC264 开源库 是免费软件
* 您可以根据自由软件基金会发布的 GPLGNU General Public License即 GNU通用公共许可证的条款
* 即 GPL 的第3版即 GPL3.0)或(您选择的)任何后来的版本,重新发布和/或修改它
*
* 本开源库的发布是希望它能发挥作用,但并未对其作任何的保证
* 甚至没有隐含的适销性或适合特定用途的保证
* 更多细节请参见 GPL
*
* 您应该在收到本开源库的同时收到一份 GPL 的副本
* 如果没有,请参阅<https://www.gnu.org/licenses/>
*
* 额外注明:
* 本开源库使用 GPL3.0 开源许可证协议 以上许可申明为译文版本
* 许可申明英文版在 libraries/doc 文件夹下的 GPL3_permission_statement.txt 文件中
* 许可证副本在 libraries 文件夹下 即该文件夹下的 LICENSE 文件
* 欢迎各位使用并传播本程序 但修改内容时必须保留逐飞科技的版权声明(即本声明)
*
* 文件名称 zf_device_wifi_spi
* 公司名称 成都逐飞科技有限公司
* 版本信息 查看 libraries/doc 文件夹内 version 文件 版本说明
* 开发环境 ADS v1.10.2
* 适用平台 TC264D
* 店铺链接 https://seekfree.taobao.com/
*
* 修改记录
* 日期 作者 备注
* 2024-01-18 SeekFree first version
********************************************************************************************************************/
/*********************************************************************************************************************
* 接线定义:
* ------------------------------------
* 模块管脚 单片机管脚
* RST 查看 zf_device_wifi_spi.h 中 WIFI_SPI_RST_PIN 宏定义
* INT 查看 zf_device_wifi_spi.h 中 WIFI_SPI_INT_PIN 宏定义
* CS 查看 zf_device_wifi_spi.h 中 WIFI_SPI_CS_PIN 宏定义
* MISO 查看 zf_device_wifi_spi.h 中 WIFI_SPI_MISO_PIN 宏定义
* SCK 查看 zf_device_wifi_spi.h 中 WIFI_SPI_SCK_PIN 宏定义
* MOSI 查看 zf_device_wifi_spi.h 中 WIFI_SPI_MOSI_PIN 宏定义
* 5V 5V 电源
* GND 电源地
* 其余引脚悬空
* ------------------------------------
*********************************************************************************************************************/
#ifndef _zf_device_wifi_spi_h
#define _zf_device_wifi_spi_h
#include "zf_common_typedef.h"
#define WIFI_SPI_INDEX (SPI_3 ) // 定义使用的SPI号
#define WIFI_SPI_SPEED (30 * 1000 * 1000 ) // 硬件 SPI 速率
#define WIFI_SPI_SCK_PIN (SPI3_SCLK_P22_3 ) // 定义SPI_SCK引脚
#define WIFI_SPI_MOSI_PIN (SPI3_MOSI_P22_0 ) // 定义SPI_MOSI引脚
#define WIFI_SPI_MISO_PIN (SPI3_MISO_P22_1 ) // 定义SPI_MISO引脚 IPS没有MISO引脚但是这里任然需要定义在spi的初始化时需要使用
#define WIFI_SPI_CS_PIN (P22_2 ) // 定义SPI_CS引脚 采用软件CS引脚
#define WIFI_SPI_INT_PIN (P15_8 ) // 定义握手引脚
#define WIFI_SPI_RST_PIN (P23_1 ) // 定义复位引脚
#define WIFI_SPI_RECVIVE_FIFO_SIZE (1024) // 接收FIFO大小
#define WIFI_SPI_READ_TRANSFER (1) // 在调用wifi_spi_read_buffer 是否尝试发起SPI通讯来检测模块内是否有数据需要读取 1发起SPI通讯 0不发起SPI通讯仅读取FIFO
// 如果应用程序中没有任何的地方调用发送函数则WIFI_SPI_READ_TRANSFER必须设置为1
#define WIFI_SPI_AUTO_CONNECT (0) // 定义是否初始化时建立TCP或者UDP连接 0-不自动连接 1-自动连接TCP服务器 2-自动连接UDP
#if (WIFI_SPI_AUTO_CONNECT > 2)
#error "WIFI_SPI_AUTO_CONNECT 的值只能为 [0,1,2]"
#else
#define WIFI_SPI_TARGET_IP "192.168.137.1" // 连接目标的 IP
#define WIFI_SPI_TARGET_PORT "8086" // 连接目标的端口
#define WIFI_SPI_LOCAL_PORT "6666" // 本机的端口 0随机 可设置范围2048-65535 默认 6666
#endif
#define WIFI_SPI_RECVIVE_SIZE (32) // 每次SPI传输接收的字节数 不允许修改
#define WIFI_SPI_TRANSFER_SIZE (4088) // 最大SPI传输接收的字节数 不允许修改
typedef enum
{
// 主机发送的命令
WIFI_SPI_INVALID1 = 0x00, // 无效数据包
WIFI_SPI_RESET = 0x01, // 复位命令
WIFI_SPI_DATA = 0x02, // 透传数据包
WIFI_SPI_UDP_SEND = 0x03, // UDP下立即发送命令,默认SPI接收数据后2MS未收到数据自动发送数据
WIFI_SPI_CLOSE_SOCKET = 0x04, // 断开连接
WIFI_SPI_SET_WIFI_INFORMATION = 0x10, // 设置WIFI信息命令
WIFI_SPI_SET_SOCKET_INFORMATION = 0x11, // 设置SOCKET信息命令
WIFI_SPI_GET_VERSION = 0x20, // 获取模块版本
WIFI_SPI_GET_MAC_ADDR = 0x21, // 获取模块MAC地址
WIFI_SPI_GET_IP_ADDR = 0x22, // 获取模块IP地址
// 从机回传的命令
WIFI_SPI_REPLY_OK = 0x80, // 从机应答的正确命令
WIFI_SPI_REPLY_ERROR = 0x81, // 从机应答的错误命令
WIFI_SPI_REPLY_DATA_START = 0x90, // 从机回传的数据包,并且还有数据需要主机读取
WIFI_SPI_REPLY_DATA_END = 0x91, // 从机回传的数据包,数据已读取完毕
WIFI_SPI_REPLY_VERSION = 0xA0, // 从机回复固件版本
WIFI_SPI_REPLY_MAC_ADDR = 0xA1, // 从机回复本机MAC地址等信息
WIFI_SPI_REPLY_IP_ADDR = 0xA2, // 从机回复本机IP地址、端口号
WIFI_SPI_INVALID2 = 0xFF // 无效数据包
}wifi_spi_packets_command_enum;
typedef enum
{
WIFI_SPI_IDLE, // 模块空闲可以进行SPI通讯
WIFI_SPI_BUSY, // 模块正忙不可进行SPI通讯
}wifi_spi_state_enum;
typedef struct
{
uint8 command; // 命令字
uint8 reserve; // 保留
uint16 length; // 包有效长度
}wifi_spi_head_struct;
typedef struct
{
wifi_spi_head_struct head; // 帧头
uint8 buffer[WIFI_SPI_RECVIVE_SIZE]; // 缓冲区
}wifi_spi_packets_struct;
extern char wifi_spi_version[12]; // 固件版本 字符串
extern char wifi_spi_mac_addr[20]; // 模块MAC地址 字符串
extern char wifi_spi_ip_addr_port[25]; // IP地址与端口号 字符串
uint8 wifi_spi_wifi_connect (char *wifi_ssid, char *pass_word);
uint8 wifi_spi_socket_connect (char *transport_type, char *ip_addr, char *port, char *local_port);
uint8 wifi_spi_socket_disconnect (void);
uint8 wifi_spi_udp_send_now (void);
uint32 wifi_spi_send_buffer (const uint8 *buff, uint32 length);
uint32 wifi_spi_read_buffer (uint8 *buffer, uint32 length);
uint8 wifi_spi_init (char *wifi_ssid, char *pass_word);
#endif