1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2018 Cadence Design Systems Inc.
5 * Author: Boris Brezillon <boris.brezillon@bootlin.com>
8 #include <linux/bitops.h>
10 #include <linux/err.h>
11 #include <linux/errno.h>
12 #include <linux/i3c/master.h>
13 #include <linux/interrupt.h>
15 #include <linux/iopoll.h>
16 #include <linux/ioport.h>
17 #include <linux/kernel.h>
18 #include <linux/list.h>
19 #include <linux/module.h>
21 #include <linux/platform_device.h>
22 #include <linux/slab.h>
23 #include <linux/spinlock.h>
24 #include <linux/workqueue.h>
27 #define DEV_ID_I3C_MASTER 0x5034
29 #define CONF_STATUS0 0x4
30 #define CONF_STATUS0_CMDR_DEPTH(x) (4 << (((x) & GENMASK(31, 29)) >> 29))
31 #define CONF_STATUS0_ECC_CHK BIT(28)
32 #define CONF_STATUS0_INTEG_CHK BIT(27)
33 #define CONF_STATUS0_CSR_DAP_CHK BIT(26)
34 #define CONF_STATUS0_TRANS_TOUT_CHK BIT(25)
35 #define CONF_STATUS0_PROT_FAULTS_CHK BIT(24)
36 #define CONF_STATUS0_GPO_NUM(x) (((x) & GENMASK(23, 16)) >> 16)
37 #define CONF_STATUS0_GPI_NUM(x) (((x) & GENMASK(15, 8)) >> 8)
38 #define CONF_STATUS0_IBIR_DEPTH(x) (4 << (((x) & GENMASK(7, 6)) >> 7))
39 #define CONF_STATUS0_SUPPORTS_DDR BIT(5)
40 #define CONF_STATUS0_SEC_MASTER BIT(4)
41 #define CONF_STATUS0_DEVS_NUM(x) ((x) & GENMASK(3, 0))
43 #define CONF_STATUS1 0x8
44 #define CONF_STATUS1_IBI_HW_RES(x) ((((x) & GENMASK(31, 28)) >> 28) + 1)
45 #define CONF_STATUS1_CMD_DEPTH(x) (4 << (((x) & GENMASK(27, 26)) >> 26))
46 #define CONF_STATUS1_SLVDDR_RX_DEPTH(x) (8 << (((x) & GENMASK(25, 21)) >> 21))
47 #define CONF_STATUS1_SLVDDR_TX_DEPTH(x) (8 << (((x) & GENMASK(20, 16)) >> 16))
48 #define CONF_STATUS1_IBI_DEPTH(x) (2 << (((x) & GENMASK(12, 10)) >> 10))
49 #define CONF_STATUS1_RX_DEPTH(x) (8 << (((x) & GENMASK(9, 5)) >> 5))
50 #define CONF_STATUS1_TX_DEPTH(x) (8 << ((x) & GENMASK(4, 0)))
53 #define REV_ID_VID(id) (((id) & GENMASK(31, 20)) >> 20)
54 #define REV_ID_PID(id) (((id) & GENMASK(19, 8)) >> 8)
55 #define REV_ID_REV_MAJOR(id) (((id) & GENMASK(7, 4)) >> 4)
56 #define REV_ID_REV_MINOR(id) ((id) & GENMASK(3, 0))
59 #define CTRL_DEV_EN BIT(31)
60 #define CTRL_HALT_EN BIT(30)
61 #define CTRL_MCS BIT(29)
62 #define CTRL_MCS_EN BIT(28)
63 #define CTRL_THD_DELAY(x) (((x) << 24) & GENMASK(25, 24))
64 #define CTRL_HJ_DISEC BIT(8)
65 #define CTRL_MST_ACK BIT(7)
66 #define CTRL_HJ_ACK BIT(6)
67 #define CTRL_HJ_INIT BIT(5)
68 #define CTRL_MST_INIT BIT(4)
69 #define CTRL_AHDR_OPT BIT(3)
70 #define CTRL_PURE_BUS_MODE 0
71 #define CTRL_MIXED_FAST_BUS_MODE 2
72 #define CTRL_MIXED_SLOW_BUS_MODE 3
73 #define CTRL_BUS_MODE_MASK GENMASK(1, 0)
74 #define THD_DELAY_MAX 3
76 #define PRESCL_CTRL0 0x14
77 #define PRESCL_CTRL0_I2C(x) ((x) << 16)
78 #define PRESCL_CTRL0_I3C(x) (x)
79 #define PRESCL_CTRL0_I3C_MAX GENMASK(9, 0)
80 #define PRESCL_CTRL0_I2C_MAX GENMASK(15, 0)
82 #define PRESCL_CTRL1 0x18
83 #define PRESCL_CTRL1_PP_LOW_MASK GENMASK(15, 8)
84 #define PRESCL_CTRL1_PP_LOW(x) ((x) << 8)
85 #define PRESCL_CTRL1_OD_LOW_MASK GENMASK(7, 0)
86 #define PRESCL_CTRL1_OD_LOW(x) (x)
93 #define MST_INT_HALTED BIT(18)
94 #define MST_INT_MR_DONE BIT(17)
95 #define MST_INT_IMM_COMP BIT(16)
96 #define MST_INT_TX_THR BIT(15)
97 #define MST_INT_TX_OVF BIT(14)
98 #define MST_INT_IBID_THR BIT(12)
99 #define MST_INT_IBID_UNF BIT(11)
100 #define MST_INT_IBIR_THR BIT(10)
101 #define MST_INT_IBIR_UNF BIT(9)
102 #define MST_INT_IBIR_OVF BIT(8)
103 #define MST_INT_RX_THR BIT(7)
104 #define MST_INT_RX_UNF BIT(6)
105 #define MST_INT_CMDD_EMP BIT(5)
106 #define MST_INT_CMDD_THR BIT(4)
107 #define MST_INT_CMDD_OVF BIT(3)
108 #define MST_INT_CMDR_THR BIT(2)
109 #define MST_INT_CMDR_UNF BIT(1)
110 #define MST_INT_CMDR_OVF BIT(0)
112 #define MST_STATUS0 0x34
113 #define MST_STATUS0_IDLE BIT(18)
114 #define MST_STATUS0_HALTED BIT(17)
115 #define MST_STATUS0_MASTER_MODE BIT(16)
116 #define MST_STATUS0_TX_FULL BIT(13)
117 #define MST_STATUS0_IBID_FULL BIT(12)
118 #define MST_STATUS0_IBIR_FULL BIT(11)
119 #define MST_STATUS0_RX_FULL BIT(10)
120 #define MST_STATUS0_CMDD_FULL BIT(9)
121 #define MST_STATUS0_CMDR_FULL BIT(8)
122 #define MST_STATUS0_TX_EMP BIT(5)
123 #define MST_STATUS0_IBID_EMP BIT(4)
124 #define MST_STATUS0_IBIR_EMP BIT(3)
125 #define MST_STATUS0_RX_EMP BIT(2)
126 #define MST_STATUS0_CMDD_EMP BIT(1)
127 #define MST_STATUS0_CMDR_EMP BIT(0)
130 #define CMDR_NO_ERROR 0
131 #define CMDR_DDR_PREAMBLE_ERROR 1
132 #define CMDR_DDR_PARITY_ERROR 2
133 #define CMDR_DDR_RX_FIFO_OVF 3
134 #define CMDR_DDR_TX_FIFO_UNF 4
135 #define CMDR_M0_ERROR 5
136 #define CMDR_M1_ERROR 6
137 #define CMDR_M2_ERROR 7
138 #define CMDR_MST_ABORT 8
139 #define CMDR_NACK_RESP 9
140 #define CMDR_INVALID_DA 10
141 #define CMDR_DDR_DROPPED 11
142 #define CMDR_ERROR(x) (((x) & GENMASK(27, 24)) >> 24)
143 #define CMDR_XFER_BYTES(x) (((x) & GENMASK(19, 8)) >> 8)
144 #define CMDR_CMDID_HJACK_DISEC 0xfe
145 #define CMDR_CMDID_HJACK_ENTDAA 0xff
146 #define CMDR_CMDID(x) ((x) & GENMASK(7, 0))
149 #define IBIR_ACKED BIT(12)
150 #define IBIR_SLVID(x) (((x) & GENMASK(11, 8)) >> 8)
151 #define IBIR_ERROR BIT(7)
152 #define IBIR_XFER_BYTES(x) (((x) & GENMASK(6, 2)) >> 2)
153 #define IBIR_TYPE_IBI 0
154 #define IBIR_TYPE_HJ 1
155 #define IBIR_TYPE_MR 2
156 #define IBIR_TYPE(x) ((x) & GENMASK(1, 0))
163 #define SLV_INT_TM BIT(20)
164 #define SLV_INT_ERROR BIT(19)
165 #define SLV_INT_EVENT_UP BIT(18)
166 #define SLV_INT_HJ_DONE BIT(17)
167 #define SLV_INT_MR_DONE BIT(16)
168 #define SLV_INT_DA_UPD BIT(15)
169 #define SLV_INT_SDR_FAIL BIT(14)
170 #define SLV_INT_DDR_FAIL BIT(13)
171 #define SLV_INT_M_RD_ABORT BIT(12)
172 #define SLV_INT_DDR_RX_THR BIT(11)
173 #define SLV_INT_DDR_TX_THR BIT(10)
174 #define SLV_INT_SDR_RX_THR BIT(9)
175 #define SLV_INT_SDR_TX_THR BIT(8)
176 #define SLV_INT_DDR_RX_UNF BIT(7)
177 #define SLV_INT_DDR_TX_OVF BIT(6)
178 #define SLV_INT_SDR_RX_UNF BIT(5)
179 #define SLV_INT_SDR_TX_OVF BIT(4)
180 #define SLV_INT_DDR_RD_COMP BIT(3)
181 #define SLV_INT_DDR_WR_COMP BIT(2)
182 #define SLV_INT_SDR_RD_COMP BIT(1)
183 #define SLV_INT_SDR_WR_COMP BIT(0)
185 #define SLV_STATUS0 0x54
186 #define SLV_STATUS0_REG_ADDR(s) (((s) & GENMASK(23, 16)) >> 16)
187 #define SLV_STATUS0_XFRD_BYTES(s) ((s) & GENMASK(15, 0))
189 #define SLV_STATUS1 0x58
190 #define SLV_STATUS1_AS(s) (((s) & GENMASK(21, 20)) >> 20)
191 #define SLV_STATUS1_VEN_TM BIT(19)
192 #define SLV_STATUS1_HJ_DIS BIT(18)
193 #define SLV_STATUS1_MR_DIS BIT(17)
194 #define SLV_STATUS1_PROT_ERR BIT(16)
195 #define SLV_STATUS1_DA(s) (((s) & GENMASK(15, 9)) >> 9)
196 #define SLV_STATUS1_HAS_DA BIT(8)
197 #define SLV_STATUS1_DDR_RX_FULL BIT(7)
198 #define SLV_STATUS1_DDR_TX_FULL BIT(6)
199 #define SLV_STATUS1_DDR_RX_EMPTY BIT(5)
200 #define SLV_STATUS1_DDR_TX_EMPTY BIT(4)
201 #define SLV_STATUS1_SDR_RX_FULL BIT(3)
202 #define SLV_STATUS1_SDR_TX_FULL BIT(2)
203 #define SLV_STATUS1_SDR_RX_EMPTY BIT(1)
204 #define SLV_STATUS1_SDR_TX_EMPTY BIT(0)
206 #define CMD0_FIFO 0x60
207 #define CMD0_FIFO_IS_DDR BIT(31)
208 #define CMD0_FIFO_IS_CCC BIT(30)
209 #define CMD0_FIFO_BCH BIT(29)
210 #define XMIT_BURST_STATIC_SUBADDR 0
211 #define XMIT_SINGLE_INC_SUBADDR 1
212 #define XMIT_SINGLE_STATIC_SUBADDR 2
213 #define XMIT_BURST_WITHOUT_SUBADDR 3
214 #define CMD0_FIFO_PRIV_XMIT_MODE(m) ((m) << 27)
215 #define CMD0_FIFO_SBCA BIT(26)
216 #define CMD0_FIFO_RSBC BIT(25)
217 #define CMD0_FIFO_IS_10B BIT(24)
218 #define CMD0_FIFO_PL_LEN(l) ((l) << 12)
219 #define CMD0_FIFO_PL_LEN_MAX 4095
220 #define CMD0_FIFO_DEV_ADDR(a) ((a) << 1)
221 #define CMD0_FIFO_RNW BIT(0)
223 #define CMD1_FIFO 0x64
224 #define CMD1_FIFO_CMDID(id) ((id) << 24)
225 #define CMD1_FIFO_CSRADDR(a) (a)
226 #define CMD1_FIFO_CCC(id) (id)
230 #define IMD_CMD0 0x70
231 #define IMD_CMD0_PL_LEN(l) ((l) << 12)
232 #define IMD_CMD0_DEV_ADDR(a) ((a) << 1)
233 #define IMD_CMD0_RNW BIT(0)
235 #define IMD_CMD1 0x74
236 #define IMD_CMD1_CCC(id) (id)
238 #define IMD_DATA 0x78
240 #define IBI_DATA_FIFO 0x84
241 #define SLV_DDR_TX_FIFO 0x88
242 #define SLV_DDR_RX_FIFO 0x8c
244 #define CMD_IBI_THR_CTRL 0x90
245 #define IBIR_THR(t) ((t) << 24)
246 #define CMDR_THR(t) ((t) << 16)
247 #define IBI_THR(t) ((t) << 8)
248 #define CMD_THR(t) (t)
250 #define TX_RX_THR_CTRL 0x94
251 #define RX_THR(t) ((t) << 16)
252 #define TX_THR(t) (t)
254 #define SLV_DDR_TX_RX_THR_CTRL 0x98
255 #define SLV_DDR_RX_THR(t) ((t) << 16)
256 #define SLV_DDR_TX_THR(t) (t)
258 #define FLUSH_CTRL 0x9c
259 #define FLUSH_IBI_RESP BIT(23)
260 #define FLUSH_CMD_RESP BIT(22)
261 #define FLUSH_SLV_DDR_RX_FIFO BIT(22)
262 #define FLUSH_SLV_DDR_TX_FIFO BIT(21)
263 #define FLUSH_IMM_FIFO BIT(20)
264 #define FLUSH_IBI_FIFO BIT(19)
265 #define FLUSH_RX_FIFO BIT(18)
266 #define FLUSH_TX_FIFO BIT(17)
267 #define FLUSH_CMD_FIFO BIT(16)
269 #define TTO_PRESCL_CTRL0 0xb0
270 #define TTO_PRESCL_CTRL0_DIVB(x) ((x) << 16)
271 #define TTO_PRESCL_CTRL0_DIVA(x) (x)
273 #define TTO_PRESCL_CTRL1 0xb4
274 #define TTO_PRESCL_CTRL1_DIVB(x) ((x) << 16)
275 #define TTO_PRESCL_CTRL1_DIVA(x) (x)
277 #define DEVS_CTRL 0xb8
278 #define DEVS_CTRL_DEV_CLR_SHIFT 16
279 #define DEVS_CTRL_DEV_CLR_ALL GENMASK(31, 16)
280 #define DEVS_CTRL_DEV_CLR(dev) BIT(16 + (dev))
281 #define DEVS_CTRL_DEV_ACTIVE(dev) BIT(dev)
282 #define DEVS_CTRL_DEVS_ACTIVE_MASK GENMASK(15, 0)
285 #define DEV_ID_RR0(d) (0xc0 + ((d) * 0x10))
286 #define DEV_ID_RR0_LVR_EXT_ADDR BIT(11)
287 #define DEV_ID_RR0_HDR_CAP BIT(10)
288 #define DEV_ID_RR0_IS_I3C BIT(9)
289 #define DEV_ID_RR0_DEV_ADDR_MASK (GENMASK(6, 0) | GENMASK(15, 13))
290 #define DEV_ID_RR0_SET_DEV_ADDR(a) (((a) & GENMASK(6, 0)) | \
291 (((a) & GENMASK(9, 7)) << 6))
292 #define DEV_ID_RR0_GET_DEV_ADDR(x) ((((x) >> 1) & GENMASK(6, 0)) | \
293 (((x) >> 6) & GENMASK(9, 7)))
295 #define DEV_ID_RR1(d) (0xc4 + ((d) * 0x10))
296 #define DEV_ID_RR1_PID_MSB(pid) (pid)
298 #define DEV_ID_RR2(d) (0xc8 + ((d) * 0x10))
299 #define DEV_ID_RR2_PID_LSB(pid) ((pid) << 16)
300 #define DEV_ID_RR2_BCR(bcr) ((bcr) << 8)
301 #define DEV_ID_RR2_DCR(dcr) (dcr)
302 #define DEV_ID_RR2_LVR(lvr) (lvr)
304 #define SIR_MAP(x) (0x180 + ((x) * 4))
305 #define SIR_MAP_DEV_REG(d) SIR_MAP((d) / 2)
306 #define SIR_MAP_DEV_SHIFT(d, fs) ((fs) + (((d) % 2) ? 16 : 0))
307 #define SIR_MAP_DEV_CONF_MASK(d) (GENMASK(15, 0) << (((d) % 2) ? 16 : 0))
308 #define SIR_MAP_DEV_CONF(d, c) ((c) << (((d) % 2) ? 16 : 0))
309 #define DEV_ROLE_SLAVE 0
310 #define DEV_ROLE_MASTER 1
311 #define SIR_MAP_DEV_ROLE(role) ((role) << 14)
312 #define SIR_MAP_DEV_SLOW BIT(13)
313 #define SIR_MAP_DEV_PL(l) ((l) << 8)
314 #define SIR_MAP_PL_MAX GENMASK(4, 0)
315 #define SIR_MAP_DEV_DA(a) ((a) << 1)
316 #define SIR_MAP_DEV_ACK BIT(0)
318 #define GPIR_WORD(x) (0x200 + ((x) * 4))
319 #define GPI_REG(val, id) \
320 (((val) >> (((id) % 4) * 8)) & GENMASK(7, 0))
322 #define GPOR_WORD(x) (0x220 + ((x) * 4))
323 #define GPO_REG(val, id) \
324 (((val) >> (((id) % 4) * 8)) & GENMASK(7, 0))
326 #define ASF_INT_STATUS 0x300
327 #define ASF_INT_RAW_STATUS 0x304
328 #define ASF_INT_MASK 0x308
329 #define ASF_INT_TEST 0x30c
330 #define ASF_INT_FATAL_SELECT 0x310
331 #define ASF_INTEGRITY_ERR BIT(6)
332 #define ASF_PROTOCOL_ERR BIT(5)
333 #define ASF_TRANS_TIMEOUT_ERR BIT(4)
334 #define ASF_CSR_ERR BIT(3)
335 #define ASF_DAP_ERR BIT(2)
336 #define ASF_SRAM_UNCORR_ERR BIT(1)
337 #define ASF_SRAM_CORR_ERR BIT(0)
339 #define ASF_SRAM_CORR_FAULT_STATUS 0x320
340 #define ASF_SRAM_UNCORR_FAULT_STATUS 0x324
341 #define ASF_SRAM_CORR_FAULT_INSTANCE(x) ((x) >> 24)
342 #define ASF_SRAM_CORR_FAULT_ADDR(x) ((x) & GENMASK(23, 0))
344 #define ASF_SRAM_FAULT_STATS 0x328
345 #define ASF_SRAM_FAULT_UNCORR_STATS(x) ((x) >> 16)
346 #define ASF_SRAM_FAULT_CORR_STATS(x) ((x) & GENMASK(15, 0))
348 #define ASF_TRANS_TOUT_CTRL 0x330
349 #define ASF_TRANS_TOUT_EN BIT(31)
350 #define ASF_TRANS_TOUT_VAL(x) (x)
352 #define ASF_TRANS_TOUT_FAULT_MASK 0x334
353 #define ASF_TRANS_TOUT_FAULT_STATUS 0x338
354 #define ASF_TRANS_TOUT_FAULT_APB BIT(3)
355 #define ASF_TRANS_TOUT_FAULT_SCL_LOW BIT(2)
356 #define ASF_TRANS_TOUT_FAULT_SCL_HIGH BIT(1)
357 #define ASF_TRANS_TOUT_FAULT_FSCL_HIGH BIT(0)
359 #define ASF_PROTO_FAULT_MASK 0x340
360 #define ASF_PROTO_FAULT_STATUS 0x344
361 #define ASF_PROTO_FAULT_SLVSDR_RD_ABORT BIT(31)
362 #define ASF_PROTO_FAULT_SLVDDR_FAIL BIT(30)
363 #define ASF_PROTO_FAULT_S(x) BIT(16 + (x))
364 #define ASF_PROTO_FAULT_MSTSDR_RD_ABORT BIT(15)
365 #define ASF_PROTO_FAULT_MSTDDR_FAIL BIT(14)
366 #define ASF_PROTO_FAULT_M(x) BIT(x)
368 struct cdns_i3c_master_caps
{
376 struct cdns_i3c_cmd
{
386 struct cdns_i3c_xfer
{
387 struct list_head node
;
388 struct completion comp
;
391 struct cdns_i3c_cmd cmds
[] __counted_by(ncmds
);
394 struct cdns_i3c_data
{
398 struct cdns_i3c_master
{
399 struct work_struct hj_work
;
400 struct i3c_master_controller base
;
402 unsigned int maxdevs
;
404 unsigned int num_slots
;
405 struct i3c_dev_desc
**slots
;
409 struct list_head list
;
410 struct cdns_i3c_xfer
*cur
;
416 struct cdns_i3c_master_caps caps
;
417 unsigned long i3c_scl_lim
;
418 const struct cdns_i3c_data
*devdata
;
421 static inline struct cdns_i3c_master
*
422 to_cdns_i3c_master(struct i3c_master_controller
*master
)
424 return container_of(master
, struct cdns_i3c_master
, base
);
427 static void cdns_i3c_master_wr_to_tx_fifo(struct cdns_i3c_master
*master
,
428 const u8
*bytes
, int nbytes
)
430 writesl(master
->regs
+ TX_FIFO
, bytes
, nbytes
/ 4);
434 memcpy(&tmp
, bytes
+ (nbytes
& ~3), nbytes
& 3);
435 writesl(master
->regs
+ TX_FIFO
, &tmp
, 1);
439 static void cdns_i3c_master_rd_from_rx_fifo(struct cdns_i3c_master
*master
,
440 u8
*bytes
, int nbytes
)
442 readsl(master
->regs
+ RX_FIFO
, bytes
, nbytes
/ 4);
446 readsl(master
->regs
+ RX_FIFO
, &tmp
, 1);
447 memcpy(bytes
+ (nbytes
& ~3), &tmp
, nbytes
& 3);
451 static bool cdns_i3c_master_supports_ccc_cmd(struct i3c_master_controller
*m
,
452 const struct i3c_ccc_cmd
*cmd
)
458 case I3C_CCC_ENEC(true):
459 case I3C_CCC_ENEC(false):
460 case I3C_CCC_DISEC(true):
461 case I3C_CCC_DISEC(false):
462 case I3C_CCC_ENTAS(0, true):
463 case I3C_CCC_ENTAS(0, false):
464 case I3C_CCC_RSTDAA(true):
465 case I3C_CCC_RSTDAA(false):
467 case I3C_CCC_SETMWL(true):
468 case I3C_CCC_SETMWL(false):
469 case I3C_CCC_SETMRL(true):
470 case I3C_CCC_SETMRL(false):
471 case I3C_CCC_DEFSLVS
:
472 case I3C_CCC_ENTHDR(0):
473 case I3C_CCC_SETDASA
:
474 case I3C_CCC_SETNEWDA
:
480 case I3C_CCC_GETSTATUS
:
481 case I3C_CCC_GETACCMST
:
482 case I3C_CCC_GETMXDS
:
483 case I3C_CCC_GETHDRCAP
:
492 static int cdns_i3c_master_disable(struct cdns_i3c_master
*master
)
496 writel(readl(master
->regs
+ CTRL
) & ~CTRL_DEV_EN
, master
->regs
+ CTRL
);
498 return readl_poll_timeout(master
->regs
+ MST_STATUS0
, status
,
499 status
& MST_STATUS0_IDLE
, 10, 1000000);
502 static void cdns_i3c_master_enable(struct cdns_i3c_master
*master
)
504 writel(readl(master
->regs
+ CTRL
) | CTRL_DEV_EN
, master
->regs
+ CTRL
);
507 static struct cdns_i3c_xfer
*
508 cdns_i3c_master_alloc_xfer(struct cdns_i3c_master
*master
, unsigned int ncmds
)
510 struct cdns_i3c_xfer
*xfer
;
512 xfer
= kzalloc(struct_size(xfer
, cmds
, ncmds
), GFP_KERNEL
);
516 INIT_LIST_HEAD(&xfer
->node
);
518 xfer
->ret
= -ETIMEDOUT
;
523 static void cdns_i3c_master_free_xfer(struct cdns_i3c_xfer
*xfer
)
528 static void cdns_i3c_master_start_xfer_locked(struct cdns_i3c_master
*master
)
530 struct cdns_i3c_xfer
*xfer
= master
->xferqueue
.cur
;
536 writel(MST_INT_CMDD_EMP
, master
->regs
+ MST_ICR
);
537 for (i
= 0; i
< xfer
->ncmds
; i
++) {
538 struct cdns_i3c_cmd
*cmd
= &xfer
->cmds
[i
];
540 cdns_i3c_master_wr_to_tx_fifo(master
, cmd
->tx_buf
,
544 for (i
= 0; i
< xfer
->ncmds
; i
++) {
545 struct cdns_i3c_cmd
*cmd
= &xfer
->cmds
[i
];
547 writel(cmd
->cmd1
| CMD1_FIFO_CMDID(i
),
548 master
->regs
+ CMD1_FIFO
);
549 writel(cmd
->cmd0
, master
->regs
+ CMD0_FIFO
);
552 writel(readl(master
->regs
+ CTRL
) | CTRL_MCS
,
553 master
->regs
+ CTRL
);
554 writel(MST_INT_CMDD_EMP
, master
->regs
+ MST_IER
);
557 static void cdns_i3c_master_end_xfer_locked(struct cdns_i3c_master
*master
,
560 struct cdns_i3c_xfer
*xfer
= master
->xferqueue
.cur
;
567 if (!(isr
& MST_INT_CMDD_EMP
))
570 writel(MST_INT_CMDD_EMP
, master
->regs
+ MST_IDR
);
572 for (status0
= readl(master
->regs
+ MST_STATUS0
);
573 !(status0
& MST_STATUS0_CMDR_EMP
);
574 status0
= readl(master
->regs
+ MST_STATUS0
)) {
575 struct cdns_i3c_cmd
*cmd
;
576 u32 cmdr
, rx_len
, id
;
578 cmdr
= readl(master
->regs
+ CMDR
);
579 id
= CMDR_CMDID(cmdr
);
580 if (id
== CMDR_CMDID_HJACK_DISEC
||
581 id
== CMDR_CMDID_HJACK_ENTDAA
||
582 WARN_ON(id
>= xfer
->ncmds
))
585 cmd
= &xfer
->cmds
[CMDR_CMDID(cmdr
)];
586 rx_len
= min_t(u32
, CMDR_XFER_BYTES(cmdr
), cmd
->rx_len
);
587 cdns_i3c_master_rd_from_rx_fifo(master
, cmd
->rx_buf
, rx_len
);
588 cmd
->error
= CMDR_ERROR(cmdr
);
591 for (i
= 0; i
< xfer
->ncmds
; i
++) {
592 switch (xfer
->cmds
[i
].error
) {
596 case CMDR_DDR_PREAMBLE_ERROR
:
597 case CMDR_DDR_PARITY_ERROR
:
603 case CMDR_DDR_DROPPED
:
607 case CMDR_DDR_RX_FIFO_OVF
:
608 case CMDR_DDR_TX_FIFO_UNF
:
612 case CMDR_INVALID_DA
:
620 complete(&xfer
->comp
);
622 xfer
= list_first_entry_or_null(&master
->xferqueue
.list
,
623 struct cdns_i3c_xfer
, node
);
625 list_del_init(&xfer
->node
);
627 master
->xferqueue
.cur
= xfer
;
628 cdns_i3c_master_start_xfer_locked(master
);
631 static void cdns_i3c_master_queue_xfer(struct cdns_i3c_master
*master
,
632 struct cdns_i3c_xfer
*xfer
)
636 init_completion(&xfer
->comp
);
637 spin_lock_irqsave(&master
->xferqueue
.lock
, flags
);
638 if (master
->xferqueue
.cur
) {
639 list_add_tail(&xfer
->node
, &master
->xferqueue
.list
);
641 master
->xferqueue
.cur
= xfer
;
642 cdns_i3c_master_start_xfer_locked(master
);
644 spin_unlock_irqrestore(&master
->xferqueue
.lock
, flags
);
647 static void cdns_i3c_master_unqueue_xfer(struct cdns_i3c_master
*master
,
648 struct cdns_i3c_xfer
*xfer
)
652 spin_lock_irqsave(&master
->xferqueue
.lock
, flags
);
653 if (master
->xferqueue
.cur
== xfer
) {
656 writel(readl(master
->regs
+ CTRL
) & ~CTRL_DEV_EN
,
657 master
->regs
+ CTRL
);
658 readl_poll_timeout_atomic(master
->regs
+ MST_STATUS0
, status
,
659 status
& MST_STATUS0_IDLE
, 10,
661 master
->xferqueue
.cur
= NULL
;
662 writel(FLUSH_RX_FIFO
| FLUSH_TX_FIFO
| FLUSH_CMD_FIFO
|
664 master
->regs
+ FLUSH_CTRL
);
665 writel(MST_INT_CMDD_EMP
, master
->regs
+ MST_IDR
);
666 writel(readl(master
->regs
+ CTRL
) | CTRL_DEV_EN
,
667 master
->regs
+ CTRL
);
669 list_del_init(&xfer
->node
);
671 spin_unlock_irqrestore(&master
->xferqueue
.lock
, flags
);
674 static enum i3c_error_code
cdns_i3c_cmd_get_err(struct cdns_i3c_cmd
*cmd
)
676 switch (cmd
->error
) {
691 return I3C_ERROR_UNKNOWN
;
694 static int cdns_i3c_master_send_ccc_cmd(struct i3c_master_controller
*m
,
695 struct i3c_ccc_cmd
*cmd
)
697 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
698 struct cdns_i3c_xfer
*xfer
;
699 struct cdns_i3c_cmd
*ccmd
;
702 xfer
= cdns_i3c_master_alloc_xfer(master
, 1);
707 ccmd
->cmd1
= CMD1_FIFO_CCC(cmd
->id
);
708 ccmd
->cmd0
= CMD0_FIFO_IS_CCC
|
709 CMD0_FIFO_PL_LEN(cmd
->dests
[0].payload
.len
);
711 if (cmd
->id
& I3C_CCC_DIRECT
)
712 ccmd
->cmd0
|= CMD0_FIFO_DEV_ADDR(cmd
->dests
[0].addr
);
715 ccmd
->cmd0
|= CMD0_FIFO_RNW
;
716 ccmd
->rx_buf
= cmd
->dests
[0].payload
.data
;
717 ccmd
->rx_len
= cmd
->dests
[0].payload
.len
;
719 ccmd
->tx_buf
= cmd
->dests
[0].payload
.data
;
720 ccmd
->tx_len
= cmd
->dests
[0].payload
.len
;
723 cdns_i3c_master_queue_xfer(master
, xfer
);
724 if (!wait_for_completion_timeout(&xfer
->comp
, msecs_to_jiffies(1000)))
725 cdns_i3c_master_unqueue_xfer(master
, xfer
);
728 cmd
->err
= cdns_i3c_cmd_get_err(&xfer
->cmds
[0]);
729 cdns_i3c_master_free_xfer(xfer
);
734 static int cdns_i3c_master_priv_xfers(struct i3c_dev_desc
*dev
,
735 struct i3c_priv_xfer
*xfers
,
738 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
739 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
740 int txslots
= 0, rxslots
= 0, i
, ret
;
741 struct cdns_i3c_xfer
*cdns_xfer
;
743 for (i
= 0; i
< nxfers
; i
++) {
744 if (xfers
[i
].len
> CMD0_FIFO_PL_LEN_MAX
)
751 if (nxfers
> master
->caps
.cmdfifodepth
||
752 nxfers
> master
->caps
.cmdrfifodepth
)
756 * First make sure that all transactions (block of transfers separated
757 * by a STOP marker) fit in the FIFOs.
759 for (i
= 0; i
< nxfers
; i
++) {
761 rxslots
+= DIV_ROUND_UP(xfers
[i
].len
, 4);
763 txslots
+= DIV_ROUND_UP(xfers
[i
].len
, 4);
766 if (rxslots
> master
->caps
.rxfifodepth
||
767 txslots
> master
->caps
.txfifodepth
)
770 cdns_xfer
= cdns_i3c_master_alloc_xfer(master
, nxfers
);
774 for (i
= 0; i
< nxfers
; i
++) {
775 struct cdns_i3c_cmd
*ccmd
= &cdns_xfer
->cmds
[i
];
776 u32 pl_len
= xfers
[i
].len
;
778 ccmd
->cmd0
= CMD0_FIFO_DEV_ADDR(dev
->info
.dyn_addr
) |
779 CMD0_FIFO_PRIV_XMIT_MODE(XMIT_BURST_WITHOUT_SUBADDR
);
782 ccmd
->cmd0
|= CMD0_FIFO_RNW
;
783 ccmd
->rx_buf
= xfers
[i
].data
.in
;
784 ccmd
->rx_len
= xfers
[i
].len
;
787 ccmd
->tx_buf
= xfers
[i
].data
.out
;
788 ccmd
->tx_len
= xfers
[i
].len
;
791 ccmd
->cmd0
|= CMD0_FIFO_PL_LEN(pl_len
);
794 ccmd
->cmd0
|= CMD0_FIFO_RSBC
;
797 ccmd
->cmd0
|= CMD0_FIFO_BCH
;
800 cdns_i3c_master_queue_xfer(master
, cdns_xfer
);
801 if (!wait_for_completion_timeout(&cdns_xfer
->comp
,
802 msecs_to_jiffies(1000)))
803 cdns_i3c_master_unqueue_xfer(master
, cdns_xfer
);
805 ret
= cdns_xfer
->ret
;
807 for (i
= 0; i
< nxfers
; i
++)
808 xfers
[i
].err
= cdns_i3c_cmd_get_err(&cdns_xfer
->cmds
[i
]);
810 cdns_i3c_master_free_xfer(cdns_xfer
);
815 static int cdns_i3c_master_i2c_xfers(struct i2c_dev_desc
*dev
,
816 const struct i2c_msg
*xfers
, int nxfers
)
818 struct i3c_master_controller
*m
= i2c_dev_get_master(dev
);
819 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
820 unsigned int nrxwords
= 0, ntxwords
= 0;
821 struct cdns_i3c_xfer
*xfer
;
824 if (nxfers
> master
->caps
.cmdfifodepth
)
827 for (i
= 0; i
< nxfers
; i
++) {
828 if (xfers
[i
].len
> CMD0_FIFO_PL_LEN_MAX
)
831 if (xfers
[i
].flags
& I2C_M_RD
)
832 nrxwords
+= DIV_ROUND_UP(xfers
[i
].len
, 4);
834 ntxwords
+= DIV_ROUND_UP(xfers
[i
].len
, 4);
837 if (ntxwords
> master
->caps
.txfifodepth
||
838 nrxwords
> master
->caps
.rxfifodepth
)
841 xfer
= cdns_i3c_master_alloc_xfer(master
, nxfers
);
845 for (i
= 0; i
< nxfers
; i
++) {
846 struct cdns_i3c_cmd
*ccmd
= &xfer
->cmds
[i
];
848 ccmd
->cmd0
= CMD0_FIFO_DEV_ADDR(xfers
[i
].addr
) |
849 CMD0_FIFO_PL_LEN(xfers
[i
].len
) |
850 CMD0_FIFO_PRIV_XMIT_MODE(XMIT_BURST_WITHOUT_SUBADDR
);
852 if (xfers
[i
].flags
& I2C_M_TEN
)
853 ccmd
->cmd0
|= CMD0_FIFO_IS_10B
;
855 if (xfers
[i
].flags
& I2C_M_RD
) {
856 ccmd
->cmd0
|= CMD0_FIFO_RNW
;
857 ccmd
->rx_buf
= xfers
[i
].buf
;
858 ccmd
->rx_len
= xfers
[i
].len
;
860 ccmd
->tx_buf
= xfers
[i
].buf
;
861 ccmd
->tx_len
= xfers
[i
].len
;
865 cdns_i3c_master_queue_xfer(master
, xfer
);
866 if (!wait_for_completion_timeout(&xfer
->comp
, msecs_to_jiffies(1000)))
867 cdns_i3c_master_unqueue_xfer(master
, xfer
);
870 cdns_i3c_master_free_xfer(xfer
);
875 struct cdns_i3c_i2c_dev_data
{
878 struct i3c_generic_ibi_pool
*ibi_pool
;
881 static u32
prepare_rr0_dev_address(u32 addr
)
883 u32 ret
= (addr
<< 1) & 0xff;
885 /* RR0[7:1] = addr[6:0] */
886 ret
|= (addr
& GENMASK(6, 0)) << 1;
888 /* RR0[15:13] = addr[9:7] */
889 ret
|= (addr
& GENMASK(9, 7)) << 6;
891 /* RR0[0] = ~XOR(addr[6:0]) */
892 if (!(hweight8(addr
& 0x7f) & 1))
898 static void cdns_i3c_master_upd_i3c_addr(struct i3c_dev_desc
*dev
)
900 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
901 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
902 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
905 rr
= prepare_rr0_dev_address(dev
->info
.dyn_addr
?
907 dev
->info
.static_addr
);
908 writel(DEV_ID_RR0_IS_I3C
| rr
, master
->regs
+ DEV_ID_RR0(data
->id
));
911 static int cdns_i3c_master_get_rr_slot(struct cdns_i3c_master
*master
,
914 unsigned long activedevs
;
919 if (!master
->free_rr_slots
)
922 return ffs(master
->free_rr_slots
) - 1;
925 activedevs
= readl(master
->regs
+ DEVS_CTRL
) & DEVS_CTRL_DEVS_ACTIVE_MASK
;
926 activedevs
&= ~BIT(0);
928 for_each_set_bit(i
, &activedevs
, master
->maxdevs
+ 1) {
929 rr
= readl(master
->regs
+ DEV_ID_RR0(i
));
930 if (!(rr
& DEV_ID_RR0_IS_I3C
) ||
931 DEV_ID_RR0_GET_DEV_ADDR(rr
) != dyn_addr
)
940 static int cdns_i3c_master_reattach_i3c_dev(struct i3c_dev_desc
*dev
,
943 cdns_i3c_master_upd_i3c_addr(dev
);
948 static int cdns_i3c_master_attach_i3c_dev(struct i3c_dev_desc
*dev
)
950 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
951 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
952 struct cdns_i3c_i2c_dev_data
*data
;
955 data
= kzalloc(sizeof(*data
), GFP_KERNEL
);
959 slot
= cdns_i3c_master_get_rr_slot(master
, dev
->info
.dyn_addr
);
967 i3c_dev_set_master_data(dev
, data
);
968 master
->free_rr_slots
&= ~BIT(slot
);
970 if (!dev
->info
.dyn_addr
) {
971 cdns_i3c_master_upd_i3c_addr(dev
);
972 writel(readl(master
->regs
+ DEVS_CTRL
) |
973 DEVS_CTRL_DEV_ACTIVE(data
->id
),
974 master
->regs
+ DEVS_CTRL
);
980 static void cdns_i3c_master_detach_i3c_dev(struct i3c_dev_desc
*dev
)
982 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
983 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
984 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
986 writel(readl(master
->regs
+ DEVS_CTRL
) |
987 DEVS_CTRL_DEV_CLR(data
->id
),
988 master
->regs
+ DEVS_CTRL
);
990 i3c_dev_set_master_data(dev
, NULL
);
991 master
->free_rr_slots
|= BIT(data
->id
);
995 static int cdns_i3c_master_attach_i2c_dev(struct i2c_dev_desc
*dev
)
997 struct i3c_master_controller
*m
= i2c_dev_get_master(dev
);
998 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
999 struct cdns_i3c_i2c_dev_data
*data
;
1002 slot
= cdns_i3c_master_get_rr_slot(master
, 0);
1006 data
= kzalloc(sizeof(*data
), GFP_KERNEL
);
1011 master
->free_rr_slots
&= ~BIT(slot
);
1012 i2c_dev_set_master_data(dev
, data
);
1014 writel(prepare_rr0_dev_address(dev
->addr
),
1015 master
->regs
+ DEV_ID_RR0(data
->id
));
1016 writel(dev
->lvr
, master
->regs
+ DEV_ID_RR2(data
->id
));
1017 writel(readl(master
->regs
+ DEVS_CTRL
) |
1018 DEVS_CTRL_DEV_ACTIVE(data
->id
),
1019 master
->regs
+ DEVS_CTRL
);
1024 static void cdns_i3c_master_detach_i2c_dev(struct i2c_dev_desc
*dev
)
1026 struct i3c_master_controller
*m
= i2c_dev_get_master(dev
);
1027 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1028 struct cdns_i3c_i2c_dev_data
*data
= i2c_dev_get_master_data(dev
);
1030 writel(readl(master
->regs
+ DEVS_CTRL
) |
1031 DEVS_CTRL_DEV_CLR(data
->id
),
1032 master
->regs
+ DEVS_CTRL
);
1033 master
->free_rr_slots
|= BIT(data
->id
);
1035 i2c_dev_set_master_data(dev
, NULL
);
1039 static void cdns_i3c_master_bus_cleanup(struct i3c_master_controller
*m
)
1041 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1043 cdns_i3c_master_disable(master
);
1046 static void cdns_i3c_master_dev_rr_to_info(struct cdns_i3c_master
*master
,
1048 struct i3c_device_info
*info
)
1052 memset(info
, 0, sizeof(*info
));
1053 rr
= readl(master
->regs
+ DEV_ID_RR0(slot
));
1054 info
->dyn_addr
= DEV_ID_RR0_GET_DEV_ADDR(rr
);
1055 rr
= readl(master
->regs
+ DEV_ID_RR2(slot
));
1057 info
->bcr
= rr
>> 8;
1058 info
->pid
= rr
>> 16;
1059 info
->pid
|= (u64
)readl(master
->regs
+ DEV_ID_RR1(slot
)) << 16;
1062 static void cdns_i3c_master_upd_i3c_scl_lim(struct cdns_i3c_master
*master
)
1064 struct i3c_master_controller
*m
= &master
->base
;
1065 unsigned long i3c_lim_period
, pres_step
, ncycles
;
1066 struct i3c_bus
*bus
= i3c_master_get_bus(m
);
1067 unsigned long new_i3c_scl_lim
= 0;
1068 struct i3c_dev_desc
*dev
;
1071 i3c_bus_for_each_i3cdev(bus
, dev
) {
1072 unsigned long max_fscl
;
1074 max_fscl
= max(I3C_CCC_MAX_SDR_FSCL(dev
->info
.max_read_ds
),
1075 I3C_CCC_MAX_SDR_FSCL(dev
->info
.max_write_ds
));
1077 case I3C_SDR1_FSCL_8MHZ
:
1080 case I3C_SDR2_FSCL_6MHZ
:
1083 case I3C_SDR3_FSCL_4MHZ
:
1086 case I3C_SDR4_FSCL_2MHZ
:
1089 case I3C_SDR0_FSCL_MAX
:
1096 (new_i3c_scl_lim
> max_fscl
|| !new_i3c_scl_lim
))
1097 new_i3c_scl_lim
= max_fscl
;
1100 /* Only update PRESCL_CTRL1 if the I3C SCL limitation has changed. */
1101 if (new_i3c_scl_lim
== master
->i3c_scl_lim
)
1103 master
->i3c_scl_lim
= new_i3c_scl_lim
;
1104 if (!new_i3c_scl_lim
)
1106 pres_step
= 1000000000UL / (bus
->scl_rate
.i3c
* 4);
1108 /* Configure PP_LOW to meet I3C slave limitations. */
1109 prescl1
= readl(master
->regs
+ PRESCL_CTRL1
) &
1110 ~PRESCL_CTRL1_PP_LOW_MASK
;
1111 ctrl
= readl(master
->regs
+ CTRL
);
1113 i3c_lim_period
= DIV_ROUND_UP(1000000000, master
->i3c_scl_lim
);
1114 ncycles
= DIV_ROUND_UP(i3c_lim_period
, pres_step
);
1120 prescl1
|= PRESCL_CTRL1_PP_LOW(ncycles
);
1122 /* Disable I3C master before updating PRESCL_CTRL1. */
1123 if (ctrl
& CTRL_DEV_EN
)
1124 cdns_i3c_master_disable(master
);
1126 writel(prescl1
, master
->regs
+ PRESCL_CTRL1
);
1128 if (ctrl
& CTRL_DEV_EN
)
1129 cdns_i3c_master_enable(master
);
1132 static int cdns_i3c_master_do_daa(struct i3c_master_controller
*m
)
1134 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1135 unsigned long olddevs
, newdevs
;
1137 u8 addrs
[MAX_DEVS
] = { };
1140 olddevs
= readl(master
->regs
+ DEVS_CTRL
) & DEVS_CTRL_DEVS_ACTIVE_MASK
;
1143 /* Prepare RR slots before launching DAA. */
1144 for_each_clear_bit(slot
, &olddevs
, master
->maxdevs
+ 1) {
1145 ret
= i3c_master_get_free_addr(m
, last_addr
+ 1);
1150 addrs
[slot
] = last_addr
;
1151 writel(prepare_rr0_dev_address(last_addr
) | DEV_ID_RR0_IS_I3C
,
1152 master
->regs
+ DEV_ID_RR0(slot
));
1153 writel(0, master
->regs
+ DEV_ID_RR1(slot
));
1154 writel(0, master
->regs
+ DEV_ID_RR2(slot
));
1157 ret
= i3c_master_entdaa_locked(&master
->base
);
1158 if (ret
&& ret
!= I3C_ERROR_M2
)
1161 newdevs
= readl(master
->regs
+ DEVS_CTRL
) & DEVS_CTRL_DEVS_ACTIVE_MASK
;
1162 newdevs
&= ~olddevs
;
1165 * Clear all retaining registers filled during DAA. We already
1166 * have the addressed assigned to them in the addrs array.
1168 for_each_set_bit(slot
, &newdevs
, master
->maxdevs
+ 1)
1169 i3c_master_add_i3c_dev_locked(m
, addrs
[slot
]);
1172 * Clear slots that ended up not being used. Can be caused by I3C
1173 * device creation failure or when the I3C device was already known
1174 * by the system but with a different address (in this case the device
1175 * already has a slot and does not need a new one).
1177 writel(readl(master
->regs
+ DEVS_CTRL
) |
1178 master
->free_rr_slots
<< DEVS_CTRL_DEV_CLR_SHIFT
,
1179 master
->regs
+ DEVS_CTRL
);
1181 i3c_master_defslvs_locked(&master
->base
);
1183 cdns_i3c_master_upd_i3c_scl_lim(master
);
1185 /* Unmask Hot-Join and Mastership request interrupts. */
1186 i3c_master_enec_locked(m
, I3C_BROADCAST_ADDR
,
1187 I3C_CCC_EVENT_HJ
| I3C_CCC_EVENT_MR
);
1192 static u8
cdns_i3c_master_calculate_thd_delay(struct cdns_i3c_master
*master
)
1194 unsigned long sysclk_rate
= clk_get_rate(master
->sysclk
);
1195 u8 thd_delay
= DIV_ROUND_UP(master
->devdata
->thd_delay_ns
,
1196 (NSEC_PER_SEC
/ sysclk_rate
));
1198 /* Every value greater than 3 is not valid. */
1199 if (thd_delay
> THD_DELAY_MAX
)
1200 thd_delay
= THD_DELAY_MAX
;
1202 /* CTLR_THD_DEL value is encoded. */
1203 return (THD_DELAY_MAX
- thd_delay
);
1206 static int cdns_i3c_master_bus_init(struct i3c_master_controller
*m
)
1208 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1209 unsigned long pres_step
, sysclk_rate
, max_i2cfreq
;
1210 struct i3c_bus
*bus
= i3c_master_get_bus(m
);
1211 u32 ctrl
, prescl0
, prescl1
, pres
, low
;
1212 struct i3c_device_info info
= { };
1215 switch (bus
->mode
) {
1216 case I3C_BUS_MODE_PURE
:
1217 ctrl
= CTRL_PURE_BUS_MODE
;
1220 case I3C_BUS_MODE_MIXED_FAST
:
1221 ctrl
= CTRL_MIXED_FAST_BUS_MODE
;
1224 case I3C_BUS_MODE_MIXED_SLOW
:
1225 ctrl
= CTRL_MIXED_SLOW_BUS_MODE
;
1232 sysclk_rate
= clk_get_rate(master
->sysclk
);
1236 pres
= DIV_ROUND_UP(sysclk_rate
, (bus
->scl_rate
.i3c
* 4)) - 1;
1237 if (pres
> PRESCL_CTRL0_I3C_MAX
)
1240 bus
->scl_rate
.i3c
= sysclk_rate
/ ((pres
+ 1) * 4);
1242 prescl0
= PRESCL_CTRL0_I3C(pres
);
1244 low
= ((I3C_BUS_TLOW_OD_MIN_NS
* sysclk_rate
) / (pres
+ 1)) - 2;
1245 prescl1
= PRESCL_CTRL1_OD_LOW(low
);
1247 max_i2cfreq
= bus
->scl_rate
.i2c
;
1249 pres
= (sysclk_rate
/ (max_i2cfreq
* 5)) - 1;
1250 if (pres
> PRESCL_CTRL0_I2C_MAX
)
1253 bus
->scl_rate
.i2c
= sysclk_rate
/ ((pres
+ 1) * 5);
1255 prescl0
|= PRESCL_CTRL0_I2C(pres
);
1256 writel(prescl0
, master
->regs
+ PRESCL_CTRL0
);
1258 /* Calculate OD and PP low. */
1259 pres_step
= 1000000000 / (bus
->scl_rate
.i3c
* 4);
1260 ncycles
= DIV_ROUND_UP(I3C_BUS_TLOW_OD_MIN_NS
, pres_step
) - 2;
1263 prescl1
= PRESCL_CTRL1_OD_LOW(ncycles
);
1264 writel(prescl1
, master
->regs
+ PRESCL_CTRL1
);
1266 /* Get an address for the master. */
1267 ret
= i3c_master_get_free_addr(m
, 0);
1271 writel(prepare_rr0_dev_address(ret
) | DEV_ID_RR0_IS_I3C
,
1272 master
->regs
+ DEV_ID_RR0(0));
1274 cdns_i3c_master_dev_rr_to_info(master
, 0, &info
);
1275 if (info
.bcr
& I3C_BCR_HDR_CAP
)
1276 info
.hdr_cap
= I3C_CCC_HDR_MODE(I3C_HDR_DDR
);
1278 ret
= i3c_master_set_info(&master
->base
, &info
);
1283 * Enable Hot-Join, and, when a Hot-Join request happens, disable all
1284 * events coming from this device.
1286 * We will issue ENTDAA afterwards from the threaded IRQ handler.
1288 ctrl
|= CTRL_HJ_ACK
| CTRL_HJ_DISEC
| CTRL_HALT_EN
| CTRL_MCS_EN
;
1291 * Configure data hold delay based on device-specific data.
1293 * MIPI I3C Specification 1.0 defines non-zero minimal tHD_PP timing on
1294 * master output. This setting allows to meet this timing on master's
1295 * SoC outputs, regardless of PCB balancing.
1297 ctrl
|= CTRL_THD_DELAY(cdns_i3c_master_calculate_thd_delay(master
));
1298 writel(ctrl
, master
->regs
+ CTRL
);
1300 cdns_i3c_master_enable(master
);
1305 static void cdns_i3c_master_handle_ibi(struct cdns_i3c_master
*master
,
1308 struct cdns_i3c_i2c_dev_data
*data
;
1309 bool data_consumed
= false;
1310 struct i3c_ibi_slot
*slot
;
1311 u32 id
= IBIR_SLVID(ibir
);
1312 struct i3c_dev_desc
*dev
;
1317 * FIXME: maybe we should report the FIFO OVF errors to the upper
1320 if (id
>= master
->ibi
.num_slots
|| (ibir
& IBIR_ERROR
))
1323 dev
= master
->ibi
.slots
[id
];
1324 spin_lock(&master
->ibi
.lock
);
1326 data
= i3c_dev_get_master_data(dev
);
1327 slot
= i3c_generic_ibi_get_free_slot(data
->ibi_pool
);
1333 nbytes
= IBIR_XFER_BYTES(ibir
);
1334 readsl(master
->regs
+ IBI_DATA_FIFO
, buf
, nbytes
/ 4);
1336 u32 tmp
= __raw_readl(master
->regs
+ IBI_DATA_FIFO
);
1338 memcpy(buf
+ (nbytes
& ~3), &tmp
, nbytes
& 3);
1341 slot
->len
= min_t(unsigned int, IBIR_XFER_BYTES(ibir
),
1342 dev
->ibi
->max_payload_len
);
1343 i3c_master_queue_ibi(dev
, slot
);
1344 data_consumed
= true;
1347 spin_unlock(&master
->ibi
.lock
);
1350 /* Consume data from the FIFO if it's not been done already. */
1351 if (!data_consumed
) {
1354 for (i
= 0; i
< IBIR_XFER_BYTES(ibir
); i
+= 4)
1355 readl(master
->regs
+ IBI_DATA_FIFO
);
1359 static void cnds_i3c_master_demux_ibis(struct cdns_i3c_master
*master
)
1363 writel(MST_INT_IBIR_THR
, master
->regs
+ MST_ICR
);
1365 for (status0
= readl(master
->regs
+ MST_STATUS0
);
1366 !(status0
& MST_STATUS0_IBIR_EMP
);
1367 status0
= readl(master
->regs
+ MST_STATUS0
)) {
1368 u32 ibir
= readl(master
->regs
+ IBIR
);
1370 switch (IBIR_TYPE(ibir
)) {
1372 cdns_i3c_master_handle_ibi(master
, ibir
);
1376 WARN_ON(IBIR_XFER_BYTES(ibir
) || (ibir
& IBIR_ERROR
));
1377 queue_work(master
->base
.wq
, &master
->hj_work
);
1381 WARN_ON(IBIR_XFER_BYTES(ibir
) || (ibir
& IBIR_ERROR
));
1390 static irqreturn_t
cdns_i3c_master_interrupt(int irq
, void *data
)
1392 struct cdns_i3c_master
*master
= data
;
1395 status
= readl(master
->regs
+ MST_ISR
);
1396 if (!(status
& readl(master
->regs
+ MST_IMR
)))
1399 spin_lock(&master
->xferqueue
.lock
);
1400 cdns_i3c_master_end_xfer_locked(master
, status
);
1401 spin_unlock(&master
->xferqueue
.lock
);
1403 if (status
& MST_INT_IBIR_THR
)
1404 cnds_i3c_master_demux_ibis(master
);
1409 static int cdns_i3c_master_disable_ibi(struct i3c_dev_desc
*dev
)
1411 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
1412 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1413 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
1414 unsigned long flags
;
1418 ret
= i3c_master_disec_locked(m
, dev
->info
.dyn_addr
,
1423 spin_lock_irqsave(&master
->ibi
.lock
, flags
);
1424 sirmap
= readl(master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1425 sirmap
&= ~SIR_MAP_DEV_CONF_MASK(data
->ibi
);
1426 sirmap
|= SIR_MAP_DEV_CONF(data
->ibi
,
1427 SIR_MAP_DEV_DA(I3C_BROADCAST_ADDR
));
1428 writel(sirmap
, master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1429 spin_unlock_irqrestore(&master
->ibi
.lock
, flags
);
1434 static int cdns_i3c_master_enable_ibi(struct i3c_dev_desc
*dev
)
1436 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
1437 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1438 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
1439 unsigned long flags
;
1443 spin_lock_irqsave(&master
->ibi
.lock
, flags
);
1444 sirmap
= readl(master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1445 sirmap
&= ~SIR_MAP_DEV_CONF_MASK(data
->ibi
);
1446 sircfg
= SIR_MAP_DEV_ROLE(dev
->info
.bcr
>> 6) |
1447 SIR_MAP_DEV_DA(dev
->info
.dyn_addr
) |
1448 SIR_MAP_DEV_PL(dev
->info
.max_ibi_len
) |
1451 if (dev
->info
.bcr
& I3C_BCR_MAX_DATA_SPEED_LIM
)
1452 sircfg
|= SIR_MAP_DEV_SLOW
;
1454 sirmap
|= SIR_MAP_DEV_CONF(data
->ibi
, sircfg
);
1455 writel(sirmap
, master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1456 spin_unlock_irqrestore(&master
->ibi
.lock
, flags
);
1458 ret
= i3c_master_enec_locked(m
, dev
->info
.dyn_addr
,
1461 spin_lock_irqsave(&master
->ibi
.lock
, flags
);
1462 sirmap
= readl(master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1463 sirmap
&= ~SIR_MAP_DEV_CONF_MASK(data
->ibi
);
1464 sirmap
|= SIR_MAP_DEV_CONF(data
->ibi
,
1465 SIR_MAP_DEV_DA(I3C_BROADCAST_ADDR
));
1466 writel(sirmap
, master
->regs
+ SIR_MAP_DEV_REG(data
->ibi
));
1467 spin_unlock_irqrestore(&master
->ibi
.lock
, flags
);
1473 static int cdns_i3c_master_request_ibi(struct i3c_dev_desc
*dev
,
1474 const struct i3c_ibi_setup
*req
)
1476 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
1477 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1478 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
1479 unsigned long flags
;
1482 data
->ibi_pool
= i3c_generic_ibi_alloc_pool(dev
, req
);
1483 if (IS_ERR(data
->ibi_pool
))
1484 return PTR_ERR(data
->ibi_pool
);
1486 spin_lock_irqsave(&master
->ibi
.lock
, flags
);
1487 for (i
= 0; i
< master
->ibi
.num_slots
; i
++) {
1488 if (!master
->ibi
.slots
[i
]) {
1490 master
->ibi
.slots
[i
] = dev
;
1494 spin_unlock_irqrestore(&master
->ibi
.lock
, flags
);
1496 if (i
< master
->ibi
.num_slots
)
1499 i3c_generic_ibi_free_pool(data
->ibi_pool
);
1500 data
->ibi_pool
= NULL
;
1505 static void cdns_i3c_master_free_ibi(struct i3c_dev_desc
*dev
)
1507 struct i3c_master_controller
*m
= i3c_dev_get_master(dev
);
1508 struct cdns_i3c_master
*master
= to_cdns_i3c_master(m
);
1509 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
1510 unsigned long flags
;
1512 spin_lock_irqsave(&master
->ibi
.lock
, flags
);
1513 master
->ibi
.slots
[data
->ibi
] = NULL
;
1515 spin_unlock_irqrestore(&master
->ibi
.lock
, flags
);
1517 i3c_generic_ibi_free_pool(data
->ibi_pool
);
1520 static void cdns_i3c_master_recycle_ibi_slot(struct i3c_dev_desc
*dev
,
1521 struct i3c_ibi_slot
*slot
)
1523 struct cdns_i3c_i2c_dev_data
*data
= i3c_dev_get_master_data(dev
);
1525 i3c_generic_ibi_recycle_slot(data
->ibi_pool
, slot
);
1528 static const struct i3c_master_controller_ops cdns_i3c_master_ops
= {
1529 .bus_init
= cdns_i3c_master_bus_init
,
1530 .bus_cleanup
= cdns_i3c_master_bus_cleanup
,
1531 .do_daa
= cdns_i3c_master_do_daa
,
1532 .attach_i3c_dev
= cdns_i3c_master_attach_i3c_dev
,
1533 .reattach_i3c_dev
= cdns_i3c_master_reattach_i3c_dev
,
1534 .detach_i3c_dev
= cdns_i3c_master_detach_i3c_dev
,
1535 .attach_i2c_dev
= cdns_i3c_master_attach_i2c_dev
,
1536 .detach_i2c_dev
= cdns_i3c_master_detach_i2c_dev
,
1537 .supports_ccc_cmd
= cdns_i3c_master_supports_ccc_cmd
,
1538 .send_ccc_cmd
= cdns_i3c_master_send_ccc_cmd
,
1539 .priv_xfers
= cdns_i3c_master_priv_xfers
,
1540 .i2c_xfers
= cdns_i3c_master_i2c_xfers
,
1541 .enable_ibi
= cdns_i3c_master_enable_ibi
,
1542 .disable_ibi
= cdns_i3c_master_disable_ibi
,
1543 .request_ibi
= cdns_i3c_master_request_ibi
,
1544 .free_ibi
= cdns_i3c_master_free_ibi
,
1545 .recycle_ibi_slot
= cdns_i3c_master_recycle_ibi_slot
,
1548 static void cdns_i3c_master_hj(struct work_struct
*work
)
1550 struct cdns_i3c_master
*master
= container_of(work
,
1551 struct cdns_i3c_master
,
1554 i3c_master_do_daa(&master
->base
);
1557 static struct cdns_i3c_data cdns_i3c_devdata
= {
1561 static const struct of_device_id cdns_i3c_master_of_ids
[] = {
1562 { .compatible
= "cdns,i3c-master", .data
= &cdns_i3c_devdata
},
1565 MODULE_DEVICE_TABLE(of
, cdns_i3c_master_of_ids
);
1567 static int cdns_i3c_master_probe(struct platform_device
*pdev
)
1569 struct cdns_i3c_master
*master
;
1573 master
= devm_kzalloc(&pdev
->dev
, sizeof(*master
), GFP_KERNEL
);
1577 master
->devdata
= of_device_get_match_data(&pdev
->dev
);
1578 if (!master
->devdata
)
1581 master
->regs
= devm_platform_ioremap_resource(pdev
, 0);
1582 if (IS_ERR(master
->regs
))
1583 return PTR_ERR(master
->regs
);
1585 master
->pclk
= devm_clk_get(&pdev
->dev
, "pclk");
1586 if (IS_ERR(master
->pclk
))
1587 return PTR_ERR(master
->pclk
);
1589 master
->sysclk
= devm_clk_get(&pdev
->dev
, "sysclk");
1590 if (IS_ERR(master
->sysclk
))
1591 return PTR_ERR(master
->sysclk
);
1593 irq
= platform_get_irq(pdev
, 0);
1597 ret
= clk_prepare_enable(master
->pclk
);
1601 ret
= clk_prepare_enable(master
->sysclk
);
1603 goto err_disable_pclk
;
1605 if (readl(master
->regs
+ DEV_ID
) != DEV_ID_I3C_MASTER
) {
1607 goto err_disable_sysclk
;
1610 spin_lock_init(&master
->xferqueue
.lock
);
1611 INIT_LIST_HEAD(&master
->xferqueue
.list
);
1613 INIT_WORK(&master
->hj_work
, cdns_i3c_master_hj
);
1614 writel(0xffffffff, master
->regs
+ MST_IDR
);
1615 writel(0xffffffff, master
->regs
+ SLV_IDR
);
1616 ret
= devm_request_irq(&pdev
->dev
, irq
, cdns_i3c_master_interrupt
, 0,
1617 dev_name(&pdev
->dev
), master
);
1619 goto err_disable_sysclk
;
1621 platform_set_drvdata(pdev
, master
);
1623 val
= readl(master
->regs
+ CONF_STATUS0
);
1625 /* Device ID0 is reserved to describe this master. */
1626 master
->maxdevs
= CONF_STATUS0_DEVS_NUM(val
);
1627 master
->free_rr_slots
= GENMASK(master
->maxdevs
, 1);
1628 master
->caps
.ibirfifodepth
= CONF_STATUS0_IBIR_DEPTH(val
);
1629 master
->caps
.cmdrfifodepth
= CONF_STATUS0_CMDR_DEPTH(val
);
1631 val
= readl(master
->regs
+ CONF_STATUS1
);
1632 master
->caps
.cmdfifodepth
= CONF_STATUS1_CMD_DEPTH(val
);
1633 master
->caps
.rxfifodepth
= CONF_STATUS1_RX_DEPTH(val
);
1634 master
->caps
.txfifodepth
= CONF_STATUS1_TX_DEPTH(val
);
1636 spin_lock_init(&master
->ibi
.lock
);
1637 master
->ibi
.num_slots
= CONF_STATUS1_IBI_HW_RES(val
);
1638 master
->ibi
.slots
= devm_kcalloc(&pdev
->dev
, master
->ibi
.num_slots
,
1639 sizeof(*master
->ibi
.slots
),
1641 if (!master
->ibi
.slots
) {
1643 goto err_disable_sysclk
;
1646 writel(IBIR_THR(1), master
->regs
+ CMD_IBI_THR_CTRL
);
1647 writel(MST_INT_IBIR_THR
, master
->regs
+ MST_IER
);
1648 writel(DEVS_CTRL_DEV_CLR_ALL
, master
->regs
+ DEVS_CTRL
);
1650 ret
= i3c_master_register(&master
->base
, &pdev
->dev
,
1651 &cdns_i3c_master_ops
, false);
1653 goto err_disable_sysclk
;
1658 clk_disable_unprepare(master
->sysclk
);
1661 clk_disable_unprepare(master
->pclk
);
1666 static void cdns_i3c_master_remove(struct platform_device
*pdev
)
1668 struct cdns_i3c_master
*master
= platform_get_drvdata(pdev
);
1670 cancel_work_sync(&master
->hj_work
);
1671 i3c_master_unregister(&master
->base
);
1673 clk_disable_unprepare(master
->sysclk
);
1674 clk_disable_unprepare(master
->pclk
);
1677 static struct platform_driver cdns_i3c_master
= {
1678 .probe
= cdns_i3c_master_probe
,
1679 .remove
= cdns_i3c_master_remove
,
1681 .name
= "cdns-i3c-master",
1682 .of_match_table
= cdns_i3c_master_of_ids
,
1685 module_platform_driver(cdns_i3c_master
);
1687 MODULE_AUTHOR("Boris Brezillon <boris.brezillon@bootlin.com>");
1688 MODULE_DESCRIPTION("Cadence I3C master driver");
1689 MODULE_LICENSE("GPL v2");
1690 MODULE_ALIAS("platform:cdns-i3c-master");