/*! \file gd32f30x_enet_eval.h \brief the header file of gd32f30x_enet_eval \version 2017-02-10, V1.0.0, firmware for GD32F30x \version 2018-10-10, V1.1.0, firmware for GD32F30x \version 2018-12-25, V2.0.0, firmware for GD32F30x */ /* Copyright (c) 2018, GigaDevice Semiconductor Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef HD_ETH_H #define HD_ETH_H #define DP83848_PHY_ADDRESS 0x1 #define ETH_INIT_FLAG 0x01 /* Ethernet Init Flag */ #define ETH_LINK_FLAG 0x10 /* Ethernet Link Flag */ #define USE_DHCP /* enable DHCP, if disabled static address is used */ /* MAC address: MAC_ADDR0:MAC_ADDR1:MAC_ADDR2:MAC_ADDR3:MAC_ADDR4:MAC_ADDR5 */ #define MAC_ADDR0 2 //取唯一id做为MAC地址0x1fffF7E8为gd32f307芯片唯一id地址 #define MAC_ADDR1 (uint8_t)((*(uint32_t*)(0x1fffF7E8))>> 0) #define MAC_ADDR2 (uint8_t)((*(uint32_t*)(0x1fffF7E8))>> 8) #define MAC_ADDR3 (uint8_t)((*(uint32_t*)(0x1fffF7E8))>> 16) #define MAC_ADDR4 (uint8_t)((*(uint32_t*)(0x1fffF7E8))>> 24) #define MAC_ADDR5 0 /* static IP address: IP_ADDR0.IP_ADDR1.IP_ADDR2.IP_ADDR3 */ #define IP_ADDR0 192 #define IP_ADDR1 168 #define IP_ADDR2 2 #define IP_ADDR3 126 /* remote station IP address: IP_S_ADDR0.IP_S_ADDR1.IP_S_ADDR2.IP_S_ADDR3 */ #define IP_S_ADDR0 192 #define IP_S_ADDR1 168 #define IP_S_ADDR2 2 #define IP_S_ADDR3 22 /* net mask */ #define NETMASK_ADDR0 255 #define NETMASK_ADDR1 255 #define NETMASK_ADDR2 254 #define NETMASK_ADDR3 0 /* gateway address */ #define GW_ADDR0 192 #define GW_ADDR1 168 #define GW_ADDR2 2 #define GW_ADDR3 1 /* MII and RMII mode selection */ //#define RMII_MODE // user have to provide the 50 MHz clock by soldering a 50 MHz oscillator #define MII_MODE /* clock the PHY from external 25MHz crystal (only for MII mode) */ #ifdef MII_MODE #define PHY_CLOCK_MCO #endif /* function declarations */ /* setup ethernet system(GPIOs, clocks, MAC, DMA, systick) */ void enet_system_setup(void); extern volatile uint32_t EthStatus; #endif /* GD32F30x_ENET_EVAL_H */