4ad8f36fcade4cac5ac98e994f93bcfccef95382
[linux-2.6-microblaze.git] / drivers / net / ethernet / aquantia / atlantic / aq_common.h
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /* Atlantic Network Driver
3  *
4  * Copyright (C) 2014-2019 aQuantia Corporation
5  * Copyright (C) 2019-2020 Marvell International Ltd.
6  */
7
8 /* File aq_common.h: Basic includes for all files in project. */
9
10 #ifndef AQ_COMMON_H
11 #define AQ_COMMON_H
12
13 #include <linux/etherdevice.h>
14 #include <linux/pci.h>
15 #include <linux/if_vlan.h>
16 #include "aq_cfg.h"
17 #include "aq_utils.h"
18
19 #define PCI_VENDOR_ID_AQUANTIA  0x1D6A
20
21 #define AQ_DEVICE_ID_0001       0x0001
22 #define AQ_DEVICE_ID_D100       0xD100
23 #define AQ_DEVICE_ID_D107       0xD107
24 #define AQ_DEVICE_ID_D108       0xD108
25 #define AQ_DEVICE_ID_D109       0xD109
26
27 #define AQ_DEVICE_ID_AQC100     0x00B1
28 #define AQ_DEVICE_ID_AQC107     0x07B1
29 #define AQ_DEVICE_ID_AQC108     0x08B1
30 #define AQ_DEVICE_ID_AQC109     0x09B1
31 #define AQ_DEVICE_ID_AQC111     0x11B1
32 #define AQ_DEVICE_ID_AQC112     0x12B1
33
34 #define AQ_DEVICE_ID_AQC100S    0x80B1
35 #define AQ_DEVICE_ID_AQC107S    0x87B1
36 #define AQ_DEVICE_ID_AQC108S    0x88B1
37 #define AQ_DEVICE_ID_AQC109S    0x89B1
38 #define AQ_DEVICE_ID_AQC111S    0x91B1
39 #define AQ_DEVICE_ID_AQC112S    0x92B1
40
41 #define AQ_DEVICE_ID_AQC113DEV  0x00C0
42 #define AQ_DEVICE_ID_AQC113CS   0x94C0
43 #define AQ_DEVICE_ID_AQC114CS   0x93C0
44 #define AQ_DEVICE_ID_AQC113     0x04C0
45 #define AQ_DEVICE_ID_AQC113C    0x14C0
46 #define AQ_DEVICE_ID_AQC115C    0x12C0
47
48 #define HW_ATL_NIC_NAME "Marvell (aQuantia) AQtion 10Gbit Network Adapter"
49
50 #define AQ_HWREV_ANY    0
51 #define AQ_HWREV_1      1
52 #define AQ_HWREV_2      2
53
54 #define AQ_NIC_RATE_10G         BIT(0)
55 #define AQ_NIC_RATE_5G          BIT(1)
56 #define AQ_NIC_RATE_2G5         BIT(2)
57 #define AQ_NIC_RATE_1G          BIT(3)
58 #define AQ_NIC_RATE_100M        BIT(4)
59 #define AQ_NIC_RATE_10M         BIT(5)
60 #define AQ_NIC_RATE_1G_HALF     BIT(6)
61 #define AQ_NIC_RATE_100M_HALF   BIT(7)
62 #define AQ_NIC_RATE_10M_HALF    BIT(8)
63
64 #define AQ_NIC_RATE_EEE_10G     BIT(9)
65 #define AQ_NIC_RATE_EEE_5G      BIT(10)
66 #define AQ_NIC_RATE_EEE_2G5     BIT(11)
67 #define AQ_NIC_RATE_EEE_1G      BIT(12)
68 #define AQ_NIC_RATE_EEE_100M    BIT(13)
69 #define AQ_NIC_RATE_EEE_MSK     (AQ_NIC_RATE_EEE_10G |\
70                                  AQ_NIC_RATE_EEE_5G |\
71                                  AQ_NIC_RATE_EEE_2G5 |\
72                                  AQ_NIC_RATE_EEE_1G |\
73                                  AQ_NIC_RATE_EEE_100M)
74
75 #endif /* AQ_COMMON_H */