blob: b836d67fb62ecf66dcf04d60d60321140f24ec2a [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Adrian Alonso48469c22015-08-11 11:19:49 -05002/*
3 * Copyright (C) 2015 Freescale Semiconductor, Inc
4 * Peng Fan <Peng.Fan@freescale.com>
Adrian Alonso48469c22015-08-11 11:19:49 -05005 */
6#ifndef __PFUZE3000_PMIC_H_
7#define __PFUZE3000_PMIC_H_
8
9/* PFUZE3000 registers */
10enum {
11 PFUZE3000_DEVICEID = 0x00,
12
13 PFUZE3000_REVID = 0x03,
14 PFUZE3000_FABID = 0x04,
15 PFUZE3000_INTSTAT0 = 0x05,
16 PFUZE3000_INTMASK0 = 0x06,
17 PFUZE3000_INTSENSE0 = 0x07,
18 PFUZE3000_INTSTAT1 = 0x08,
19 PFUZE3000_INTMASK1 = 0x09,
20 PFUZE3000_INTSENSE1 = 0x0A,
21
22 PFUZE3000_INTSTAT3 = 0x0E,
23 PFUZE3000_INTMASK3 = 0x0F,
24 PFUZE3000_INTSENSE3 = 0x10,
25 PFUZE3000_INTSTAT4 = 0x11,
26 PFUZE3000_INTMASK4 = 0x12,
27 PFUZE3000_INTSENSE4 = 0x13,
28
29 PFUZE3000_COINCTL = 0x1A,
30 PFUZE3000_PWRCTL = 0x1B,
31 PFUZE3000_MEMA = 0x1C,
32 PFUZE3000_MEMB = 0x1D,
33 PFUZE3000_MEMC = 0x1E,
34 PFUZE3000_MEMD = 0x1F,
35
36 PFUZE3000_SW1AVOLT = 0x20,
37 PFUZE3000_SW1ASTBY = 0x21,
38 PFUZE3000_SW1AOFF = 0x22,
39 PFUZE3000_SW1AMODE = 0x23,
40 PFUZE3000_SW1ACONF = 0x24,
41
42 PFUZE3000_SW1BVOLT = 0x2E,
43 PFUZE3000_SW1BSTBY = 0x2F,
44 PFUZE3000_SW1BOFF = 0x30,
45 PFUZE3000_SW1BMODE = 0x31,
46 PFUZE3000_SW1BCONF = 0x32,
47
48 PFUZE3000_SW2VOLT = 0x35,
49 PFUZE3000_SW2STBY = 0x36,
50 PFUZE3000_SW2OFF = 0x37,
51 PFUZE3000_SW2MODE = 0x38,
52 PFUZE3000_SW2CONF = 0x39,
53
54 PFUZE3000_SW3VOLT = 0x3C,
55 PFUZE3000_SW3STBY = 0x3D,
56 PFUZE3000_SW3OFF = 0x3E,
57 PFUZE3000_SW3MODE = 0x3F,
58 PFUZE3000_SW3CONF = 0x40,
59
60 PFUZE3000_SWBSTCTL = 0x66,
61
62 PFUZE3000_LDOGCTL = 0x69,
63 PFUZE3000_VREFDDRCTL = 0x6A,
64 PFUZE3000_VSNVSCTL = 0x6B,
65 PFUZE3000_VLDO1CTL = 0x6C,
66 PFUZE3000_VLDO2CTL = 0x6D,
67 PFUZE3000_VCC_SDCTL = 0x6E,
68 PFUZE3000_V33CTL = 0x6F,
69 PFUZE3000_VLDO3CTL = 0x70,
70 PFUZE3000_VLD4CTL = 0x71,
71
Trent Piepho7da7ff52018-04-25 10:06:00 -070072 PFUZE3000_NUM_OF_REGS = 0x100,
Adrian Alonso48469c22015-08-11 11:19:49 -050073};
74
75int power_pfuze3000_init(unsigned char bus);
76
Breno Lima894a4b42016-12-06 15:38:24 -020077/* Voltage Configuration */
78#define PFUZE3000_SW1AB_SETP(x) ((x - 7000) / 250)
79#define PFUZE3000_SW3_SETP(x) ((x - 9000) / 500)
80#define PFUZE3000_VLDO_SETP(x) ((x - 8000) / 500)
81
Adrian Alonso48469c22015-08-11 11:19:49 -050082#endif