2 * Blackfin On-Chip MAC Driver
4 * Copyright 2004-2007 Analog Devices Inc.
6 * Enter bugs at http://blackfin.uclinux.org/
8 * Licensed under the GPL-2 or later.
11 #define BFIN_MAC_CSUM_OFFLOAD
13 struct dma_descriptor {
14 struct dma_descriptor *next_dma_desc;
15 unsigned long start_addr;
16 unsigned short config;
17 unsigned short x_count;
20 struct status_area_rx {
21 #if defined(BFIN_MAC_CSUM_OFFLOAD)
22 unsigned short ip_hdr_csum; /* ip header checksum */
23 /* ip payload(udp or tcp or others) checksum */
24 unsigned short ip_payload_csum;
26 unsigned long status_word; /* the frame status word */
29 struct status_area_tx {
30 unsigned long status_word; /* the frame status word */
33 /* use two descriptors for a packet */
34 struct net_dma_desc_rx {
35 struct net_dma_desc_rx *next;
37 struct dma_descriptor desc_a;
38 struct dma_descriptor desc_b;
39 struct status_area_rx status;
42 /* use two descriptors for a packet */
43 struct net_dma_desc_tx {
44 struct net_dma_desc_tx *next;
46 struct dma_descriptor desc_a;
47 struct dma_descriptor desc_b;
48 unsigned char packet[1560];
49 struct status_area_tx status;
52 struct bfin_mac_local {
54 * these are things that the kernel wants me to keep, so users
55 * can find out semi-useless statistics of how well the card is
58 struct net_device_stats stats;
60 unsigned char Mac[6]; /* MAC address of the board */
63 /* MII and PHY stuffs */
64 int old_link; /* used by bf537_adjust_link */
68 struct phy_device *phydev;
69 struct mii_bus mii_bus;
72 extern void bfin_get_ether_addr(char *addr);