ab623920234ee871cb715bab1ab278ef9f49405b
[dpdk.git] / drivers / common / cnxk / roc_bphy_cgx.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(C) 2021 Marvell.
3  */
4
5 #ifndef _ROC_BPHY_CGX_H_
6 #define _ROC_BPHY_CGX_H_
7
8 #include <pthread.h>
9
10 #include "roc_api.h"
11
12 #define MAX_LMACS_PER_CGX 4
13
14 struct roc_bphy_cgx {
15         uint64_t bar0_pa;
16         void *bar0_va;
17         uint64_t lmac_bmap;
18         unsigned int id;
19         /* serialize access to the whole structure */
20         pthread_mutex_t lock;
21 } __plt_cache_aligned;
22
23 enum roc_bphy_cgx_eth_link_speed {
24         ROC_BPHY_CGX_ETH_LINK_SPEED_NONE,
25         ROC_BPHY_CGX_ETH_LINK_SPEED_10M,
26         ROC_BPHY_CGX_ETH_LINK_SPEED_100M,
27         ROC_BPHY_CGX_ETH_LINK_SPEED_1G,
28         ROC_BPHY_CGX_ETH_LINK_SPEED_2HG,
29         ROC_BPHY_CGX_ETH_LINK_SPEED_5G,
30         ROC_BPHY_CGX_ETH_LINK_SPEED_10G,
31         ROC_BPHY_CGX_ETH_LINK_SPEED_20G,
32         ROC_BPHY_CGX_ETH_LINK_SPEED_25G,
33         ROC_BPHY_CGX_ETH_LINK_SPEED_40G,
34         ROC_BPHY_CGX_ETH_LINK_SPEED_50G,
35         ROC_BPHY_CGX_ETH_LINK_SPEED_80G,
36         ROC_BPHY_CGX_ETH_LINK_SPEED_100G,
37         __ROC_BPHY_CGX_ETH_LINK_SPEED_MAX
38 };
39
40 enum roc_bphy_cgx_eth_link_fec {
41         ROC_BPHY_CGX_ETH_LINK_FEC_NONE,
42         ROC_BPHY_CGX_ETH_LINK_FEC_BASE_R,
43         ROC_BPHY_CGX_ETH_LINK_FEC_RS,
44         __ROC_BPHY_CGX_ETH_LINK_FEC_MAX
45 };
46
47 enum roc_bphy_cgx_eth_link_mode {
48         ROC_BPHY_CGX_ETH_LINK_MODE_SGMII_BIT,
49         ROC_BPHY_CGX_ETH_LINK_MODE_1000_BASEX_BIT,
50         ROC_BPHY_CGX_ETH_LINK_MODE_QSGMII_BIT,
51         ROC_BPHY_CGX_ETH_LINK_MODE_10G_C2C_BIT,
52         ROC_BPHY_CGX_ETH_LINK_MODE_10G_C2M_BIT,
53         ROC_BPHY_CGX_ETH_LINK_MODE_10G_KR_BIT,
54         ROC_BPHY_CGX_ETH_LINK_MODE_20G_C2C_BIT,
55         ROC_BPHY_CGX_ETH_LINK_MODE_25G_C2C_BIT,
56         ROC_BPHY_CGX_ETH_LINK_MODE_25G_C2M_BIT,
57         ROC_BPHY_CGX_ETH_LINK_MODE_25G_2_C2C_BIT,
58         ROC_BPHY_CGX_ETH_LINK_MODE_25G_CR_BIT,
59         ROC_BPHY_CGX_ETH_LINK_MODE_25G_KR_BIT,
60         ROC_BPHY_CGX_ETH_LINK_MODE_40G_C2C_BIT,
61         ROC_BPHY_CGX_ETH_LINK_MODE_40G_C2M_BIT,
62         ROC_BPHY_CGX_ETH_LINK_MODE_40G_CR4_BIT,
63         ROC_BPHY_CGX_ETH_LINK_MODE_40G_KR4_BIT,
64         ROC_BPHY_CGX_ETH_LINK_MODE_40GAUI_C2C_BIT,
65         ROC_BPHY_CGX_ETH_LINK_MODE_50G_C2C_BIT,
66         ROC_BPHY_CGX_ETH_LINK_MODE_50G_C2M_BIT,
67         ROC_BPHY_CGX_ETH_LINK_MODE_50G_4_C2C_BIT,
68         ROC_BPHY_CGX_ETH_LINK_MODE_50G_CR_BIT,
69         ROC_BPHY_CGX_ETH_LINK_MODE_50G_KR_BIT,
70         ROC_BPHY_CGX_ETH_LINK_MODE_80GAUI_C2C_BIT,
71         ROC_BPHY_CGX_ETH_LINK_MODE_100G_C2C_BIT,
72         ROC_BPHY_CGX_ETH_LINK_MODE_100G_C2M_BIT,
73         ROC_BPHY_CGX_ETH_LINK_MODE_100G_CR4_BIT,
74         ROC_BPHY_CGX_ETH_LINK_MODE_100G_KR4_BIT,
75         __ROC_BPHY_CGX_ETH_LINK_MODE_MAX
76 };
77
78 struct roc_bphy_cgx_link_mode {
79         bool full_duplex;
80         bool an;
81         unsigned int port;
82         enum roc_bphy_cgx_eth_link_speed speed;
83         enum roc_bphy_cgx_eth_link_mode mode;
84 };
85
86 struct roc_bphy_cgx_link_info {
87         bool link_up;
88         bool full_duplex;
89         enum roc_bphy_cgx_eth_link_speed speed;
90         bool an;
91         enum roc_bphy_cgx_eth_link_fec fec;
92         enum roc_bphy_cgx_eth_link_mode mode;
93 };
94
95 __roc_api int roc_bphy_cgx_dev_init(struct roc_bphy_cgx *roc_cgx);
96 __roc_api int roc_bphy_cgx_dev_fini(struct roc_bphy_cgx *roc_cgx);
97
98 __roc_api int roc_bphy_cgx_set_link_state(struct roc_bphy_cgx *roc_cgx,
99                                           unsigned int lmac, bool state);
100 __roc_api int roc_bphy_cgx_get_linkinfo(struct roc_bphy_cgx *roc_cgx,
101                                         unsigned int lmac,
102                                         struct roc_bphy_cgx_link_info *info);
103 __roc_api int roc_bphy_cgx_set_link_mode(struct roc_bphy_cgx *roc_cgx,
104                                          unsigned int lmac,
105                                          struct roc_bphy_cgx_link_mode *mode);
106 __roc_api int roc_bphy_cgx_intlbk_enable(struct roc_bphy_cgx *roc_cgx,
107                                          unsigned int lmac);
108 __roc_api int roc_bphy_cgx_intlbk_disable(struct roc_bphy_cgx *roc_cgx,
109                                           unsigned int lmac);
110 __roc_api int roc_bphy_cgx_ptp_rx_enable(struct roc_bphy_cgx *roc_cgx,
111                                          unsigned int lmac);
112 __roc_api int roc_bphy_cgx_ptp_rx_disable(struct roc_bphy_cgx *roc_cgx,
113                                           unsigned int lmac);
114
115
116 #endif /* _ROC_BPHY_CGX_H_ */