hc
2024-08-12 0517ab8c70e05fc5877c0c6dae1a5f42a16dcf88
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * TI LMU (Lighting Management Unit) Device Register Map
 *
 * Copyright 2017 Texas Instruments
 *
 * Author: Milo Kim <milo.kim@ti.com>
 */
 
#ifndef __MFD_TI_LMU_REGISTER_H__
#define __MFD_TI_LMU_REGISTER_H__
 
#include <linux/bitops.h>
 
/* LM3631 */
#define LM3631_REG_DEVCTRL            0x00
#define LM3631_LCD_EN_MASK            BIT(1)
#define LM3631_BL_EN_MASK            BIT(0)
 
#define LM3631_REG_BRT_LSB            0x01
#define LM3631_REG_BRT_MSB            0x02
 
#define LM3631_REG_BL_CFG            0x06
#define LM3631_BL_CHANNEL_MASK            BIT(3)
#define LM3631_BL_DUAL_CHANNEL            0
#define LM3631_BL_SINGLE_CHANNEL        BIT(3)
#define LM3631_MAP_MASK                BIT(5)
#define LM3631_EXPONENTIAL_MAP            0
 
#define LM3631_REG_BRT_MODE            0x08
#define LM3631_MODE_MASK            (BIT(1) | BIT(2) | BIT(3))
#define LM3631_DEFAULT_MODE            (BIT(1) | BIT(3))
 
#define LM3631_REG_SLOPE            0x09
#define LM3631_SLOPE_MASK            0xF0
#define LM3631_SLOPE_SHIFT            4
 
#define LM3631_REG_LDO_CTRL1            0x0A
#define LM3631_EN_OREF_MASK            BIT(0)
#define LM3631_EN_VNEG_MASK            BIT(1)
#define LM3631_EN_VPOS_MASK            BIT(2)
 
#define LM3631_REG_LDO_CTRL2            0x0B
#define LM3631_EN_CONT_MASK            BIT(0)
 
#define LM3631_REG_VOUT_CONT            0x0C
#define LM3631_VOUT_CONT_MASK            (BIT(6) | BIT(7))
 
#define LM3631_REG_VOUT_BOOST            0x0C
#define LM3631_REG_VOUT_POS            0x0D
#define LM3631_REG_VOUT_NEG            0x0E
#define LM3631_REG_VOUT_OREF            0x0F
#define LM3631_VOUT_MASK            0x3F
 
#define LM3631_REG_ENTIME_VCONT            0x0B
#define LM3631_ENTIME_CONT_MASK            0x70
 
#define LM3631_REG_ENTIME_VOREF            0x0F
#define LM3631_REG_ENTIME_VPOS            0x10
#define LM3631_REG_ENTIME_VNEG            0x11
#define LM3631_ENTIME_MASK            0xF0
#define LM3631_ENTIME_SHIFT            4
 
#define LM3631_MAX_REG                0x16
 
/* LM3632 */
#define LM3632_REG_CONFIG1            0x02
#define LM3632_OVP_MASK                (BIT(5) | BIT(6) | BIT(7))
#define LM3632_OVP_25V                BIT(6)
 
#define LM3632_REG_CONFIG2            0x03
#define LM3632_SWFREQ_MASK            BIT(7)
#define LM3632_SWFREQ_1MHZ            BIT(7)
 
#define LM3632_REG_BRT_LSB            0x04
#define LM3632_REG_BRT_MSB            0x05
 
#define LM3632_REG_IO_CTRL            0x09
#define LM3632_PWM_MASK                BIT(6)
#define LM3632_I2C_MODE                0
#define LM3632_PWM_MODE                BIT(6)
 
#define LM3632_REG_ENABLE            0x0A
#define LM3632_BL_EN_MASK            BIT(0)
#define LM3632_BL_CHANNEL_MASK            (BIT(3) | BIT(4))
#define LM3632_BL_SINGLE_CHANNEL            BIT(4)
#define LM3632_BL_DUAL_CHANNEL            BIT(3)
 
#define LM3632_REG_BIAS_CONFIG            0x0C
#define LM3632_EXT_EN_MASK            BIT(0)
#define LM3632_EN_VNEG_MASK            BIT(1)
#define LM3632_EN_VPOS_MASK            BIT(2)
 
#define LM3632_REG_VOUT_BOOST            0x0D
#define LM3632_REG_VOUT_POS            0x0E
#define LM3632_REG_VOUT_NEG            0x0F
#define LM3632_VOUT_MASK            0x3F
 
#define LM3632_MAX_REG                0x10
 
/* LM3633 */
#define LM3633_REG_HVLED_OUTPUT_CFG        0x10
#define LM3633_HVLED1_CFG_MASK            BIT(0)
#define LM3633_HVLED2_CFG_MASK            BIT(1)
#define LM3633_HVLED3_CFG_MASK            BIT(2)
#define LM3633_HVLED1_CFG_SHIFT            0
#define LM3633_HVLED2_CFG_SHIFT            1
#define LM3633_HVLED3_CFG_SHIFT            2
 
