mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-21 08:33:30 +08:00
1408 lines
60 KiB
C
1408 lines
60 KiB
C
|
/**
|
||
|
******************************************************************************
|
||
|
* @brief ETH header file of the firmware library.
|
||
|
******************************************************************************
|
||
|
*/
|
||
|
|
||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||
|
#ifndef __GD32F10X_ETH_H
|
||
|
#define __GD32F10X_ETH_H
|
||
|
#define IF_USE_EXTERNPHY_LIB 0
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/* Includes ------------------------------------------------------------------*/
|
||
|
#include "gd32f10x.h"
|
||
|
#if (1 == IF_USE_EXTERNPHY_LIB)
|
||
|
#include "phy.h"
|
||
|
#endif
|
||
|
|
||
|
/** @addtogroup GD32F10x_Firmware
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup ETH
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Exported_Types
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief ETH MAC Initial Parameters
|
||
|
*/
|
||
|
typedef struct {
|
||
|
/**
|
||
|
* @brief / * MAC
|
||
|
*/
|
||
|
uint32_t ETH_MAC_AutoNegotiation; /*!< Enable or disable external PHY's AutoNegotiation function
|
||
|
detailed in @ref ETH_AutoNegotiation */
|
||
|
|
||
|
uint32_t ETH_MAC_Watchdog; /*!< Enable or disable the Watchdog timer
|
||
|
detailed in @ref ETH_watchdog */
|
||
|
|
||
|
uint32_t ETH_MAC_Jabber; /*!< Enable or disable Jabber timer
|
||
|
detailed in @ref ETH_Jabber */
|
||
|
|
||
|
uint32_t ETH_MAC_InterFrameGap; /*!< Set the gap of two frames when transmission
|
||
|
detailed in @ref ETH_Inter_Frame_Gap */
|
||
|
|
||
|
uint32_t ETH_MAC_CarrierSense; /*!< Enable or disable the Carrier Sense
|
||
|
detailed in @ref ETH_Carrier_Sense */
|
||
|
|
||
|
uint32_t ETH_MAC_Speed; /*!< Set the Ethernet speed, detailed in @ref ETH_Speed */
|
||
|
|
||
|
|
||
|
uint32_t ETH_MAC_ReceiveOwn; /*!< Enable or disable the ReceiveOwn mode
|
||
|
detailed in @ref ETH_Receive_Own */
|
||
|
|
||
|
uint32_t ETH_MAC_LoopbackMode; /*!< Enable or disable the MAC Loopback mode
|
||
|
detailed in @ref ETH_Loop_Back_Mode */
|
||
|
|
||
|
uint32_t ETH_MAC_Mode; /*!< Set the MAC duplex mode, detailed in @ref ETH_Duplex_Mode */
|
||
|
|
||
|
uint32_t ETH_MAC_ChecksumOffload; /*!< Enable or disable the IPv4(TCP/UDP/ICMP headers) checksum checking when reception
|
||
|
detailed in @ref ETH_Checksum_Offload */
|
||
|
|
||
|
uint32_t ETH_MAC_RetryTransmission; /*!< Enable or disable the MAC attempt retries transmission in Half-Duplex mode when a colision occurs
|
||
|
detailed in @ref ETH_Retry_Transmission */
|
||
|
|
||
|
uint32_t ETH_MAC_AutomaticPadCRCDrop; /*!< Enable or disable the Automatic Pad/CRC Drop
|
||
|
detailed in @ref ETH_Automatic_Pad_CRC_Drop */
|
||
|
|
||
|
uint32_t ETH_MAC_BackOffLimit; /*!< Set the BackOff limit value, detailed in @ref ETH_Back_Off_Limit */
|
||
|
|
||
|
uint32_t ETH_MAC_DeferralCheck; /*!< Enable or disable the deferral check function only in Half-Duplex mode
|
||
|
detailed in @ref ETH_Deferral_Check */
|
||
|
|
||
|
uint32_t ETH_MAC_FilterDisable; /*!< Enable or disable the MAC filter, detailed in @ref ETH_Filter_Disable */
|
||
|
|
||
|
uint32_t ETH_MAC_SourceAddrFilter; /*!< Set the SA Filter mode, detailed in @ref ETH_Source_Addr_Filter */
|
||
|
|
||
|
uint32_t ETH_MAC_PassControlFrames; /*!< Set the mode of the control frames (including unicast and multicast PAUSE frames)
|
||
|
detailed in @ref ETH_Pass_Control_Frames */
|
||
|
|
||
|
uint32_t ETH_MAC_BroadcastFramesReception; /*!< Enable or disable the reception of Broadcast Frames
|
||
|
detailed in @ref ETH_Broadcast_Frames_Reception */
|
||
|
|
||
|
uint32_t ETH_MAC_DestinationAddrFilter; /*!< Set the DA filter mode, detailed in @ref ETH_Destination_Addr_Filter */
|
||
|
|
||
|
uint32_t ETH_MAC_PromiscuousMode; /*!< Enable or disable the Promiscuous Mode
|
||
|
detailed in @ref ETH_Promiscuous_Mode */
|
||
|
|
||
|
uint32_t ETH_MAC_MulticastFramesFilter; /*!< Set the Multicast Frames filter mode
|
||
|
detailed in @ref ETH_Multicast_Frames_Filter */
|
||
|
|
||
|
uint32_t ETH_MAC_UnicastFramesFilter; /*!< Set the Unicast Frames filter mode
|
||
|
detailed in @ref ETH_Unicast_Frames_Filter */
|
||
|
|
||
|
uint32_t ETH_MAC_HashListHigh; /*!< Hash list higher 32 bits */
|
||
|
|
||
|
uint32_t ETH_MAC_HashListLow; /*!< Hash list lower 32 bits */
|
||
|
|
||
|
uint32_t ETH_MAC_PauseTime; /*!< Set the Pause Time field value in the transmit control frame */
|
||
|
|
||
|
uint32_t ETH_MAC_ZeroQuantaPause; /*!< Enable or disable the automatic generation of Zero-Quanta Pause Control frames
|
||
|
detailed in @ref ETH_Zero_Quanta_Pause */
|
||
|
|
||
|
uint32_t ETH_MAC_PauseLowThreshold; /*!< Set the threshold of the PAUSE to be checked for
|
||
|
automatic retransmission of PAUSE Frame
|
||
|
detailed in @ref ETH_Pause_Low_Threshold */
|
||
|
|
||
|
uint32_t ETH_MAC_FlowControlDeactiveThreshold;/*!< Set the threshold of the deactive flow control
|
||
|
detailed in @ref ETH_RFD_Threshold */
|
||
|
|
||
|
uint32_t ETH_MAC_FlowControlActiveThreshold; /*!< Set the threshold of the active flow control
|
||
|
detailed in @ref ETH_RFA_Threshold */
|
||
|
|
||
|
uint32_t ETH_MAC_UnicastPauseFrameDetect; /*!< Enable or disable the unicast Pause frames detection
|
||
|
detailed in @ref ETH_Unicast_Pause_Frame_Detect */
|
||
|
|
||
|
uint32_t ETH_MAC_ReceiveFlowControl; /*!< Enable or disable the MAC to received Pause frame
|
||
|
detailed in @ref ETH_Receive_Flow_Control */
|
||
|
|
||
|
uint32_t ETH_MAC_TransmitFlowControl; /*!< Enable or disable the MAC to transmit Pause frames in Full-Duplex mode
|
||
|
or back-pressure operation in Half-Duplex mode
|
||
|
detailed in @ref ETH_Transmit_Flow_Control */
|
||
|
|
||
|
uint32_t ETH_MAC_VLANTagComparison; /*!< Set VLAN tag comparison and filtering mode
|
||
|
detailed in @ref ETH_VLAN_Tag_Comparison */
|
||
|
|
||
|
uint32_t ETH_MAC_VLANTagIdentifier; /*!< Set VLAN tag identifier for receive frames */
|
||
|
|
||
|
/**
|
||
|
* @brief / * DMA
|
||
|
*/
|
||
|
|
||
|
uint32_t ETH_DMA_DropTCPIPChecksumErrorFrame; /*!< Enable or disable the TCP/IP Checksum Error Frames drop
|
||
|
detailed in @ref ETH_Drop_TCP_IP_Checksum_Error_Frame */
|
||
|
|
||
|
uint32_t ETH_DMA_ReceiveStoreForward; /*!< Set the Rx FIFO operation mode
|
||
|
detailed in @ref ETH_Receive_Store_Forward */
|
||
|
|
||
|
uint32_t ETH_DMA_FlushReceivedFrame; /*!< Enable or disable the flushing Receive FIFO
|
||
|
detailed in @ref ETH_Flush_Received_Frame */
|
||
|
|
||
|
uint32_t ETH_DMA_TransmitStoreForward; /*!< Enable or disable Tx FIFO operation mode
|
||
|
detailed in @ref ETH_Transmit_Store_Forward */
|
||
|
|
||
|
uint32_t ETH_DMA_TransmitThresholdControl; /*!< Enable or disable the Transmit Threshold Control and set the level
|
||
|
detailed in @ref ETH_Transmit_Threshold_Control */
|
||
|
|
||
|
uint32_t ETH_DMA_ForwardErrorFrames; /*!< Enable or disable receive the erroneous frames to the DMA
|
||
|
detailed in @ref ETH_Forward_Error_Frames */
|
||
|
|
||
|
uint32_t ETH_DMA_ForwardUndersizedGoodFrames; /*!< Enable or disable receive the Undersized frames with no Error
|
||
|
and length less than 64 bytes including pad-bytes and CRC to the DMA
|
||
|
detailed in @ref ETH_Forward_Undersized_Good_Frames */
|
||
|
|
||
|
uint32_t ETH_DMA_ReceiveThresholdControl; /*!< Enable or disable the Receive Threshold Control and set the level
|
||
|
detailed in @ref ETH_Receive_Threshold_Control */
|
||
|
|
||
|
uint32_t ETH_DMA_SecondFrameOperate; /*!< Enable or disable the Operate on second frame mode
|
||
|
detailed in @ref ETH_Second_Frame_Operate */
|
||
|
|
||
|
uint32_t ETH_DMA_AddressAligned; /*!< Enable or disable the Address Aligned
|
||
|
detailed in @ref ETH_Address_Aligned */
|
||
|
|
||
|
uint32_t ETH_DMA_FixedBurst; /*!< Enable or disable the AHB Master interface fixed burst transfers
|
||
|
detailed in @ref ETH_Fixed_Burst */
|
||
|
|
||
|
uint32_t ETH_DMA_RxDMABurstLength; /*!< Set the maximum number of beats to be transferred in one Rx DMA transaction
|
||
|
detailed in @ref ETH_Rx_DMA_Burst_Length */
|
||
|
|
||
|
uint32_t ETH_DMA_TxDMABurstLength; /*!< Set the maximum number of beats to be transferred in one Tx DMA transaction
|
||
|
detailed in @ref ETH_Tx_DMA_Burst_Length */
|
||
|
|
||
|
uint32_t ETH_DMA_DescriptorSkipLength; /*!< Set the number of word to skip between two descriptors only in Ring mode */
|
||
|
|
||
|
uint32_t ETH_DMA_Arbitration; /*!< Set the DMA Tx/Rx priority ratio
|
||
|
detailed in @ref ETH_DMA_Arbitration */
|
||
|
} ETH_InitPara;
|
||
|
|
||
|
/**
|
||
|
* @brief ETH DMA Desciptors structure def
|
||
|
*/
|
||
|
typedef struct {
|
||
|
uint32_t Status; /*!< Status */
|
||
|
uint32_t ControlBufferSize; /*!< Control and Buffer1, Buffer2 lengths */
|
||
|
uint32_t Buffer1Addr; /*!< Buffer1 address pointer */
|
||
|
uint32_t Buffer2NextDescAddr; /*!< Buffer2 or next descriptor address pointer */
|
||
|
} ETH_DMADESCTypeDef;
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Exported_Constants
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_delay_Def
|
||
|
* @{
|
||
|
*/
|
||
|
/* #define USE_Delay */
|
||
|
|
||
|
#ifdef USE_Delay
|
||
|
#define _eth_delay_ Delay /*!< User can provide more timing precise _eth_delay_ function */
|
||
|
#else
|
||
|
#define _eth_delay_ ETH_Delay /*!< Default _eth_delay_ function with less precise timing */
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Buffer_Def
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAX_FRAME_SIZE 1520 /*!< FRAME_HEADER + FRAME_EXTRA + MAX_FRAME_PAYLOAD + FRAME_CRC */
|
||
|
#define ETH_HEADER 14 /*!< 6 byte DA, 6 byte SA, 2 byte length/type */
|
||
|
#define ETH_CRC 4 /*!< 4 byte CRC */
|
||
|
#define ETH_EXTRA 2 /*!< Extra bytes in some cases */
|
||
|
#define VLAN_TAG 4 /*!< optional 802.1q VLAN Tag */
|
||
|
#define MIN_ETH_DATALENGTH 46 /*!< Minimum Eth payload byte */
|
||
|
#define MAX_ETH_DATALENGTH 1500 /*!< Maximum Eth payload byte */
|
||
|
#define JUMBO_FRAME_DATALENGTH 9000 /*!< Jumbo frame payload byte */
|
||
|
|
||
|
/**
|
||
|
DMA Tx Desciptor
|
||
|
-----------------------------------------------------------------------------------------------
|
||
|
TDES0 | BUSY(31) | CTRL[30:26] | Reserved[25:24] | CTRL[23:20] | Reserved[19:17] | Status[16:0] |
|
||
|
-----------------------------------------------------------------------------------------------
|
||
|
TDES1 | Reserved[31:29] | Buffer2 ByteCount[28:16] | Reserved[15:13] | Buffer1 ByteCount[12:0] |
|
||
|
-----------------------------------------------------------------------------------------------
|
||
|
TDES2 | Buffer1 Address [31:0] |
|
||
|
-----------------------------------------------------------------------------------------------
|
||
|
TDES3 | Buffer2 Address [31:0] / Next Desciptor Address [31:0] |
|
||
|
-----------------------------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Tx descriptor TDES0 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_BUSY ((uint32_t)0x80000000) /*!< DMA or CPU control descriptor*/
|
||
|
#define ETH_DMATXDESC_INTC ((uint32_t)0x40000000) /*!< Interrupt on Completion */
|
||
|
#define ETH_DMATXDESC_LSG ((uint32_t)0x20000000) /*!< contains the last segment of the frame */
|
||
|
#define ETH_DMATXDESC_FSG ((uint32_t)0x10000000) /*!< contains the first segment of the frame */
|
||
|
#define ETH_DMATXDESC_DCRC ((uint32_t)0x08000000) /*!< Disable CRC */
|
||
|
#define ETH_DMATXDESC_DPAD ((uint32_t)0x04000000) /*!< Disable Pad */
|
||
|
#define ETH_DMATXDESC_TTSEN ((uint32_t)0x02000000) /*!< Transmit Time Stamp Enable */
|
||
|
#define ETH_DMATXDESC_CM ((uint32_t)0x00C00000) /*!< Checksum Mode: 4 cases */
|
||
|
#define ETH_DMATXDESC_CM_DISABLE ((uint32_t)0x00000000) /*!< Checksum Insertion disabled */
|
||
|
#define ETH_DMATXDESC_CM_IPV4HEADER ((uint32_t)0x00400000) /*!< Only IP header checksum calculation and insertion are enabled */
|
||
|
#define ETH_DMATXDESC_CM_TCPUDPICMP_SEGMENT ((uint32_t)0x00800000) /*!< TCP/UDP/ICMP Checksum Insertion calculated but pseudo-header */
|
||
|
#define ETH_DMATXDESC_CM_TCPUDPICMP_FULL ((uint32_t)0x00C00000) /*!< TCP/UDP/ICMP Checksum Insertion fully calculated */
|
||
|
#define ETH_DMATXDESC_TERM ((uint32_t)0x00200000) /*!< Transmit End of Ring Mode*/
|
||
|
#define ETH_DMATXDESC_TCHM ((uint32_t)0x00100000) /*!< Transmit des Chained Mode*/
|
||
|
#define ETH_DMATXDESC_TTMSS ((uint32_t)0x00020000) /*!< Tx Time Stamp Status */
|
||
|
#define ETH_DMATXDESC_IPHE ((uint32_t)0x00010000) /*!< IP Header Error: IP4 or IP6*/
|
||
|
#define ETH_DMATXDESC_ES ((uint32_t)0x00008000) /*!< Error summary */
|
||
|
#define ETH_DMATXDESC_JT ((uint32_t)0x00004000) /*!< Jabber Timeout */
|
||
|
#define ETH_DMATXDESC_FRMF ((uint32_t)0x00002000) /*!< clean FIFO */
|
||
|
#define ETH_DMATXDESC_IPPE ((uint32_t)0x00001000) /*!< IP Payload Error */
|
||
|
#define ETH_DMATXDESC_LCA ((uint32_t)0x00000800) /*!< Loss of Carrier */
|
||
|
#define ETH_DMATXDESC_NCA ((uint32_t)0x00000400) /*!< No Carrier */
|
||
|
#define ETH_DMATXDESC_LCO ((uint32_t)0x00000200) /*!< Late Collision */
|
||
|
#define ETH_DMATXDESC_ECO ((uint32_t)0x00000100) /*!< abort transmission due to collision */
|
||
|
#define ETH_DMATXDESC_VFRM ((uint32_t)0x00000080) /*!< VLAN Frame */
|
||
|
#define ETH_DMATXDESC_COCNT ((uint32_t)0x00000078) /*!< Collision Count */
|
||
|
#define ETH_DMATXDESC_EXD ((uint32_t)0x00000004) /*!< Excessive Deferral */
|
||
|
#define ETH_DMATXDESC_UFE ((uint32_t)0x00000002) /*!< late data arrival from the memory */
|
||
|
#define ETH_DMATXDESC_DB ((uint32_t)0x00000001) /*!< Deferred Bit */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Tx descriptor TDES1 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_TB2S ((uint32_t)0x1FFF0000) /*!< Transmit Buffer2 Size */
|
||
|
#define ETH_DMATXDESC_TB1S ((uint32_t)0x00001FFF) /*!< Transmit Buffer1 Size */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Tx descriptor TDES2 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_TB1AP ((uint32_t)0xFFFFFFFF) /*!< Buffer1 Address Pointer */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Tx descriptor TDES3 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_TB2AP ((uint32_t)0xFFFFFFFF) /*!< Buffer2 Address Pointer */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup DMA_Rx_descriptor
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
DMA Rx Desciptor
|
||
|
--------------------------------------------------------------------------------------------------------------------
|
||
|
RDES0 | BUSY(31) | Status [30:0] |
|
||
|
---------------------------------------------------------------------------------------------------------------------
|
||
|
RDES1 | CTRL(31) | Reserved[30:29] | Buffer2 ByteCount[28:16] | CTRL[15:14] | Reserved(13) | Buffer1 ByteCount[12:0] |
|
||
|
---------------------------------------------------------------------------------------------------------------------
|
||
|
RDES2 | Buffer1 Address [31:0] |
|
||
|
---------------------------------------------------------------------------------------------------------------------
|
||
|
RDES3 | Buffer2 Address [31:0] / Next Desciptor Address [31:0] |
|
||
|
---------------------------------------------------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Rx descriptor RDES0 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMARXDESC_BUSY ((uint32_t)0x80000000) /*!< DMA or CPU control descriptor */
|
||
|
#define ETH_DMARXDESC_DAFF ((uint32_t)0x40000000) /*!< DA filter fail */
|
||
|
#define ETH_DMARXDESC_FRML ((uint32_t)0x3FFF0000) /*!< Frame length */
|
||
|
#define ETH_DMARXDESC_ERRS ((uint32_t)0x00008000) /*!< Error summary */
|
||
|
#define ETH_DMARXDESC_DERR ((uint32_t)0x00004000) /*!< no more descriptors for receive frame */
|
||
|
#define ETH_DMARXDESC_SAFF ((uint32_t)0x00002000) /*!< SA filter fail */
|
||
|
#define ETH_DMARXDESC_LERR ((uint32_t)0x00001000) /*!< Frame size not matching with length field */
|
||
|
#define ETH_DMARXDESC_OERR ((uint32_t)0x00000800) /*!< FIFO Overflow Error */
|
||
|
#define ETH_DMARXDESC_VTAG ((uint32_t)0x00000400) /*!< VLAN Tag: a VLAN frame tag */
|
||
|
#define ETH_DMARXDESC_FDES ((uint32_t)0x00000200) /*!< First descriptor of the frame */
|
||
|
#define ETH_DMARXDESC_LDES ((uint32_t)0x00000100) /*!< Last descriptor of the frame */
|
||
|
#define ETH_DMARXDESC_IPHCERR ((uint32_t)0x00000080) /*!< IPC Checksum Error: Rx Ipv4 or Ipv6 header checksum error */
|
||
|
#define ETH_DMARXDESC_LCO ((uint32_t)0x00000040) /*!< Late collision occurred during reception */
|
||
|
#define ETH_DMARXDESC_FRMT ((uint32_t)0x00000020) /*!< Frame type */
|
||
|
#define ETH_DMARXDESC_RWDT ((uint32_t)0x00000010) /*!< Receive WD Timeout */
|
||
|
#define ETH_DMARXDESC_RERR ((uint32_t)0x00000008) /*!< the RX_ERR signal is asserted while RX_DV is asserted during frame reception */
|
||
|
#define ETH_DMARXDESC_DBERR ((uint32_t)0x00000004) /*!< received frame has a non int multiple of bytes */
|
||
|
#define ETH_DMARXDESC_CERR ((uint32_t)0x00000002) /*!< CRC error */
|
||
|
#define ETH_DMARXDESC_PCERR ((uint32_t)0x00000001) /*!< Receive MAC address matched/ Receive Payload Checksum Error */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Rx descriptor RDES1 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMARXDESC_DINTC ((uint32_t)0x80000000) /*!< Disable Interrupt on Completion */
|
||
|
#define ETH_DMARXDESC_RB2S ((uint32_t)0x1FFF0000) /*!< Receive Buffer2 Size */
|
||
|
#define ETH_DMARXDESC_RERM ((uint32_t)0x00008000) /*!< Receive End of Ring mode*/
|
||
|
#define ETH_DMARXDESC_RCHM ((uint32_t)0x00004000) /*!< Receive des Chained mode */
|
||
|
#define ETH_DMARXDESC_RB1S ((uint32_t)0x00001FFF) /*!< Receive Buffer1 Size */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Rx descriptor RDES2 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMARXDESC_RB1AP ((uint32_t)0xFFFFFFFF) /*!< Buffer1 Address Pointer */
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Rx descriptor RDES3 register Bit def
|
||
|
*/
|
||
|
#define ETH_DMARXDESC_RB2AP ((uint32_t)0xFFFFFFFF) /*!< Buffer2 Address Pointer */
|
||
|
|
||
|
#ifndef _PHY_H_
|
||
|
#define DP83848 0
|
||
|
#define LAN8700 1
|
||
|
#define PHY_TYPE DP83848
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_Read_write_Timeouts
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_READ_TO ((uint32_t)0x0004FFFF)
|
||
|
#define PHY_WRITE_TO ((uint32_t)0x0004FFFF)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_Reset_Delay
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_RESETDELAY ((uint32_t)0x000FFFFF)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_Config_Delay
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_CONFIGDELAY ((uint32_t)0x00FFFFFF)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_Register_address
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_BCR 0 /*!< Tranceiver Basic Control Register */
|
||
|
#define PHY_BSR 1 /*!< Tranceiver Basic Status Register */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_basic_Control_register
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_RESET ((u16)0x8000) /*!< PHY Reset */
|
||
|
#define PHY_LOOPBACK ((u16)0x4000) /*!< Enable loop-back mode */
|
||
|
#define PHY_FULLDUPLEX_100M ((u16)0x2100) /*!< Configure speed to 100 Mb/s and the full-duplex mode */
|
||
|
#define PHY_HALFDUPLEX_100M ((u16)0x2000) /*!< Configure speed to 100 Mb/s and the half-duplex mode */
|
||
|
#define PHY_FULLDUPLEX_10M ((u16)0x0100) /*!< Configure speed to 10 Mb/s and the full-duplex mode */
|
||
|
#define PHY_HALFDUPLEX_10M ((u16)0x0000) /*!< Configure speed to 10 Mb/s and the half-duplex mode */
|
||
|
#define PHY_AUTONEGOTIATION ((u16)0x1000) /*!< Enable auto-negotiation function */
|
||
|
#define PHY_RESTART_AUTONEGOTIATION ((u16)0x0200) /*!< Restart auto-negotiation function */
|
||
|
#define PHY_POWERDOWN ((u16)0x0800) /*!< Enable the power down mode */
|
||
|
#define PHY_ISOLATE ((u16)0x0400) /*!< Isolate PHY from MII */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_basic_status_register
|
||
|
* @{
|
||
|
*/
|
||
|
#define PHY_AUTONEGO_COMPLETE ((u16)0x0020) /*!< Auto-Negotioation process completed */
|
||
|
#define PHY_LINKED_STATUS ((u16)0x0004) /*!< Valid link established */
|
||
|
#define PHY_JABBER_DETECTION ((u16)0x0002) /*!< Jabber condition detected */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup PHY_status_register
|
||
|
* @{
|
||
|
*/
|
||
|
/* The PHY status register value change with PHY in different Manufacturer
|
||
|
so the user can use external PHY lib to update this value if PHY types user selected not included in firmware */
|
||
|
#if(PHY_TYPE == LAN8700)
|
||
|
/**
|
||
|
* @brief For LAN8700
|
||
|
*/
|
||
|
#define PHY_SR 31 /*!< Tranceiver Status Register */
|
||
|
/* The Speed and Duplex mask values change with PHY in different Manufacturer
|
||
|
so the user can use external PHY lib to update this value if PHY types user selected not included in firmware */
|
||
|
#define PHY_Speed_Status ((u16)0x0004) /*!< Configured information of Speed: 10Mbps */
|
||
|
#define PHY_DUPLEX_STATUS ((u16)0x0010) /*!< Configured information of Duplex: Full-duplex */
|
||
|
|
||
|
#elif(PHY_TYPE == DP83848)
|
||
|
/**
|
||
|
* @brief For DP83848
|
||
|
*/
|
||
|
#define PHY_SR 16 /*!< Tranceiver Status Register */
|
||
|
/* The Speed and Duplex mask values change with PHY in different Manufacturer
|
||
|
so the user can use external PHY lib to update this value if PHY types user selected not included in firmware */
|
||
|
#define PHY_SPEED_STATUS ((u16)0x0002) /*!< Configured information of Speed: 10Mbps */
|
||
|
#define PHY_DUPLEX_STATUS ((u16)0x0004) /*!< Configured information of Duplex: Full-duplex */
|
||
|
|
||
|
#define PHY_Reset PHY_RESETDELAY
|
||
|
#define PHY_ResetDelay PHY_RESETDELAY
|
||
|
#define PHY_Speed_Status PHY_SPEED_STATUS
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#endif
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_AutoNegotiation
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_AUTONEGOTIATION_ENABLE ((uint32_t)0x00000001)
|
||
|
#define ETH_AUTONEGOTIATION_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_watchdog
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_WATCHDOG_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_WATCHDOG_DISABLE ((uint32_t)0x00800000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Jabber
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_JABBER_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_JABBER_DISABLE ((uint32_t)0x00400000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Inter_Frame_Gap
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_INTERFRAMEGAP_96BIT ((uint32_t)0x00000000)
|
||
|
#define ETH_INTERFRAMEGAP_88BIT ((uint32_t)0x00020000)
|
||
|
#define ETH_INTERFRAMEGAP_80BIT ((uint32_t)0x00040000)
|
||
|
#define ETH_INTERFRAMEGAP_72BIT ((uint32_t)0x00060000)
|
||
|
#define ETH_INTERFRAMEGAP_64BIT ((uint32_t)0x00080000)
|
||
|
#define ETH_INTERFRAMEGAP_56BIT ((uint32_t)0x000A0000)
|
||
|
#define ETH_INTERFRAMEGAP_48BIT ((uint32_t)0x000C0000)
|
||
|
#define ETH_INTERFRAMEGAP_40BIT ((uint32_t)0x000E0000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Carrier_Sense
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_CARRIERSENSE_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_CARRIERSENSE_DISABLE ((uint32_t)0x00010000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Speed
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_SPEEDMODE_10M ((uint32_t)0x00000000)
|
||
|
#define ETH_SPEEDMODE_100M ((uint32_t)0x00004000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Receive_Own
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RECEIVEOWN_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_RECEIVEOWN_DISABLE ((uint32_t)0x00002000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Loop_Back_Mode
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_LOOPBACKMODE_ENABLE ((uint32_t)0x00001000)
|
||
|
#define ETH_LOOPBACKMODE_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Duplex_Mode
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MODE_FULLDUPLEX ((uint32_t)0x00000800)
|
||
|
#define ETH_MODE_HALFDUPLEX ((uint32_t)0x00000000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Checksum_Offload
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_CHECKSUMOFFLOAD_ENABLE ((uint32_t)0x00000400)
|
||
|
#define ETH_CHECKSUMOFFLOAD_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Retry_Transmission
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RETRYTRANSMISSION_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_RETRYTRANSMISSION_DISABLE ((uint32_t)0x00000200)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Automatic_Pad_CRC_Drop
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_AUTOMATICPADCRCDROP_ENABLE ((uint32_t)0x00000080)
|
||
|
#define ETH_AUTOMATICPADCRCDROP_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Back_Off_Limit
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_BACKOFFLIMIT_10 ((uint32_t)0x00000000)
|
||
|
#define ETH_BACKOFFLIMIT_8 ((uint32_t)0x00000020)
|
||
|
#define ETH_BACKOFFLIMIT_4 ((uint32_t)0x00000040)
|
||
|
#define ETH_BACKOFFLIMIT_1 ((uint32_t)0x00000060)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Deferral_Check
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DEFERRALCHECK_ENABLE ((uint32_t)0x00000010)
|
||
|
#define ETH_DEFERRALCHECK_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Filter_Disable
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_FILTERDISABLE_ENABLE ((uint32_t)0x80000000)
|
||
|
#define ETH_FILTERDISABLE_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Source_Addr_Filter
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_SOURCEADDRFILTER_NORMAL_ENABLE ((uint32_t)0x00000200)
|
||
|
#define ETH_SOURCEADDRFILTER_INVERSE_ENABLE ((uint32_t)0x00000300)
|
||
|
#define ETH_SOURCEADDRFILTER_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Pass_Control_Frames
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PASSCONTROLFRAMES_BLOCKALL ((uint32_t)0x00000040)
|
||
|
#define ETH_PASSCONTROLFRAMES_FORWARDALL ((uint32_t)0x00000080)
|
||
|
#define ETH_PASSCONTROLFRAMES_FORWARDPASSEDADDRFILTER ((uint32_t)0x000000C0)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Broadcast_Frames_Reception
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_BROADCASTFRAMESRECEPTION_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_BROADCASTFRAMESRECEPTION_DISABLE ((uint32_t)0x00000020)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Destination_Addr_Filter
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DESTINATIONADDRFILTER_NORMAL ((uint32_t)0x00000000)
|
||
|
#define ETH_DESTINATIONADDRFILTER_INVERSE ((uint32_t)0x00000008)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Promiscuous_Mode
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PROMISCUOUSMODE_ENABLE ((uint32_t)0x00000001)
|
||
|
#define ETH_PROMISCUOUSMODE_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Multicast_Frames_Filter
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MULTICASTFRAMESFILTER_PERFECTHASHTABLE ((uint32_t)0x00000404)
|
||
|
#define ETH_MULTICASTFRAMESFILTER_HASHTABLE ((uint32_t)0x00000004)
|
||
|
#define ETH_MULTICASTFRAMESFILTER_PERFECT ((uint32_t)0x00000000)
|
||
|
#define ETH_MULTICASTFRAMESFILTER_NONE ((uint32_t)0x00000010)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Unicast_Frames_Filter
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_UNICASTFRAMESFILTER_PERFECTHASHTABLE ((uint32_t)0x00000402)
|
||
|
#define ETH_UNICASTFRAMESFILTER_HASHTABLE ((uint32_t)0x00000002)
|
||
|
#define ETH_UNICASTFRAMESFILTER_PERFECT ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup ETH_Zero_Quanta_Pause
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_ZEROQUANTAPAUSE_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_ZEROQUANTAPAUSE_DISABLE ((uint32_t)0x00000080)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Pause_Low_Threshold
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PAUSELOWTHRESHOLD_MINUS4 ((uint32_t)0x00000000)
|
||
|
#define ETH_PAUSELOWTHRESHOLD_MINUS28 ((uint32_t)0x00000010)
|
||
|
#define ETH_PAUSELOWTHRESHOLD_MINUS144 ((uint32_t)0x00000020)
|
||
|
#define ETH_PAUSELOWTHRESHOLD_MINUS256 ((uint32_t)0x00000030)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_RFD_Threshold
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RFD_256BYTES ((uint32_t)0x00000000)
|
||
|
#define ETH_RFD_512BYTES ((uint32_t)0x00000010)
|
||
|
#define ETH_RFD_768BYTES ((uint32_t)0x00000020)
|
||
|
#define ETH_RFD_1024BYTES ((uint32_t)0x00000030)
|
||
|
#define ETH_RFD_1280BYTES ((uint32_t)0x00000040)
|
||
|
#define ETH_RFD_1536BYTES ((uint32_t)0x00000050)
|
||
|
#define ETH_RFD_1792BYTES ((uint32_t)0x00000060)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_RFA_Threshold
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RFA_256BYTES ((uint32_t)0x00000000)
|
||
|
#define ETH_RFA_512BYTES ((uint32_t)0x00000001)
|
||
|
#define ETH_RFA_768BYTES ((uint32_t)0x00000002)
|
||
|
#define ETH_RFA_1024BYTES ((uint32_t)0x00000003)
|
||
|
#define ETH_RFA_1280BYTES ((uint32_t)0x00000004)
|
||
|
#define ETH_RFA_1536BYTES ((uint32_t)0x00000005)
|
||
|
#define ETH_RFA_1792BYTES ((uint32_t)0x00000006)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Unicast_Pause_Frame_Detect
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_UNICASTPAUSEFRAMEDETECT_ENABLE ((uint32_t)0x00000008)
|
||
|
#define ETH_UNICASTPAUSEFRAMEDETECT_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Receive_Flow_Control
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RECEIVEFLOWCONTROL_ENABLE ((uint32_t)0x00000004)
|
||
|
#define ETH_RECEIVEFLOWCONTROL_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Transmit_Flow_Control
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_TRANSMITFLOWCONTROL_ENABLE ((uint32_t)0x00000002)
|
||
|
#define ETH_TRANSMITFLOWCONTROL_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_VLAN_Tag_Comparison
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_VLANTAGCOMPARISON_12BIT ((uint32_t)0x00010000)
|
||
|
#define ETH_VLANTAGCOMPARISON_16BIT ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MAC_Flags
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAC_FLAG_TST ((uint32_t)0x00000200) /*!< Time stamp trigger flag (on MAC) */
|
||
|
#define ETH_MAC_FLAG_MSCT ((uint32_t)0x00000040) /*!< MSC transmit flag */
|
||
|
#define ETH_MAC_FLAG_MSCR ((uint32_t)0x00000020) /*!< MSC receive flag */
|
||
|
#define ETH_MAC_FLAG_MSC ((uint32_t)0x00000010)
|
||
|
#define ETH_MAC_FLAG_WUM ((uint32_t)0x00000008)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MAC_Interrupts
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAC_INT_TST ((uint32_t)0x00000200) /*!< Time stamp trigger interrupt (on MAC) */
|
||
|
#define ETH_MAC_INT_MSCT ((uint32_t)0x00000040) /*!< MSC transmit interrupt */
|
||
|
#define ETH_MAC_INT_MSCR ((uint32_t)0x00000020) /*!< MSC receive interrupt */
|
||
|
#define ETH_MAC_INT_MSC ((uint32_t)0x00000010)
|
||
|
#define ETH_MAC_INT_WUM ((uint32_t)0x00000008)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MAC_addresses
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAC_ADDRESS0 ((uint32_t)0x00000000)
|
||
|
#define ETH_MAC_ADDRESS1 ((uint32_t)0x00000008)
|
||
|
#define ETH_MAC_ADDRESS2 ((uint32_t)0x00000010)
|
||
|
#define ETH_MAC_ADDRESS3 ((uint32_t)0x00000018)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MAC_addresses_filter_SA_DA_filed_of_received_frames
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAC_ADDRESSFILTER_SA ((uint32_t)0x00000000)
|
||
|
#define ETH_MAC_ADDRESSFILTER_DA ((uint32_t)0x00000008)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MAC_addresses_filter_Mask_bytes
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE6 ((uint32_t)0x20000000) /*!< Mask MAC Address high reg bits [15:8] */
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE5 ((uint32_t)0x10000000) /*!< Mask MAC Address high reg bits [7:0] */
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE4 ((uint32_t)0x08000000) /*!< Mask MAC Address low reg bits [31:24] */
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE3 ((uint32_t)0x04000000) /*!< Mask MAC Address low reg bits [23:16] */
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE2 ((uint32_t)0x02000000) /*!< Mask MAC Address low reg bits [15:8] */
|
||
|
#define ETH_MAC_ADDRESSMASK_BYTE1 ((uint32_t)0x01000000) /*!< Mask MAC Address low reg bits [7:0] */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup ETH_DMA_Tx_descriptor_segment
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_LASTSEGMENT ((uint32_t)0x40000000)
|
||
|
#define ETH_DMATXDESC_FIRSTSEGMENT ((uint32_t)0x20000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_Tx_descriptor_Checksum_Insertion_Control
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMATXDESC_CHECKSUMDISABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_DMATXDESC_CHECKSUMIPV4HEADER ((uint32_t)0x00400000)
|
||
|
#define ETH_DMATXDESC_CHECKSUMTCPUDPICMPSEGMENT ((uint32_t)0x00800000)
|
||
|
#define ETH_DMATXDESC_CHECKSUMTCPUDPICMPFULL ((uint32_t)0x00C00000)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_Rx_descriptor_buffers_
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMARXDESC_BUFFER1 ((uint32_t)0x00000000)
|
||
|
#define ETH_DMARXDESC_BUFFER2 ((uint32_t)0x00000001)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Drop_TCP_IP_Checksum_Error_Frame
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DROPTCPIPCHECKSUMERRORFRAME_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_DROPTCPIPCHECKSUMERRORFRAME_DISABLE ((uint32_t)0x04000000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Receive_Store_Forward
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RECEIVESTOREFORWARD_ENABLE ((uint32_t)0x02000000)
|
||
|
#define ETH_RECEIVESTOREFORWARD_DISABLE ((uint32_t)0x00000000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Flush_Received_Frame
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_FLUSHRECEIVEDFRAME_ENABLE ((uint32_t)0x00000000)
|
||
|
#define ETH_FLUSHRECEIVEDFRAME_DISABLE ((uint32_t)0x01000000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Transmit_Store_Forward
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_TRANSMITSTOREFORWARD_ENABLE ((uint32_t)0x00200000)
|
||
|
#define ETH_TRANSMITSTOREFORWARD_DISABLE ((uint32_t)0x00000000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Transmit_Threshold_Control
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_64BYTES ((uint32_t)0x00000000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_128BYTES ((uint32_t)0x00004000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_192BYTES ((uint32_t)0x00008000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_256BYTES ((uint32_t)0x0000C000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_40BYTES ((uint32_t)0x00010000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_32BYTES ((uint32_t)0x00014000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_24BYTES ((uint32_t)0x00018000)
|
||
|
#define ETH_TRANSMITTHRESHOLDCONTROL_16BYTES ((uint32_t)0x0001C000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Forward_Error_Frames
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_FORWARDERRORFRAMES_ENABLE ((uint32_t)0x00000080)
|
||
|
#define ETH_FORWARDERRORFRAMES_DISABLE ((uint32_t)0x00000000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Forward_Undersized_Good_Frames
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_FORWARDUNDERSIZEDGOODFRAMES_ENABLE ((uint32_t)0x00000040)
|
||
|
#define ETH_FORWARDUNDERSIZEDGOODFRAMES_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Receive_Threshold_Control
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RECEIVETHRESHOLDCONTROL_64BYTES ((uint32_t)0x00000000)
|
||
|
#define ETH_RECEIVETHRESHOLDCONTROL_32BYTES ((uint32_t)0x00000008)
|
||
|
#define ETH_RECEIVETHRESHOLDCONTROL_96BYTES ((uint32_t)0x00000010)
|
||
|
#define ETH_RECEIVETHRESHOLDCONTROL_128BYTES ((uint32_t)0x00000018)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Second_Frame_Operate
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_SECONDFRAMEOPERATE_ENABLE ((uint32_t)0x00000004)
|
||
|
#define ETH_SECONDFRAMEOPERATE_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Address_Aligned
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_ADDRESSALIGNED_ENABLE ((uint32_t)0x02000000)
|
||
|
#define ETH_ADDRESSALIGNED_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Fixed_Burst
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_FIXEDBURST_ENABLE ((uint32_t)0x00010000)
|
||
|
#define ETH_FIXEDBURST_DISABLE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Rx_DMA_Burst_Length
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_RXDMABURSTLENGTH_1BEAT ((uint32_t)0x00020000)
|
||
|
#define ETH_RXDMABURSTLENGTH_2BEAT ((uint32_t)0x00040000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4BEAT ((uint32_t)0x00080000)
|
||
|
#define ETH_RXDMABURSTLENGTH_8BEAT ((uint32_t)0x00100000)
|
||
|
#define ETH_RXDMABURSTLENGTH_16BEAT ((uint32_t)0x00200000)
|
||
|
#define ETH_RXDMABURSTLENGTH_32BEAT ((uint32_t)0x00400000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_4BEAT ((uint32_t)0x01020000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_8BEAT ((uint32_t)0x01040000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_16BEAT ((uint32_t)0x01080000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_32BEAT ((uint32_t)0x01100000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_64BEAT ((uint32_t)0x01200000)
|
||
|
#define ETH_RXDMABURSTLENGTH_4XPBL_128BEAT ((uint32_t)0x01400000)
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_Tx_DMA_Burst_Length
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_TXDMABURSTLENGTH_1BEAT ((uint32_t)0x00000100)
|
||
|
#define ETH_TXDMABURSTLENGTH_2BEAT ((uint32_t)0x00000200)
|
||
|
#define ETH_TXDMABURSTLENGTH_4BEAT ((uint32_t)0x00000400)
|
||
|
#define ETH_TXDMABURSTLENGTH_8BEAT ((uint32_t)0x00000800)
|
||
|
#define ETH_TXDMABURSTLENGTH_16BEAT ((uint32_t)0x00001000)
|
||
|
#define ETH_TXDMABURSTLENGTH_32BEAT ((uint32_t)0x00002000)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_4BEAT ((uint32_t)0x01000100)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_8BEAT ((uint32_t)0x01000200)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_16BEAT ((uint32_t)0x01000400)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_32BEAT ((uint32_t)0x01000800)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_64BEAT ((uint32_t)0x01001000)
|
||
|
#define ETH_TXDMABURSTLENGTH_4XPBL_128BEAT ((uint32_t)0x01002000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_Arbitration
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMAARBITRATION_ROUNDROBIN_RXTX_1_1 ((uint32_t)0x00000000)
|
||
|
#define ETH_DMAARBITRATION_ROUNDROBIN_RXTX_2_1 ((uint32_t)0x00004000)
|
||
|
#define ETH_DMAARBITRATION_ROUNDROBIN_RXTX_3_1 ((uint32_t)0x00008000)
|
||
|
#define ETH_DMAARBITRATION_ROUNDROBIN_RXTX_4_1 ((uint32_t)0x0000C000)
|
||
|
#define ETH_DMAARBITRATION_RXPRIORTX ((uint32_t)0x00000002)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_Flags
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMA_FLAG_TST ((uint32_t)0x20000000) /*!< Time-stamp trigger interrupt (on DMA) */
|
||
|
#define ETH_DMA_FLAG_WUM ((uint32_t)0x10000000) /*!< WUM interrupt (on DMA) */
|
||
|
#define ETH_DMA_FLAG_MSC ((uint32_t)0x08000000) /*!< MSC interrupt (on DMA) */
|
||
|
#define ETH_DMA_FLAG_DATATRANSFERERROR ((uint32_t)0x00800000) /*!< Error bits 0-Rx DMA, 1-Tx DMA */
|
||
|
#define ETH_DMA_FLAG_READWRITEERROR ((uint32_t)0x01000000) /*!< Error bits 0-write trnsf, 1-read transfr */
|
||
|
#define ETH_DMA_FLAG_ACCESSERROR ((uint32_t)0x02000000) /*!< Error bits 0-data buffer, 1-desc. access */
|
||
|
#define ETH_DMA_FLAG_NIS ((uint32_t)0x00010000) /*!< Normal interrupt summary flag */
|
||
|
#define ETH_DMA_FLAG_AIS ((uint32_t)0x00008000) /*!< Abnormal interrupt summary flag */
|
||
|
#define ETH_DMA_FLAG_ER ((uint32_t)0x00004000) /*!< Early receive flag */
|
||
|
#define ETH_DMA_FLAG_FBE ((uint32_t)0x00002000) /*!< Fatal bus error flag */
|
||
|
#define ETH_DMA_FLAG_ET ((uint32_t)0x00000400) /*!< Early transmit flag */
|
||
|
#define ETH_DMA_FLAG_RWT ((uint32_t)0x00000200) /*!< Receive watchdog timeout flag */
|
||
|
#define ETH_DMA_FLAG_RPS ((uint32_t)0x00000100) /*!< Receive process stopped flag */
|
||
|
#define ETH_DMA_FLAG_RBU ((uint32_t)0x00000080) /*!< Receive buffer unavailable flag */
|
||
|
#define ETH_DMA_FLAG_R ((uint32_t)0x00000040) /*!< Receive flag */
|
||
|
#define ETH_DMA_FLAG_TU ((uint32_t)0x00000020) /*!< Transmit Underflow flag */
|
||
|
#define ETH_DMA_FLAG_RO ((uint32_t)0x00000010) /*!< Receive Overflow flag */
|
||
|
#define ETH_DMA_FLAG_TJT ((uint32_t)0x00000008) /*!< Transmit jabber timeout flag */
|
||
|
#define ETH_DMA_FLAG_TBU ((uint32_t)0x00000004) /*!< Transmit buffer unavailable flag */
|
||
|
#define ETH_DMA_FLAG_TPS ((uint32_t)0x00000002) /*!< Transmit process stopped flag */
|
||
|
#define ETH_DMA_FLAG_T ((uint32_t)0x00000001) /*!< Transmit flag */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_Interrupts
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMA_INT_TST ((uint32_t)0x20000000) /*!< Time-stamp trigger interrupt (on DMA) */
|
||
|
#define ETH_DMA_INT_WUM ((uint32_t)0x10000000) /*!< WUM interrupt (on DMA) */
|
||
|
#define ETH_DMA_INT_MSC ((uint32_t)0x08000000) /*!< MSC interrupt (on DMA) */
|
||
|
#define ETH_DMA_INT_NIS ((uint32_t)0x00010000) /*!< Normal interrupt summary */
|
||
|
#define ETH_DMA_INT_AIS ((uint32_t)0x00008000) /*!< Abnormal interrupt summary */
|
||
|
#define ETH_DMA_INT_ER ((uint32_t)0x00004000) /*!< Early receive interrupt */
|
||
|
#define ETH_DMA_INT_FBE ((uint32_t)0x00002000) /*!< Fatal bus error interrupt */
|
||
|
#define ETH_DMA_INT_ET ((uint32_t)0x00000400) /*!< Early transmit interrupt */
|
||
|
#define ETH_DMA_INT_RWT ((uint32_t)0x00000200) /*!< Receive watchdog timeout interrupt */
|
||
|
#define ETH_DMA_INT_RPS ((uint32_t)0x00000100) /*!< Receive process stopped interrupt */
|
||
|
#define ETH_DMA_INT_RBU ((uint32_t)0x00000080) /*!< Receive buffer unavailable interrupt */
|
||
|
#define ETH_DMA_INT_R ((uint32_t)0x00000040) /*!< Receive interrupt */
|
||
|
#define ETH_DMA_INT_TU ((uint32_t)0x00000020) /*!< Transmit Underflow interrupt */
|
||
|
#define ETH_DMA_INT_RO ((uint32_t)0x00000010) /*!< Receive Overflow interrupt */
|
||
|
#define ETH_DMA_INT_TJT ((uint32_t)0x00000008) /*!< Transmit jabber timeout interrupt */
|
||
|
#define ETH_DMA_INT_TBU ((uint32_t)0x00000004) /*!< Transmit buffer unavailable interrupt */
|
||
|
#define ETH_DMA_INT_TPS ((uint32_t)0x00000002) /*!< Transmit process stopped interrupt */
|
||
|
#define ETH_DMA_INT_T ((uint32_t)0x00000001) /*!< Transmit interrupt */
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_transmit_process_state_
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMA_TRANSMITPROCESS_STOPPED ((uint32_t)0x00000000)
|
||
|
#define ETH_DMA_TRANSMITPROCESS_FETCHING ((uint32_t)0x00100000)
|
||
|
#define ETH_DMA_TRANSMITPROCESS_WAITING ((uint32_t)0x00200000)
|
||
|
#define ETH_DMA_TRANSMITPROCESS_READING ((uint32_t)0x00300000)
|
||
|
#define ETH_DMA_TRANSMITPROCESS_SUSPENDED ((uint32_t)0x00600000)
|
||
|
#define ETH_DMA_TRANSMITPROCESS_CLOSING ((uint32_t)0x00700000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup ETH_DMA_receive_process_state_
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMA_RECEIVEPROCESS_STOPPED ((uint32_t)0x00000000)
|
||
|
#define ETH_DMA_RECEIVEPROCESS_FETCHING ((uint32_t)0x00020000)
|
||
|
#define ETH_DMA_RECEIVEPROCESS_WAITING ((uint32_t)0x00060000)
|
||
|
#define ETH_DMA_RECEIVEPROCESS_SUSPENDED ((uint32_t)0x00080000)
|
||
|
#define ETH_DMA_RECEIVEPROCESS_CLOSING ((uint32_t)0x000A0000)
|
||
|
#define ETH_DMA_RECEIVEPROCESS_QUEUING ((uint32_t)0x000E0000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_DMA_overflow_
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_DMA_OVERFLOW_RXFIFOCOUNTER ((uint32_t)0x10000000)
|
||
|
#define ETH_DMA_OVERFLOW_MISSEDFRAMECOUNTER ((uint32_t)0x00010000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_WUM_Flags
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_WUM_FLAG_WUFFRPR ((uint32_t)0x80000000) /*!< Wake-Up Frame Filter Register Poniter Reset */
|
||
|
#define ETH_WUM_FLAG_WUFR ((uint32_t)0x00000040) /*!< Wake-Up Frame Received */
|
||
|
#define ETH_WUM_FLAG_MPKR ((uint32_t)0x00000020) /*!< Magic Packet Received */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MSC_Tx_Interrupts
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MSC_INT_TGF ((uint32_t)0x00200000) /*!< When Tx good frame counter reaches half the maximum value */
|
||
|
#define ETH_MSC_INT_TGFMSC ((uint32_t)0x00008000) /*!< When Tx good multi col counter reaches half the maximum value */
|
||
|
#define ETH_MSC_INT_TGFSC ((uint32_t)0x00004000) /*!< When Tx good single col counter reaches half the maximum value */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MSC_Rx_Interrupts
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MSC_INT_RGUF ((uint32_t)0x10020000) /*!< When Rx good unicast frames counter reaches half the maximum value */
|
||
|
#define ETH_MSC_INT_RFAE ((uint32_t)0x10000040) /*!< When Rx alignment error counter reaches half the maximum value */
|
||
|
#define ETH_MSC_INT_RFCE ((uint32_t)0x10000020) /*!< When Rx crc error counter reaches half the maximum value */
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_MSC_Registers
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_MSC_CTLR ((uint32_t)0x00000100)
|
||
|
#define ETH_MSC_RISR ((uint32_t)0x00000104)
|
||
|
#define ETH_MSC_TISR ((uint32_t)0x00000108)
|
||
|
#define ETH_MSC_RIMR ((uint32_t)0x0000010C)
|
||
|
#define ETH_MSC_TIMR ((uint32_t)0x00000110)
|
||
|
#define ETH_MSC_SCCNT ((uint32_t)0x0000014C)
|
||
|
#define ETH_MSC_MSCCNT ((uint32_t)0x00000150)
|
||
|
#define ETH_MSC_TGFCNT ((uint32_t)0x00000168)
|
||
|
#define ETH_MSC_RFCECNT ((uint32_t)0x00000194)
|
||
|
#define ETH_MSC_RFAECNT ((uint32_t)0x00000198)
|
||
|
#define ETH_MSC_RGUFCNT ((uint32_t)0x000001C4)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_PTP_time_update_mode
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PTP_FINEMODE ((uint32_t)0x00000001)
|
||
|
#define ETH_PTP_COARSEMODE ((uint32_t)0x00000000)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup ETH_PTP_Flags
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PTP_FLAG_TMSARU ((uint32_t)0x00000020) /*!< Addend Register Update */
|
||
|
#define ETH_PTP_FLAG_TMSITEN ((uint32_t)0x00000010) /*!< Time Stamp Interrupt Trigger Enable */
|
||
|
#define ETH_PTP_FLAG_TMSSTU ((uint32_t)0x00000008) /*!< Time Stamp Update */
|
||
|
#define ETH_PTP_FLAG_TMSSTI ((uint32_t)0x00000004) /*!< Time Stamp Initialize */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/** @defgroup ETH_PTP_time_sign
|
||
|
* @{
|
||
|
*/
|
||
|
#define ETH_PTP_POSITIVETIME ((uint32_t)0x00000000)
|
||
|
#define ETH_PTP_NEGATIVETIME ((uint32_t)0x80000000)
|
||
|
|
||
|
/**
|
||
|
* @brief ETH PTP registers
|
||
|
*/
|
||
|
#define ETH_PTP_TSCTLR ((uint32_t)0x00000700)
|
||
|
#define ETH_PTP_SSINCR ((uint32_t)0x00000704)
|
||
|
#define ETH_PTP_TMSHR ((uint32_t)0x00000708)
|
||
|
#define ETH_PTP_TMSLR ((uint32_t)0x0000070C)
|
||
|
#define ETH_PTP_TMSHUR ((uint32_t)0x00000710)
|
||
|
#define ETH_PTP_TMSLUR ((uint32_t)0x00000714)
|
||
|
#define ETH_PTP_TSACNT ((uint32_t)0x00000718)
|
||
|
#define ETH_PTP_ETHR ((uint32_t)0x0000071C)
|
||
|
#define ETH_PTP_ETLR ((uint32_t)0x00000720)
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
|
||
|
/** @defgroup ETH_Exported_Functions
|
||
|
* @{
|
||
|
*/
|
||
|
void ETH_DeInit(void);
|
||
|
void ETH_MDIOInit(void);
|
||
|
uint32_t ETH_Init(ETH_InitPara *ETH_InitParaStruct, u16 PHYAddress);
|
||
|
void ETH_ParaInit(ETH_InitPara *ETH_InitParaStruct);
|
||
|
void ETH_SoftReset(void);
|
||
|
TypeState ETH_GetSoftResetStatus(void);
|
||
|
void ETH_Enable(TypeState NewValue);
|
||
|
uint32_t ETH_HandleTxPkt(uint8_t *pbuf, uint16_t size);
|
||
|
uint32_t ETH_HandleRxPkt(uint8_t *pbuf);
|
||
|
uint32_t ETH_GetRxPktSize(void);
|
||
|
void ETH_DropRxPkt(void);
|
||
|
/**
|
||
|
* @brief PHY
|
||
|
*/
|
||
|
uint16_t ETH_GetPHYRegisterValue(uint16_t PHYAddr, uint16_t PHYReg);
|
||
|
uint32_t ETH_SetPHYRegisterValue(uint16_t PHYAddr, uint16_t PHYReg, uint16_t PHYValue);
|
||
|
uint32_t ETH_PHYLoopBack_Enable(uint16_t PHYAddr, TypeState NewValue);
|
||
|
|
||
|
/**
|
||
|
* @brief MAC
|
||
|
*/
|
||
|
void ETH_MACTransmission_Enable(TypeState NewValue);
|
||
|
void ETH_MACReception_Enable(TypeState NewValue);
|
||
|
TypeState ETH_GetFlowControlBusyBitState(void);
|
||
|
void ETH_PauseFrameInit(void) ;
|
||
|
void ETH_BackPressureActivation_Enable(TypeState NewValue);
|
||
|
TypeState ETH_GetMACBitState(uint32_t ETH_MAC_FLAG);
|
||
|
TypeState ETH_GetMACIntBitState(uint32_t ETH_MAC_IT);
|
||
|
void ETH_MACINTConfig(uint32_t ETH_MAC_IT, TypeState NewValue);
|
||
|
void ETH_SetMACAddress(uint32_t addr, uint8_t *buf);
|
||
|
void ETH_GetMACAddress(uint32_t addr, uint8_t *buf);
|
||
|
void ETH_MACAddressPerfectFilter_Enable(uint32_t addr, TypeState NewValue);
|
||
|
void ETH_MACAddressFilterConfig(uint32_t addr, uint32_t Filterfield);
|
||
|
void ETH_MACAddressFilterMaskBytesConfig(uint32_t addr, uint32_t addrmask);
|
||
|
|
||
|
/**
|
||
|
* @brief DMA Tx/Rx descriptors
|
||
|
*/
|
||
|
void ETH_DMATxDescChainModeInit(ETH_DMADESCTypeDef *DMATxDescTab, uint8_t *pTxBuff, uint32_t TxBuffCnt);
|
||
|
void ETH_DMATxDescRingModeInit(ETH_DMADESCTypeDef *DMATxDescTab, uint8_t *pTxBuff1, uint8_t *pTxBuff2, uint32_t TxBuffCnt);
|
||
|
TypeState ETH_GetDMATxDescBitState(ETH_DMADESCTypeDef *DMATxDesc, uint32_t ETH_DMATxDescFlag);
|
||
|
uint32_t ETH_GetDMATxDescCollisionCount(ETH_DMADESCTypeDef *DMATxDesc);
|
||
|
void ETH_SetDMATxDescBusyBit(ETH_DMADESCTypeDef *DMATxDesc);
|
||
|
void ETH_DMATxDescTransmitINTConfig(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_SetDMATxDescFrameSegment(ETH_DMADESCTypeDef *DMATxDesc, uint32_t DMATxDesc_Segment);
|
||
|
void ETH_SetDMATxDescChecksumInsertion(ETH_DMADESCTypeDef *DMATxDesc, uint32_t DMATxDesc_Checksum);
|
||
|
void ETH_DMATxDescCRC_Enable(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_DMATxDescEndOfRing_Enable(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_DMATxDescSecondAddressChained_Enable(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_DMATxDescShortFramePadding_Enable(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_DMATxDescTimeStamp_Enable(ETH_DMADESCTypeDef *DMATxDesc, TypeState NewValue);
|
||
|
void ETH_SetDMATxDescBufferSize(ETH_DMADESCTypeDef *DMATxDesc, uint32_t Buffer1Size, uint32_t Buffer2Size);
|
||
|
void ETH_DMARxDescChainModeInit(ETH_DMADESCTypeDef *DMARxDescTab, uint8_t *pRxBuff, uint32_t RxBuffCnt);
|
||
|
void ETH_DMARxDescRingModeInit(ETH_DMADESCTypeDef *DMARxDescTab, uint8_t *pRxBuff1, uint8_t *pRxBuff2, uint32_t RxBuffCnt);
|
||
|
TypeState ETH_GetDMARxDescBitState(ETH_DMADESCTypeDef *DMARxDesc, uint32_t ETH_DMARxDescFlag);
|
||
|
void ETH_SetDMARxDescBusyBit(ETH_DMADESCTypeDef *DMARxDesc);
|
||
|
uint32_t ETH_GetDMARxDescFrameLength(ETH_DMADESCTypeDef *DMARxDesc);
|
||
|
void ETH_DMARxDescReceiveINTConfig(ETH_DMADESCTypeDef *DMARxDesc, TypeState NewValue);
|
||
|
void ETH_DMARxDescEndOfRing_Enable(ETH_DMADESCTypeDef *DMARxDesc, TypeState NewValue);
|
||
|
void ETH_DMARxDescSecondAddressChained_Enable(ETH_DMADESCTypeDef *DMARxDesc, TypeState NewValue);
|
||
|
uint32_t ETH_GetDMARxDescBufferSize(ETH_DMADESCTypeDef *DMARxDesc, uint32_t DMARxDesc_Buffer);
|
||
|
|
||
|
/**
|
||
|
* @brief DMA
|
||
|
*/
|
||
|
TypeState ETH_GetDMABitState(uint32_t ETH_DMA_FLAG);
|
||
|
void ETH_DMAClearBitState(uint32_t ETH_DMA_FLAG);
|
||
|
TypeState ETH_GetDMAIntBitState(uint32_t ETH_DMA_IT);
|
||
|
void ETH_DMAClearIntBitState(uint32_t ETH_DMA_IT);
|
||
|
uint32_t ETH_GetTransmitProcessState(void);
|
||
|
uint32_t ETH_GetReceiveProcessState(void);
|
||
|
void ETH_CleanTransmitFIFO(void);
|
||
|
TypeState ETH_GetFlushTransmitFIFOStatus(void);
|
||
|
void ETH_DMATransmission_Enable(TypeState NewValue);
|
||
|
void ETH_DMAReception_Enable(TypeState NewValue);
|
||
|
void ETH_DMAINTConfig(uint32_t ETH_DMA_IT, TypeState NewValue);
|
||
|
TypeState ETH_GetDMAOverflowStatus(uint32_t ETH_DMA_Overflow);
|
||
|
uint32_t ETH_GetRxOverflowMissedFrameCounter(void);
|
||
|
uint32_t ETH_GetBufferUnavailableMissedFrameCounter(void);
|
||
|
uint32_t ETH_GetCurrentTxDescStartAddress(void);
|
||
|
uint32_t ETH_GetCurrentRxDescStartAddress(void);
|
||
|
uint32_t ETH_GetCurrentTxBufferAddress(void);
|
||
|
uint32_t ETH_GetCurrentRxBufferAddress(void);
|
||
|
void ETH_ResumeDMATransmission(void);
|
||
|
void ETH_ResumeDMAReception(void);
|
||
|
|
||
|
/**
|
||
|
* @brief WUM
|
||
|
*/
|
||
|
void ETH_ResetWakeUpFrameFilterRegister(void);
|
||
|
void ETH_SetWakeUpFrameFilterRegister(uint32_t *pBuffer);
|
||
|
void ETH_GlobalUnicastWakeUp_Enable(TypeState NewValue);
|
||
|
TypeState ETH_GetWUMBitState(uint32_t ETH_WUM_FLAG);
|
||
|
void ETH_WakeUpFrameDetection_Enable(TypeState NewValue);
|
||
|
void ETH_MagicPacketDetection_Enable(TypeState NewValue);
|
||
|
void ETH_PowerDown_Enable(TypeState NewValue);
|
||
|
|
||
|
/**
|
||
|
* @brief MSC
|
||
|
*/
|
||
|
void ETH_MSCCounterFreeze_Enable(TypeState NewValue);
|
||
|
void ETH_MSCResetOnRead_Enable(TypeState NewValue);
|
||
|
void ETH_MSCCounterRollover_Enable(TypeState NewValue);
|
||
|
void ETH_ResetMSCCounters(void);
|
||
|
void ETH_MSCINTConfig(uint32_t ETH_MSC_IT, TypeState NewValue);
|
||
|
TypeState ETH_GetMSCINTStatus(uint32_t ETH_MSC_IT);
|
||
|
uint32_t ETH_GetMSCRegister(uint32_t ETH_MSC_Register);
|
||
|
|
||
|
/**
|
||
|
* @brief PTP
|
||
|
*/
|
||
|
void ETH_PTPTimeStampAddendUpdate(void);
|
||
|
void ETH_PTPTimeStampIntTrigger_Enable(TypeState NewValue);
|
||
|
void ETH_PTPTimeStampUpdate_Enable(TypeState NewValue);
|
||
|
void ETH_PTPTimeStampInit(void);
|
||
|
void ETH_PTPUpdateModeConfig(uint32_t UpdateMode);
|
||
|
void ETH_PTPTimeStamp_Enable(TypeState NewValue);
|
||
|
TypeState ETH_GetPTPBitState(uint32_t ETH_PTP_FLAG);
|
||
|
void ETH_SetPTPSubSecondIncrement(uint32_t SubSecond);
|
||
|
void ETH_SetPTPUpdateTimeValue(uint32_t Sign, uint32_t SecondValue, uint32_t SubSecondValue);
|
||
|
void ETH_SetPTPTimeStampAddend(uint32_t add);
|
||
|
void ETH_SetPTPTargetTime(uint32_t HighReg_Value, uint32_t LowReg_Value);
|
||
|
uint32_t ETH_GetPTPRegister(uint32_t ETH_PTPRegister);
|
||
|
void ETH_DMAPTPTxDescChainModeInit(ETH_DMADESCTypeDef *DMATxDescTab, ETH_DMADESCTypeDef *DMAPTPTxDescTab,
|
||
|
uint8_t *pTxBuff, uint32_t TxBuffCnt);
|
||
|
void ETH_DMAPTPRxDescChainModeInit(ETH_DMADESCTypeDef *DMARxDescTab, ETH_DMADESCTypeDef *DMAPTPRxDescTab,
|
||
|
uint8_t *pRxBuff, uint32_t RxBuffCnt);
|
||
|
uint32_t ETH_HandlePTPTxPkt(uint8_t *pbuf, uint16_t size, uint32_t *PTPTxTab);
|
||
|
uint32_t ETH_HandlePTPRxPkt(uint8_t *pbuf, uint32_t *PTPRxTab);
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* __GD32F10X_ETH_H */
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|