123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- STMicroelectronics 10/100/1000 Synopsys Ethernet driver
- Copyright (C) 2007-2010 STMicroelectronics Ltd
- Author: Giuseppe Cavallaro <peppe.cavallaro@st.com>
- This is the driver for the MAC 10/100/1000 on-chip Ethernet controllers
- (Synopsys IP blocks); it has been fully tested on STLinux platforms.
- Currently this network device driver is for all STM embedded MAC/GMAC
- (7xxx SoCs). Other platforms start using it i.e. ARM SPEAr.
- DWC Ether MAC 10/100/1000 Universal version 3.41a and DWC Ether MAC 10/100
- Universal version 4.0 have been used for developing the first code
- implementation.
- Please, for more information also visit: www.stlinux.com
- 1) Kernel Configuration
- The kernel configuration option is STMMAC_ETH:
- Device Drivers ---> Network device support ---> Ethernet (1000 Mbit) --->
- STMicroelectronics 10/100/1000 Ethernet driver (STMMAC_ETH)
- 2) Driver parameters list:
- debug: message level (0: no output, 16: all);
- phyaddr: to manually provide the physical address to the PHY device;
- dma_rxsize: DMA rx ring size;
- dma_txsize: DMA tx ring size;
- buf_sz: DMA buffer size;
- tc: control the HW FIFO threshold;
- tx_coe: Enable/Disable Tx Checksum Offload engine;
- watchdog: transmit timeout (in milliseconds);
- flow_ctrl: Flow control ability [on/off];
- pause: Flow Control Pause Time;
- tmrate: timer period (only if timer optimisation is configured).
- 3) Command line options
- Driver parameters can be also passed in command line by using:
- stmmaceth=dma_rxsize:128,dma_txsize:512
- 4) Driver information and notes
- 4.1) Transmit process
- The xmit method is invoked when the kernel needs to transmit a packet; it sets
- the descriptors in the ring and informs the DMA engine that there is a packet
- ready to be transmitted.
- Once the controller has finished transmitting the packet, an interrupt is
- triggered; So the driver will be able to release the socket buffers.
- By default, the driver sets the NETIF_F_SG bit in the features field of the
- net_device structure enabling the scatter/gather feature.
- 4.2) Receive process
- When one or more packets are received, an interrupt happens. The interrupts
- are not queued so the driver has to scan all the descriptors in the ring during
- the receive process.
- This is based on NAPI so the interrupt handler signals only if there is work to be
- done, and it exits.
- Then the poll method will be scheduled at some future point.
- The incoming packets are stored, by the DMA, in a list of pre-allocated socket
- buffers in order to avoid the memcpy (Zero-copy).
- 4.3) Timer-Driver Interrupt
- Instead of having the device that asynchronously notifies the frame receptions, the
- driver configures a timer to generate an interrupt at regular intervals.
- Based on the granularity of the timer, the frames that are received by the device
- will experience different levels of latency. Some NICs have dedicated timer
- device to perform this task. STMMAC can use either the RTC device or the TMU
- channel 2 on STLinux platforms.
- The timers frequency can be passed to the driver as parameter; when change it,
- take care of both hardware capability and network stability/performance impact.
- Several performance tests on STM platforms showed this optimisation allows to spare
- the CPU while having the maximum throughput.
- 4.4) WOL
- Wake up on Lan feature through Magic Frame is only supported for the GMAC
- core.
- 4.5) DMA descriptors
- Driver handles both normal and enhanced descriptors. The latter has been only
- tested on DWC Ether MAC 10/100/1000 Universal version 3.41a.
- 4.6) Ethtool support
- Ethtool is supported. Driver statistics and internal errors can be taken using:
- ethtool -S ethX command. It is possible to dump registers etc.
- 4.7) Jumbo and Segmentation Offloading
- Jumbo frames are supported and tested for the GMAC.
- The GSO has been also added but it's performed in software.
- LRO is not supported.
- 4.8) Physical
- The driver is compatible with PAL to work with PHY and GPHY devices.
- 4.9) Platform information
- Several information came from the platform; please refer to the
- driver's Header file in include/linux directory.
- struct plat_stmmacenet_data {
- int bus_id;
- int pbl;
- int clk_csr;
- int has_gmac;
- int enh_desc;
- int tx_coe;
- int bugged_jumbo;
- int pmt;
- void (*fix_mac_speed)(void *priv, unsigned int speed);
- void (*bus_setup)(unsigned long ioaddr);
- #ifdef CONFIG_STM_DRIVERS
- struct stm_pad_config *pad_config;
- #endif
- void *bsp_priv;
- };
- Where:
- - pbl (Programmable Burst Length) is maximum number of
- beats to be transferred in one DMA transaction.
- GMAC also enables the 4xPBL by default.
- - fix_mac_speed and bus_setup are used to configure internal target
- registers (on STM platforms);
- - has_gmac: GMAC core is on board (get it at run-time in the next step);
- - bus_id: bus identifier.
- - tx_coe: core is able to perform the tx csum in HW.
- - enh_desc: if sets the MAC will use the enhanced descriptor structure.
- - clk_csr: CSR Clock range selection.
- - bugged_jumbo: some HWs are not able to perform the csum in HW for
- over-sized frames due to limited buffer sizes. Setting this
- flag the csum will be done in SW on JUMBO frames.
- struct plat_stmmacphy_data {
- int bus_id;
- int phy_addr;
- unsigned int phy_mask;
- int interface;
- int (*phy_reset)(void *priv);
- void *priv;
- };
- Where:
- - bus_id: bus identifier;
- - phy_addr: physical address used for the attached phy device;
- set it to -1 to get it at run-time;
- - interface: physical MII interface mode;
- - phy_reset: hook to reset HW function.
- SOURCES:
- - Kconfig
- - Makefile
- - stmmac_main.c: main network device driver;
- - stmmac_mdio.c: mdio functions;
- - stmmac_ethtool.c: ethtool support;
- - stmmac_timer.[ch]: timer code used for mitigating the driver dma interrupts
- Only tested on ST40 platforms based.
- - stmmac.h: private driver structure;
- - common.h: common definitions and VFTs;
- - descs.h: descriptor structure definitions;
- - dwmac1000_core.c: GMAC core functions;
- - dwmac1000_dma.c: dma functions for the GMAC chip;
- - dwmac1000.h: specific header file for the GMAC;
- - dwmac100_core: MAC 100 core and dma code;
- - dwmac100_dma.c: dma funtions for the MAC chip;
- - dwmac1000.h: specific header file for the MAC;
- - dwmac_lib.c: generic DMA functions shared among chips
- - enh_desc.c: functions for handling enhanced descriptors
- - norm_desc.c: functions for handling normal descriptors
- TODO:
- - XGMAC controller is not supported.
- - Review the timer optimisation code to use an embedded device that seems to be
- available in new chip generations.
|