2  * drivers/net/ibm_emac/ibm_emac_core.h
 
   4  * Driver for PowerPC 4xx on-chip ethernet controller.
 
   6  * Copyright (c) 2004, 2005 Zultys Technologies.
 
   7  * Eugene Surovegin <eugene.surovegin@zultys.com> or <ebs@ebshome.net>
 
   9  * Based on original work by
 
  10  *      Armin Kuster <akuster@mvista.com>
 
  11  *      Johnnie Peters <jpeters@mvista.com>
 
  12  *      Copyright 2000, 2001 MontaVista Softare Inc.
 
  14  * This program is free software; you can redistribute  it and/or modify it
 
  15  * under  the terms of  the GNU General  Public License as published by the
 
  16  * Free Software Foundation;  either version 2 of the  License, or (at your
 
  17  * option) any later version.
 
  20 #ifndef __IBM_EMAC_CORE_H_
 
  21 #define __IBM_EMAC_CORE_H_
 
  23 #include <linux/config.h>
 
  24 #include <linux/netdevice.h>
 
  25 #include <linux/dma-mapping.h>
 
  29 #include "ibm_emac_phy.h"
 
  30 #include "ibm_emac_zmii.h"
 
  31 #include "ibm_emac_rgmii.h"
 
  32 #include "ibm_emac_mal.h"
 
  33 #include "ibm_emac_tah.h"
 
  35 #define NUM_TX_BUFF                     CONFIG_IBM_EMAC_TXB
 
  36 #define NUM_RX_BUFF                     CONFIG_IBM_EMAC_RXB
 
  38 /* Simple sanity check */
 
  39 #if NUM_TX_BUFF > 256 || NUM_RX_BUFF > 256
 
  40 #error Invalid number of buffer descriptors (greater than 256)
 
  44 #define EMAC_MIN_MTU                    46
 
  45 #define EMAC_MAX_MTU                    9000
 
  47 /* Maximum L2 header length (VLAN tagged, no FCS) */
 
  48 #define EMAC_MTU_OVERHEAD               (6 * 2 + 2 + 4)
 
  50 /* RX BD size for the given MTU */
 
  51 static inline int emac_rx_size(int mtu)
 
  53         if (mtu > ETH_DATA_LEN)
 
  54                 return MAL_MAX_RX_SIZE;
 
  56                 return mal_rx_size(ETH_DATA_LEN + EMAC_MTU_OVERHEAD);
 
  59 #define EMAC_DMA_ALIGN(x)               ALIGN((x), dma_get_cache_alignment())
 
  61 #define EMAC_RX_SKB_HEADROOM            \
 
  62         EMAC_DMA_ALIGN(CONFIG_IBM_EMAC_RX_SKB_HEADROOM)
 
  64 /* Size of RX skb for the given MTU */
 
  65 static inline int emac_rx_skb_size(int mtu)
 
  67         int size = max(mtu + EMAC_MTU_OVERHEAD, emac_rx_size(mtu));
 
  68         return EMAC_DMA_ALIGN(size + 2) + EMAC_RX_SKB_HEADROOM;
 
  71 /* RX DMA sync size */
 
  72 static inline int emac_rx_sync_size(int mtu)
 
  74         return EMAC_DMA_ALIGN(emac_rx_size(mtu) + 2);
 
  77 /* Driver statistcs is split into two parts to make it more cache friendly:
 
  78  *   - normal statistics (packet count, etc)
 
  81  * When statistics is requested by ethtool, these parts are concatenated,
 
  82  * normal one goes first.
 
  84  * Please, keep these structures in sync with emac_stats_keys.
 
  87 /* Normal TX/RX Statistics */
 
  88 struct ibm_emac_stats {
 
  97 /* Error statistics */
 
  98 struct ibm_emac_error_stats {
 
 101         /* Software RX Errors */
 
 102         u64 rx_dropped_stack;
 
 104         u64 rx_dropped_error;
 
 105         u64 rx_dropped_resize;
 
 108         /* BD reported RX errors */
 
 111         u64 rx_bd_bad_packet;
 
 112         u64 rx_bd_runt_packet;
 
 113         u64 rx_bd_short_event;
 
 114         u64 rx_bd_alignment_error;
 
 116         u64 rx_bd_packet_too_long;
 
 117         u64 rx_bd_out_of_range;
 
 119         /* EMAC IRQ reported RX errors */
 
 126         u64 rx_alignment_error;
 
 128         u64 rx_packet_too_long;
 
 132         /* Software TX Errors */
 
 134         /* BD reported TX errors */
 
 137         u64 tx_bd_carrier_loss;
 
 138         u64 tx_bd_excessive_deferral;
 
 139         u64 tx_bd_excessive_collisions;
 
 140         u64 tx_bd_late_collision;
 
 141         u64 tx_bd_multple_collisions;
 
 142         u64 tx_bd_single_collision;
 
 145         /* EMAC IRQ reported TX errors */
 
 152 #define EMAC_ETHTOOL_STATS_COUNT        ((sizeof(struct ibm_emac_stats) + \
 
 153                                           sizeof(struct ibm_emac_error_stats)) \
 
 156 struct ocp_enet_private {
 
 157         struct net_device               *ndev;          /* 0 */
 
 158         struct emac_regs                *emacp;
 
 160         struct mal_descriptor           *tx_desc;
 
 165         struct mal_descriptor           *rx_desc;
 
 167         struct sk_buff                  *rx_sg_skb;     /* 1 */
 
 171         struct ibm_emac_stats           stats;
 
 172         struct ocp_device               *tah_dev;
 
 174         struct ibm_ocp_mal              *mal;
 
 175         struct mal_commac               commac;
 
 177         struct sk_buff                  *tx_skb[NUM_TX_BUFF];
 
 178         struct sk_buff                  *rx_skb[NUM_RX_BUFF];
 
 180         struct ocp_device               *zmii_dev;
 
 182         struct ocp_enet_private         *mdio_dev;
 
 183         struct ocp_device               *rgmii_dev;
 
 189         struct timer_list               link_timer;
 
 192         int                             stop_timeout;   /* in us */
 
 194         struct ibm_emac_error_stats     estats;
 
 195         struct net_device_stats         nstats;
 
 200 /* Ethtool get_regs complex data.
 
 201  * We want to get not just EMAC registers, but also MAL, ZMII, RGMII, TAH 
 
 204  * Returned BLOB consists of the ibm_emac_ethtool_regs_hdr, 
 
 205  * MAL registers, EMAC registers and optional ZMII, RGMII, TAH registers.
 
 206  * Each register component is preceded with emac_ethtool_regs_subhdr.
 
 207  * Order of the optional headers follows their relative bit posititions 
 
 208  * in emac_ethtool_regs_hdr.components
 
 210 #define EMAC_ETHTOOL_REGS_ZMII          0x00000001
 
 211 #define EMAC_ETHTOOL_REGS_RGMII         0x00000002
 
 212 #define EMAC_ETHTOOL_REGS_TAH           0x00000004
 
 214 struct emac_ethtool_regs_hdr {
 
 218 struct emac_ethtool_regs_subhdr {
 
 223 #endif                          /* __IBM_EMAC_CORE_H_ */