目录

银杏科技有限公司旗下技术文档发布平台
技术支持电话0379-69926675-801
技术支持邮件Gingko@vip.163.com
版本 日期 作者 修改内容
V1.0 2020-08-01 gingko 初次建立






STM32CubeMX教程二十三——LAN_TCPC实验

1. 新建工程:在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR  2. 出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置 在搜索栏的下面,提供的各种查找方式,可以选择芯片内核、型号等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32F407IGTx。  3. 配置RCC,使用外部时钟源  4. 配置调试引脚  5. 将LED对应的3个引脚(PI5,PI6,PI7)设置为GPIO_Output  6. 引脚模式配置  7. 配置SPI  选用PA15引脚作为SPI1_CS  8. 时钟源设置,选择外部高速时钟源,配置为最大主频

9. 工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK5  10. 点击Code Generator,进行进一步配置

自行选择方式即可

11. 然后点击GENERATE CODE 创建工程  创建成功,打开工程。





实验二十三:LAN_TCPC实验——以太网数据传输

一、 实验目的与意义

  1. 了解STM32的SPI和W5500的TCPC结构
  2. 了解STM32的SPI和W5500的TCPC特征
  3. 掌握SPI和TCPC的使用方法
  4. 掌握STM32 HAL库中SPI和TCPC的配置方法
  5. 掌握KEIL MDK集成开发环境使用方法

二、 实验设备及平台

  1. iCore3 双核心板。点击购买
  2. JLINK(或相同功能)仿真器。点击购买
  3. Micro USB线缆。
  4. 网线
  5. Keil MDK 开发平台。
  6. STM32CubeMX开发平台。
  7. 装有WIN XP(及更高版本)系统的计算机。

三、 实验原理

1、SPI简介

2、W5500简介

3、TCPC简介

  1. 在建立通道时,客户端首先要向服务端发送一个SYN同步信号。
  2. 服务端在接收到这个信号之后会向客户端发出SYN同步信号和ACK确认信号。
  3. 当服务端的ACK和SYN到达客户端后,客户端与服务端之间的这个“通道”就会被建立起来
  1. 在数据传输完毕之后,客户端会向服务端发出一个FIN终止信号
  2. 服务端在收到这个信号之后会向客户端发出一个ACK确认信号
  3. 如果服务端此后也没有数据发给客户端时服务端会向客户端发送一个FIN终止信号
  4. 客户端在收到这个信号之后会回复一个确认信号,在服务端接收到这个信号之后,服务端与客户端的通道也就关闭了

四、 实验原理

五、 实验程序

1. main()函数中建立的客户端程序

 while (1)
  {
	//处理TCP client信息
	switch(getSn_SR(0))    /*获取socket0的状态*/
	{
		case SOCK_INIT:                   /*socket初始化完成*/
		connect(0, remote_ip ,60001);  /*在TCP模式下向服务器发送连接请求*/ 
		break;
		case SOCK_ESTABLISHED:          /*socket连接建立*/
		if(getSn_IR(0) & Sn_IR_CON)
		{
			setSn_IR(0, Sn_IR_CON);   /*Sn_IR的第0位置1*/
		}
		receive_length = getSn_RX_RSR(0); /*len为已接收数据的大小*/
		if(receive_length > 0)
		{
			memset(receive_buffer,0,sizeof(receive_buffer));
			recv(0,receive_buffer,receive_length);
/*W5500接收来自Sever的数据*/
			send(0,receive_buffer,receive_length);
		}		  
		break;
		case SOCK_CLOSE_WAIT:          /*socket等待关闭状态*/
		disconnect(0);
		break;
		case SOCK_CLOSED:              /*socket关闭*/
		local_port = rand() % 10000 + 50000;
		socket(0,Sn_MR_TCP,local_port,Sn_MR_ND);      
/*打开socket0的一个端口*/
		break;
	}
}

2. SPI初始化配置

