Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / drivers / net / ethernet / atheros / alx / hw.h
1 /*
2  * Copyright (c) 2013 Johannes Berg <johannes@sipsolutions.net>
3  *
4  *  This file is free software: you may copy, redistribute and/or modify it
5  *  under the terms of the GNU General Public License as published by the
6  *  Free Software Foundation, either version 2 of the License, or (at your
7  *  option) any later version.
8  *
9  *  This file is distributed in the hope that it will be useful, but
10  *  WITHOUT ANY WARRANTY; without even the implied warranty of
11  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  *  General Public License for more details.
13  *
14  *  You should have received a copy of the GNU General Public License
15  *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  *
17  * This file incorporates work covered by the following copyright and
18  * permission notice:
19  *
20  * Copyright (c) 2012 Qualcomm Atheros, Inc.
21  *
22  * Permission to use, copy, modify, and/or distribute this software for any
23  * purpose with or without fee is hereby granted, provided that the above
24  * copyright notice and this permission notice appear in all copies.
25  *
26  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
27  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
28  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
29  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
30  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
31  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
32  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
33  */
34
35 #ifndef ALX_HW_H_
36 #define ALX_HW_H_
37 #include <linux/types.h>
38 #include <linux/mdio.h>
39 #include <linux/pci.h>
40 #include "reg.h"
41
42 /* Transmit Packet Descriptor, contains 4 32-bit words.
43  *
44  *   31               16               0
45  *   +----------------+----------------+
46  *   |    vlan-tag    |   buf length   |
47  *   +----------------+----------------+
48  *   |              Word 1             |
49  *   +----------------+----------------+
50  *   |      Word 2: buf addr lo        |
51  *   +----------------+----------------+
52  *   |      Word 3: buf addr hi        |
53  *   +----------------+----------------+
54  *
55  * Word 2 and 3 combine to form a 64-bit buffer address
56  *
57  * Word 1 has three forms, depending on the state of bit 8/12/13:
58  * if bit8 =='1', the definition is just for custom checksum offload.
59  * if bit8 == '0' && bit12 == '1' && bit13 == '1', the *FIRST* descriptor
60  *     for the skb is special for LSO V2, Word 2 become total skb length ,
61  *     Word 3 is meaningless.
62  * other condition, the definition is for general skb or ip/tcp/udp
63  *     checksum or LSO(TSO) offload.
64  *
65  * Here is the depiction:
66  *
67  *   0-+                                  0-+
68  *   1 |                                  1 |
69  *   2 |                                  2 |
70  *   3 |    Payload offset                3 |    L4 header offset
71  *   4 |        (7:0)                     4 |        (7:0)
72  *   5 |                                  5 |
73  *   6 |                                  6 |
74  *   7-+                                  7-+
75  *   8      Custom csum enable = 1        8      Custom csum enable = 0
76  *   9      General IPv4 checksum         9      General IPv4 checksum
77  *   10     General TCP checksum          10     General TCP checksum
78  *   11     General UDP checksum          11     General UDP checksum
79  *   12     Large Send Segment enable     12     Large Send Segment enable
80  *   13     Large Send Segment type       13     Large Send Segment type
81  *   14     VLAN tagged                   14     VLAN tagged
82  *   15     Insert VLAN tag               15     Insert VLAN tag
83  *   16     IPv4 packet                   16     IPv4 packet
84  *   17     Ethernet frame type           17     Ethernet frame type
85  *   18-+                                 18-+
86  *   19 |                                 19 |
87  *   20 |                                 20 |
88  *   21 |   Custom csum offset            21 |
89  *   22 |       (25:18)                   22 |
90  *   23 |                                 23 |   MSS (30:18)
91  *   24 |                                 24 |
92  *   25-+                                 25 |
93  *   26-+                                 26 |
94  *   27 |                                 27 |
95  *   28 |   Reserved                      28 |
96  *   29 |                                 29 |
97  *   30-+                                 30-+
98  *   31     End of packet                 31     End of packet
99  */
100 struct alx_txd {
101         __le16 len;
102         __le16 vlan_tag;
103         __le32 word1;
104         union {
105                 __le64 addr;
106                 struct {
107                         __le32 pkt_len;
108                         __le32 resvd;
109                 } l;
110         } adrl;
111 } __packed;
112
113 /* tpd word 1 */
114 #define TPD_CXSUMSTART_MASK             0x00FF
115 #define TPD_CXSUMSTART_SHIFT            0
116 #define TPD_L4HDROFFSET_MASK            0x00FF
117 #define TPD_L4HDROFFSET_SHIFT           0
118 #define TPD_CXSUM_EN_MASK               0x0001
119 #define TPD_CXSUM_EN_SHIFT              8
120 #define TPD_IP_XSUM_MASK                0x0001
121 #define TPD_IP_XSUM_SHIFT               9
122 #define TPD_TCP_XSUM_MASK               0x0001
123 #define TPD_TCP_XSUM_SHIFT              10
124 #define TPD_UDP_XSUM_MASK               0x0001
125 #define TPD_UDP_XSUM_SHIFT              11
126 #define TPD_LSO_EN_MASK                 0x0001
127 #define TPD_LSO_EN_SHIFT                12
128 #define TPD_LSO_V2_MASK                 0x0001
129 #define TPD_LSO_V2_SHIFT                13
130 #define TPD_VLTAGGED_MASK               0x0001
131 #define TPD_VLTAGGED_SHIFT              14
132 #define TPD_INS_VLTAG_MASK              0x0001
133 #define TPD_INS_VLTAG_SHIFT             15
134 #define TPD_IPV4_MASK                   0x0001
135 #define TPD_IPV4_SHIFT                  16
136 #define TPD_ETHTYPE_MASK                0x0001
137 #define TPD_ETHTYPE_SHIFT               17
138 #define TPD_CXSUMOFFSET_MASK            0x00FF
139 #define TPD_CXSUMOFFSET_SHIFT           18
140 #define TPD_MSS_MASK                    0x1FFF
141 #define TPD_MSS_SHIFT                   18
142 #define TPD_EOP_MASK                    0x0001
143 #define TPD_EOP_SHIFT                   31
144
145 #define DESC_GET(_x, _name) ((_x) >> _name##SHIFT & _name##MASK)
146
147 /* Receive Free Descriptor */
148 struct alx_rfd {
149         __le64 addr;            /* data buffer address, length is
150                                  * declared in register --- every
151                                  * buffer has the same size
152                                  */
153 } __packed;
154
155 /* Receive Return Descriptor, contains 4 32-bit words.
156  *
157  *   31               16               0
158  *   +----------------+----------------+
159  *   |              Word 0             |
160  *   +----------------+----------------+
161  *   |     Word 1: RSS Hash value      |
162  *   +----------------+----------------+
163  *   |              Word 2             |
164  *   +----------------+----------------+
165  *   |              Word 3             |
166  *   +----------------+----------------+
167  *
168  * Word 0 depiction         &            Word 2 depiction:
169  *
170  *   0--+                                 0--+
171  *   1  |                                 1  |
172  *   2  |                                 2  |
173  *   3  |                                 3  |
174  *   4  |                                 4  |
175  *   5  |                                 5  |
176  *   6  |                                 6  |
177  *   7  |    IP payload checksum          7  |     VLAN tag
178  *   8  |         (15:0)                  8  |      (15:0)
179  *   9  |                                 9  |
180  *   10 |                                 10 |
181  *   11 |                                 11 |
182  *   12 |                                 12 |
183  *   13 |                                 13 |
184  *   14 |                                 14 |
185  *   15-+                                 15-+
186  *   16-+                                 16-+
187  *   17 |     Number of RFDs              17 |
188  *   18 |        (19:16)                  18 |
189  *   19-+                                 19 |     Protocol ID
190  *   20-+                                 20 |      (23:16)
191  *   21 |                                 21 |
192  *   22 |                                 22 |
193  *   23 |                                 23-+
194  *   24 |                                 24 |     Reserved
195  *   25 |     Start index of RFD-ring     25-+
196  *   26 |         (31:20)                 26 |     RSS Q-num (27:25)
197  *   27 |                                 27-+
198  *   28 |                                 28-+
199  *   29 |                                 29 |     RSS Hash algorithm
200  *   30 |                                 30 |      (31:28)
201  *   31-+                                 31-+
202  *
203  * Word 3 depiction:
204  *
205  *   0--+
206  *   1  |
207  *   2  |
208  *   3  |
209  *   4  |
210  *   5  |
211  *   6  |
212  *   7  |    Packet length (include FCS)
213  *   8  |         (13:0)
214  *   9  |
215  *   10 |
216  *   11 |
217  *   12 |
218  *   13-+
219  *   14      L4 Header checksum error
220  *   15      IPv4 checksum error
221  *   16      VLAN tagged
222  *   17-+
223  *   18 |    Protocol ID (19:17)
224  *   19-+
225  *   20      Receive error summary
226  *   21      FCS(CRC) error
227  *   22      Frame alignment error
228  *   23      Truncated packet
229  *   24      Runt packet
230  *   25      Incomplete packet due to insufficient rx-desc
231  *   26      Broadcast packet
232  *   27      Multicast packet
233  *   28      Ethernet type (EII or 802.3)
234  *   29      FIFO overflow
235  *   30      Length error (for 802.3, length field mismatch with actual len)
236  *   31      Updated, indicate to driver that this RRD is refreshed.
237  */
238 struct alx_rrd {
239         __le32 word0;
240         __le32 rss_hash;
241         __le32 word2;
242         __le32 word3;
243 } __packed;
244
245 /* rrd word 0 */
246 #define RRD_XSUM_MASK           0xFFFF
247 #define RRD_XSUM_SHIFT          0
248 #define RRD_NOR_MASK            0x000F
249 #define RRD_NOR_SHIFT           16
250 #define RRD_SI_MASK             0x0FFF
251 #define RRD_SI_SHIFT            20
252
253 /* rrd word 2 */
254 #define RRD_VLTAG_MASK          0xFFFF
255 #define RRD_VLTAG_SHIFT         0
256 #define RRD_PID_MASK            0x00FF
257 #define RRD_PID_SHIFT           16
258 /* non-ip packet */
259 #define RRD_PID_NONIP           0
260 /* ipv4(only) */
261 #define RRD_PID_IPV4            1
262 /* tcp/ipv6 */
263 #define RRD_PID_IPV6TCP         2
264 /* tcp/ipv4 */
265 #define RRD_PID_IPV4TCP         3
266 /* udp/ipv6 */
267 #define RRD_PID_IPV6UDP         4
268 /* udp/ipv4 */
269 #define RRD_PID_IPV4UDP         5
270 /* ipv6(only) */
271 #define RRD_PID_IPV6            6
272 /* LLDP packet */
273 #define RRD_PID_LLDP            7
274 /* 1588 packet */
275 #define RRD_PID_1588            8
276 #define RRD_RSSQ_MASK           0x0007
277 #define RRD_RSSQ_SHIFT          25
278 #define RRD_RSSALG_MASK         0x000F
279 #define RRD_RSSALG_SHIFT        28
280 #define RRD_RSSALG_TCPV6        0x1
281 #define RRD_RSSALG_IPV6         0x2
282 #define RRD_RSSALG_TCPV4        0x4
283 #define RRD_RSSALG_IPV4         0x8
284
285 /* rrd word 3 */
286 #define RRD_PKTLEN_MASK         0x3FFF
287 #define RRD_PKTLEN_SHIFT        0
288 #define RRD_ERR_L4_MASK         0x0001
289 #define RRD_ERR_L4_SHIFT        14
290 #define RRD_ERR_IPV4_MASK       0x0001
291 #define RRD_ERR_IPV4_SHIFT      15
292 #define RRD_VLTAGGED_MASK       0x0001
293 #define RRD_VLTAGGED_SHIFT      16
294 #define RRD_OLD_PID_MASK        0x0007
295 #define RRD_OLD_PID_SHIFT       17
296 #define RRD_ERR_RES_MASK        0x0001
297 #define RRD_ERR_RES_SHIFT       20
298 #define RRD_ERR_FCS_MASK        0x0001
299 #define RRD_ERR_FCS_SHIFT       21
300 #define RRD_ERR_FAE_MASK        0x0001
301 #define RRD_ERR_FAE_SHIFT       22
302 #define RRD_ERR_TRUNC_MASK      0x0001
303 #define RRD_ERR_TRUNC_SHIFT     23
304 #define RRD_ERR_RUNT_MASK       0x0001
305 #define RRD_ERR_RUNT_SHIFT      24
306 #define RRD_ERR_ICMP_MASK       0x0001
307 #define RRD_ERR_ICMP_SHIFT      25
308 #define RRD_BCAST_MASK          0x0001
309 #define RRD_BCAST_SHIFT         26
310 #define RRD_MCAST_MASK          0x0001
311 #define RRD_MCAST_SHIFT         27
312 #define RRD_ETHTYPE_MASK        0x0001
313 #define RRD_ETHTYPE_SHIFT       28
314 #define RRD_ERR_FIFOV_MASK      0x0001
315 #define RRD_ERR_FIFOV_SHIFT     29
316 #define RRD_ERR_LEN_MASK        0x0001
317 #define RRD_ERR_LEN_SHIFT       30
318 #define RRD_UPDATED_MASK        0x0001
319 #define RRD_UPDATED_SHIFT       31
320
321
322 #define ALX_MAX_SETUP_LNK_CYCLE 50
323
324 /* for FlowControl */
325 #define ALX_FC_RX               0x01
326 #define ALX_FC_TX               0x02
327 #define ALX_FC_ANEG             0x04
328
329 /* for sleep control */
330 #define ALX_SLEEP_WOL_PHY       0x00000001
331 #define ALX_SLEEP_WOL_MAGIC     0x00000002
332 #define ALX_SLEEP_CIFS          0x00000004
333 #define ALX_SLEEP_ACTIVE        (ALX_SLEEP_WOL_PHY | \
334                                  ALX_SLEEP_WOL_MAGIC | \
335                                  ALX_SLEEP_CIFS)
336
337 /* for RSS hash type */
338 #define ALX_RSS_HASH_TYPE_IPV4          0x1
339 #define ALX_RSS_HASH_TYPE_IPV4_TCP      0x2
340 #define ALX_RSS_HASH_TYPE_IPV6          0x4
341 #define ALX_RSS_HASH_TYPE_IPV6_TCP      0x8
342 #define ALX_RSS_HASH_TYPE_ALL           (ALX_RSS_HASH_TYPE_IPV4 | \
343                                          ALX_RSS_HASH_TYPE_IPV4_TCP | \
344                                          ALX_RSS_HASH_TYPE_IPV6 | \
345                                          ALX_RSS_HASH_TYPE_IPV6_TCP)
346 #define ALX_DEF_RXBUF_SIZE      1536
347 #define ALX_MAX_JUMBO_PKT_SIZE  (9*1024)
348 #define ALX_MAX_TSO_PKT_SIZE    (7*1024)
349 #define ALX_MAX_FRAME_SIZE      ALX_MAX_JUMBO_PKT_SIZE
350 #define ALX_MIN_FRAME_SIZE      68
351 #define ALX_RAW_MTU(_mtu)       (_mtu + ETH_HLEN + ETH_FCS_LEN + VLAN_HLEN)
352
353 #define ALX_MAX_RX_QUEUES       8
354 #define ALX_MAX_TX_QUEUES       4
355 #define ALX_MAX_HANDLED_INTRS   5
356
357 #define ALX_ISR_MISC            (ALX_ISR_PCIE_LNKDOWN | \
358                                  ALX_ISR_DMAW | \
359                                  ALX_ISR_DMAR | \
360                                  ALX_ISR_SMB | \
361                                  ALX_ISR_MANU | \
362                                  ALX_ISR_TIMER)
363
364 #define ALX_ISR_FATAL           (ALX_ISR_PCIE_LNKDOWN | \
365                                  ALX_ISR_DMAW | ALX_ISR_DMAR)
366
367 #define ALX_ISR_ALERT           (ALX_ISR_RXF_OV | \
368                                  ALX_ISR_TXF_UR | \
369                                  ALX_ISR_RFD_UR)
370
371 #define ALX_ISR_ALL_QUEUES      (ALX_ISR_TX_Q0 | \
372                                  ALX_ISR_TX_Q1 | \
373                                  ALX_ISR_TX_Q2 | \
374                                  ALX_ISR_TX_Q3 | \
375                                  ALX_ISR_RX_Q0 | \
376                                  ALX_ISR_RX_Q1 | \
377                                  ALX_ISR_RX_Q2 | \
378                                  ALX_ISR_RX_Q3 | \
379                                  ALX_ISR_RX_Q4 | \
380                                  ALX_ISR_RX_Q5 | \
381                                  ALX_ISR_RX_Q6 | \
382                                  ALX_ISR_RX_Q7)
383
384 /* Statistics counters collected by the MAC
385  *
386  * The order of the fields must match the strings in alx_gstrings_stats
387  * All stats fields should be u64
388  * See ethtool.c
389  */
390 struct alx_hw_stats {
391         /* rx */
392         u64 rx_ok;              /* good RX packets */
393         u64 rx_bcast;           /* good RX broadcast packets */
394         u64 rx_mcast;           /* good RX multicast packets */
395         u64 rx_pause;           /* RX pause frames */
396         u64 rx_ctrl;            /* RX control packets other than pause frames */
397         u64 rx_fcs_err;         /* RX packets with bad FCS */
398         u64 rx_len_err;         /* RX packets with length != actual size */
399         u64 rx_byte_cnt;        /* good bytes received. FCS is NOT included */
400         u64 rx_runt;            /* RX packets < 64 bytes with good FCS */
401         u64 rx_frag;            /* RX packets < 64 bytes with bad FCS */
402         u64 rx_sz_64B;          /* 64 byte RX packets */
403         u64 rx_sz_127B;         /* 65-127 byte RX packets */
404         u64 rx_sz_255B;         /* 128-255 byte RX packets */
405         u64 rx_sz_511B;         /* 256-511 byte RX packets */
406         u64 rx_sz_1023B;        /* 512-1023 byte RX packets */
407         u64 rx_sz_1518B;        /* 1024-1518 byte RX packets */
408         u64 rx_sz_max;          /* 1519 byte to MTU RX packets */
409         u64 rx_ov_sz;           /* truncated RX packets, size > MTU */
410         u64 rx_ov_rxf;          /* frames dropped due to RX FIFO overflow */
411         u64 rx_ov_rrd;          /* frames dropped due to RRD overflow */
412         u64 rx_align_err;       /* alignment errors */
413         u64 rx_bc_byte_cnt;     /* RX broadcast bytes, excluding FCS */
414         u64 rx_mc_byte_cnt;     /* RX multicast bytes, excluding FCS */
415         u64 rx_err_addr;        /* packets dropped due to address filtering */
416
417         /* tx */
418         u64 tx_ok;              /* good TX packets */
419         u64 tx_bcast;           /* good TX broadcast packets */
420         u64 tx_mcast;           /* good TX multicast packets */
421         u64 tx_pause;           /* TX pause frames */
422         u64 tx_exc_defer;       /* TX packets deferred excessively */
423         u64 tx_ctrl;            /* TX control frames, excluding pause frames */
424         u64 tx_defer;           /* TX packets deferred */
425         u64 tx_byte_cnt;        /* bytes transmitted, FCS is NOT included */
426         u64 tx_sz_64B;          /* 64 byte TX packets */
427         u64 tx_sz_127B;         /* 65-127 byte TX packets */
428         u64 tx_sz_255B;         /* 128-255 byte TX packets */
429         u64 tx_sz_511B;         /* 256-511 byte TX packets */
430         u64 tx_sz_1023B;        /* 512-1023 byte TX packets */
431         u64 tx_sz_1518B;        /* 1024-1518 byte TX packets */
432         u64 tx_sz_max;          /* 1519 byte to MTU TX packets */
433         u64 tx_single_col;      /* packets TX after a single collision */
434         u64 tx_multi_col;       /* packets TX after multiple collisions */
435         u64 tx_late_col;        /* TX packets with late collisions */
436         u64 tx_abort_col;       /* TX packets aborted w/excessive collisions */
437         u64 tx_underrun;        /* TX packets aborted due to TX FIFO underrun
438                                  * or TRD FIFO underrun
439                                  */
440         u64 tx_trd_eop;         /* reads beyond the EOP into the next frame
441                                  * when TRD was not written timely
442                                  */
443         u64 tx_len_err;         /* TX packets where length != actual size */
444         u64 tx_trunc;           /* TX packets truncated due to size > MTU */
445         u64 tx_bc_byte_cnt;     /* broadcast bytes transmitted, excluding FCS */
446         u64 tx_mc_byte_cnt;     /* multicast bytes transmitted, excluding FCS */
447         u64 update;
448 };
449
450
451 /* maximum interrupt vectors for msix */
452 #define ALX_MAX_MSIX_INTRS      16
453
454 #define ALX_GET_FIELD(_data, _field)                                    \
455         (((_data) >> _field ## _SHIFT) & _field ## _MASK)
456
457 #define ALX_SET_FIELD(_data, _field, _value)    do {                    \
458                 (_data) &= ~(_field ## _MASK << _field ## _SHIFT);      \
459                 (_data) |= ((_value) & _field ## _MASK) << _field ## _SHIFT;\
460         } while (0)
461
462 struct alx_hw {
463         struct pci_dev *pdev;
464         u8 __iomem *hw_addr;
465
466         /* current & permanent mac addr */
467         u8 mac_addr[ETH_ALEN];
468         u8 perm_addr[ETH_ALEN];
469
470         u16 mtu;
471         u16 imt;
472         u8 dma_chnl;
473         u8 max_dma_chnl;
474         /* tpd threshold to trig INT */
475         u32 ith_tpd;
476         u32 rx_ctrl;
477         u32 mc_hash[2];
478
479         u32 smb_timer;
480         /* SPEED_* + DUPLEX_*, SPEED_UNKNOWN if link is down */
481         int link_speed;
482         u8 duplex;
483
484         /* auto-neg advertisement or force mode config */
485         u8 flowctrl;
486         u32 adv_cfg;
487
488         spinlock_t mdio_lock;
489         struct mdio_if_info mdio;
490         u16 phy_id[2];
491
492         /* PHY link patch flag */
493         bool lnk_patch;
494
495         /* cumulated stats from the hardware (registers are cleared on read) */
496         struct alx_hw_stats stats;
497 };
498
499 static inline int alx_hw_revision(struct alx_hw *hw)
500 {
501         return hw->pdev->revision >> ALX_PCI_REVID_SHIFT;
502 }
503
504 static inline bool alx_hw_with_cr(struct alx_hw *hw)
505 {
506         return hw->pdev->revision & 1;
507 }
508
509 static inline bool alx_hw_giga(struct alx_hw *hw)
510 {
511         return hw->pdev->device & 1;
512 }
513
514 static inline void alx_write_mem8(struct alx_hw *hw, u32 reg, u8 val)
515 {
516         writeb(val, hw->hw_addr + reg);
517 }
518
519 static inline void alx_write_mem16(struct alx_hw *hw, u32 reg, u16 val)
520 {
521         writew(val, hw->hw_addr + reg);
522 }
523
524 static inline u16 alx_read_mem16(struct alx_hw *hw, u32 reg)
525 {
526         return readw(hw->hw_addr + reg);
527 }
528
529 static inline void alx_write_mem32(struct alx_hw *hw, u32 reg, u32 val)
530 {
531         writel(val, hw->hw_addr + reg);
532 }
533
534 static inline u32 alx_read_mem32(struct alx_hw *hw, u32 reg)
535 {
536         return readl(hw->hw_addr + reg);
537 }
538
539 static inline void alx_post_write(struct alx_hw *hw)
540 {
541         readl(hw->hw_addr);
542 }
543
544 int alx_get_perm_macaddr(struct alx_hw *hw, u8 *addr);
545 void alx_reset_phy(struct alx_hw *hw);
546 void alx_reset_pcie(struct alx_hw *hw);
547 void alx_enable_aspm(struct alx_hw *hw, bool l0s_en, bool l1_en);
548 int alx_setup_speed_duplex(struct alx_hw *hw, u32 ethadv, u8 flowctrl);
549 void alx_post_phy_link(struct alx_hw *hw);
550 int alx_read_phy_reg(struct alx_hw *hw, u16 reg, u16 *phy_data);
551 int alx_write_phy_reg(struct alx_hw *hw, u16 reg, u16 phy_data);
552 int alx_read_phy_ext(struct alx_hw *hw, u8 dev, u16 reg, u16 *pdata);
553 int alx_write_phy_ext(struct alx_hw *hw, u8 dev, u16 reg, u16 data);
554 int alx_read_phy_link(struct alx_hw *hw);
555 int alx_clear_phy_intr(struct alx_hw *hw);
556 void alx_cfg_mac_flowcontrol(struct alx_hw *hw, u8 fc);
557 void alx_start_mac(struct alx_hw *hw);
558 int alx_reset_mac(struct alx_hw *hw);
559 void alx_set_macaddr(struct alx_hw *hw, const u8 *addr);
560 bool alx_phy_configured(struct alx_hw *hw);
561 void alx_configure_basic(struct alx_hw *hw);
562 void alx_disable_rss(struct alx_hw *hw);
563 bool alx_get_phy_info(struct alx_hw *hw);
564 void alx_update_hw_stats(struct alx_hw *hw);
565
566 static inline u32 alx_speed_to_ethadv(int speed, u8 duplex)
567 {
568         if (speed == SPEED_1000 && duplex == DUPLEX_FULL)
569                 return ADVERTISED_1000baseT_Full;
570         if (speed == SPEED_100 && duplex == DUPLEX_FULL)
571                 return ADVERTISED_100baseT_Full;
572         if (speed == SPEED_100 && duplex== DUPLEX_HALF)
573                 return ADVERTISED_100baseT_Half;
574         if (speed == SPEED_10 && duplex == DUPLEX_FULL)
575                 return ADVERTISED_10baseT_Full;
576         if (speed == SPEED_10 && duplex == DUPLEX_HALF)
577                 return ADVERTISED_10baseT_Half;
578         return 0;
579 }
580
581 #endif