xref: /linux/include/linux/mfd/idtRC38xxx_reg.h (revision 79790b6818e96c58fe2bffee1b418c16e64e7b80)
1*1ddfecafSMin Li /* SPDX-License-Identifier: GPL-2.0+ */
2*1ddfecafSMin Li /*
3*1ddfecafSMin Li  * Register Map - Based on PolarBear_CSRs.RevA.xlsx (2023-04-21)
4*1ddfecafSMin Li  *
5*1ddfecafSMin Li  * Copyright (C) 2023 Integrated Device Technology, Inc., a Renesas Company.
6*1ddfecafSMin Li  */
7*1ddfecafSMin Li #ifndef MFD_IDTRC38XXX_REG
8*1ddfecafSMin Li #define MFD_IDTRC38XXX_REG
9*1ddfecafSMin Li 
10*1ddfecafSMin Li /* GLOBAL */
11*1ddfecafSMin Li #define SOFT_RESET_CTRL		(0x15) /* Specific to FC3W */
12*1ddfecafSMin Li #define MISC_CTRL		(0x14) /* Specific to FC3A */
13*1ddfecafSMin Li #define APLL_REINIT		BIT(1)
14*1ddfecafSMin Li #define APLL_REINIT_VFC3A	BIT(2)
15*1ddfecafSMin Li 
16*1ddfecafSMin Li #define DEVICE_ID		(0x2)
17*1ddfecafSMin Li #define DEVICE_ID_MASK		(0x1000) /* Bit 12 is 1 if FC3W and 0 if FC3A */
18*1ddfecafSMin Li #define DEVICE_ID_SHIFT		(12)
19*1ddfecafSMin Li 
20*1ddfecafSMin Li /* FOD */
21*1ddfecafSMin Li #define FOD_0		(0x300)
22*1ddfecafSMin Li #define FOD_0_VFC3A	(0x400)
23*1ddfecafSMin Li #define FOD_1		(0x340)
24*1ddfecafSMin Li #define FOD_1_VFC3A	(0x440)
25*1ddfecafSMin Li #define FOD_2		(0x380)
26*1ddfecafSMin Li #define FOD_2_VFC3A	(0x480)
27*1ddfecafSMin Li 
28*1ddfecafSMin Li /* TDCAPLL */
29*1ddfecafSMin Li #define TDC_CTRL		(0x44a) /* Specific to FC3W */
30*1ddfecafSMin Li #define TDC_ENABLE_CTRL		(0x169) /* Specific to FC3A */
31*1ddfecafSMin Li #define TDC_DAC_CAL_CTRL	(0x16a) /* Specific to FC3A */
32*1ddfecafSMin Li #define TDC_EN			BIT(0)
33*1ddfecafSMin Li #define TDC_DAC_RECAL_REQ	BIT(1)
34*1ddfecafSMin Li #define TDC_DAC_RECAL_REQ_VFC3A	BIT(0)
35*1ddfecafSMin Li 
36*1ddfecafSMin Li #define TDC_FB_DIV_INT_CNFG		(0x442)
37*1ddfecafSMin Li #define TDC_FB_DIV_INT_CNFG_VFC3A	(0x162)
38*1ddfecafSMin Li #define TDC_FB_DIV_INT_MASK		GENMASK(7, 0)
39*1ddfecafSMin Li #define TDC_REF_DIV_CNFG		(0x443)
40*1ddfecafSMin Li #define TDC_REF_DIV_CNFG_VFC3A		(0x163)
41*1ddfecafSMin Li #define TDC_REF_DIV_CONFIG_MASK		GENMASK(2, 0)
42*1ddfecafSMin Li 
43*1ddfecafSMin Li /* TIME SYNC CHANNEL */
44*1ddfecafSMin Li #define TIME_CLOCK_SRC		(0xa01) /* Specific to FC3W */
45*1ddfecafSMin Li #define TIME_CLOCK_COUNT	(0xa00) /* Specific to FC3W */
46*1ddfecafSMin Li #define TIME_CLOCK_COUNT_MASK	GENMASK(5, 0)
47*1ddfecafSMin Li 
48*1ddfecafSMin Li #define SUB_SYNC_GEN_CNFG	(0xa04)
49*1ddfecafSMin Li 
50*1ddfecafSMin Li #define TOD_COUNTER_READ_REQ		(0xa5f)
51*1ddfecafSMin Li #define TOD_COUNTER_READ_REQ_VFC3A	(0x6df)
52*1ddfecafSMin Li #define TOD_SYNC_LOAD_VAL_CTRL		(0xa10)
53*1ddfecafSMin Li #define TOD_SYNC_LOAD_VAL_CTRL_VFC3A	(0x690)
54*1ddfecafSMin Li #define SYNC_COUNTER_MASK		GENMASK_ULL(51, 0)
55*1ddfecafSMin Li #define SUB_SYNC_COUNTER_MASK		GENMASK(30, 0)
56*1ddfecafSMin Li #define TOD_SYNC_LOAD_REQ_CTRL		(0xa21)
57*1ddfecafSMin Li #define TOD_SYNC_LOAD_REQ_CTRL_VFC3A	(0x6a1)
58*1ddfecafSMin Li #define SYNC_LOAD_ENABLE		BIT(1)
59*1ddfecafSMin Li #define SUB_SYNC_LOAD_ENABLE		BIT(0)
60*1ddfecafSMin Li #define SYNC_LOAD_REQ			BIT(0)
61*1ddfecafSMin Li 
62*1ddfecafSMin Li #define LPF_MODE_CNFG		(0xa80)
63*1ddfecafSMin Li #define LPF_MODE_CNFG_VFC3A	(0x700)
64*1ddfecafSMin Li enum lpf_mode {
65*1ddfecafSMin Li 	LPF_DISABLED = 0,
66*1ddfecafSMin Li 	LPF_WP       = 1,
67*1ddfecafSMin Li 	LPF_HOLDOVER = 2,
68*1ddfecafSMin Li 	LPF_WF       = 3,
69*1ddfecafSMin Li 	LPF_INVALID  = 4
70*1ddfecafSMin Li };
71*1ddfecafSMin Li #define LPF_CTRL	(0xa98)
72*1ddfecafSMin Li #define LPF_CTRL_VFC3A	(0x718)
73*1ddfecafSMin Li #define LPF_EN		BIT(0)
74*1ddfecafSMin Li 
75*1ddfecafSMin Li #define LPF_BW_CNFG	(0xa81)
76*1ddfecafSMin Li #define LPF_BW_SHIFT	GENMASK(7, 3)
77*1ddfecafSMin Li #define LPF_BW_MULT		GENMASK(2, 0)
78*1ddfecafSMin Li #define LPF_BW_SHIFT_DEFAULT	(0xb)
79*1ddfecafSMin Li #define LPF_BW_MULT_DEFAULT		(0x0)
80*1ddfecafSMin Li #define LPF_BW_SHIFT_1PPS		(0x5)
81*1ddfecafSMin Li 
82*1ddfecafSMin Li #define LPF_WR_PHASE_CTRL	(0xaa8)
83*1ddfecafSMin Li #define LPF_WR_PHASE_CTRL_VFC3A	(0x728)
84*1ddfecafSMin Li #define LPF_WR_FREQ_CTRL	(0xab0)
85*1ddfecafSMin Li #define LPF_WR_FREQ_CTRL_VFC3A	(0x730)
86*1ddfecafSMin Li 
87*1ddfecafSMin Li #define TIME_CLOCK_TDC_FANOUT_CNFG	(0xB00)
88*1ddfecafSMin Li #define TIME_SYNC_TO_TDC_EN	BIT(0)
89*1ddfecafSMin Li #define SIG1_MUX_SEL_MASK	GENMASK(7, 4)
90*1ddfecafSMin Li #define SIG2_MUX_SEL_MASK	GENMASK(11, 8)
91*1ddfecafSMin Li enum tdc_mux_sel {
92*1ddfecafSMin Li 	REF0 = 0,
93*1ddfecafSMin Li 	REF1 = 1,
94*1ddfecafSMin Li 	REF2 = 2,
95*1ddfecafSMin Li 	REF3 = 3,
96*1ddfecafSMin Li 	REF_CLK5 = 4,
97*1ddfecafSMin Li 	REF_CLK6 = 5,
98*1ddfecafSMin Li 	DPLL_FB_TO_TDC = 6,
99*1ddfecafSMin Li 	DPLL_FB_DIVIDED_TO_TDC = 7,
100*1ddfecafSMin Li 	TIME_CLK_DIVIDED = 8,
101*1ddfecafSMin Li 	TIME_SYNC = 9,
102*1ddfecafSMin Li };
103*1ddfecafSMin Li 
104*1ddfecafSMin Li #define TIME_CLOCK_MEAS_CNFG	(0xB04)
105*1ddfecafSMin Li #define TDC_MEAS_MODE	BIT(0)
106*1ddfecafSMin Li enum tdc_meas_mode {
107*1ddfecafSMin Li 	CONTINUOUS = 0,
108*1ddfecafSMin Li 	ONE_SHOT = 1,
109*1ddfecafSMin Li 	MEAS_MODE_INVALID = 2,
110*1ddfecafSMin Li };
111*1ddfecafSMin Li 
112*1ddfecafSMin Li #define TIME_CLOCK_MEAS_DIV_CNFG	(0xB08)
113*1ddfecafSMin Li #define TIME_REF_DIV_MASK	GENMASK(29, 24)
114*1ddfecafSMin Li 
115*1ddfecafSMin Li #define TIME_CLOCK_MEAS_CTRL	(0xB10)
116*1ddfecafSMin Li #define TDC_MEAS_EN	BIT(0)
117*1ddfecafSMin Li #define TDC_MEAS_START	BIT(1)
118*1ddfecafSMin Li 
119*1ddfecafSMin Li #define TDC_FIFO_READ_REQ	(0xB2F)
120*1ddfecafSMin Li #define TDC_FIFO_READ		(0xB30)
121*1ddfecafSMin Li #define COARSE_MEAS_MASK	GENMASK_ULL(39, 13)
122*1ddfecafSMin Li #define FINE_MEAS_MASK		GENMASK(12, 0)
123*1ddfecafSMin Li 
124*1ddfecafSMin Li #define TDC_FIFO_CTRL		(0xB12)
125*1ddfecafSMin Li #define FIFO_CLEAR		BIT(0)
126*1ddfecafSMin Li #define TDC_FIFO_STS		(0xB38)
127*1ddfecafSMin Li #define FIFO_FULL		BIT(1)
128*1ddfecafSMin Li #define FIFO_EMPTY		BIT(0)
129*1ddfecafSMin Li #define TDC_FIFO_EVENT		(0xB39)
130*1ddfecafSMin Li #define FIFO_OVERRUN		BIT(1)
131*1ddfecafSMin Li 
132*1ddfecafSMin Li /* DPLL */
133*1ddfecafSMin Li #define MAX_REFERENCE_INDEX	(3)
134*1ddfecafSMin Li #define MAX_NUM_REF_PRIORITY	(4)
135*1ddfecafSMin Li 
136*1ddfecafSMin Li #define MAX_DPLL_INDEX	(2)
137*1ddfecafSMin Li 
138*1ddfecafSMin Li #define DPLL_STS		(0x580)
139*1ddfecafSMin Li #define DPLL_STS_VFC3A		(0x571)
140*1ddfecafSMin Li #define DPLL_STATE_STS_MASK	(0x70)
141*1ddfecafSMin Li #define DPLL_STATE_STS_SHIFT	(4)
142*1ddfecafSMin Li #define DPLL_REF_SEL_STS_MASK	(0x6)
143*1ddfecafSMin Li #define DPLL_REF_SEL_STS_SHIFT	(1)
144*1ddfecafSMin Li 
145*1ddfecafSMin Li #define DPLL_REF_PRIORITY_CNFG			(0x502)
146*1ddfecafSMin Li #define DPLL_REFX_PRIORITY_DISABLE_MASK		(0xf)
147*1ddfecafSMin Li #define DPLL_REF0_PRIORITY_ENABLE_AND_SET_MASK	(0x31)
148*1ddfecafSMin Li #define DPLL_REF1_PRIORITY_ENABLE_AND_SET_MASK	(0xc2)
149*1ddfecafSMin Li #define DPLL_REF2_PRIORITY_ENABLE_AND_SET_MASK	(0x304)
150*1ddfecafSMin Li #define DPLL_REF3_PRIORITY_ENABLE_AND_SET_MASK	(0xc08)
151*1ddfecafSMin Li #define DPLL_REF0_PRIORITY_SHIFT		(4)
152*1ddfecafSMin Li #define DPLL_REF1_PRIORITY_SHIFT		(6)
153*1ddfecafSMin Li #define DPLL_REF2_PRIORITY_SHIFT		(8)
154*1ddfecafSMin Li #define DPLL_REF3_PRIORITY_SHIFT		(10)
155*1ddfecafSMin Li 
156*1ddfecafSMin Li enum dpll_state {
157*1ddfecafSMin Li 	DPLL_STATE_MIN             = 0,
158*1ddfecafSMin Li 	DPLL_STATE_FREERUN         = DPLL_STATE_MIN,
159*1ddfecafSMin Li 	DPLL_STATE_LOCKED          = 1,
160*1ddfecafSMin Li 	DPLL_STATE_HOLDOVER        = 2,
161*1ddfecafSMin Li 	DPLL_STATE_WRITE_FREQUENCY = 3,
162*1ddfecafSMin Li 	DPLL_STATE_ACQUIRE         = 4,
163*1ddfecafSMin Li 	DPLL_STATE_HITLESS_SWITCH  = 5,
164*1ddfecafSMin Li 	DPLL_STATE_MAX             = DPLL_STATE_HITLESS_SWITCH
165*1ddfecafSMin Li };
166*1ddfecafSMin Li 
167*1ddfecafSMin Li /* REFMON */
168*1ddfecafSMin Li #define LOSMON_STS_0		(0x81e)
169*1ddfecafSMin Li #define LOSMON_STS_0_VFC3A	(0x18e)
170*1ddfecafSMin Li #define LOSMON_STS_1		(0x82e)
171*1ddfecafSMin Li #define LOSMON_STS_1_VFC3A	(0x19e)
172*1ddfecafSMin Li #define LOSMON_STS_2		(0x83e)
173*1ddfecafSMin Li #define LOSMON_STS_2_VFC3A	(0x1ae)
174*1ddfecafSMin Li #define LOSMON_STS_3		(0x84e)
175*1ddfecafSMin Li #define LOSMON_STS_3_VFC3A	(0x1be)
176*1ddfecafSMin Li #define LOS_STS_MASK		(0x1)
177*1ddfecafSMin Li 
178*1ddfecafSMin Li #define FREQMON_STS_0		(0x874)
179*1ddfecafSMin Li #define FREQMON_STS_0_VFC3A	(0x1d4)
180*1ddfecafSMin Li #define FREQMON_STS_1		(0x894)
181*1ddfecafSMin Li #define FREQMON_STS_1_VFC3A	(0x1f4)
182*1ddfecafSMin Li #define FREQMON_STS_2		(0x8b4)
183*1ddfecafSMin Li #define FREQMON_STS_2_VFC3A	(0x214)
184*1ddfecafSMin Li #define FREQMON_STS_3		(0x8d4)
185*1ddfecafSMin Li #define FREQMON_STS_3_VFC3A	(0x234)
186*1ddfecafSMin Li #define FREQ_FAIL_STS_SHIFT	(31)
187*1ddfecafSMin Li 
188*1ddfecafSMin Li /* Firmware interface */
189*1ddfecafSMin Li #define TIME_CLK_FREQ_ADDR	(0xffa0)
190*1ddfecafSMin Li #define XTAL_FREQ_ADDR		(0xffa1)
191*1ddfecafSMin Li 
192*1ddfecafSMin Li /*
193*1ddfecafSMin Li  * Return register address and field mask based on passed in firmware version
194*1ddfecafSMin Li  */
195*1ddfecafSMin Li #define IDTFC3_FW_REG(FW, VER, REG)	(((FW) < (VER)) ? (REG) : (REG##_##VER))
196*1ddfecafSMin Li #define IDTFC3_FW_FIELD(FW, VER, FIELD)	(((FW) < (VER)) ? (FIELD) : (FIELD##_##VER))
197*1ddfecafSMin Li enum fw_version {
198*1ddfecafSMin Li 	V_DEFAULT = 0,
199*1ddfecafSMin Li 	VFC3W     = 1,
200*1ddfecafSMin Li 	VFC3A     = 2
201*1ddfecafSMin Li };
202*1ddfecafSMin Li 
203*1ddfecafSMin Li /* XTAL_FREQ_ADDR/TIME_CLK_FREQ_ADDR */
204*1ddfecafSMin Li enum {
205*1ddfecafSMin Li 	FREQ_MIN     = 0,
206*1ddfecafSMin Li 	FREQ_25M     = 1,
207*1ddfecafSMin Li 	FREQ_49_152M = 2,
208*1ddfecafSMin Li 	FREQ_50M     = 3,
209*1ddfecafSMin Li 	FREQ_100M    = 4,
210*1ddfecafSMin Li 	FREQ_125M    = 5,
211*1ddfecafSMin Li 	FREQ_250M    = 6,
212*1ddfecafSMin Li 	FREQ_MAX
213*1ddfecafSMin Li };
214*1ddfecafSMin Li 
215*1ddfecafSMin Li struct idtfc3_hw_param {
216*1ddfecafSMin Li 	u32 xtal_freq;
217*1ddfecafSMin Li 	u32 time_clk_freq;
218*1ddfecafSMin Li };
219*1ddfecafSMin Li 
220*1ddfecafSMin Li struct idtfc3_fwrc {
221*1ddfecafSMin Li 	u8 hiaddr;
222*1ddfecafSMin Li 	u8 loaddr;
223*1ddfecafSMin Li 	u8 value;
224*1ddfecafSMin Li 	u8 reserved;
225*1ddfecafSMin Li } __packed;
226*1ddfecafSMin Li 
idtfc3_default_hw_param(struct idtfc3_hw_param * hw_param)227*1ddfecafSMin Li static inline void idtfc3_default_hw_param(struct idtfc3_hw_param *hw_param)
228*1ddfecafSMin Li {
229*1ddfecafSMin Li 	hw_param->xtal_freq = 49152000;
230*1ddfecafSMin Li 	hw_param->time_clk_freq = 25000000;
231*1ddfecafSMin Li }
232*1ddfecafSMin Li 
idtfc3_set_hw_param(struct idtfc3_hw_param * hw_param,u16 addr,u8 val)233*1ddfecafSMin Li static inline int idtfc3_set_hw_param(struct idtfc3_hw_param *hw_param,
234*1ddfecafSMin Li 				      u16 addr, u8 val)
235*1ddfecafSMin Li {
236*1ddfecafSMin Li 	if (addr == XTAL_FREQ_ADDR)
237*1ddfecafSMin Li 		switch (val) {
238*1ddfecafSMin Li 		case FREQ_49_152M:
239*1ddfecafSMin Li 			hw_param->xtal_freq = 49152000;
240*1ddfecafSMin Li 			break;
241*1ddfecafSMin Li 		case FREQ_50M:
242*1ddfecafSMin Li 			hw_param->xtal_freq = 50000000;
243*1ddfecafSMin Li 			break;
244*1ddfecafSMin Li 		default:
245*1ddfecafSMin Li 			return -EINVAL;
246*1ddfecafSMin Li 		}
247*1ddfecafSMin Li 	else if (addr == TIME_CLK_FREQ_ADDR)
248*1ddfecafSMin Li 		switch (val) {
249*1ddfecafSMin Li 		case FREQ_25M:
250*1ddfecafSMin Li 			hw_param->time_clk_freq = 25000000;
251*1ddfecafSMin Li 			break;
252*1ddfecafSMin Li 		case FREQ_50M:
253*1ddfecafSMin Li 			hw_param->time_clk_freq = 50000000;
254*1ddfecafSMin Li 			break;
255*1ddfecafSMin Li 		case FREQ_100M:
256*1ddfecafSMin Li 			hw_param->time_clk_freq = 100000000;
257*1ddfecafSMin Li 			break;
258*1ddfecafSMin Li 		case FREQ_125M:
259*1ddfecafSMin Li 			hw_param->time_clk_freq = 125000000;
260*1ddfecafSMin Li 			break;
261*1ddfecafSMin Li 		case FREQ_250M:
262*1ddfecafSMin Li 			hw_param->time_clk_freq = 250000000;
263*1ddfecafSMin Li 			break;
264*1ddfecafSMin Li 		default:
265*1ddfecafSMin Li 			return -EINVAL;
266*1ddfecafSMin Li 		}
267*1ddfecafSMin Li 	else
268*1ddfecafSMin Li 		return -EFAULT;
269*1ddfecafSMin Li 
270*1ddfecafSMin Li 	return 0;
271*1ddfecafSMin Li }
272*1ddfecafSMin Li 
273*1ddfecafSMin Li #endif
274