From 0061fe02e624d87e743bd17988f34dae25e02650 Mon Sep 17 00:00:00 2001 From: "Sergio R. Caprile" Date: Mon, 27 May 2024 14:31:44 -0300 Subject: [PATCH] add 100/10M --- .github/workflows/nightly.yml | 1 + .github/workflows/quicktest.yml | 1 + mongoose.c | 32 +++++++++++++++++++++++--------- src/drivers/xmc7.c | 32 +++++++++++++++++++++++--------- 4 files changed, 48 insertions(+), 18 deletions(-) diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml index 6a41dbb8..3486991b 100644 --- a/.github/workflows/nightly.yml +++ b/.github/workflows/nightly.yml @@ -369,6 +369,7 @@ jobs: matrix: ssl: ["", -DMG_TLS=MG_TLS_BUILTIN] example: + - path: infineon/infineon-xmc7200 - path: microchip/same54-xpro/device-dashboard - path: nxp/rt1020-evk-make-baremetal-builtin - path: nxp/rt1020-evk-make-freertos-builtin diff --git a/.github/workflows/quicktest.yml b/.github/workflows/quicktest.yml index d10f2f21..f2459dbf 100644 --- a/.github/workflows/quicktest.yml +++ b/.github/workflows/quicktest.yml @@ -241,6 +241,7 @@ jobs: fail-fast: false matrix: example: + - path: infineon/infineon-xmc7200 - path: microchip/same54-xpro/device-dashboard - path: nxp/rt1020-evk-make-baremetal-builtin - path: nxp/rt1020-evk-make-freertos-builtin diff --git a/mongoose.c b/mongoose.c index 3fc0e14a..34966698 100644 --- a/mongoose.c +++ b/mongoose.c @@ -17468,14 +17468,14 @@ static bool mg_tcpip_driver_xmc7_init(struct mg_tcpip_if *ifp) { s_ifp = ifp; // enable controller, set RGMII mode - ETH0->CTL = MG_BIT(31) | 2; + ETH0->CTL = MG_BIT(31) | (4 << 8) | 2; uint32_t cr = get_clock_rate(d); // set NSP change, ignore RX FCS, data bus width, clock rate // frame length 1536, full duplex, speed ETH0->NETWORK_CONFIG = MG_BIT(29) | MG_BIT(26) | MG_BIT(21) | - ((cr & 7) << 18) | MG_BIT(8) | MG_BIT(4) | - MG_BIT(1) | MG_BIT(0); + ((cr & 7) << 18) | MG_BIT(8) | MG_BIT(4) | MG_BIT(1) | + MG_BIT(0); // config DMA settings: Force TX burst, Discard on Error, set RX buffer size // to 1536, TX_PBUF_SIZE, RX_PBUF_SIZE, AMBA_BURST_LENGTH @@ -17559,15 +17559,30 @@ static bool mg_tcpip_driver_xmc7_up(struct mg_tcpip_if *ifp) { struct mg_phy phy = {eth_read_phy, eth_write_phy}; up = mg_phy_up(&phy, d->phy_addr, &full_duplex, &speed); if ((ifp->state == MG_TCPIP_STATE_DOWN) && up) { // link state just went up + // tmp = reg with flags set to the most likely situation: 100M full-duplex + // if(link is slow or half) set flags otherwise + // reg = tmp + uint32_t netconf = ETH0->NETWORK_CONFIG; + MG_SET_BITS(netconf, MG_BIT(10), + MG_BIT(1) | MG_BIT(0)); // 100M, Full-duplex + uint32_t ctl = ETH0->CTL; + MG_SET_BITS(ctl, 0xFF00, 4 << 8); // /5 for 25M clock if (speed == MG_PHY_SPEED_1000M) { - ETH0->NETWORK_CONFIG |= MG_BIT(10); - } + netconf |= MG_BIT(10); // 1000M + MG_SET_BITS(ctl, 0xFF00, 0); // /1 for 125M clock TODO() IS THIS NEEDED ? + } else if (speed == MG_PHY_SPEED_10M) { + netconf &= ~MG_BIT(0); // 10M + MG_SET_BITS(ctl, 0xFF00, 49); // /50 for 2.5M clock + } + if (full_duplex == false) netconf &= ~MG_BIT(1); // Half-duplex + ETH0->NETWORK_CONFIG = netconf; // IRQ handler does not fiddle with these + ETH0->CTL = ctl; MG_DEBUG(("Link is %uM %s-duplex", - speed == MG_PHY_SPEED_10M ? 10 : - (speed == MG_PHY_SPEED_100M ? 100 : 1000), + speed == MG_PHY_SPEED_10M + ? 10 + : (speed == MG_PHY_SPEED_100M ? 100 : 1000), full_duplex ? "full" : "half")); } - (void) d; return up; } @@ -17577,7 +17592,6 @@ void ETH_IRQHandler(void) { for (uint8_t i = 0; i < ETH_DESC_CNT; i++) { if (s_rxdesc[s_rxno][0] & MG_BIT(0)) { size_t len = s_rxdesc[s_rxno][1] & (MG_BIT(13) - 1); - //MG_INFO(("Receive complete: %ld bytes", len)); mg_tcpip_qwrite(s_rxbuf[s_rxno], len, s_ifp); s_rxdesc[s_rxno][0] &= ~MG_BIT(0); // OWN bit: handle control to DMA if (++s_rxno >= ETH_DESC_CNT) s_rxno = 0; diff --git a/src/drivers/xmc7.c b/src/drivers/xmc7.c index ff404c49..a530cb30 100644 --- a/src/drivers/xmc7.c +++ b/src/drivers/xmc7.c @@ -95,14 +95,14 @@ static bool mg_tcpip_driver_xmc7_init(struct mg_tcpip_if *ifp) { s_ifp = ifp; // enable controller, set RGMII mode - ETH0->CTL = MG_BIT(31) | 2; + ETH0->CTL = MG_BIT(31) | (4 << 8) | 2; uint32_t cr = get_clock_rate(d); // set NSP change, ignore RX FCS, data bus width, clock rate // frame length 1536, full duplex, speed ETH0->NETWORK_CONFIG = MG_BIT(29) | MG_BIT(26) | MG_BIT(21) | - ((cr & 7) << 18) | MG_BIT(8) | MG_BIT(4) | - MG_BIT(1) | MG_BIT(0); + ((cr & 7) << 18) | MG_BIT(8) | MG_BIT(4) | MG_BIT(1) | + MG_BIT(0); // config DMA settings: Force TX burst, Discard on Error, set RX buffer size // to 1536, TX_PBUF_SIZE, RX_PBUF_SIZE, AMBA_BURST_LENGTH @@ -186,15 +186,30 @@ static bool mg_tcpip_driver_xmc7_up(struct mg_tcpip_if *ifp) { struct mg_phy phy = {eth_read_phy, eth_write_phy}; up = mg_phy_up(&phy, d->phy_addr, &full_duplex, &speed); if ((ifp->state == MG_TCPIP_STATE_DOWN) && up) { // link state just went up + // tmp = reg with flags set to the most likely situation: 100M full-duplex + // if(link is slow or half) set flags otherwise + // reg = tmp + uint32_t netconf = ETH0->NETWORK_CONFIG; + MG_SET_BITS(netconf, MG_BIT(10), + MG_BIT(1) | MG_BIT(0)); // 100M, Full-duplex + uint32_t ctl = ETH0->CTL; + MG_SET_BITS(ctl, 0xFF00, 4 << 8); // /5 for 25M clock if (speed == MG_PHY_SPEED_1000M) { - ETH0->NETWORK_CONFIG |= MG_BIT(10); - } + netconf |= MG_BIT(10); // 1000M + MG_SET_BITS(ctl, 0xFF00, 0); // /1 for 125M clock TODO() IS THIS NEEDED ? + } else if (speed == MG_PHY_SPEED_10M) { + netconf &= ~MG_BIT(0); // 10M + MG_SET_BITS(ctl, 0xFF00, 49); // /50 for 2.5M clock + } + if (full_duplex == false) netconf &= ~MG_BIT(1); // Half-duplex + ETH0->NETWORK_CONFIG = netconf; // IRQ handler does not fiddle with these + ETH0->CTL = ctl; MG_DEBUG(("Link is %uM %s-duplex", - speed == MG_PHY_SPEED_10M ? 10 : - (speed == MG_PHY_SPEED_100M ? 100 : 1000), + speed == MG_PHY_SPEED_10M + ? 10 + : (speed == MG_PHY_SPEED_100M ? 100 : 1000), full_duplex ? "full" : "half")); } - (void) d; return up; } @@ -204,7 +219,6 @@ void ETH_IRQHandler(void) { for (uint8_t i = 0; i < ETH_DESC_CNT; i++) { if (s_rxdesc[s_rxno][0] & MG_BIT(0)) { size_t len = s_rxdesc[s_rxno][1] & (MG_BIT(13) - 1); - //MG_INFO(("Receive complete: %ld bytes", len)); mg_tcpip_qwrite(s_rxbuf[s_rxno], len, s_ifp); s_rxdesc[s_rxno][0] &= ~MG_BIT(0); // OWN bit: handle control to DMA if (++s_rxno >= ETH_DESC_CNT) s_rxno = 0;