1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (c) 2017, The Linux Foundation. All rights reserved.
4 */
5
6#ifndef QCOM_PHY_QMP_QSERDES_COM_V5_H_
7#define QCOM_PHY_QMP_QSERDES_COM_V5_H_
8
9/* Only for QMP V5 PHY - QSERDES COM registers */
10#define QSERDES_V5_COM_ATB_SEL1 0x000
11#define QSERDES_V5_COM_ATB_SEL2 0x004
12#define QSERDES_V5_COM_FREQ_UPDATE 0x008
13#define QSERDES_V5_COM_BG_TIMER 0x00c
14#define QSERDES_V5_COM_SSC_EN_CENTER 0x010
15#define QSERDES_V5_COM_SSC_ADJ_PER1 0x014
16#define QSERDES_V5_COM_SSC_ADJ_PER2 0x018
17#define QSERDES_V5_COM_SSC_PER1 0x01c
18#define QSERDES_V5_COM_SSC_PER2 0x020
19#define QSERDES_V5_COM_SSC_STEP_SIZE1_MODE0 0x024
20#define QSERDES_V5_COM_SSC_STEP_SIZE2_MODE0 0x028
21#define QSERDES_V5_COM_SSC_STEP_SIZE3_MODE0 0x02c
22#define QSERDES_V5_COM_SSC_STEP_SIZE1_MODE1 0x030
23#define QSERDES_V5_COM_SSC_STEP_SIZE2_MODE1 0x034
24#define QSERDES_V5_COM_SSC_STEP_SIZE3_MODE1 0x038
25#define QSERDES_V5_COM_POST_DIV 0x03c
26#define QSERDES_V5_COM_POST_DIV_MUX 0x040
27#define QSERDES_V5_COM_BIAS_EN_CLKBUFLR_EN 0x044
28#define QSERDES_V5_COM_CLK_ENABLE1 0x048
29#define QSERDES_V5_COM_SYS_CLK_CTRL 0x04c
30#define QSERDES_V5_COM_SYSCLK_BUF_ENABLE 0x050
31#define QSERDES_V5_COM_PLL_EN 0x054
32#define QSERDES_V5_COM_PLL_IVCO 0x058
33#define QSERDES_V5_COM_CMN_IETRIM 0x05c
34#define QSERDES_V5_COM_CMN_IPTRIM 0x060
35#define QSERDES_V5_COM_EP_CLOCK_DETECT_CTRL 0x064
36#define QSERDES_V5_COM_SYSCLK_DET_COMP_STATUS 0x068
37#define QSERDES_V5_COM_CLK_EP_DIV_MODE0 0x06c
38#define QSERDES_V5_COM_CLK_EP_DIV_MODE1 0x070
39#define QSERDES_V5_COM_CP_CTRL_MODE0 0x074
40#define QSERDES_V5_COM_CP_CTRL_MODE1 0x078
41#define QSERDES_V5_COM_PLL_RCTRL_MODE0 0x07c
42#define QSERDES_V5_COM_PLL_RCTRL_MODE1 0x080
43#define QSERDES_V5_COM_PLL_CCTRL_MODE0 0x084
44#define QSERDES_V5_COM_PLL_CCTRL_MODE1 0x088
45#define QSERDES_V5_COM_PLL_CNTRL 0x08c
46#define QSERDES_V5_COM_BIAS_EN_CTRL_BY_PSM 0x090
47#define QSERDES_V5_COM_SYSCLK_EN_SEL 0x094
48#define QSERDES_V5_COM_CML_SYSCLK_SEL 0x098
49#define QSERDES_V5_COM_RESETSM_CNTRL 0x09c
50#define QSERDES_V5_COM_RESETSM_CNTRL2 0x0a0
51#define QSERDES_V5_COM_LOCK_CMP_EN 0x0a4
52#define QSERDES_V5_COM_LOCK_CMP_CFG 0x0a8
53#define QSERDES_V5_COM_LOCK_CMP1_MODE0 0x0ac
54#define QSERDES_V5_COM_LOCK_CMP2_MODE0 0x0b0
55#define QSERDES_V5_COM_LOCK_CMP1_MODE1 0x0b4
56#define QSERDES_V5_COM_LOCK_CMP2_MODE1 0x0b8
57#define QSERDES_V5_COM_DEC_START_MODE0 0x0bc
58#define QSERDES_V5_COM_DEC_START_MSB_MODE0 0x0c0
59#define QSERDES_V5_COM_DEC_START_MODE1 0x0c4
60#define QSERDES_V5_COM_DEC_START_MSB_MODE1 0x0c8
61#define QSERDES_V5_COM_DIV_FRAC_START1_MODE0 0x0cc
62#define QSERDES_V5_COM_DIV_FRAC_START2_MODE0 0x0d0
63#define QSERDES_V5_COM_DIV_FRAC_START3_MODE0 0x0d4
64#define QSERDES_V5_COM_DIV_FRAC_START1_MODE1 0x0d8
65#define QSERDES_V5_COM_DIV_FRAC_START2_MODE1 0x0dc
66#define QSERDES_V5_COM_DIV_FRAC_START3_MODE1 0x0e0
67#define QSERDES_V5_COM_INTEGLOOP_INITVAL 0x0e4
68#define QSERDES_V5_COM_INTEGLOOP_EN 0x0e8
69#define QSERDES_V5_COM_INTEGLOOP_GAIN0_MODE0 0x0ec
70#define QSERDES_V5_COM_INTEGLOOP_GAIN1_MODE0 0x0f0
71#define QSERDES_V5_COM_INTEGLOOP_GAIN0_MODE1 0x0f4
72#define QSERDES_V5_COM_INTEGLOOP_GAIN1_MODE1 0x0f8
73#define QSERDES_V5_COM_INTEGLOOP_P_PATH_GAIN0 0x0fc
74#define QSERDES_V5_COM_INTEGLOOP_P_PATH_GAIN1 0x100
75#define QSERDES_V5_COM_VCOCAL_DEADMAN_CTRL 0x104
76#define QSERDES_V5_COM_VCO_TUNE_CTRL 0x108
77#define QSERDES_V5_COM_VCO_TUNE_MAP 0x10c
78#define QSERDES_V5_COM_VCO_TUNE1_MODE0 0x110
79#define QSERDES_V5_COM_VCO_TUNE2_MODE0 0x114
80#define QSERDES_V5_COM_VCO_TUNE1_MODE1 0x118
81#define QSERDES_V5_COM_VCO_TUNE2_MODE1 0x11c
82#define QSERDES_V5_COM_VCO_TUNE_INITVAL1 0x120
83#define QSERDES_V5_COM_VCO_TUNE_INITVAL2 0x124
84#define QSERDES_V5_COM_VCO_TUNE_MINVAL1 0x128
85#define QSERDES_V5_COM_VCO_TUNE_MINVAL2 0x12c
86#define QSERDES_V5_COM_VCO_TUNE_MAXVAL1 0x130
87#define QSERDES_V5_COM_VCO_TUNE_MAXVAL2 0x134
88#define QSERDES_V5_COM_VCO_TUNE_TIMER1 0x138
89#define QSERDES_V5_COM_VCO_TUNE_TIMER2 0x13c
90#define QSERDES_V5_COM_CMN_STATUS 0x140
91#define QSERDES_V5_COM_RESET_SM_STATUS 0x144
92#define QSERDES_V5_COM_RESTRIM_CODE_STATUS 0x148
93#define QSERDES_V5_COM_PLLCAL_CODE1_STATUS 0x14c
94#define QSERDES_V5_COM_PLLCAL_CODE2_STATUS 0x150
95#define QSERDES_V5_COM_CLK_SELECT 0x154
96#define QSERDES_V5_COM_HSCLK_SEL 0x158
97#define QSERDES_V5_COM_HSCLK_HS_SWITCH_SEL 0x15c
98#define QSERDES_V5_COM_INTEGLOOP_BINCODE_STATUS 0x160
99#define QSERDES_V5_COM_PLL_ANALOG 0x164
100#define QSERDES_V5_COM_CORECLK_DIV_MODE0 0x168
101#define QSERDES_V5_COM_CORECLK_DIV_MODE1 0x16c
102#define QSERDES_V5_COM_SW_RESET 0x170
103#define QSERDES_V5_COM_CORE_CLK_EN 0x174
104#define QSERDES_V5_COM_C_READY_STATUS 0x178
105#define QSERDES_V5_COM_CMN_CONFIG 0x17c
106#define QSERDES_V5_COM_CMN_RATE_OVERRIDE 0x180
107#define QSERDES_V5_COM_SVS_MODE_CLK_SEL 0x184
108#define QSERDES_V5_COM_DEBUG_BUS0 0x188
109#define QSERDES_V5_COM_DEBUG_BUS1 0x18c
110#define QSERDES_V5_COM_DEBUG_BUS2 0x190
111#define QSERDES_V5_COM_DEBUG_BUS3 0x194
112#define QSERDES_V5_COM_DEBUG_BUS_SEL 0x198
113#define QSERDES_V5_COM_CMN_MISC1 0x19c
114#define QSERDES_V5_COM_CMN_MODE 0x1a0
115#define QSERDES_V5_COM_CMN_MODE_CONTD 0x1a4
116#define QSERDES_V5_COM_VCO_DC_LEVEL_CTRL 0x1a8
117#define QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE1_MODE0 0x1ac
118#define QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE2_MODE0 0x1b0
119#define QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE1_MODE1 0x1b4
120#define QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE2_MODE1 0x1b8
121#define QSERDES_V5_COM_BIN_VCOCAL_HSCLK_SEL 0x1bc
122#define QSERDES_V5_COM_RESERVED_1 0x1c0
123
124#endif
125

source code of linux/drivers/phy/qualcomm/phy-qcom-qmp-qserdes-com-v5.h