用户工具

站点工具


icore4t_41

差别

这里会显示出您选择的修订版和当前版本之间的差别。

到此差别页面的链接

两侧同时换到之前的修订记录 前一修订版
后一修订版
前一修订版
icore4t_41 [2020/09/30 17:47]
zgf [附录:]
icore4t_41 [2020/11/10 08:55] (当前版本)
zgf [四、 实验程序]
行 5: 行 5:
 ^  版本 ​ ^  日期 ​ ^  作者 ​ ^  修改内容 ​ ^ ^  版本 ​ ^  日期 ​ ^  作者 ​ ^  修改内容 ​ ^
 |  V0.1  |20200103 ​ |XiaomaGee| ​ 初次建立 ​ | |  V0.1  |20200103 ​ |XiaomaGee| ​ 初次建立 ​ |
 +
 +\\
 +\\
 +\\
 +\\
 +\\
 +\\
  
 ===== STM32CubeMX教程四十一—LWIP_UDP以太网数据传输 ===== ===== STM32CubeMX教程四十一—LWIP_UDP以太网数据传输 =====
  
 1. 在主界面选择File-->​New Project或者直接点击ACCEE TO MCU SELECTOR  ​ 1. 在主界面选择File-->​New Project或者直接点击ACCEE TO MCU SELECTOR  ​
- +{{ :​icore4t:​icore4t_cube_41_1.png?​direct |}} 
 2. 出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置 2. 出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置
 在搜索栏的下面,提供的各种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。 在搜索栏的下面,提供的各种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。
- +{{ :​icore4t:​icore4t_cube_41_2.png?​direct |}} 
 3. 配置RCC,使用外部时钟源 3. 配置RCC,使用外部时钟源
- +{{ :​icore4t:​icore4t_cube_41_3.png?​direct |}} 
 4. 配置调试引脚 4. 配置调试引脚
-  +{{ :​icore4t:​icore4t_cube_41_4.png?​direct |}} 
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
  
 5. 将PA10,PB7,PB8设置为GPIO_Output 5. 将PA10,PB7,PB8设置为GPIO_Output
- +{{ :​icore4t:​icore4t_cube_41_5.png?​direct |}} 
 6. 引脚模式配置 6. 引脚模式配置
-  +{{ :​icore4t:​icore4t_cube_41_6.png?​direct |}}  
- +{{ :​icore4t:​icore4t_cube_41_7.png?​direct |}} 
 7. 配置以太网 7. 配置以太网
-  +{{ :​icore4t:​icore4t_cube_41_8.png?​direct |}}  
-  +{{ :​icore4t:​icore4t_cube_41_9.png?​direct |}}  
-  +{{ :​icore4t:​icore4t_cube_41_10.png?​direct |}}  
- +{{ :​icore4t:​icore4t_cube_41_11.png?​direct |}} 
 8. 时钟设置,选择外部高速时钟源,配置为最大主频 8. 时钟设置,选择外部高速时钟源,配置为最大主频
- +{{ :​icore4t:​icore4t_cube_41_12.png?​direct |}} 
 9. 工程文件的设置,​ 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 ​ IDE我们使用的是 MDK5.27 9. 工程文件的设置,​ 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 ​ IDE我们使用的是 MDK5.27
- +{{ :​icore4t:​icore4t_cube_41_13.png?​direct |}} 
 10. 点击Code Generator,进行进一步配置 10. 点击Code Generator,进行进一步配置
- +{{ :​icore4t:​icore4t_cube_41_14.png?​direct |}} 
   * **Copy all used libraries into the project folder**   * **Copy all used libraries into the project folder**
   * 将HAL库的所有.C和.H都复制到所建工程中   * 将HAL库的所有.C和.H都复制到所建工程中
行 59: 行 55:
   * 自行选择方式即可   * 自行选择方式即可
 11. 然后点击GENERATE CODE  创建工程 11. 然后点击GENERATE CODE  创建工程
- +{{ :​icore4t:​icore4t_cube_41_15.png?​direct |}} 
 创建成功,打开工程。 创建成功,打开工程。
  
 +
 +\\
 +\\
 +\\
  
 ===== 实验四十一:LWIP_UDP实验——以太网数据传输 ===== ===== 实验四十一:LWIP_UDP实验——以太网数据传输 =====