#define LM3633_REG_BANK_SEL            0x11
 
#define LM3633_REG_BL0_RAMP            0x12
#define LM3633_REG_BL1_RAMP            0x13
#define LM3633_BL_RAMPUP_MASK            0xF0
#define LM3633_BL_RAMPUP_SHIFT            4
#define LM3633_BL_RAMPDN_MASK            0x0F
#define LM3633_BL_RAMPDN_SHIFT            0
 
#define LM3633_REG_BL_RAMP_CONF            0x1B
#define LM3633_BL_RAMP_MASK            0x0F
#define LM3633_BL_RAMP_EACH            0x05
 
#define LM3633_REG_PTN0_RAMP            0x1C
#define LM3633_REG_PTN1_RAMP            0x1D
#define LM3633_PTN_RAMPUP_MASK            0x70
#define LM3633_PTN_RAMPUP_SHIFT            4
#define LM3633_PTN_RAMPDN_MASK            0x07
#define LM3633_PTN_RAMPDN_SHIFT            0
 
#define LM3633_REG_LED_MAPPING_MODE        0x1F
#define LM3633_LED_EXPONENTIAL            BIT(1)
 
#define LM3633_REG_IMAX_HVLED_A            0x20
#define LM3633_REG_IMAX_HVLED_B            0x21
#define LM3633_REG_IMAX_LVLED_BASE        0x22
 
#define LM3633_REG_BL_FEEDBACK_ENABLE        0x28
 
#define LM3633_REG_ENABLE            0x2B
#define LM3633_LED_BANK_OFFSET            2
 
#define LM3633_REG_PATTERN            0x2C
 
#define LM3633_REG_BOOST_CFG            0x2D
#define LM3633_OVP_MASK                (BIT(1) | BIT(2))
#define LM3633_OVP_40V                0x6
 
#define LM3633_REG_PWM_CFG            0x2F
#define LM3633_PWM_A_MASK            BIT(0)
#define LM3633_PWM_B_MASK            BIT(1)
 
#define LM3633_REG_BRT_HVLED_A_LSB        0x40
#define LM3633_REG_BRT_HVLED_A_MSB        0x41
#define LM3633_REG_BRT_HVLED_B_LSB        0x42
#define LM3633_REG_BRT_HVLED_B_MSB        0x43
 
#define LM3633_REG_BRT_LVLED_BASE        0x44
 
#define LM3633_REG_PTN_DELAY            0x50
 
#define LM3633_REG_PTN_LOWTIME            0x51
 
#define LM3633_REG_PTN_HIGHTIME            0x52
 
#define LM3633_REG_PTN_LOWBRT            0x53
 
#define LM3633_REG_PTN_HIGHBRT            LM3633_REG_BRT_LVLED_BASE
 
#define LM3633_REG_BL_OPEN_FAULT_STATUS        0xB0
 
#define LM3633_REG_BL_SHORT_FAULT_STATUS    0xB2
 
#define LM3633_REG_MONITOR_ENABLE        0xB4
 
#define LM3633_MAX_REG                0xB4
 
/* LM3695 */
#define LM3695_REG_GP                0x10
#define LM3695_BL_CHANNEL_MASK            BIT(3)
#define LM3695_BL_DUAL_CHANNEL            0
#define LM3695_BL_SINGLE_CHANNEL            BIT(3)
#define LM3695_BRT_RW_MASK            BIT(2)
#define LM3695_BL_EN_MASK            BIT(0)
 
#define LM3695_REG_BRT_LSB            0x13
#define LM3695_REG_BRT_MSB            0x14
 
#define LM3695_MAX_REG                0x14
 
/* LM36274 */
#define LM36274_REG_REV                0x01
#define LM36274_REG_BL_CFG_1            0x02
#define LM36274_REG_BL_CFG_2            0x03
#define LM36274_REG_BRT_LSB            0x04
#define LM36274_REG_BRT_MSB            0x05
#define LM36274_REG_BL_EN            0x08
 
#define LM36274_REG_BIAS_CONFIG_1        0x09
#define LM36274_EXT_EN_MASK            BIT(0)
#define LM36274_EN_VNEG_MASK            BIT(1)
#define LM36274_EN_VPOS_MASK            BIT(2)
 
#define LM36274_REG_BIAS_CONFIG_2        0x0a
#define LM36274_REG_BIAS_CONFIG_3        0x0b
#define LM36274_REG_VOUT_BOOST            0x0c
#define LM36274_REG_VOUT_POS            0x0d
#define LM36274_REG_VOUT_NEG            0x0e
#define LM36274_VOUT_MASK            0x3F
 
#define LM36274_MAX_REG                0x13
 
#endif