summaryrefslogtreecommitdiffstats
path: root/src/soc/mediatek/mt8173/include/soc/da9212.h
blob: 54be8950437ea958acd13399223fd04dc09d9c08 (plain)
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/* SPDX-License-Identifier: GPL-2.0-only */
/* This file is part of the coreboot project. */

#ifndef __SOC_DA9212_H_
#define __SOC_DA9212_H_

#include <stdint.h>

void da9212_probe(uint8_t i2c_num);

enum {
	/* Page selection */
	DA9212_REG_PAGE_CON = 0x0,

	/* Regulator Registers */
	DA9212_REG_BUCKA_CONT = 0x5D,
	DA9212_REG_BUCKB_CONT = 0x5E,
	DA9212_REG_BUCKA_CONF = 0xD1,
	DA9212_REG_BUCKB_CONF = 0xD2,
};

/* DA9212_REG_PAGE_CON (addr=0x0) */
enum {
	DA9212_REG_PAGE_SHIFT = 0,
	DA9212_REG_PAGE_MASK = 0xf
};

enum {
	DA9212_REG_PAGE0 = 0,
	DA9212_REG_PAGE2 = 2,
	DA9212_REG_PAGE4 = 4,
	DA9212_PAGE_WRITE_MODE = 0x0,
	DA9212_REPEAT_WRITE_MODE = 0x40,
	DA9212_PAGE_REVERT = 0x80
};

/* DA9212_REG_BUCKA/B_CONT (addr=0x5D/0x5E) */
enum {
	DA9212_BUCK_EN_SHIFT = 0,
	DA9212_BUCK_OFF = 0x0,
	DA9212_BUCK_ON = 0x1,
	DA9212_BUCK_GPI_SHIFT = 1,
	DA9212_BUCK_GPI_MASK = 0x3,
	DA9212_BUCK_GPI_OFF = 0x0,
	DA9212_BUCK_GPI_GPIO0 = 0x1,
	DA9212_BUCK_GPI_GPIO1 = 0x2,
	DA9212_BUCK_GPI_GPIO4 = 0x3,
	DA9212_VBUCK_SEL_SHIFT = 4,
	DA9212_VBUCK_SEL_MASK = 0x1,
	DA9212_VBUCK_SEL_A = 0x0,
	DA9212_VBUCK_SEL_B = 0x1,
};

/* DA9212_REG_BUCKA/B_CONF (addr=0xD1/0xD2) */
enum {
	DA9212_BUCK_MODE_SHIFT = 0,
	DA9212_BUCK_MODE_MASK = 0x3,
	DA9212_BUCK_MODE_MANUAL = 0x0,
	DA9212_BUCK_MODE_PFM = 0x1,
	DA9212_BUCK_MODE_PWM = 0x2,
	DA9212_BUCK_MODE_AUTO = 0x3,
};

/* DA9212_REG_CONFIG_E (addr=0x147) */
enum {
	/* DEVICE IDs */
	DA9212_REG_DEVICE_ID = 0x1,
	DA9212_ID	     = 0x22,
	DA9213_ID	     = 0x23,
	DA9212_REG_VARIANT_ID = 0x2,
	DA9212_VARIANT_ID_AB  = 0x10,
	DA9212_VARIANT_ID_AC  = 0x20
};

#endif