1e9c11c6eSCaleb Connolly /* SPDX-License-Identifier: GPL-2.0-only */
2e9c11c6eSCaleb Connolly /* Copyright (c) 2022 Linaro. All rights reserved.
3e9c11c6eSCaleb Connolly  * Author: Caleb Connolly <caleb.connolly@linaro.org>
4e9c11c6eSCaleb Connolly  */
5e9c11c6eSCaleb Connolly 
6e9c11c6eSCaleb Connolly #ifndef __QCOM_SPMI_PMIC_H__
7e9c11c6eSCaleb Connolly #define __QCOM_SPMI_PMIC_H__
8e9c11c6eSCaleb Connolly 
9e9c11c6eSCaleb Connolly #include <linux/device.h>
10e9c11c6eSCaleb Connolly 
11e9c11c6eSCaleb Connolly #define COMMON_SUBTYPE		0x00
12e9c11c6eSCaleb Connolly #define PM8941_SUBTYPE		0x01
13e9c11c6eSCaleb Connolly #define PM8841_SUBTYPE		0x02
14e9c11c6eSCaleb Connolly #define PM8019_SUBTYPE		0x03
15e9c11c6eSCaleb Connolly #define PM8226_SUBTYPE		0x04
16e9c11c6eSCaleb Connolly #define PM8110_SUBTYPE		0x05
17e9c11c6eSCaleb Connolly #define PMA8084_SUBTYPE		0x06
18e9c11c6eSCaleb Connolly #define PMI8962_SUBTYPE		0x07
19e9c11c6eSCaleb Connolly #define PMD9635_SUBTYPE		0x08
20e9c11c6eSCaleb Connolly #define PM8994_SUBTYPE		0x09
21e9c11c6eSCaleb Connolly #define PMI8994_SUBTYPE		0x0a
22e9c11c6eSCaleb Connolly #define PM8916_SUBTYPE		0x0b
23e9c11c6eSCaleb Connolly #define PM8004_SUBTYPE		0x0c
24e9c11c6eSCaleb Connolly #define PM8909_SUBTYPE		0x0d
25e9c11c6eSCaleb Connolly #define PM8028_SUBTYPE		0x0e
26e9c11c6eSCaleb Connolly #define PM8901_SUBTYPE		0x0f
27e9c11c6eSCaleb Connolly #define PM8950_SUBTYPE		0x10
28e9c11c6eSCaleb Connolly #define PMI8950_SUBTYPE		0x11
29e9c11c6eSCaleb Connolly #define PM8998_SUBTYPE		0x14
30e9c11c6eSCaleb Connolly #define PMI8998_SUBTYPE		0x15
31e9c11c6eSCaleb Connolly #define PM8005_SUBTYPE		0x18
32e9c11c6eSCaleb Connolly #define PM660L_SUBTYPE		0x1A
33e9c11c6eSCaleb Connolly #define PM660_SUBTYPE		0x1B
34e9c11c6eSCaleb Connolly #define PM8150_SUBTYPE		0x1E
35e9c11c6eSCaleb Connolly #define PM8150L_SUBTYPE		0x1f
36e9c11c6eSCaleb Connolly #define PM8150B_SUBTYPE		0x20
37e9c11c6eSCaleb Connolly #define PMK8002_SUBTYPE		0x21
38e9c11c6eSCaleb Connolly #define PM8009_SUBTYPE		0x24
39e9c11c6eSCaleb Connolly #define PM8150C_SUBTYPE		0x26
40e9c11c6eSCaleb Connolly #define SMB2351_SUBTYPE		0x29
41e9c11c6eSCaleb Connolly 
42e9c11c6eSCaleb Connolly #define PMI8998_FAB_ID_SMIC	0x11
43e9c11c6eSCaleb Connolly #define PMI8998_FAB_ID_GF	0x30
44e9c11c6eSCaleb Connolly 
45e9c11c6eSCaleb Connolly #define PM660_FAB_ID_GF		0x0
46e9c11c6eSCaleb Connolly #define PM660_FAB_ID_TSMC	0x2
47e9c11c6eSCaleb Connolly #define PM660_FAB_ID_MX		0x3
48e9c11c6eSCaleb Connolly 
49e9c11c6eSCaleb Connolly struct qcom_spmi_pmic {
50e9c11c6eSCaleb Connolly 	unsigned int type;
51e9c11c6eSCaleb Connolly 	unsigned int subtype;
52e9c11c6eSCaleb Connolly 	unsigned int major;
53e9c11c6eSCaleb Connolly 	unsigned int minor;
54e9c11c6eSCaleb Connolly 	unsigned int rev2;
55*d23c3c08SCaleb Connolly 	unsigned int fab_id;
56e9c11c6eSCaleb Connolly 	const char *name;
57e9c11c6eSCaleb Connolly };
58e9c11c6eSCaleb Connolly 
59e9c11c6eSCaleb Connolly const struct qcom_spmi_pmic *qcom_pmic_get(struct device *dev);
60e9c11c6eSCaleb Connolly 
61e9c11c6eSCaleb Connolly #endif /* __QCOM_SPMI_PMIC_H__ */
62