root/drivers/net/ethernet/atheros/alx/hw.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


DEFINITIONS

This source file includes following definitions.
  1. alx_hw_revision
  2. alx_hw_with_cr
  3. alx_hw_giga
  4. alx_write_mem8
  5. alx_write_mem16
  6. alx_read_mem16
  7. alx_write_mem32
  8. alx_read_mem32
  9. alx_post_write
  10. alx_speed_to_ethadv

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

/* [<][>][^][v][top][bottom][index][help] */