]> git.donarmstrong.com Git - qmk_firmware.git/blob - drivers/issi/is31fl3731-simple.h
c102837a30f57f4008e0ebb2700427949ddd0be7
[qmk_firmware.git] / drivers / issi / is31fl3731-simple.h
1 /* Copyright 2017 Jason Williams
2  * Copyright 2018 Jack Humbert
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17
18
19 #ifndef IS31FL3731_DRIVER_H
20 #define IS31FL3731_DRIVER_H
21
22
23 typedef struct is31_led {
24   uint8_t driver:2;
25   uint8_t v;
26 } __attribute__((packed)) is31_led;
27
28 extern const is31_led g_is31_leds[DRIVER_LED_TOTAL];
29
30 void IS31FL3731_init(uint8_t addr);
31 void IS31FL3731_write_register(uint8_t addr, uint8_t reg, uint8_t data);
32 void IS31FL3731_write_pwm_buffer(uint8_t addr, uint8_t *pwm_buffer);
33
34 void IS31FL3731_set_value(int index, uint8_t value);
35 void IS31FL3731_set_value_all(uint8_t value);
36
37 void IS31FL3731_set_led_control_register(uint8_t index, bool value);
38
39 // This should not be called from an interrupt
40 // (eg. from a timer interrupt).
41 // Call this while idle (in between matrix scans).
42 // If the buffer is dirty, it will update the driver with the buffer.
43 void IS31FL3731_update_pwm_buffers(uint8_t addr, uint8_t index);
44 void IS31FL3731_update_led_control_registers(uint8_t addr, uint8_t index);
45
46 #define C1_1  0x24
47 #define C1_2  0x25
48 #define C1_3  0x26
49 #define C1_4  0x27
50 #define C1_5  0x28
51 #define C1_6  0x29
52 #define C1_7  0x2A
53 #define C1_8  0x2B
54
55 #define C1_9  0x2C
56 #define C1_10 0x2D
57 #define C1_11 0x2E
58 #define C1_12 0x2F
59 #define C1_13 0x30
60 #define C1_14 0x31
61 #define C1_15 0x32
62 #define C1_16 0x33
63
64 #define C2_1  0x34
65 #define C2_2  0x35
66 #define C2_3  0x36
67 #define C2_4  0x37
68 #define C2_5  0x38
69 #define C2_6  0x39
70 #define C2_7  0x3A
71 #define C2_8  0x3B
72
73 #define C2_9  0x3C
74 #define C2_10 0x3D
75 #define C2_11 0x3E
76 #define C2_12 0x3F
77 #define C2_13 0x40
78 #define C2_14 0x41
79 #define C2_15 0x42
80 #define C2_16 0x43
81
82 #define C3_1  0x44
83 #define C3_2  0x45
84 #define C3_3  0x46
85 #define C3_4  0x47
86 #define C3_5  0x48
87 #define C3_6  0x49
88 #define C3_7  0x4A
89 #define C3_8  0x4B
90
91 #define C3_9  0x4C
92 #define C3_10 0x4D
93 #define C3_11 0x4E
94 #define C3_12 0x4F
95 #define C3_13 0x50
96 #define C3_14 0x51
97 #define C3_15 0x52
98 #define C3_16 0x53
99
100 #define C4_1  0x54
101 #define C4_2  0x55
102 #define C4_3  0x56
103 #define C4_4  0x57
104 #define C4_5  0x58
105 #define C4_6  0x59
106 #define C4_7  0x5A
107 #define C4_8  0x5B
108
109 #define C4_9  0x5C
110 #define C4_10 0x5D
111 #define C4_11 0x5E
112 #define C4_12 0x5F
113 #define C4_13 0x60
114 #define C4_14 0x61
115 #define C4_15 0x62
116 #define C4_16 0x63
117
118 #define C5_1  0x64
119 #define C5_2  0x65
120 #define C5_3  0x66
121 #define C5_4  0x67
122 #define C5_5  0x68
123 #define C5_6  0x69
124 #define C5_7  0x6A
125 #define C5_8  0x6B
126
127 #define C5_9  0x6C
128 #define C5_10 0x6D
129 #define C5_11 0x6E
130 #define C5_12 0x6F
131 #define C5_13 0x70
132 #define C5_14 0x71
133 #define C5_15 0x72
134 #define C5_16 0x73
135
136 #define C6_1  0x74
137 #define C6_2  0x75
138 #define C6_3  0x76
139 #define C6_4  0x77
140 #define C6_5  0x78
141 #define C6_6  0x79
142 #define C6_7  0x7A
143 #define C6_8  0x7B
144
145 #define C6_9  0x7C
146 #define C6_10 0x7D
147 #define C6_11 0x7E
148 #define C6_12 0x7F
149 #define C6_13 0x80
150 #define C6_14 0x81
151 #define C6_15 0x82
152 #define C6_16 0x83
153
154 #define C7_1  0x84
155 #define C7_2  0x85
156 #define C7_3  0x86
157 #define C7_4  0x87
158 #define C7_5  0x88
159 #define C7_6  0x89
160 #define C7_7  0x8A
161 #define C7_8  0x8B
162
163 #define C7_9  0x8C
164 #define C7_10 0x8D
165 #define C7_11 0x8E
166 #define C7_12 0x8F
167 #define C7_13 0x90
168 #define C7_14 0x91
169 #define C7_15 0x92
170 #define C7_16 0x93
171
172 #define C8_1  0x94
173 #define C8_2  0x95
174 #define C8_3  0x96
175 #define C8_4  0x97
176 #define C8_5  0x98
177 #define C8_6  0x99
178 #define C8_7  0x9A
179 #define C8_8  0x9B
180
181 #define C8_9  0x9C
182 #define C8_10 0x9D
183 #define C8_11 0x9E
184 #define C8_12 0x9F
185 #define C8_13 0xA0
186 #define C8_14 0xA1
187 #define C8_15 0xA2
188 #define C8_16 0xA3
189
190 #define C9_1  0xA4
191 #define C9_2  0xA5
192 #define C9_3  0xA6
193 #define C9_4  0xA7
194 #define C9_5  0xA8
195 #define C9_6  0xA9
196 #define C9_7  0xAA
197 #define C9_8  0xAB
198
199 #define C9_9  0xAC
200 #define C9_10 0xAD
201 #define C9_11 0xAE
202 #define C9_12 0xAF
203 #define C9_13 0xB0
204 #define C9_14 0xB1
205 #define C9_15 0xB2
206 #define C9_16 0xB3
207
208
209 #endif // IS31FL3731_DRIVER_H