xref: /openbmc/linux/include/linux/mfd/pcf50633/mbc.h (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 /*
3  * mbc.h  -- Driver for NXP PCF50633 Main Battery Charger
4  *
5  * (C) 2006-2008 by Openmoko, Inc.
6  * All rights reserved.
7  */
8 
9 #ifndef __LINUX_MFD_PCF50633_MBC_H
10 #define __LINUX_MFD_PCF50633_MBC_H
11 
12 #include <linux/mfd/pcf50633/core.h>
13 #include <linux/platform_device.h>
14 
15 #define PCF50633_REG_MBCC1	0x43
16 #define PCF50633_REG_MBCC2	0x44
17 #define PCF50633_REG_MBCC3	0x45
18 #define PCF50633_REG_MBCC4	0x46
19 #define PCF50633_REG_MBCC5	0x47
20 #define PCF50633_REG_MBCC6	0x48
21 #define PCF50633_REG_MBCC7	0x49
22 #define PCF50633_REG_MBCC8	0x4a
23 #define PCF50633_REG_MBCS1	0x4b
24 #define PCF50633_REG_MBCS2	0x4c
25 #define PCF50633_REG_MBCS3	0x4d
26 
27 enum pcf50633_reg_mbcc1 {
28 	PCF50633_MBCC1_CHGENA		= 0x01,	/* Charger enable */
29 	PCF50633_MBCC1_AUTOSTOP		= 0x02,
30 	PCF50633_MBCC1_AUTORES		= 0x04, /* automatic resume */
31 	PCF50633_MBCC1_RESUME		= 0x08, /* explicit resume cmd */
32 	PCF50633_MBCC1_RESTART		= 0x10, /* restart charging */
33 	PCF50633_MBCC1_PREWDTIME_60M	= 0x20,	/* max. precharging time */
34 	PCF50633_MBCC1_WDTIME_1H	= 0x00,
35 	PCF50633_MBCC1_WDTIME_2H	= 0x40,
36 	PCF50633_MBCC1_WDTIME_4H	= 0x80,
37 	PCF50633_MBCC1_WDTIME_6H	= 0xc0,
38 };
39 #define PCF50633_MBCC1_WDTIME_MASK	  0xc0
40 
41 enum pcf50633_reg_mbcc2 {
42 	PCF50633_MBCC2_VBATCOND_2V7	= 0x00,
43 	PCF50633_MBCC2_VBATCOND_2V85	= 0x01,
44 	PCF50633_MBCC2_VBATCOND_3V0	= 0x02,
45 	PCF50633_MBCC2_VBATCOND_3V15	= 0x03,
46 	PCF50633_MBCC2_VMAX_4V		= 0x00,
47 	PCF50633_MBCC2_VMAX_4V20	= 0x28,
48 	PCF50633_MBCC2_VRESDEBTIME_64S	= 0x80,	/* debounce time (32/64sec) */
49 };
50 
51 enum pcf50633_reg_mbcc7 {
52 	PCF50633_MBCC7_USB_100mA	= 0x00,
53 	PCF50633_MBCC7_USB_500mA	= 0x01,
54 	PCF50633_MBCC7_USB_1000mA	= 0x02,
55 	PCF50633_MBCC7_USB_SUSPEND	= 0x03,
56 	PCF50633_MBCC7_BATTEMP_EN	= 0x04,
57 	PCF50633_MBCC7_BATSYSIMAX_1A6	= 0x00,
58 	PCF50633_MBCC7_BATSYSIMAX_1A8	= 0x40,
59 	PCF50633_MBCC7_BATSYSIMAX_2A0	= 0x80,
60 	PCF50633_MBCC7_BATSYSIMAX_2A2	= 0xc0,
61 };
62 #define PCF50633_MBCC7_USB_MASK 0x03
63 
64 enum pcf50633_reg_mbcc8 {
65 	PCF50633_MBCC8_USBENASUS	= 0x10,
66 };
67 
68 enum pcf50633_reg_mbcs1 {
69 	PCF50633_MBCS1_USBPRES		= 0x01,
70 	PCF50633_MBCS1_USBOK		= 0x02,
71 	PCF50633_MBCS1_ADAPTPRES	= 0x04,
72 	PCF50633_MBCS1_ADAPTOK		= 0x08,
73 	PCF50633_MBCS1_TBAT_OK		= 0x00,
74 	PCF50633_MBCS1_TBAT_ABOVE	= 0x10,
75 	PCF50633_MBCS1_TBAT_BELOW	= 0x20,
76 	PCF50633_MBCS1_TBAT_UNDEF	= 0x30,
77 	PCF50633_MBCS1_PREWDTEXP	= 0x40,
78 	PCF50633_MBCS1_WDTEXP		= 0x80,
79 };
80 
81 enum pcf50633_reg_mbcs2_mbcmod {
82 	PCF50633_MBCS2_MBC_PLAY		= 0x00,
83 	PCF50633_MBCS2_MBC_USB_PRE	= 0x01,
84 	PCF50633_MBCS2_MBC_USB_PRE_WAIT	= 0x02,
85 	PCF50633_MBCS2_MBC_USB_FAST	= 0x03,
86 	PCF50633_MBCS2_MBC_USB_FAST_WAIT = 0x04,
87 	PCF50633_MBCS2_MBC_USB_SUSPEND	= 0x05,
88 	PCF50633_MBCS2_MBC_ADP_PRE	= 0x06,
89 	PCF50633_MBCS2_MBC_ADP_PRE_WAIT	= 0x07,
90 	PCF50633_MBCS2_MBC_ADP_FAST	= 0x08,
91 	PCF50633_MBCS2_MBC_ADP_FAST_WAIT = 0x09,
92 	PCF50633_MBCS2_MBC_BAT_FULL	= 0x0a,
93 	PCF50633_MBCS2_MBC_HALT		= 0x0b,
94 };
95 #define PCF50633_MBCS2_MBC_MASK		0x0f
96 enum pcf50633_reg_mbcs2_chgstat {
97 	PCF50633_MBCS2_CHGS_NONE	= 0x00,
98 	PCF50633_MBCS2_CHGS_ADAPTER	= 0x10,
99 	PCF50633_MBCS2_CHGS_USB		= 0x20,
100 	PCF50633_MBCS2_CHGS_BOTH	= 0x30,
101 };
102 #define PCF50633_MBCS2_RESSTAT_AUTO	0x40
103 
104 enum pcf50633_reg_mbcs3 {
105 	PCF50633_MBCS3_USBLIM_PLAY	= 0x01,
106 	PCF50633_MBCS3_USBLIM_CGH	= 0x02,
107 	PCF50633_MBCS3_TLIM_PLAY	= 0x04,
108 	PCF50633_MBCS3_TLIM_CHG		= 0x08,
109 	PCF50633_MBCS3_ILIM		= 0x10,	/* 1: Ibat > Icutoff */
110 	PCF50633_MBCS3_VLIM		= 0x20,	/* 1: Vbat == Vmax */
111 	PCF50633_MBCS3_VBATSTAT		= 0x40,	/* 1: Vbat > Vbatcond */
112 	PCF50633_MBCS3_VRES		= 0x80, /* 1: Vbat > Vth(RES) */
113 };
114 
115 #define PCF50633_MBCC2_VBATCOND_MASK	  0x03
116 #define PCF50633_MBCC2_VMAX_MASK	  0x3c
117 
118 /* Charger status */
119 #define PCF50633_MBC_USB_ONLINE		0x01
120 #define PCF50633_MBC_USB_ACTIVE		0x02
121 #define PCF50633_MBC_ADAPTER_ONLINE	0x04
122 #define PCF50633_MBC_ADAPTER_ACTIVE	0x08
123 
124 int pcf50633_mbc_usb_curlim_set(struct pcf50633 *pcf, int ma);
125 
126 int pcf50633_mbc_get_status(struct pcf50633 *);
127 int pcf50633_mbc_get_usb_online_status(struct pcf50633 *);
128 
129 #endif
130 
131