aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpio/pca9555.h
diff options
context:
space:
mode:
authorJoel Challis <git@zvecr.com>2019-08-22 15:27:18 +0100
committerGitHub <noreply@github.com>2019-08-22 15:27:18 +0100
commit1c805b3d008a98a5a15112b0655ba14b42dbae67 (patch)
tree56eb8ff23486c276b9126a86479a51e3db91577a /drivers/gpio/pca9555.h
parenta20e6aa0224ff243e6dc80259c9de868c4acc9ce (diff)
downloadqmk_firmware-1c805b3d008a98a5a15112b0655ba14b42dbae67.tar.gz
qmk_firmware-1c805b3d008a98a5a15112b0655ba14b42dbae67.zip
Relocate pca9555 driver to core (#6563)
* Move pca9555 files to central location * Get pca9555 boards compiling * Slight alignment of rules.mk
Diffstat (limited to 'drivers/gpio/pca9555.h')
-rw-r--r--drivers/gpio/pca9555.h55
1 files changed, 55 insertions, 0 deletions
diff --git a/drivers/gpio/pca9555.h b/drivers/gpio/pca9555.h
new file mode 100644
index 000000000..ebb97e2f3
--- /dev/null
+++ b/drivers/gpio/pca9555.h
@@ -0,0 +1,55 @@
1/* Copyright 2019
2 *
3 * This program is free software: you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation, either version 2 of the License, or
6 * (at your option) any later version.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 */
16#pragma once
17
18/*
19 PCA9555
20 ,----------.
21 SDA --| SDA P00 |-- P00
22 SCL --| SCL P01 |-- P01
23 INT --| INT P02 |-- P02
24 | P03 |-- P03
25 A0 --| A0 P04 |-- P04
26 A1 --| A1 P05 |-- P05
27 A2 --| A2 P06 |-- P06
28 | P07 |-- P07
29 | |
30 | P10 |-- P10
31 | P11 |-- P11
32 | P12 |-- P12
33 | P13 |-- P13
34 | P14 |-- P14
35 | P15 |-- P15
36 | P16 |-- P16
37 | P17 |-- P17
38 `----------'
39*/
40
41#define PCA9555_PORT0 0
42#define PCA9555_PORT1 1
43
44#define ALL_OUTPUT 0
45#define ALL_INPUT 0xFF
46#define ALL_LOW 0
47#define ALL_HIGH 0xFF
48
49void pca9555_init(uint8_t slave_addr);
50
51void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf);
52
53void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf);
54
55uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port);