1*9ad9a52cSNicolas Pitre // SPDX-License-Identifier: BSD-3-Clause
2*9ad9a52cSNicolas Pitre /*
3*9ad9a52cSNicolas Pitre  * Copyright (c) 2020, MIPI Alliance, Inc.
4*9ad9a52cSNicolas Pitre  *
5*9ad9a52cSNicolas Pitre  * Author: Nicolas Pitre <npitre@baylibre.com>
6*9ad9a52cSNicolas Pitre  */
7*9ad9a52cSNicolas Pitre 
8*9ad9a52cSNicolas Pitre #include <linux/device.h>
9*9ad9a52cSNicolas Pitre #include <linux/bitfield.h>
10*9ad9a52cSNicolas Pitre #include <linux/i3c/master.h>
11*9ad9a52cSNicolas Pitre #include <linux/io.h>
12*9ad9a52cSNicolas Pitre 
13*9ad9a52cSNicolas Pitre #include "hci.h"
14*9ad9a52cSNicolas Pitre #include "dct.h"
15*9ad9a52cSNicolas Pitre 
16*9ad9a52cSNicolas Pitre /*
17*9ad9a52cSNicolas Pitre  * Device Characteristic Table
18*9ad9a52cSNicolas Pitre  */
19*9ad9a52cSNicolas Pitre 
i3c_hci_dct_get_val(struct i3c_hci * hci,unsigned int dct_idx,u64 * pid,unsigned int * dcr,unsigned int * bcr)20*9ad9a52cSNicolas Pitre void i3c_hci_dct_get_val(struct i3c_hci *hci, unsigned int dct_idx,
21*9ad9a52cSNicolas Pitre 			 u64 *pid, unsigned int *dcr, unsigned int *bcr)
22*9ad9a52cSNicolas Pitre {
23*9ad9a52cSNicolas Pitre 	void __iomem *reg = hci->DCT_regs + dct_idx * 4 * 4;
24*9ad9a52cSNicolas Pitre 	u32 dct_entry_data[4];
25*9ad9a52cSNicolas Pitre 	unsigned int i;
26*9ad9a52cSNicolas Pitre 
27*9ad9a52cSNicolas Pitre 	for (i = 0; i < 4; i++) {
28*9ad9a52cSNicolas Pitre 		dct_entry_data[i] = readl(reg);
29*9ad9a52cSNicolas Pitre 		reg += 4;
30*9ad9a52cSNicolas Pitre 	}
31*9ad9a52cSNicolas Pitre 
32*9ad9a52cSNicolas Pitre 	*pid = ((u64)dct_entry_data[0]) << (47 - 32 + 1) |
33*9ad9a52cSNicolas Pitre 	       FIELD_GET(W1_MASK(47, 32), dct_entry_data[1]);
34*9ad9a52cSNicolas Pitre 	*dcr = FIELD_GET(W2_MASK(71, 64), dct_entry_data[2]);
35*9ad9a52cSNicolas Pitre 	*bcr = FIELD_GET(W2_MASK(79, 72), dct_entry_data[2]);
36*9ad9a52cSNicolas Pitre }
37