void MX_SPI1_Init(void)
{
hspi1.Instance = SPI1;					
hspi1.Init.Mode = SPI_MODE_MASTER;			//SPI主模式
hspi1.Init.Direction = SPI_DIRECTION_2LINES;	//全双工模式
hspi1.Init.DataSize = SPI_DATASIZE_8BIT;		//数据位为8位
hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;		//CPOL = 0
hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;		//CPHA为数据线的第一个变化沿
hspi1.Init.NSS = SPI_NSS_SOFT;				//软件控制NSS
hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;//2分频
hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;		//最高位先发送
hspi1.Init.TIMode = SPI_TIMODE_DISABLE;		//TIMODE模式关闭
hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;//CRC关闭
hspi1.Init.CRCPolynomial = 10;//默认值,无效
if (HAL_SPI_Init(&hspi1) != HAL_OK)//初始化
{
Error_Handler();
}
}

3. SPI读写函数配置

static unsigned char send_data(unsigned char data)//SPI读写字节函数
{
unsigned char receive_data;
HAL_SPI_TransmitReceive(&hspi1,&data,&receive_data,1,1000);//接收发送函数
return receive_data;//返回接收到的值
}
static int write(int number, unsigned char * buf) //SPI读写多字节函数
{
int i;
SPI1_CS_OFF;                       //拉低CS引脚
for (i = 0; i < number; i++){
buf[i] = send_data(buf[i]);	  //调用send_data()函数
}
SPI1_CS_ON;					  //拉高CS引脚
return 0;
}

4. W5500.c中的寄存器读写函数

//定义本设备IP地址、默认网关、MAC地址、子网掩码
W5500_T w5500={
	.initialize=initialize,
	.mac = {0x00,0x98,0xdc,0x42,0x61,0x11},
	.ip = {192,168,0,10},
	.sub = {255,255,255,0},
	.gw = {192,168,0,1}		
};
//W5500写函数
void IINCHIP_WRITE (unsigned long int addrbsb, unsigned char data) 
{
SPI1_CS_OFF;
spi1.send_data( (addrbsb & 0x00FF0000)>>16);      // Address byte 1
spi1.send_data( (addrbsb & 0x0000FF00)>> 8);      // Address byte 2
spi1.send_data( (addrbsb & 0x000000F8) + 4);  
// Data write command and Write data length 1
spi1.send_data(data);               // Data write (write 1byte data)
SPI1_CS_ON
}
 
//W5500读函数
unsigned char IINCHIP_READ (unsigned long int addrbsb) // Address byte 1
{
 unsigned char data = 0;
 SPI1_CS_OFF;
 spi1.send_data( (addrbsb & 0x00FF0000)>>16);      // Address byte 1
 spi1.send_data( (addrbsb & 0x0000FF00)>> 8);      // Address byte 2
 spi1.send_data( (addrbsb & 0x000000F8))    ;                               
// Data read command and Read data length 1
 data = spi1.send_data(0x00);          // Data read (read 1byte data)
 SPI1_CS_ON;
 return data;  
}

六、 实验步骤

  1. 把仿真器与iCore3的SWD调试口相连(直接相连或者通过转接器相连);
  2. 把iCore3(USB OTG)通过Micro USB线与计算机相连,为iCore3供电;
  3. 把iCore3网口通过网线与计算机网口相连;
  4. 设置本机电脑IP;(方法见附录1)
  5. 打开Keil MDK 开发环境,并打开本实验工程;
  6. 打开TCP&UDP测试工具;(安装及使用方法见附录2)
  7. 烧写程序到iCore3上;
  8. 也可以进入Debug 模式,单步运行或设置断点验证程序逻辑。

七、 实验现象

附录1

1、打开控制面板网络和Internet网络和共享中心更改适配器设置以太网属性 2、Internet协议版本选择使用下面的IP地址(如下图所示),然后更改IP地址和默认网关

附录2

1、TCP&UDP测试工具安装 双击TCPUDPDebug102_Setup.exe,点击下一步,在这里安装路径我们默认即可,点击安装,然后Finish。 2、TCP&UDP测试工具的使用 (1)打开测试工具,界面如下。点击创建服务器,弹出了设置端口的窗口,端口设置为60001。 (2)服务器已经创建完成(如下图),点击启动服务器 (3)iCore3客户端自动连接服务器,即可进行通信。(若连接不上请关闭电脑防火墙)