aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/i3c/master/mipi-i3c-hci/dct_v1.c
blob: acfd4d60f7b071c34ebc50aa7c5a0a52f94623c5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// SPDX-License-Identifier: BSD-3-Clause
/*
 * Copyright (c) 2020, MIPI Alliance, Inc.
 *
 * Author: Nicolas Pitre <npitre@baylibre.com>
 */

#include <linux/device.h>
#include <linux/bitfield.h>
#include <linux/i3c/master.h>
#include <linux/io.h>

#include "hci.h"
#include "dct.h"

/*
 * Device Characteristic Table
 */

void i3c_hci_dct_get_val(struct i3c_hci *hci, unsigned int dct_idx,
			 u64 *pid, unsigned int *dcr, unsigned int *bcr)
{
	void __iomem *reg = hci->DCT_regs + dct_idx * 4 * 4;
	u32 dct_entry_data[4];
	unsigned int i;

	for (i = 0; i < 4; i++) {
		dct_entry_data[i] = readl(reg);
		reg += 4;
	}

	*pid = ((u64)dct_entry_data[0]) << (47 - 32 + 1) |
	       FIELD_GET(W1_MASK(47, 32), dct_entry_data[1]);
	*dcr = FIELD_GET(W2_MASK(71, 64), dct_entry_data[2]);
	*bcr = FIELD_GET(W2_MASK(79, 72), dct_entry_data[2]);
}