mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
4729bea46e
stm32eth: Move to stm32_common periph
cpu/stm32_periph_eth: Rebase to current master branch
- Update DMA to use new vendor headers
- Update send to use iolist. It looks like the packet headers are now transfered as seperate iolist entries which results in the eth periph sending each header as own packet. To fix this a rather ugly workaround is used where the whole iolist content is first copied to a static buffer. This will be fixed soon in another commit
- If MAC is set to zero use luid to generate one
- Small code style fixes
cpu/stm312f7: Add periph config for on-board ethernet
boards/nucleo-f767zi: Add config for on board ethernet
tests/stm32_eth_lwip: Remove board restriction
boards/common/nucleo: Add luid module if stm32 ethernet is used
tests/stm32_eth_gnrc: Add Testcase for gnrc using the stm32 eth periph
stm32_eth: Rework netdev driver layour
tests/stm32_eth_*: Use netdev driver header file for prototypes
stm32_eth: Add auto init for stm32 eth netdev driver
boards/stm32: Enable ethernet conf for nucleo boards
stm32_eth_auto_init: Add dont be pendantic flag
stm32_eth: Remove dma specific stuff from periph_cpu.h
Looks like this was implemented in PR #9171 and 021697ae94
with the same interface.
stm32_eth: Remove eth feature from stm32f4discovery boards
stm32_eth: Migrate to stm32 DMA API
stm32_eth: Add iolist to module deps
stm32_eth: Rework send function to use iolist
stm32_eth: Fix ci build warnings
stm32_eth: Fix bug introduced with iolist usage
stm32_eth: Remove redundant static buffer
stm32_eth: Fix feature dependencies
stm32_eth: Fix wrong header guard name
stm32_eth: Implement correct l2 netstats interface
stm32_eth: Rename public functions to stm32_eth_*
stm32_eth: Fix doccheck
stm32_eth: Move register DEFINE to appropriate header file
stm32_eth: remove untested configuration for f446ze boards
stm32_eth: Move periph configuration struct to stm32_common
stm32_eth: Fix naming of eth_phy_read and eth_phy_write
stm32_eth: Remove obsolete test applications
157 lines
3.5 KiB
C
157 lines
3.5 KiB
C
/*
|
|
* 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 <victor.arino@triagnosys.com>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#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 <string.h>
|
|
static mutex_t _tx = MUTEX_INIT;
|
|
static mutex_t _rx = MUTEX_INIT;
|
|
netdev_t *_netdev;
|
|
|
|
void stm32_eth_set_mac(const char *mac);
|
|
void stm32_eth_get_mac(char *out);
|
|
int stm32_eth_init(void);
|
|
int stm32_eth_receive_blocking(char *data, unsigned max_len);
|
|
int stm32_eth_send(const struct iolist *iolist);
|
|
int stm32_eth_get_rx_status_owned(void);
|
|
|
|
static void _isr(netdev_t *netdev) {
|
|
if(stm32_eth_get_rx_status_owned()) {
|
|
netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE);
|
|
}
|
|
}
|
|
|
|
void isr_eth(void)
|
|
{
|
|
volatile unsigned tmp = ETH->DMASR;
|
|
|
|
if ((tmp & ETH_DMASR_TS)) {
|
|
ETH->DMASR = ETH_DMASR_TS | ETH_DMASR_NIS;
|
|
mutex_unlock(&_tx);
|
|
}
|
|
|
|
if ((tmp & ETH_DMASR_RS)) {
|
|
ETH->DMASR = ETH_DMASR_RS | ETH_DMASR_NIS;
|
|
mutex_unlock(&_rx);
|
|
if (_netdev) {
|
|
_netdev->event_callback(_netdev, NETDEV_EVENT_ISR);
|
|
}
|
|
}
|
|
|
|
/* printf("r:%x\n\n", tmp); */
|
|
|
|
cortexm_isr_end();
|
|
}
|
|
|
|
static int _recv(netdev_t *netdev, void *buf, size_t len, void *info)
|
|
{
|
|
(void)info;
|
|
(void)netdev;
|
|
if(!stm32_eth_get_rx_status_owned()){
|
|
mutex_lock(&_rx);
|
|
}
|
|
int ret = stm32_eth_receive_blocking((char *)buf, len);
|
|
DEBUG("stm32_eth_netdev: _recev: %d\n", ret);
|
|
|
|
return ret;
|
|
}
|
|
|
|
static int _send(netdev_t *netdev, const struct iolist *iolist)
|
|
{
|
|
(void)netdev;
|
|
int ret = 0;
|
|
if(stm32_eth_get_rx_status_owned()) {
|
|
mutex_lock(&_tx);
|
|
}
|
|
netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED);
|
|
ret = stm32_eth_send(iolist);
|
|
DEBUG("stm32_eth_netdev: _send: %d %d\n", ret, iolist_size(iolist));
|
|
if (ret < 0)
|
|
{
|
|
netdev->event_callback(netdev, NETDEV_EVENT_TX_MEDIUM_BUSY);
|
|
return ret;
|
|
}
|
|
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;
|
|
} |