linux-bk/drivers/net/acenic.h
<<
>>
Prefs
   1#ifndef _ACENIC_H_
   2#define _ACENIC_H_
   3
   4#include <linux/config.h>
   5
   6/*
   7 * Generate TX index update each time, when TX ring is closed.
   8 * Normally, this is not useful, because results in more dma (and irqs
   9 * without TX_COAL_INTS_ONLY).
  10 */
  11#define USE_TX_COAL_NOW  0
  12
  13#ifndef MAX_SKB_FRAGS
  14#define MAX_SKB_FRAGS 0
  15#endif
  16
  17
  18/*
  19 * Addressing:
  20 *
  21 * The Tigon uses 64-bit host addresses, regardless of their actual
  22 * length, and it expects a big-endian format. For 32 bit systems the
  23 * upper 32 bits of the address are simply ignored (zero), however for
  24 * little endian 64 bit systems (Alpha) this looks strange with the
  25 * two parts of the address word being swapped.
  26 *
  27 * The addresses are split in two 32 bit words for all architectures
  28 * as some of them are in PCI shared memory and it is necessary to use
  29 * readl/writel to access them.
  30 *
  31 * The addressing code is derived from Pete Wyckoff's work, but
  32 * modified to deal properly with readl/writel usage.
  33 */
  34
  35struct ace_regs {
  36        u32     pad0[16];       /* PCI control registers */
  37
  38        u32     HostCtrl;       /* 0x40 */
  39        u32     LocalCtrl;
  40
  41        u32     pad1[2];
  42
  43        u32     MiscCfg;        /* 0x50 */
  44
  45        u32     pad2[2];
  46
  47        u32     PciState;
  48
  49        u32     pad3[2];        /* 0x60 */
  50
  51        u32     WinBase;
  52        u32     WinData;
  53
  54        u32     pad4[12];       /* 0x70 */
  55
  56        u32     DmaWriteState;  /* 0xa0 */
  57        u32     pad5[3];
  58        u32     DmaReadState;   /* 0xb0 */
  59
  60        u32     pad6[26];
  61
  62        u32     AssistState;
  63
  64        u32     pad7[8];        /* 0x120 */
  65
  66        u32     CpuCtrl;        /* 0x140 */
  67        u32     Pc;
  68
  69        u32     pad8[3];
  70
  71        u32     SramAddr;       /* 0x154 */
  72        u32     SramData;
  73
  74        u32     pad9[49];
  75
  76        u32     MacRxState;     /* 0x220 */
  77
  78        u32     pad10[7];
  79
  80        u32     CpuBCtrl;       /* 0x240 */
  81        u32     PcB;
  82
  83        u32     pad11[3];
  84
  85        u32     SramBAddr;      /* 0x254 */
  86        u32     SramBData;
  87
  88        u32     pad12[105];
  89
  90        u32     pad13[32];      /* 0x400 */
  91        u32     Stats[32];
  92
  93        u32     Mb0Hi;          /* 0x500 */
  94        u32     Mb0Lo;
  95        u32     Mb1Hi;
  96        u32     CmdPrd;
  97        u32     Mb2Hi;
  98        u32     TxPrd;
  99        u32     Mb3Hi;
 100        u32     RxStdPrd;
 101        u32     Mb4Hi;
 102        u32     RxJumboPrd;
 103        u32     Mb5Hi;
 104        u32     RxMiniPrd;
 105        u32     Mb6Hi;
 106        u32     Mb6Lo;
 107        u32     Mb7Hi;
 108        u32     Mb7Lo;
 109        u32     Mb8Hi;
 110        u32     Mb8Lo;
 111        u32     Mb9Hi;
 112        u32     Mb9Lo;
 113        u32     MbAHi;
 114        u32     MbALo;
 115        u32     MbBHi;
 116        u32     MbBLo;
 117        u32     MbCHi;
 118        u32     MbCLo;
 119        u32     MbDHi;
 120        u32     MbDLo;
 121        u32     MbEHi;
 122        u32     MbELo;
 123        u32     MbFHi;
 124        u32     MbFLo;
 125
 126        u32     pad14[32];
 127
 128        u32     MacAddrHi;      /* 0x600 */
 129        u32     MacAddrLo;
 130        u32     InfoPtrHi;
 131        u32     InfoPtrLo;
 132        u32     MultiCastHi;    /* 0x610 */
 133        u32     MultiCastLo;
 134        u32     ModeStat;
 135        u32     DmaReadCfg;
 136        u32     DmaWriteCfg;    /* 0x620 */
 137        u32     TxBufRat;
 138        u32     EvtCsm;
 139        u32     CmdCsm;
 140        u32     TuneRxCoalTicks;/* 0x630 */
 141        u32     TuneTxCoalTicks;
 142        u32     TuneStatTicks;
 143        u32     TuneMaxTxDesc;
 144        u32     TuneMaxRxDesc;  /* 0x640 */
 145        u32     TuneTrace;
 146        u32     TuneLink;
 147        u32     TuneFastLink;
 148        u32     TracePtr;       /* 0x650 */
 149        u32     TraceStrt;
 150        u32     TraceLen;
 151        u32     IfIdx;
 152        u32     IfMtu;          /* 0x660 */
 153        u32     MaskInt;
 154        u32     GigLnkState;
 155        u32     FastLnkState;
 156        u32     pad16[4];       /* 0x670 */
 157        u32     RxRetCsm;       /* 0x680 */
 158
 159        u32     pad17[31];
 160
 161        u32     CmdRng[64];     /* 0x700 */
 162        u32     Window[0x200];
 163};
 164
 165
 166typedef struct {
 167        u32 addrhi;
 168        u32 addrlo;
 169} aceaddr;
 170
 171
 172#define ACE_WINDOW_SIZE 0x800
 173
 174#define ACE_JUMBO_MTU 9000
 175#define ACE_STD_MTU 1500
 176
 177#define ACE_TRACE_SIZE 0x8000
 178
 179/*
 180 * Host control register bits.
 181 */
 182        
 183#define IN_INT          0x01
 184#define CLR_INT         0x02
 185#define HW_RESET        0x08
 186#define BYTE_SWAP       0x10
 187#define WORD_SWAP       0x20
 188#define MASK_INTS       0x40
 189
 190/*
 191 * Local control register bits.
 192 */
 193
 194#define EEPROM_DATA_IN          0x800000
 195#define EEPROM_DATA_OUT         0x400000
 196#define EEPROM_WRITE_ENABLE     0x200000
 197#define EEPROM_CLK_OUT          0x100000
 198
 199#define EEPROM_BASE             0xa0000000
 200
 201#define EEPROM_WRITE_SELECT     0xa0
 202#define EEPROM_READ_SELECT      0xa1
 203
 204#define SRAM_BANK_512K          0x200
 205
 206
 207/*
 208 * udelay() values for when clocking the eeprom
 209 */
 210#define ACE_SHORT_DELAY         2
 211#define ACE_LONG_DELAY          4
 212
 213
 214/*
 215 * Misc Config bits
 216 */
 217
 218#define SYNC_SRAM_TIMING        0x100000
 219
 220
 221/*
 222 * CPU state bits.
 223 */
 224
 225#define CPU_RESET               0x01
 226#define CPU_TRACE               0x02
 227#define CPU_PROM_FAILED         0x10
 228#define CPU_HALT                0x00010000
 229#define CPU_HALTED              0xffff0000
 230
 231
 232/*
 233 * PCI State bits.
 234 */
 235
 236#define DMA_READ_MAX_4          0x04
 237#define DMA_READ_MAX_16         0x08
 238#define DMA_READ_MAX_32         0x0c
 239#define DMA_READ_MAX_64         0x10
 240#define DMA_READ_MAX_128        0x14
 241#define DMA_READ_MAX_256        0x18
 242#define DMA_READ_MAX_1K         0x1c
 243#define DMA_WRITE_MAX_4         0x20
 244#define DMA_WRITE_MAX_16        0x40
 245#define DMA_WRITE_MAX_32        0x60
 246#define DMA_WRITE_MAX_64        0x80
 247#define DMA_WRITE_MAX_128       0xa0
 248#define DMA_WRITE_MAX_256       0xc0
 249#define DMA_WRITE_MAX_1K        0xe0
 250#define DMA_READ_WRITE_MASK     0xfc
 251#define MEM_READ_MULTIPLE       0x00020000
 252#define PCI_66MHZ               0x00080000
 253#define PCI_32BIT               0x00100000
 254#define DMA_WRITE_ALL_ALIGN     0x00800000
 255#define READ_CMD_MEM            0x06000000
 256#define WRITE_CMD_MEM           0x70000000
 257
 258
 259/*
 260 * Mode status
 261 */
 262
 263#define ACE_BYTE_SWAP_BD        0x02
 264#define ACE_WORD_SWAP_BD        0x04            /* not actually used */
 265#define ACE_WARN                0x08
 266#define ACE_BYTE_SWAP_DMA       0x10
 267#define ACE_NO_JUMBO_FRAG       0x200
 268#define ACE_FATAL               0x40000000
 269
 270
 271/*
 272 * DMA config
 273 */
 274
 275#define DMA_THRESH_1W           0x10
 276#define DMA_THRESH_2W           0x20
 277#define DMA_THRESH_4W           0x40
 278#define DMA_THRESH_8W           0x80
 279#define DMA_THRESH_16W          0x100
 280#define DMA_THRESH_32W          0x0     /* not described in doc, but exists. */
 281
 282
 283/*
 284 * Tuning parameters
 285 */
 286
 287#define TICKS_PER_SEC           1000000
 288
 289
 290/*
 291 * Link bits
 292 */
 293
 294#define LNK_PREF                0x00008000
 295#define LNK_10MB                0x00010000
 296#define LNK_100MB               0x00020000
 297#define LNK_1000MB              0x00040000
 298#define LNK_FULL_DUPLEX         0x00080000
 299#define LNK_HALF_DUPLEX         0x00100000
 300#define LNK_TX_FLOW_CTL_Y       0x00200000
 301#define LNK_NEG_ADVANCED        0x00400000
 302#define LNK_RX_FLOW_CTL_Y       0x00800000
 303#define LNK_NIC                 0x01000000
 304#define LNK_JAM                 0x02000000
 305#define LNK_JUMBO               0x04000000
 306#define LNK_ALTEON              0x08000000
 307#define LNK_NEG_FCTL            0x10000000
 308#define LNK_NEGOTIATE           0x20000000
 309#define LNK_ENABLE              0x40000000
 310#define LNK_UP                  0x80000000
 311
 312
 313/*
 314 * Event definitions
 315 */
 316
 317#define EVT_RING_ENTRIES        256
 318#define EVT_RING_SIZE   (EVT_RING_ENTRIES * sizeof(struct event))
 319
 320struct event {
 321#ifdef __LITTLE_ENDIAN_BITFIELD
 322        u32     idx:12;
 323        u32     code:12;
 324        u32     evt:8;
 325#else
 326        u32     evt:8;
 327        u32     code:12;
 328        u32     idx:12;
 329#endif
 330        u32     pad;
 331};
 332
 333
 334/*
 335 * Events
 336 */
 337
 338#define E_FW_RUNNING            0x01
 339#define E_STATS_UPDATED         0x04
 340
 341#define E_STATS_UPDATE          0x04
 342
 343#define E_LNK_STATE             0x06
 344#define E_C_LINK_UP             0x01
 345#define E_C_LINK_DOWN           0x02
 346#define E_C_LINK_10_100         0x03
 347
 348#define E_ERROR                 0x07
 349#define E_C_ERR_INVAL_CMD       0x01
 350#define E_C_ERR_UNIMP_CMD       0x02
 351#define E_C_ERR_BAD_CFG         0x03
 352
 353#define E_MCAST_LIST            0x08
 354#define E_C_MCAST_ADDR_ADD      0x01
 355#define E_C_MCAST_ADDR_DEL      0x02
 356
 357#define E_RESET_JUMBO_RNG       0x09
 358
 359
 360/*
 361 * Commands
 362 */
 363
 364#define CMD_RING_ENTRIES        64
 365
 366struct cmd {
 367#ifdef __LITTLE_ENDIAN_BITFIELD
 368        u32     idx:12;
 369        u32     code:12;
 370        u32     evt:8;
 371#else
 372        u32     evt:8;
 373        u32     code:12;
 374        u32     idx:12;
 375#endif
 376};
 377
 378
 379#define C_HOST_STATE            0x01
 380#define C_C_STACK_UP            0x01
 381#define C_C_STACK_DOWN          0x02
 382
 383#define C_FDR_FILTERING         0x02
 384#define C_C_FDR_FILT_ENABLE     0x01
 385#define C_C_FDR_FILT_DISABLE    0x02
 386
 387#define C_SET_RX_PRD_IDX        0x03
 388#define C_UPDATE_STATS          0x04
 389#define C_RESET_JUMBO_RNG       0x05
 390#define C_ADD_MULTICAST_ADDR    0x08
 391#define C_DEL_MULTICAST_ADDR    0x09
 392
 393#define C_SET_PROMISC_MODE      0x0a
 394#define C_C_PROMISC_ENABLE      0x01
 395#define C_C_PROMISC_DISABLE     0x02
 396
 397#define C_LNK_NEGOTIATION       0x0b
 398#define C_C_NEGOTIATE_BOTH      0x00
 399#define C_C_NEGOTIATE_GIG       0x01
 400#define C_C_NEGOTIATE_10_100    0x02
 401
 402#define C_SET_MAC_ADDR          0x0c
 403#define C_CLEAR_PROFILE         0x0d
 404
 405#define C_SET_MULTICAST_MODE    0x0e
 406#define C_C_MCAST_ENABLE        0x01
 407#define C_C_MCAST_DISABLE       0x02
 408
 409#define C_CLEAR_STATS           0x0f
 410#define C_SET_RX_JUMBO_PRD_IDX  0x10
 411#define C_REFRESH_STATS         0x11
 412
 413
 414/*
 415 * Descriptor flags
 416 */
 417#define BD_FLG_TCP_UDP_SUM      0x01
 418#define BD_FLG_IP_SUM           0x02
 419#define BD_FLG_END              0x04
 420#define BD_FLG_MORE             0x08
 421#define BD_FLG_JUMBO            0x10
 422#define BD_FLG_UCAST            0x20
 423#define BD_FLG_MCAST            0x40
 424#define BD_FLG_BCAST            0x60
 425#define BD_FLG_TYP_MASK         0x60
 426#define BD_FLG_IP_FRAG          0x80
 427#define BD_FLG_IP_FRAG_END      0x100
 428#define BD_FLG_VLAN_TAG         0x200
 429#define BD_FLG_FRAME_ERROR      0x400
 430#define BD_FLG_COAL_NOW         0x800
 431#define BD_FLG_MINI             0x1000
 432
 433
 434/*
 435 * Ring Control block flags
 436 */
 437#define RCB_FLG_TCP_UDP_SUM     0x01
 438#define RCB_FLG_IP_SUM          0x02
 439#define RCB_FLG_NO_PSEUDO_HDR   0x08
 440#define RCB_FLG_VLAN_ASSIST     0x10
 441#define RCB_FLG_COAL_INT_ONLY   0x20
 442#define RCB_FLG_TX_HOST_RING    0x40
 443#define RCB_FLG_IEEE_SNAP_SUM   0x80
 444#define RCB_FLG_EXT_RX_BD       0x100
 445#define RCB_FLG_RNG_DISABLE     0x200
 446
 447
 448/*
 449 * TX ring - maximum TX ring entries for Tigon I's is 128
 450 */
 451#define MAX_TX_RING_ENTRIES     256
 452#define TIGON_I_TX_RING_ENTRIES 128
 453#define TX_RING_SIZE            (MAX_TX_RING_ENTRIES * sizeof(struct tx_desc))
 454#define TX_RING_BASE            0x3800
 455
 456struct tx_desc{
 457        aceaddr addr;
 458        u32     flagsize; 
 459#if 0
 460/*
 461 * This is in PCI shared mem and must be accessed with readl/writel
 462 * real layout is:
 463 */
 464#if __LITTLE_ENDIAN
 465        u16     flags;
 466        u16     size;
 467        u16     vlan;
 468        u16     reserved;
 469#else
 470        u16     size;
 471        u16     flags;
 472        u16     reserved;
 473        u16     vlan;
 474#endif
 475#endif
 476        u32     vlanres;
 477};
 478
 479
 480#define RX_STD_RING_ENTRIES     512
 481#define RX_STD_RING_SIZE        (RX_STD_RING_ENTRIES * sizeof(struct rx_desc))
 482
 483#define RX_JUMBO_RING_ENTRIES   256
 484#define RX_JUMBO_RING_SIZE      (RX_JUMBO_RING_ENTRIES *sizeof(struct rx_desc))
 485
 486#define RX_MINI_RING_ENTRIES    1024
 487#define RX_MINI_RING_SIZE       (RX_MINI_RING_ENTRIES *sizeof(struct rx_desc))
 488
 489#define RX_RETURN_RING_ENTRIES  2048
 490#define RX_RETURN_RING_SIZE     (RX_MAX_RETURN_RING_ENTRIES * \
 491                                 sizeof(struct rx_desc))
 492
 493struct rx_desc{
 494        aceaddr addr;
 495#ifdef __LITTLE_ENDIAN
 496        u16     size;
 497        u16     idx;
 498#else
 499        u16     idx;
 500        u16     size;
 501#endif
 502#ifdef __LITTLE_ENDIAN
 503        u16     flags;
 504        u16     type;
 505#else
 506        u16     type;
 507        u16     flags;
 508#endif
 509#ifdef __LITTLE_ENDIAN
 510        u16     tcp_udp_csum;
 511        u16     ip_csum;
 512#else
 513        u16     ip_csum;
 514        u16     tcp_udp_csum;
 515#endif
 516#ifdef __LITTLE_ENDIAN
 517        u16     vlan;
 518        u16     err_flags;
 519#else
 520        u16     err_flags;
 521        u16     vlan;
 522#endif
 523        u32     reserved;
 524        u32     opague;
 525};
 526
 527
 528/*
 529 * This struct is shared with the NIC firmware.
 530 */
 531struct ring_ctrl {
 532        aceaddr rngptr;
 533#ifdef __LITTLE_ENDIAN
 534        u16     flags;
 535        u16     max_len;
 536#else
 537        u16     max_len;
 538        u16     flags;
 539#endif
 540        u32     pad;
 541};
 542
 543
 544struct ace_mac_stats {
 545        u32 excess_colls;
 546        u32 coll_1;
 547        u32 coll_2;
 548        u32 coll_3;
 549        u32 coll_4;
 550        u32 coll_5;
 551        u32 coll_6;
 552        u32 coll_7;
 553        u32 coll_8;
 554        u32 coll_9;
 555        u32 coll_10;
 556        u32 coll_11;
 557        u32 coll_12;
 558        u32 coll_13;
 559        u32 coll_14;
 560        u32 coll_15;
 561        u32 late_coll;
 562        u32 defers;
 563        u32 crc_err;
 564        u32 underrun;
 565        u32 crs_err;
 566        u32 pad[3];
 567        u32 drop_ula;
 568        u32 drop_mc;
 569        u32 drop_fc;
 570        u32 drop_space;
 571        u32 coll;
 572        u32 kept_bc;
 573        u32 kept_mc;
 574        u32 kept_uc;
 575};
 576
 577
 578struct ace_info {
 579        union {
 580                u32 stats[256];
 581        } s;
 582        struct ring_ctrl        evt_ctrl;
 583        struct ring_ctrl        cmd_ctrl;
 584        struct ring_ctrl        tx_ctrl;
 585        struct ring_ctrl        rx_std_ctrl;
 586        struct ring_ctrl        rx_jumbo_ctrl;
 587        struct ring_ctrl        rx_mini_ctrl;
 588        struct ring_ctrl        rx_return_ctrl;
 589        aceaddr evt_prd_ptr;
 590        aceaddr rx_ret_prd_ptr;
 591        aceaddr tx_csm_ptr;
 592        aceaddr stats2_ptr;
 593};
 594
 595
 596struct ring_info {
 597        struct sk_buff          *skb;
 598        DECLARE_PCI_UNMAP_ADDR(mapping)
 599};
 600
 601
 602/*
 603 * Funny... As soon as we add maplen on alpha, it starts to work
 604 * much slower. Hmm... is it because struct does not fit to one cacheline?
 605 * So, split tx_ring_info.
 606 */
 607struct tx_ring_info {
 608        struct sk_buff          *skb;
 609        DECLARE_PCI_UNMAP_ADDR(mapping)
 610        DECLARE_PCI_UNMAP_LEN(maplen)
 611};
 612
 613
 614/*
 615 * struct ace_skb holding the rings of skb's. This is an awful lot of
 616 * pointers, but I don't see any other smart mode to do this in an
 617 * efficient manner ;-(
 618 */
 619struct ace_skb
 620{
 621        struct tx_ring_info     tx_skbuff[MAX_TX_RING_ENTRIES];
 622        struct ring_info        rx_std_skbuff[RX_STD_RING_ENTRIES];
 623        struct ring_info        rx_mini_skbuff[RX_MINI_RING_ENTRIES];
 624        struct ring_info        rx_jumbo_skbuff[RX_JUMBO_RING_ENTRIES];
 625};
 626
 627
 628/*
 629 * Struct private for the AceNIC.
 630 *
 631 * Elements are grouped so variables used by the tx handling goes
 632 * together, and will go into the same cache lines etc. in order to
 633 * avoid cache line contention between the rx and tx handling on SMP.
 634 *
 635 * Frequently accessed variables are put at the beginning of the
 636 * struct to help the compiler generate better/shorter code.
 637 */
 638struct ace_private
 639{
 640        struct ace_info         *info;
 641        struct ace_regs         *regs;          /* register base */
 642        struct ace_skb          *skb;
 643        dma_addr_t              info_dma;       /* 32/64 bit */
 644
 645        int                     version, link;
 646        int                     promisc, mcast_all;
 647
 648        /*
 649         * TX elements
 650         */
 651        struct tx_desc          *tx_ring;
 652        u32                     tx_prd;
 653        volatile u32            tx_ret_csm;
 654        int                     tx_ring_entries;
 655
 656        /*
 657         * RX elements
 658         */
 659        unsigned long           std_refill_busy
 660                                __attribute__ ((aligned (SMP_CACHE_BYTES)));
 661        unsigned long           mini_refill_busy, jumbo_refill_busy;
 662        atomic_t                cur_rx_bufs;
 663        atomic_t                cur_mini_bufs;
 664        atomic_t                cur_jumbo_bufs;
 665        u32                     rx_std_skbprd, rx_mini_skbprd, rx_jumbo_skbprd;
 666        u32                     cur_rx;
 667
 668        struct rx_desc          *rx_std_ring;
 669        struct rx_desc          *rx_jumbo_ring;
 670        struct rx_desc          *rx_mini_ring;
 671        struct rx_desc          *rx_return_ring;
 672
 673#if ACENIC_DO_VLAN
 674        struct vlan_group       *vlgrp;
 675#endif
 676
 677        int                     tasklet_pending, jumbo;
 678        struct tasklet_struct   ace_tasklet;
 679
 680        struct event            *evt_ring;
 681
 682        volatile u32            *evt_prd, *rx_ret_prd, *tx_csm;
 683
 684        dma_addr_t              tx_ring_dma;    /* 32/64 bit */
 685        dma_addr_t              rx_ring_base_dma;
 686        dma_addr_t              evt_ring_dma;
 687        dma_addr_t              evt_prd_dma, rx_ret_prd_dma, tx_csm_dma;
 688
 689        unsigned char           *trace_buf;
 690        struct pci_dev          *pdev;
 691        struct net_device       *next;
 692        volatile int            fw_running;
 693        int                     board_idx;
 694        u16                     pci_command;
 695        u8                      pci_latency;
 696        char                    name[48];
 697#ifdef INDEX_DEBUG
 698        spinlock_t              debug_lock
 699                                __attribute__ ((aligned (SMP_CACHE_BYTES)));;
 700        u32                     last_tx, last_std_rx, last_mini_rx;
 701#endif
 702        struct net_device_stats stats;
 703        int                     pci_using_dac;
 704};
 705
 706
 707#define TX_RESERVED     MAX_SKB_FRAGS
 708
 709static inline int tx_space (struct ace_private *ap, u32 csm, u32 prd)
 710{
 711        return (csm - prd - 1) & (ACE_TX_RING_ENTRIES(ap) - 1);
 712}
 713
 714#define tx_free(ap)             tx_space((ap)->tx_ret_csm, (ap)->tx_prd, ap)
 715
 716#if MAX_SKB_FRAGS
 717#define tx_ring_full(ap, csm, prd)      (tx_space(ap, csm, prd) <= TX_RESERVED)
 718#else
 719#define tx_ring_full                    0
 720#endif
 721
 722
 723static inline void set_aceaddr(aceaddr *aa, dma_addr_t addr)
 724{
 725        u64 baddr = (u64) addr;
 726        aa->addrlo = baddr & 0xffffffff;
 727        aa->addrhi = baddr >> 32;
 728        wmb();
 729}
 730
 731
 732static inline void ace_set_txprd(struct ace_regs *regs,
 733                                 struct ace_private *ap, u32 value)
 734{
 735#ifdef INDEX_DEBUG
 736        unsigned long flags;
 737        spin_lock_irqsave(&ap->debug_lock, flags);
 738        writel(value, &regs->TxPrd);
 739        if (value == ap->last_tx)
 740                printk(KERN_ERR "AceNIC RACE ALERT! writing identical value "
 741                       "to tx producer (%i)\n", value);
 742        ap->last_tx = value;
 743        spin_unlock_irqrestore(&ap->debug_lock, flags);
 744#else
 745        writel(value, &regs->TxPrd);
 746#endif
 747        wmb();
 748}
 749
 750
 751static inline void ace_mask_irq(struct net_device *dev)
 752{
 753        struct ace_private *ap = dev->priv;
 754        struct ace_regs *regs = ap->regs;
 755
 756        if (ACE_IS_TIGON_I(ap))
 757                writel(1, &regs->MaskInt);
 758        else
 759                writel(readl(&regs->HostCtrl) | MASK_INTS, &regs->HostCtrl);
 760
 761        ace_sync_irq(dev->irq);
 762}
 763
 764
 765static inline void ace_unmask_irq(struct net_device *dev)
 766{
 767        struct ace_private *ap = dev->priv;
 768        struct ace_regs *regs = ap->regs;
 769 
 770        if (ACE_IS_TIGON_I(ap))
 771                writel(0, &regs->MaskInt);
 772        else
 773                writel(readl(&regs->HostCtrl) &= ~MASK_INTS, &regs->HostCtrl);
 774}
 775
 776
 777/*
 778 * Prototypes
 779 */
 780static int ace_init(struct net_device *dev);
 781static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs);
 782static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs);
 783static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs);
 784static void ace_interrupt(int irq, void *dev_id, struct pt_regs *regs);
 785static int ace_load_firmware(struct net_device *dev);
 786static int ace_open(struct net_device *dev);
 787static int ace_start_xmit(struct sk_buff *skb, struct net_device *dev);
 788static int ace_close(struct net_device *dev);
 789static void ace_tasklet(unsigned long dev);
 790static void ace_dump_trace(struct ace_private *ap);
 791static void ace_set_multicast_list(struct net_device *dev);
 792static int ace_change_mtu(struct net_device *dev, int new_mtu);
 793static int ace_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd);
 794static int ace_set_mac_addr(struct net_device *dev, void *p);
 795static void ace_set_rxtx_parms(struct net_device *dev, int jumbo);
 796static int ace_allocate_descriptors(struct net_device *dev);
 797static void ace_free_descriptors(struct net_device *dev);
 798static void ace_init_cleanup(struct net_device *dev);
 799static struct net_device_stats *ace_get_stats(struct net_device *dev);
 800static int read_eeprom_byte(struct net_device *dev, unsigned long offset);
 801#if ACENIC_DO_VLAN
 802static void ace_vlan_rx_register(struct net_device *dev, struct vlan_group *grp);
 803static void ace_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid);
 804#endif
 805
 806#endif /* _ACENIC_H_ */
 807
lxr.linux.no kindly hosted by Redpill Linpro AS, provider of Linux consulting and operations services since 1995.