From 8d8af31e39ba5cf8dd5c33a24f82e1e86b672d0a Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Sun, 26 Jul 2020 22:05:18 +0200 Subject: [PATCH] driver/stm32_eth: Integrate into periph_eth The stm32_eth driver was build on top of the internal API periph_eth, which was unused anywhere. (Additionally, with two obscure exceptions, no functions where declared in headers, making them pretty hard to use anyway.) The separation of the driver into two layers incurs overhead, but does not result in cleaner structure or reuse of code. Thus, this artificial separation was dropped. --- cpu/stm32/Makefile.dep | 7 ++ cpu/stm32/include/periph_cpu.h | 23 ------ cpu/stm32/periph/eth.c | 117 ++++++++++++++++++++++++---- drivers/stm32_eth/Makefile | 1 - drivers/stm32_eth/Makefile.dep | 5 -- drivers/stm32_eth/doc.txt | 13 ---- drivers/stm32_eth/stm32_eth.c | 135 --------------------------------- makefiles/pseudomodules.inc.mk | 3 +- 8 files changed, 112 insertions(+), 192 deletions(-) delete mode 100644 drivers/stm32_eth/Makefile delete mode 100644 drivers/stm32_eth/Makefile.dep delete mode 100644 drivers/stm32_eth/doc.txt delete mode 100644 drivers/stm32_eth/stm32_eth.c diff --git a/cpu/stm32/Makefile.dep b/cpu/stm32/Makefile.dep index b39081a74f..ea8843d6ea 100644 --- a/cpu/stm32/Makefile.dep +++ b/cpu/stm32/Makefile.dep @@ -16,6 +16,13 @@ ifneq (,$(filter periph_uart_nonblocking,$(USEMODULE))) USEMODULE += tsrb endif +ifneq (,$(filter stm32_eth,$(USEMODULE))) + FEATURES_REQUIRED += periph_eth + USEMODULE += netdev_eth + USEMODULE += iolist + USEMODULE += luid +endif + ifneq (STM32F030x4, $(CPU_LINE)) # Retrieve vendor CMSIS headers from ST cmsis_device_ repositories on # GitHub, https://github.com/STMicroelectronics diff --git a/cpu/stm32/include/periph_cpu.h b/cpu/stm32/include/periph_cpu.h index bdace91256..3a7ec7cd37 100644 --- a/cpu/stm32/include/periph_cpu.h +++ b/cpu/stm32/include/periph_cpu.h @@ -1227,29 +1227,6 @@ typedef struct eth_dma_desc { #define ANER_LP_AN_ABLE (0x0001) /** @} */ -#ifdef MODULE_STM32_ETH -/** - * @brief Read a PHY register - * - * @param[in] addr address of the PHY to read - * @param[in] reg register to be read - * - * @return value in the register, or <=0 on error - */ -int32_t stm32_eth_phy_read(uint16_t addr, uint8_t reg); - -/** - * @brief Write a PHY register - * - * @param[in] addr address of the PHY to write - * @param[in] reg register to be written - * @param[in] value value to write into the register - * - * @return 0 in case of success or <=0 on error - */ -int32_t stm32_eth_phy_write(uint16_t addr, uint8_t reg, uint16_t value); -#endif /* MODULE_STM32_ETH */ - #ifdef __cplusplus } #endif diff --git a/cpu/stm32/periph/eth.c b/cpu/stm32/periph/eth.c index 40ec778e36..606ee11844 100644 --- a/cpu/stm32/periph/eth.c +++ b/cpu/stm32/periph/eth.c @@ -23,12 +23,11 @@ #include #include "bitarithm.h" -#include "mutex.h" -#include "luid.h" - #include "iolist.h" +#include "luid.h" +#include "mutex.h" #include "net/ethernet.h" - +#include "net/netdev/eth.h" #include "periph/gpio.h" #define ENABLE_DEBUG (0) @@ -84,6 +83,9 @@ static edma_desc_t *rx_curr; /* RX Buffers */ static char rx_buffer[ETH_RX_DESCRIPTOR_COUNT][ETH_RX_BUFFER_SIZE]; +/* Netdev used in RIOT's API to upper layer */ +netdev_t *_netdev; + /** Read or write a phy register, to write the register ETH_MACMIIAR_MW is to * be passed as the higher nibble of the value */ static unsigned _rw_phy(unsigned addr, unsigned reg, unsigned value) @@ -105,18 +107,17 @@ static unsigned _rw_phy(unsigned addr, unsigned reg, unsigned value) return (ETH->MACMIIDR & 0x0000ffff); } -int32_t stm32_eth_phy_read(uint16_t addr, uint8_t reg) +static inline int32_t _phy_read(uint16_t addr, uint8_t reg) { return _rw_phy(addr, reg, 0); } -int32_t stm32_eth_phy_write(uint16_t addr, uint8_t reg, uint16_t value) +static inline void _phy_write(uint16_t addr, uint8_t reg, uint16_t value) { _rw_phy(addr, reg, (value & 0xffff) | (ETH_MACMIIAR_MW << 16)); - return 0; } -void stm32_eth_get_mac(char *out) +static void stm32_eth_get_mac(char *out) { unsigned t; @@ -133,7 +134,7 @@ void stm32_eth_get_mac(char *out) /** Set the mac address. The peripheral supports up to 4 MACs but only one is * implemented */ -void stm32_eth_set_mac(const char *mac) +static void stm32_eth_set_mac(const char *mac) { ETH->MACA0HR &= 0xffff0000; ETH->MACA0HR |= ((mac[5] << 8) | mac[4]); @@ -165,8 +166,9 @@ static void _init_buffer(void) ETH->DMATDLAR = (uintptr_t)&tx_desc[0]; } -int stm32_eth_init(void) +static int stm32_eth_init(netdev_t *netdev) { + (void)netdev; /* enable APB2 clock */ RCC->APB2ENR |= RCC_APB2ENR_SYSCFGEN; @@ -199,7 +201,7 @@ int stm32_eth_init(void) /* configure the PHY (standard for all PHY's) */ /* if there's no PHY, this has no effect */ - stm32_eth_phy_write(eth_config.phy_addr, PHY_BMCR, BMCR_RESET); + _phy_write(eth_config.phy_addr, PHY_BMCR, BMCR_RESET); /* speed from conf */ ETH->MACCR |= (ETH_MACCR_ROD | ETH_MACCR_IPCO | ETH_MACCR_APCS | @@ -244,13 +246,15 @@ int stm32_eth_init(void) /* configure speed, do it at the end so the PHY had time to * reset */ - stm32_eth_phy_write(eth_config.phy_addr, PHY_BMCR, eth_config.speed); + _phy_write(eth_config.phy_addr, PHY_BMCR, eth_config.speed); return 0; } -int stm32_eth_send(const struct iolist *iolist) +static int stm32_eth_send(netdev_t *netdev, const struct iolist *iolist) { + (void)netdev; + netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED); unsigned bytes_to_send = iolist_size(iolist); /* Input must not be bigger than maximum allowed frame length */ assert(bytes_to_send <= ETHERNET_FRAME_LEN); @@ -294,7 +298,10 @@ int stm32_eth_send(const struct iolist *iolist) (status & TX_DESC_STAT_NC) ? '1' : '0', (status & TX_DESC_STAT_FS) ? '1' : '0', (status & TX_DESC_STAT_LS) ? '1' : '0'); + /* The Error Summary (ES) bit is set, if any error during TX occurred */ if (status & TX_DESC_STAT_ES) { + /* TODO: Report better event to reflect error */ + netdev->event_callback(netdev, NETDEV_EVENT_TX_COMPLETE); return -1; } if (status & TX_DESC_STAT_LS) { @@ -302,6 +309,7 @@ int stm32_eth_send(const struct iolist *iolist) } i++; } + netdev->event_callback(netdev, NETDEV_EVENT_TX_COMPLETE); return (int)bytes_to_send; } @@ -345,8 +353,11 @@ static void drop_frame_and_update_rx_curr(void) } } -int stm32_eth_receive(void *buf, size_t max_len) +static int stm32_eth_recv(netdev_t *netdev, void *buf, size_t max_len, + void *info) { + (void)info; + (void)netdev; char *data = buf; /* Determine the size of received frame. The frame might span multiple * DMA buffers */ @@ -390,3 +401,81 @@ void stm32_eth_isr_eth_wkup(void) { cortexm_isr_end(); } + +static void stm32_eth_isr(netdev_t *netdev) { + netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE); +} + +void isr_eth(void) +{ + unsigned tmp = ETH->DMASR; + + if ((tmp & ETH_DMASR_TS)) { + ETH->DMASR = ETH_DMASR_NIS | ETH_DMASR_TS; + DEBUG("isr_eth: TX completed\n"); + mutex_unlock(&stm32_eth_tx_completed); + } + + if ((tmp & ETH_DMASR_RS)) { + ETH->DMASR = ETH_DMASR_NIS | ETH_DMASR_RS; + DEBUG("isr_eth: RX completed\n"); + if (_netdev) { + netdev_trigger_event_isr(_netdev); + } + } + + cortexm_isr_end(); +} + +static int stm32_eth_set(netdev_t *dev, netopt_t opt, + const void *value, size_t max_len) +{ + int res = -1; + + switch (opt) { + case NETOPT_ADDRESS: + assert(max_len >= ETHERNET_ADDR_LEN); + stm32_eth_set_mac((char *)value); + res = ETHERNET_ADDR_LEN; + break; + default: + res = netdev_eth_set(dev, opt, value, max_len); + break; + } + + return res; +} + +static int stm32_eth_get(netdev_t *dev, netopt_t opt, + void *value, size_t max_len) +{ + int res = -1; + + switch (opt) { + case NETOPT_ADDRESS: + assert(max_len >= ETHERNET_ADDR_LEN); + stm32_eth_get_mac((char *)value); + res = ETHERNET_ADDR_LEN; + break; + default: + res = netdev_eth_get(dev, opt, value, max_len); + break; + } + + return res; +} + +static const netdev_driver_t netdev_driver_stm32f4eth = { + .send = stm32_eth_send, + .recv = stm32_eth_recv, + .init = stm32_eth_init, + .isr = stm32_eth_isr, + .get = stm32_eth_get, + .set = stm32_eth_set, +}; + +void stm32_eth_netdev_setup(netdev_t *netdev) +{ + _netdev = netdev; + netdev->driver = &netdev_driver_stm32f4eth; +} diff --git a/drivers/stm32_eth/Makefile b/drivers/stm32_eth/Makefile deleted file mode 100644 index 48422e909a..0000000000 --- a/drivers/stm32_eth/Makefile +++ /dev/null @@ -1 +0,0 @@ -include $(RIOTBASE)/Makefile.base diff --git a/drivers/stm32_eth/Makefile.dep b/drivers/stm32_eth/Makefile.dep deleted file mode 100644 index a6efd51ab2..0000000000 --- a/drivers/stm32_eth/Makefile.dep +++ /dev/null @@ -1,5 +0,0 @@ -FEATURES_REQUIRED += periph_eth -FEATURES_REQUIRED += periph_dma -USEMODULE += netdev_eth -USEMODULE += iolist -USEMODULE += luid diff --git a/drivers/stm32_eth/doc.txt b/drivers/stm32_eth/doc.txt deleted file mode 100644 index 0bff9e38df..0000000000 --- a/drivers/stm32_eth/doc.txt +++ /dev/null @@ -1,13 +0,0 @@ -/* - * - * This file is subject to the terms and conditions of the GNU Lesser - * General Public License v2.1. See the file LICENSE in the top level - * directory for more details. - */ - -/** -@defgroup drivers_stm32_common Driver for stm32 ethernet -@ingroup drivers_netdev -@brief Device Driver for STM32 Ethernet - -*/ diff --git a/drivers/stm32_eth/stm32_eth.c b/drivers/stm32_eth/stm32_eth.c deleted file mode 100644 index 5f406a943a..0000000000 --- a/drivers/stm32_eth/stm32_eth.c +++ /dev/null @@ -1,135 +0,0 @@ -/* - * Copyright (C) 2016 TriaGnoSys GmbH - * - * This file is subject to the terms and conditions of the GNU Lesser General - * Public License v2.1. See the file LICENSE in the top level directory for more - * details. - */ - -/** - * @ingroup drivers_stm32_common - * @{ - * - * @file - * @brief Netdev wrapper for stm32 ethernet - * - * @author Víctor Ariño - * - * @} - */ - -#include "periph_conf.h" -#include "mutex.h" -#include "net/netdev/eth.h" -#include "net/ethernet.h" -#include "iolist.h" -#define ENABLE_DEBUG (0) -#include "debug.h" - -#include -netdev_t *_netdev; -extern mutex_t stm32_eth_tx_completed; - -void stm32_eth_set_mac(const char *mac); -void stm32_eth_get_mac(char *out); -int stm32_eth_init(void); -int stm32_eth_receive(void *data, size_t max_len); -int stm32_eth_send(const struct iolist *iolist); - -static void _isr(netdev_t *netdev) { - netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE); -} - -void isr_eth(void) -{ - unsigned tmp = ETH->DMASR; - - if ((tmp & ETH_DMASR_TS)) { - ETH->DMASR = ETH_DMASR_NIS | ETH_DMASR_TS; - DEBUG("isr_eth: TX completed\n"); - mutex_unlock(&stm32_eth_tx_completed); - } - - if ((tmp & ETH_DMASR_RS)) { - ETH->DMASR = ETH_DMASR_NIS | ETH_DMASR_RS; - DEBUG("isr_eth: RX completed\n"); - if (_netdev) { - netdev_trigger_event_isr(_netdev); - } - } - - cortexm_isr_end(); -} - -static int _recv(netdev_t *netdev, void *buf, size_t len, void *info) -{ - (void)info; - (void)netdev; - return stm32_eth_receive(buf, len); -} - -static int _send(netdev_t *netdev, const struct iolist *iolist) -{ - (void)netdev; - netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED); - int ret = stm32_eth_send(iolist); - netdev->event_callback(netdev, NETDEV_EVENT_TX_COMPLETE); - return ret; -} - -static int _set(netdev_t *dev, netopt_t opt, const void *value, size_t max_len) -{ - int res = -1; - - switch (opt) { - case NETOPT_ADDRESS: - assert(max_len >= ETHERNET_ADDR_LEN); - stm32_eth_set_mac((char *)value); - res = ETHERNET_ADDR_LEN; - break; - default: - res = netdev_eth_set(dev, opt, value, max_len); - break; - } - - return res; -} - -static int _get(netdev_t *dev, netopt_t opt, void *value, size_t max_len) -{ - int res = -1; - - switch (opt) { - case NETOPT_ADDRESS: - assert(max_len >= ETHERNET_ADDR_LEN); - stm32_eth_get_mac((char *)value); - res = ETHERNET_ADDR_LEN; - break; - default: - res = netdev_eth_get(dev, opt, value, max_len); - break; - } - - return res; -} - -static int _init(netdev_t *netdev) -{ - (void)netdev; - return stm32_eth_init(); -} - -static const netdev_driver_t netdev_driver_stm32f4eth = { - .send = _send, - .recv = _recv, - .init = _init, - .isr = _isr, - .get = _get, - .set = _set, -}; - -void stm32_eth_netdev_setup(netdev_t *netdev) -{ - _netdev = netdev; - netdev->driver = &netdev_driver_stm32f4eth; -} diff --git a/makefiles/pseudomodules.inc.mk b/makefiles/pseudomodules.inc.mk index 4cf00c3ab4..eecd7260a5 100644 --- a/makefiles/pseudomodules.inc.mk +++ b/makefiles/pseudomodules.inc.mk @@ -107,9 +107,10 @@ PSEUDOMODULES += sock_tcp PSEUDOMODULES += sock_udp PSEUDOMODULES += soft_uart_modecfg PSEUDOMODULES += stdin -PSEUDOMODULES += stdio_ethos PSEUDOMODULES += stdio_cdc_acm +PSEUDOMODULES += stdio_ethos PSEUDOMODULES += stdio_uart_rx +PSEUDOMODULES += stm32_eth PSEUDOMODULES += suit_transport_% PSEUDOMODULES += wakaama_objects_% PSEUDOMODULES += wifi_enterprise