OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [net/] [acenic.h] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
#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
 
35
struct 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
 
166
typedef 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
 
320
struct 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
 
366
struct 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
 
456
struct 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
 
493
struct 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
 */
531
struct 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
 
544
struct 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
 
578
struct 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
 
596
struct 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
 */
607
struct 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
 */
619
struct 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
 */
638
struct 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
 
709
static 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
 
723
static 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
 
732
static 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
 
751
static 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
 
765
static 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
 */
780
static int ace_init(struct net_device *dev);
781
static void ace_load_std_rx_ring(struct ace_private *ap, int nr_bufs);
782
static void ace_load_mini_rx_ring(struct ace_private *ap, int nr_bufs);
783
static void ace_load_jumbo_rx_ring(struct ace_private *ap, int nr_bufs);
784
static void ace_interrupt(int irq, void *dev_id, struct pt_regs *regs);
785
static int ace_load_firmware(struct net_device *dev);
786
static int ace_open(struct net_device *dev);
787
static int ace_start_xmit(struct sk_buff *skb, struct net_device *dev);
788
static int ace_close(struct net_device *dev);
789
static void ace_tasklet(unsigned long dev);
790
static void ace_dump_trace(struct ace_private *ap);
791
static void ace_set_multicast_list(struct net_device *dev);
792
static int ace_change_mtu(struct net_device *dev, int new_mtu);
793
static int ace_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd);
794
static int ace_set_mac_addr(struct net_device *dev, void *p);
795
static void ace_set_rxtx_parms(struct net_device *dev, int jumbo);
796
static int ace_allocate_descriptors(struct net_device *dev);
797
static void ace_free_descriptors(struct net_device *dev);
798
static void ace_init_cleanup(struct net_device *dev);
799
static struct net_device_stats *ace_get_stats(struct net_device *dev);
800
static int read_eeprom_byte(struct net_device *dev, unsigned long offset);
801
#if ACENIC_DO_VLAN
802
static void ace_vlan_rx_register(struct net_device *dev, struct vlan_group *grp);
803
static void ace_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid);
804
#endif
805
 
806
#endif /* _ACENIC_H_ */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.