ESPHome  2024.12.4
sx1509_registers.h
Go to the documentation of this file.
1 /*
2 sx1509_registers.h
3 Register definitions for SX1509.
4 Jim Lindblom @ SparkFun Electronics
5 Original Creation Date: September 21, 2015
6 https://github.com/sparkfun/SparkFun_SX1509_Arduino_Library
7 */
8 #pragma once
9 
10 namespace esphome {
28 namespace sx1509 {
29 
30 const uint8_t REG_INPUT_DISABLE_B =
31  0x00; // RegInputDisableB Input buffer disable register _ I/O[15_8] (Bank B) 0000 0000
32 const uint8_t REG_INPUT_DISABLE_A =
33  0x01; // RegInputDisableA Input buffer disable register _ I/O[7_0] (Bank A) 0000 0000
34 const uint8_t REG_LONG_SLEW_B =
35  0x02; // RegLongSlewB Output buffer long slew register _ I/O[15_8] (Bank B) 0000 0000
36 const uint8_t REG_LONG_SLEW_A = 0x03; // RegLongSlewA Output buffer long slew register _ I/O[7_0] (Bank A) 0000 0000
37 const uint8_t REG_LOW_DRIVE_B =
38  0x04; // RegLowDriveB Output buffer low drive register _ I/O[15_8] (Bank B) 0000 0000
39 const uint8_t REG_LOW_DRIVE_A = 0x05; // RegLowDriveA Output buffer low drive register _ I/O[7_0] (Bank A) 0000 0000
40 const uint8_t REG_PULL_UP_B = 0x06; // RegPullUpB Pull_up register _ I/O[15_8] (Bank B) 0000 0000
41 const uint8_t REG_PULL_UP_A = 0x07; // RegPullUpA Pull_up register _ I/O[7_0] (Bank A) 0000 0000
42 const uint8_t REG_PULL_DOWN_B = 0x08; // RegPullDownB Pull_down register _ I/O[15_8] (Bank B) 0000 0000
43 const uint8_t REG_PULL_DOWN_A = 0x09; // RegPullDownA Pull_down register _ I/O[7_0] (Bank A) 0000 0000
44 const uint8_t REG_OPEN_DRAIN_B = 0x0A; // RegOpenDrainB Open drain register _ I/O[15_8] (Bank B) 0000 0000
45 const uint8_t REG_OPEN_DRAIN_A = 0x0B; // RegOpenDrainA Open drain register _ I/O[7_0] (Bank A) 0000 0000
46 const uint8_t REG_POLARITY_B = 0x0C; // RegPolarityB Polarity register _ I/O[15_8] (Bank B) 0000 0000
47 const uint8_t REG_POLARITY_A = 0x0D; // RegPolarityA Polarity register _ I/O[7_0] (Bank A) 0000 0000
48 const uint8_t REG_DIR_B = 0x0E; // RegDirB Direction register _ I/O[15_8] (Bank B) 1111 1111
49 const uint8_t REG_DIR_A = 0x0F; // RegDirA Direction register _ I/O[7_0] (Bank A) 1111 1111
50 const uint8_t REG_DATA_B = 0x10; // RegDataB Data register _ I/O[15_8] (Bank B) 1111 1111*
51 const uint8_t REG_DATA_A = 0x11; // RegDataA Data register _ I/O[7_0] (Bank A) 1111 1111*
52 const uint8_t REG_INTERRUPT_MASK_B =
53  0x12; // RegInterruptMaskB Interrupt mask register _ I/O[15_8] (Bank B) 1111 1111
54 const uint8_t REG_INTERRUPT_MASK_A =
55  0x13; // RegInterruptMaskA Interrupt mask register _ I/O[7_0] (Bank A) 1111 1111
56 const uint8_t REG_SENSE_HIGH_B = 0x14; // RegSenseHighB Sense register for I/O[15:12] 0000 0000
57 const uint8_t REG_SENSE_LOW_B = 0x15; // RegSenseLowB Sense register for I/O[11:8] 0000 0000
58 const uint8_t REG_SENSE_HIGH_A = 0x16; // RegSenseHighA Sense register for I/O[7:4] 0000 0000
59 const uint8_t REG_SENSE_LOW_A = 0x17; // RegSenseLowA Sense register for I/O[3:0] 0000 0000
60 const uint8_t REG_INTERRUPT_SOURCE_B =
61  0x18; // RegInterruptSourceB Interrupt source register _ I/O[15_8] (Bank B) 0000 0000
62 const uint8_t REG_INTERRUPT_SOURCE_A =
63  0x19; // RegInterruptSourceA Interrupt source register _ I/O[7_0] (Bank A) 0000 0000
64 const uint8_t REG_EVENT_STATUS_B = 0x1A; // RegEventStatusB Event status register _ I/O[15_8] (Bank B) 0000 0000
65 const uint8_t REG_EVENT_STATUS_A = 0x1B; // RegEventStatusA Event status register _ I/O[7_0] (Bank A) 0000 0000
66 const uint8_t REG_LEVEL_SHIFTER_1 = 0x1C; // RegLevelShifter1 Level shifter register 0000 0000
67 const uint8_t REG_LEVEL_SHIFTER_2 = 0x1D; // RegLevelShifter2 Level shifter register 0000 0000
68 const uint8_t REG_CLOCK = 0x1E; // RegClock Clock management register 0000 0000
69 const uint8_t REG_MISC = 0x1F; // RegMisc Miscellaneous device settings register 0000 0000
70 const uint8_t REG_LED_DRIVER_ENABLE_B =
71  0x20; // RegLEDDriverEnableB LED driver enable register _ I/O[15_8] (Bank B) 0000 0000
72 const uint8_t REG_LED_DRIVER_ENABLE_A =
73  0x21; // RegLEDDriverEnableA LED driver enable register _ I/O[7_0] (Bank A) 0000 0000
74 // Debounce and Keypad Engine
75 const uint8_t REG_DEBOUNCE_CONFIG = 0x22; // RegDebounceConfig Debounce configuration register 0000 0000
76 const uint8_t REG_DEBOUNCE_ENABLE_B =
77  0x23; // RegDebounceEnableB Debounce enable register _ I/O[15_8] (Bank B) 0000 0000
78 const uint8_t REG_DEBOUNCE_ENABLE_A =
79  0x24; // RegDebounceEnableA Debounce enable register _ I/O[7_0] (Bank A) 0000 0000
80 const uint8_t REG_KEY_CONFIG_1 = 0x25; // RegKeyConfig1 Key scan configuration register 0000 0000
81 const uint8_t REG_KEY_CONFIG_2 = 0x26; // RegKeyConfig2 Key scan configuration register 0000 0000
82 const uint8_t REG_KEY_DATA_1 = 0x27; // RegKeyData1 Key value (column) 1111 1111
83 const uint8_t REG_KEY_DATA_2 = 0x28; // RegKeyData2 Key value (row) 1111 1111
84 // LED Driver (PWM, blinking, breathing)
85 const uint8_t REG_I_ON_0 = 0x2A; // RegIOn0 ON intensity register for I/O[0] 1111 1111
86 const uint8_t REG_I_ON_1 = 0x2D; // RegIOn1 ON intensity register for I/O[1] 1111 1111
87 const uint8_t REG_I_ON_2 = 0x30; // RegIOn2 ON intensity register for I/O[2] 1111 1111
88 const uint8_t REG_I_ON_3 = 0x33; // RegIOn3 ON intensity register for I/O[3] 1111 1111
89 const uint8_t REG_I_ON_4 = 0x36; // RegIOn4 ON intensity register for I/O[4] 1111 1111
90 const uint8_t REG_I_ON_5 = 0x3B; // RegIOn5 ON intensity register for I/O[5] 1111 1111
91 const uint8_t REG_I_ON_6 = 0x40; // RegIOn6 ON intensity register for I/O[6] 1111 1111
92 const uint8_t REG_I_ON_7 = 0x45; // RegIOn7 ON intensity register for I/O[7] 1111 1111
93 const uint8_t REG_I_ON_8 = 0x4A; // RegIOn8 ON intensity register for I/O[8] 1111 1111
94 const uint8_t REG_I_ON_9 = 0x4D; // RegIOn9 ON intensity register for I/O[9] 1111 1111
95 const uint8_t REG_I_ON_10 = 0x50; // RegIOn10 ON intensity register for I/O[10] 1111 1111
96 const uint8_t REG_I_ON_11 = 0x53; // RegIOn11 ON intensity register for I/O[11] 1111 1111
97 const uint8_t REG_I_ON_12 = 0x56; // RegIOn12 ON intensity register for I/O[12] 1111 1111
98 const uint8_t REG_I_ON_13 = 0x5B; // RegIOn13 ON intensity register for I/O[13] 1111 1111
99 const uint8_t REG_I_ON_14 = 0x60; // RegIOn14 ON intensity register for I/O[14] 1111 1111
100 const uint8_t REG_I_ON_15 = 0x65; // RegIOn15 ON intensity register for I/O[15] 1111 1111
101 // Miscellaneous
102 const uint8_t REG_HIGH_INPUT_B = 0x69; // RegHighInputB High input enable register _ I/O[15_8] (Bank B) 0000 0000
103 const uint8_t REG_HIGH_INPUT_A = 0x6A; // RegHighInputA High input enable register _ I/O[7_0] (Bank A) 0000 0000
104 // Software Reset
105 const uint8_t REG_RESET = 0x7D; // RegReset Software reset register 0000 0000
106 const uint8_t REG_TEST_1 = 0x7E; // RegTest1 Test register 0000 0000
107 const uint8_t REG_TEST_2 = 0x7F; // RegTest2 Test register 0000 0000
108 
109 } // namespace sx1509
110 } // namespace esphome
const uint8_t REG_POLARITY_A
const uint8_t REG_DATA_A
const uint8_t REG_POLARITY_B
const uint8_t REG_RESET
const uint8_t REG_KEY_DATA_1
const uint8_t REG_HIGH_INPUT_B
const uint8_t REG_MISC
const uint8_t REG_I_ON_9
const uint8_t REG_I_ON_6
const uint8_t REG_I_ON_10
const uint8_t REG_I_ON_3
const uint8_t REG_PULL_UP_A
const uint8_t REG_PULL_DOWN_A
const uint8_t REG_LED_DRIVER_ENABLE_A
const uint8_t REG_SENSE_HIGH_B
const uint8_t REG_DATA_B
const uint8_t REG_LEVEL_SHIFTER_2
const uint8_t REG_I_ON_4
const uint8_t REG_EVENT_STATUS_B
const uint8_t REG_LED_DRIVER_ENABLE_B
const uint8_t REG_I_ON_2
const uint8_t REG_INTERRUPT_MASK_B
const uint8_t REG_LONG_SLEW_A
const uint8_t REG_DIR_A
const uint8_t REG_DEBOUNCE_ENABLE_B
const uint8_t REG_SENSE_HIGH_A
const uint8_t REG_I_ON_15
const uint8_t REG_SENSE_LOW_B
const uint8_t REG_TEST_1
const uint8_t REG_INPUT_DISABLE_B
const uint8_t REG_DIR_B
const uint8_t REG_KEY_CONFIG_1
const uint8_t REG_I_ON_7
const uint8_t REG_I_ON_5
const uint8_t REG_INTERRUPT_MASK_A
const uint8_t REG_HIGH_INPUT_A
const uint8_t REG_EVENT_STATUS_A
const uint8_t REG_I_ON_14
const uint8_t REG_I_ON_13
const uint8_t REG_LOW_DRIVE_B
const uint8_t REG_I_ON_12
const uint8_t REG_LONG_SLEW_B
const uint8_t REG_I_ON_11
const uint8_t REG_I_ON_1
const uint8_t REG_INTERRUPT_SOURCE_A
const uint8_t REG_SENSE_LOW_A
Implementation of SPI Controller mode.
Definition: a01nyub.cpp:7
const uint8_t REG_LEVEL_SHIFTER_1
const uint8_t REG_PULL_UP_B
const uint8_t REG_TEST_2
const uint8_t REG_DEBOUNCE_ENABLE_A
const uint8_t REG_I_ON_0
const uint8_t REG_CLOCK
const uint8_t REG_KEY_CONFIG_2
const uint8_t REG_OPEN_DRAIN_A
const uint8_t REG_KEY_DATA_2
const uint8_t REG_OPEN_DRAIN_B
const uint8_t REG_I_ON_8
const uint8_t REG_LOW_DRIVE_A
const uint8_t REG_INTERRUPT_SOURCE_B
const uint8_t REG_PULL_DOWN_B
const uint8_t REG_DEBOUNCE_CONFIG
const uint8_t REG_INPUT_DISABLE_A