行 157: 行 157:
 === 1. 主函数 === === 1. 主函数 ===
 <code c> <code c>
 +//​LWIP初始化
 +NETMPU_Config();​
 +lwip.initialize();​
 +eth_tcpc.initialize();​
 + while (1)
 +  {
 + if((cnt ++ / 800000) % 2){
 + LED_RED_ON;​
 + }else{
 + LED_RED_OFF;​
 + }
 + lwip.periodic_handle();​
 + //udp test
 + if(eth_udp.receive_ok_flag == 1){
 + eth_udp.receive_ok_flag = 0;
 + eth_udp.send_data(eth_udp.udppcb);​
 + }
 +  }  ​
  
 </​code> ​ </​code> ​
 === 2. LwIP初始化 === === 2. LwIP初始化 ===
 <code c> <code c>
 +unsigned char initialize(void)
 +{
 +  unsigned char retry = 0;
 + Struct netif *Netif_Init_Flag; ​ //​调用netif_add()函数时的返回值,用于判断网络初始化是否成功
 + struct ip_addr ipaddr; ​         //ip地址
 + struct ip_addr netmask; ​        //​子网掩码
 + struct ip_addr gw;      //​默认网关
 +
 + while(lan8720.initialize()){ //​初始化LAN8720,如果失败的话就重试5次
 + retry++;
 + if(retry > 5){
 + retry = 0;
 +   return 3;
 + }                       //​LAN8720初始化失败
 + }
 + lwip_init();​ //​初始化LWIP内核
 + IP4_ADDR(&​ipaddr,​lan8720.ip[0],​lan8720.ip[1],​lan8720.ip[2],​lan8720.ip[3]);​
 + IP4_ADDR(&​netmask,​lan8720.sub[0],​lan8720.sub[1] ,​lan8720.sub[2],​lan8720.sub[3]);​
 + IP4_ADDR(&​gw,​lan8720.gw[0],​lan8720.gw[1],​lan8720.gw[2],​lan8720.gw[3]);​
 +        //​向网卡列表中添加一个网口
 + Netif_Init_Flag=netif_add(&​lwip_netif,&​ipaddr,&​netmask,&​gw,​NULL,&​ethernetif_init,&​ethernet_input);​
 + if(Netif_Init_Flag==NULL){
 + return 4;             //​网卡添加失败
 + }else{ ​                       //​网口添加成功后,设置netif为默认值,并且打开netif网口
 + netif_set_default(&​lwip_netif); ​     //​设置netif为默认网口
 + netif_set_up(&​lwip_netif); ​          //​打开netif网口
 + }
 +
 + return 0;                     //​操作OK
 +
  
 </​code> ​ </​code> ​
 === 3. eth_udp初始化 === === 3. eth_udp初始化 ===
 <code c> <code c>
 +void initialize(void)
 +{
 +struct ip_addr rmtipaddr;
 +eth_tcpc.tcpc_pcb = tcp_new(); //​该函数简单的调用tcp_alloc函数为一个谅解分配一个TCP控制块tcp_pcb。
 +                               //​tcp_alloc函数首先为新的tcp_pcb分配内存空间,若内存空间不足,则函数会释放出新的pcb空间。
 +IP4_ADDR(&​rmtipaddr,​lan8720.pc_ip[0],​lan8720.pc_ip[1],​lan8720.pc_ip[2],​lan8720.pc_ip[3]);​
 +udp_connect(eth_udp.udppcb,&​rmtipaddr,​PC_PORT);​
 +udp_bind(eth_udp.udppcb,​IP_ADDR_ANY,​30000);​
 +udp_recv(eth_udp.udppcb,​eth_udp.receive_data,​NULL);​
 +
  
 </​code> ​ </​code> ​
行 195: 行 253:
   * **2、TCP&​UDP测试工具的使用**   * **2、TCP&​UDP测试工具的使用**
   * (1)打开测试工具,点击创建连接,弹出设置端口的窗口,设置为30001.   * (1)打开测试工具,点击创建连接,弹出设置端口的窗口,设置为30001.
- {{ :icore4t:icore4t_arm_hal_41_1.png?direct |}} + {{ :icore4t:icore4t_arm_hal_41_8.png?direct |}} 
   * (2)创建完成(如下图),点击连接   * (2)创建完成(如下图),点击连接
-{{ :icore4t:icore4t_arm_hal_41_1.png?direct |}} +{{ :icore4t:icore4t_arm_hal_41_9.png?direct |}} 
   * (3)iCore4T自动连接即可通信。(若连接不成功,请关闭电脑防火墙)   * (3)iCore4T自动连接即可通信。(若连接不成功,请关闭电脑防火墙)
  
icore4t_41.1601459250.txt.gz · 最后更改: 2020/09/30 17:47 由 zgf · 目前已被下列人员锁定: 52.167.144.145