关于GD32F107的eth、mac、phy的问题

原创 2015年11月18日 17:15:23

  由于项目需要,由STM32F107更换到了GD32F107,传说中,完全PIN2PIN,代码基本不用改,这也是吸引人的地方。于是。。。。。

但是移植到ETH的时候,发现跑不通,数据只进不出,后面发现是DMA发送不了数据。可是,为什么DMA会发送不了?于是,就不是简单的移植了,只能从最基本的下手了,数据怎么进来?数据怎么处理?数据怎么出去?然后利用Wireshark抓包工具来,用STM32F107的旧板,抓取了上电之后,Lwip首先需要发出的数据是一个ARP请求包。GD32F107这个包怎么都发不出去,后来无意在百度的时候看到一段配置代码,COPY下来放到我的代码里,一运行,竟然发出去了,然后细细对比一番,原来是GD32F107不能采用自动协商模式。选定了100M模式后,一切正常,真是折腾死人,三天,整整折腾了三天。GD的工程师如果看到这文章,希望能给出解决办法,或者如果读者在自动协商下能正常运行的,欢迎指教指教。下面,我贴出配置代码。

/*------------------------   MAC   -----------------------------------*/
// ETH_InitStruct.ETH_AutoNegotiation = ETH_AutoNegotiation_Enable  ;
ETH_InitStruct.ETH_AutoNegotiation = ETH_AutoNegotiation_Disable;
ETH_InitStruct.ETH_Mode = ETH_Mode_FullDuplex;
ETH_InitStruct.ETH_Speed = ETH_Speed_100M;
ETH_InitStruct.ETH_LoopbackMode = ETH_LoopbackMode_Disable;
ETH_InitStruct.ETH_RetryTransmission = ETH_RetryTransmission_Disable;
ETH_InitStruct.ETH_AutomaticPadCRCStrip = ETH_AutomaticPadCRCStrip_Disable;
ETH_InitStruct.ETH_ReceiveAll = ETH_ReceiveAll_Disable;
ETH_InitStruct.ETH_BroadcastFramesReception = ETH_BroadcastFramesReception_Enable;
ETH_InitStruct.ETH_PromiscuousMode = ETH_PromiscuousMode_Disable;
ETH_InitStruct.ETH_MulticastFramesFilter = ETH_MulticastFramesFilter_Perfect;
ETH_InitStruct.ETH_UnicastFramesFilter = ETH_UnicastFramesFilter_Perfect;
#ifdef CHECKSUM_GEN_ICMP
ETH_InitStruct.ETH_ChecksumOffload = ETH_ChecksumOffload_Enable;
#endif


/*------------------------   DMA   -----------------------------------*/  
  
/* When we use the Checksum offload feature, we need to enable the Store and Forward mode: 
the store and forward guarantee that a whole frame is stored in the FIFO, so the MAC can insert/verify the checksum, 
if the checksum is OK the DMA can handle the frame otherwise the frame is dropped */
ETH_InitStruct.ETH_DropTCPIPChecksumErrorFrame = ETH_DropTCPIPChecksumErrorFrame_Enable; 
ETH_InitStruct.ETH_ReceiveStoreForward = ETH_ReceiveStoreForward_Enable;         
ETH_InitStruct.ETH_TransmitStoreForward = ETH_TransmitStoreForward_Enable;     


ETH_InitStruct.ETH_ForwardErrorFrames = ETH_ForwardErrorFrames_Disable;       
ETH_InitStruct.ETH_ForwardUndersizedGoodFrames = ETH_ForwardUndersizedGoodFrames_Disable;   
ETH_InitStruct.ETH_SecondFrameOperate = ETH_SecondFrameOperate_Enable;                                                          
ETH_InitStruct.ETH_AddressAlignedBeats = ETH_AddressAlignedBeats_Enable;      
ETH_InitStruct.ETH_FixedBurst = ETH_FixedBurst_Enable;                
ETH_InitStruct.ETH_RxDMABurstLength = ETH_RxDMABurstLength_32Beat;          
ETH_InitStruct.ETH_TxDMABurstLength = ETH_TxDMABurstLength_32Beat;                                                                 
ETH_InitStruct.ETH_DMAArbitration = ETH_DMAArbitration_RoundRobin_RxTx_2_1;

关于GD32芯片读保护的描述和解决办法

  • 2016年11月14日 15:31
  • 728KB
  • 下载

关于网卡及MAC和PHY的区别,讲的比较清楚(转帖)

关于网卡及MAC和PHY的区别,讲的比较清楚(转帖)  一块以太网网卡包括OSI(开方系统互联)模型的两个层。物理层和数据链路层。物理层定义了数据传送与接收所需要的电与光信号、线...
  • tyshtang
  • tyshtang
  • 2015年04月27日 01:15
  • 2548

远程升级学习

升级说明 ①升级程序结构: bootloader 应用程序区 程序备份区                           ...
  • baiyibin0530
  • baiyibin0530
  • 2015年07月13日 16:02
  • 461

mac与phy如何实现网络自适应

对于100M phy,外部网络10/100M切换,仅需要改变mac提供的数据时钟即可,mac接口模式不变,因为MII兼容10/100M。 对于1000M phy,外部网络10/100/1000M切换,...
  • skyflying2012
  • skyflying2012
  • 2015年07月29日 18:46
  • 5997

以太网知识2:Mac与Phy组成原理的简单分析

1. general 下图是网口结构简图.网口由CPU、MAC和PHY三部分组成.DMA控制器通常属于CPU的一部分,用虚线放在这里是为了表示DMA控制器可能会参与到网口数据传输中. 对于上述...
  • gang_life
  • gang_life
  • 2015年11月25日 17:26
  • 1293

MAC、MII、PHY的关系与区别

嗯,实验室的嵌入式项目需要写设备驱动,我分到了网络驱动的活,写一个适配SylixOS的(这里夸一句,这个真是国内相当不错的嵌入式实时操作系统了)MPC8377的网卡驱动,说实话原来从来没接触过写驱动的...
  • hahajinbu
  • hahajinbu
  • 2016年08月10日 17:56
  • 5870

以太网卡杂记之MAC和PHY

网卡工作在osi的最后两层,物理层和数据链路层。 物理层的芯片称之为PHY。物理层定义了数据传送与接收所需要的电与光信号、线路状态、时钟基准、数据编码和电路等,并向数据链路层设备提供标准接口。 以太网...
  • yayong
  • yayong
  • 2010年03月01日 00:29
  • 9289

【收藏】以太网MAC和PHY之间的接口总结

【收藏】以太网MAC和PHY之间的接口总结 2016-07-10硬件十万个为什么 1、100M 接口(Fast Ethernet 快速以太网,也称百兆以太网) FE速率模式下各种MI...
  • krens
  • krens
  • 2017年02月16日 20:18
  • 2114

MAC和PHY的介绍

一.有关MAC的硬件知识 MAC: Media Access Control 全双工或者半双工模式,依赖于物理层的支持。 功能: 1. 封装上一层数据,下发 2. 帧的接收、发送 ...
  • woshi_ziyu
  • woshi_ziyu
  • 2012年07月11日 09:15
  • 3043

网络结构及mac和phy介绍

这两天想看看网卡驱动,就先收集了一些网络结构的相关资料,这些基本上都是凑的,是伪原创    网络七层协议 OSI是一个开放性的通行系统互连参考模型,他是一个定义的非常...
  • bugouyonggan
  • bugouyonggan
  • 2013年06月09日 13:21
  • 4855
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于GD32F107的eth、mac、phy的问题
举报原因:
原因补充:

(最多只允许输入30个字)