Welcome to mirror list, hosted at ThFree Co, Russian Federation.

SX1509Registers.h « DuetNG « src - github.com/Duet3D/RepRapFirmware.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 8f8c89cddd725955d91b1acb181cd0de6c8cbed4 (plain)
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
/******************************************************************************
SX1509Registers.h
Register definitions for SX1509.
Jim Lindblom @ SparkFun Electronics
Original Creation Date: September 21, 2015
https://github.com/sparkfun/SparkFun_SX1509_Arduino_Library

Here you'll find the Arduino code used to interface with the SX1509 I2C
16 I/O expander. There are functions to take advantage of everything the
SX1509 provides - input/output setting, writing pins high/low, reading 
the input value of pins, LED driver utilities (blink, breath, pwm), and
keypad engine utilites.

Development environment specifics:
	IDE: Arduino 1.6.5
	Hardware Platform: Arduino Uno
	SX1509 Breakout Version: v2.0

This code is beerware; if you see me (or any other SparkFun employee) at the
local, and you've found our code helpful, please buy us a round!

Distributed as-is; no warranty is given.
******************************************************************************/

const uint8_t 	REG_INPUT_DISABLE_B		= 0x00;	//	RegInputDisableB Input buffer disable register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_INPUT_DISABLE_A		= 0x01;	//	RegInputDisableA Input buffer disable register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_LONG_SLEW_B			= 0x02;	//	RegLongSlewB Output buffer long slew register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_LONG_SLEW_A			= 0x03;	//	RegLongSlewA Output buffer long slew register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_LOW_DRIVE_B			= 0x04;	//	RegLowDriveB Output buffer low drive register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_LOW_DRIVE_A			= 0x05;	//	RegLowDriveA Output buffer low drive register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_PULL_UP_B			= 0x06;	//	RegPullUpB Pull_up register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_PULL_UP_A			= 0x07;	//	RegPullUpA Pull_up register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_PULL_DOWN_B			= 0x08;	//	RegPullDownB Pull_down register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_PULL_DOWN_A			= 0x09;	//	RegPullDownA Pull_down register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_OPEN_DRAIN_B		= 0x0A;	//	RegOpenDrainB Open drain register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_OPEN_DRAIN_A		= 0x0B;	//	RegOpenDrainA Open drain register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_POLARITY_B			= 0x0C;	//	RegPolarityB Polarity register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_POLARITY_A			= 0x0D;	//	RegPolarityA Polarity register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_DIR_B				= 0x0E;	//	RegDirB Direction register _ I/O[15_8] (Bank B) 1111 1111
const uint8_t 	REG_DIR_A				= 0x0F;	//	RegDirA Direction register _ I/O[7_0] (Bank A) 1111 1111
const uint8_t 	REG_DATA_B				= 0x10;	//	RegDataB Data register _ I/O[15_8] (Bank B) 1111 1111*
const uint8_t 	REG_DATA_A				= 0x11;	//	RegDataA Data register _ I/O[7_0] (Bank A) 1111 1111*
const uint8_t 	REG_INTERRUPT_MASK_B	= 0x12;	//	RegInterruptMaskB Interrupt mask register _ I/O[15_8] (Bank B) 1111 1111
const uint8_t 	REG_INTERRUPT_MASK_A	= 0x13;	//	RegInterruptMaskA Interrupt mask register _ I/O[7_0] (Bank A) 1111 1111
const uint8_t 	REG_SENSE_HIGH_B		= 0x14;	//	RegSenseHighB Sense register for I/O[15:12] 0000 0000
const uint8_t 	REG_SENSE_LOW_B			= 0x15;	//	RegSenseLowB Sense register for I/O[11:8] 0000 0000
const uint8_t 	REG_SENSE_HIGH_A		= 0x16;	//	RegSenseHighA Sense register for I/O[7:4] 0000 0000
const uint8_t 	REG_SENSE_LOW_A			= 0x17;	//	RegSenseLowA Sense register for I/O[3:0] 0000 0000
const uint8_t 	REG_INTERRUPT_SOURCE_B	= 0x18;	//	RegInterruptSourceB Interrupt source register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_INTERRUPT_SOURCE_A	= 0x19;	//	RegInterruptSourceA Interrupt source register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_EVENT_STATUS_B		= 0x1A;	//	RegEventStatusB Event status register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_EVENT_STATUS_A		= 0x1B;	//	RegEventStatusA Event status register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_LEVEL_SHIFTER_1		= 0x1C;	//	RegLevelShifter1 Level shifter register 0000 0000
const uint8_t 	REG_LEVEL_SHIFTER_2		= 0x1D;	//	RegLevelShifter2 Level shifter register 0000 0000
const uint8_t 	REG_CLOCK				= 0x1E;	//	RegClock Clock management register 0000 0000
const uint8_t 	REG_MISC				= 0x1F;	//	RegMisc Miscellaneous device settings register 0000 0000
const uint8_t 	REG_LED_DRIVER_ENABLE_B	= 0x20;	//	RegLEDDriverEnableB LED driver enable register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_LED_DRIVER_ENABLE_A	= 0x21;	//	RegLEDDriverEnableA LED driver enable register _ I/O[7_0] (Bank A) 0000 0000
// Debounce and Keypad Engine		
const uint8_t 	REG_DEBOUNCE_CONFIG		= 0x22;	//	RegDebounceConfig Debounce configuration register 0000 0000
const uint8_t 	REG_DEBOUNCE_ENABLE_B	= 0x23;	//	RegDebounceEnableB Debounce enable register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_DEBOUNCE_ENABLE_A	= 0x24;	//	RegDebounceEnableA Debounce enable register _ I/O[7_0] (Bank A) 0000 0000
const uint8_t 	REG_KEY_CONFIG_1		= 0x25;	//	RegKeyConfig1 Key scan configuration register 0000 0000
const uint8_t 	REG_KEY_CONFIG_2		= 0x26;	//	RegKeyConfig2 Key scan configuration register 0000 0000
const uint8_t 	REG_KEY_DATA_1			= 0x27;	//	RegKeyData1 Key value (column) 1111 1111
const uint8_t 	REG_KEY_DATA_2			= 0x28;	//	RegKeyData2 Key value (row) 1111 1111
// LED Driver (PWM, blinking, breathing)		
const uint8_t 	REG_T_ON_0				= 0x29;	//	RegTOn0 ON time register for I/O[0] 0000 0000
const uint8_t 	REG_I_ON_0				= 0x2A;	//	RegIOn0 ON intensity register for I/O[0] 1111 1111
const uint8_t 	REG_OFF_0				= 0x2B;	//	RegOff0 OFF time/intensity register for I/O[0] 0000 0000
const uint8_t 	REG_T_ON_1				= 0x2C;	//	RegTOn1 ON time register for I/O[1] 0000 0000
const uint8_t 	REG_I_ON_1				= 0x2D;	//	RegIOn1 ON intensity register for I/O[1] 1111 1111
const uint8_t 	REG_OFF_1				= 0x2E;	//	RegOff1 OFF time/intensity register for I/O[1] 0000 0000
const uint8_t 	REG_T_ON_2				= 0x2F;	//	RegTOn2 ON time register for I/O[2] 0000 0000
const uint8_t 	REG_I_ON_2				= 0x30;	//	RegIOn2 ON intensity register for I/O[2] 1111 1111
const uint8_t 	REG_OFF_2				= 0x31;	//	RegOff2 OFF time/intensity register for I/O[2] 0000 0000
const uint8_t 	REG_T_ON_3				= 0x32;	//	RegTOn3 ON time register for I/O[3] 0000 0000
const uint8_t 	REG_I_ON_3				= 0x33;	//	RegIOn3 ON intensity register for I/O[3] 1111 1111
const uint8_t 	REG_OFF_3				= 0x34;	//	RegOff3 OFF time/intensity register for I/O[3] 0000 0000
const uint8_t 	REG_T_ON_4				= 0x35;	//	RegTOn4 ON time register for I/O[4] 0000 0000
const uint8_t 	REG_I_ON_4				= 0x36;	//	RegIOn4 ON intensity register for I/O[4] 1111 1111
const uint8_t 	REG_OFF_4				= 0x37;	//	RegOff4 OFF time/intensity register for I/O[4] 0000 0000
const uint8_t 	REG_T_RISE_4			= 0x38;	//	RegTRise4 Fade in register for I/O[4] 0000 0000
const uint8_t 	REG_T_FALL_4			= 0x39;	//	RegTFall4 Fade out register for I/O[4] 0000 0000
const uint8_t 	REG_T_ON_5				= 0x3A;	//	RegTOn5 ON time register for I/O[5] 0000 0000
const uint8_t 	REG_I_ON_5				= 0x3B;	//	RegIOn5 ON intensity register for I/O[5] 1111 1111
const uint8_t 	REG_OFF_5				= 0x3C;	//	RegOff5 OFF time/intensity register for I/O[5] 0000 0000
const uint8_t 	REG_T_RISE_5			= 0x3D;	//	RegTRise5 Fade in register for I/O[5] 0000 0000
const uint8_t 	REG_T_FALL_5			= 0x3E;	//	RegTFall5 Fade out register for I/O[5] 0000 0000
const uint8_t 	REG_T_ON_6				= 0x3F;	//	RegTOn6 ON time register for I/O[6] 0000 0000
const uint8_t 	REG_I_ON_6				= 0x40;	//	RegIOn6 ON intensity register for I/O[6] 1111 1111
const uint8_t 	REG_OFF_6				= 0x41;	//	RegOff6 OFF time/intensity register for I/O[6] 0000 0000
const uint8_t 	REG_T_RISE_6			= 0x42;	//	RegTRise6 Fade in register for I/O[6] 0000 0000
const uint8_t 	REG_T_FALL_6			= 0x43;	//	RegTFall6 Fade out register for I/O[6] 0000 0000
const uint8_t 	REG_T_ON_7				= 0x44;	//	RegTOn7 ON time register for I/O[7] 0000 0000
const uint8_t 	REG_I_ON_7				= 0x45;	//	RegIOn7 ON intensity register for I/O[7] 1111 1111
const uint8_t 	REG_OFF_7				= 0x46;	//	RegOff7 OFF time/intensity register for I/O[7] 0000 0000
const uint8_t 	REG_T_RISE_7			= 0x47;	//	RegTRise7 Fade in register for I/O[7] 0000 0000
const uint8_t 	REG_T_FALL_7			= 0x48;	//	RegTFall7 Fade out register for I/O[7] 0000 0000
const uint8_t 	REG_T_ON_8				= 0x49;	//	RegTOn8 ON time register for I/O[8] 0000 0000
const uint8_t 	REG_I_ON_8				= 0x4A;	//	RegIOn8 ON intensity register for I/O[8] 1111 1111
const uint8_t 	REG_OFF_8				= 0x4B;	//	RegOff8 OFF time/intensity register for I/O[8] 0000 0000
const uint8_t 	REG_T_ON_9				= 0x4C;	//	RegTOn9 ON time register for I/O[9] 0000 0000
const uint8_t 	REG_I_ON_9				= 0x4D;	//	RegIOn9 ON intensity register for I/O[9] 1111 1111
const uint8_t 	REG_OFF_9				= 0x4E;	//	RegOff9 OFF time/intensity register for I/O[9] 0000 0000
const uint8_t 	REG_T_ON_10				= 0x4F;	//	RegTOn10 ON time register for I/O[10] 0000 0000
const uint8_t 	REG_I_ON_10				= 0x50;	//	RegIOn10 ON intensity register for I/O[10] 1111 1111
const uint8_t 	REG_OFF_10				= 0x51;	//	RegOff10 OFF time/intensity register for I/O[10] 0000 0000
const uint8_t 	REG_T_ON_11				= 0x52;	//	RegTOn11 ON time register for I/O[11] 0000 0000
const uint8_t 	REG_I_ON_11				= 0x53;	//	RegIOn11 ON intensity register for I/O[11] 1111 1111
const uint8_t 	REG_OFF_11				= 0x54;	//	RegOff11 OFF time/intensity register for I/O[11] 0000 0000
const uint8_t 	REG_T_ON_12				= 0x55;	//	RegTOn12 ON time register for I/O[12] 0000 0000
const uint8_t 	REG_I_ON_12				= 0x56;	//	RegIOn12 ON intensity register for I/O[12] 1111 1111
const uint8_t 	REG_OFF_12				= 0x57;	//	RegOff12 OFF time/intensity register for I/O[12] 0000 0000
const uint8_t 	REG_T_RISE_12			= 0x58;	//	RegTRise12 Fade in register for I/O[12] 0000 0000
const uint8_t 	REG_T_FALL_12			= 0x59;	//	RegTFall12 Fade out register for I/O[12] 0000 0000
const uint8_t 	REG_T_ON_13				= 0x5A;	//	RegTOn13 ON time register for I/O[13] 0000 0000
const uint8_t 	REG_I_ON_13				= 0x5B;	//	RegIOn13 ON intensity register for I/O[13] 1111 1111
const uint8_t 	REG_OFF_13				= 0x5C;	//	RegOff13 OFF time/intensity register for I/O[13] 0000 0000
const uint8_t 	REG_T_RISE_13			= 0x5D;	//	RegTRise13 Fade in register for I/O[13] 0000 0000
const uint8_t 	REG_T_FALL_13			= 0x5E;	//	RegTFall13 Fade out register for I/O[13] 0000 0000
const uint8_t 	REG_T_ON_14				= 0x5F;	//	RegTOn14 ON time register for I/O[14] 0000 0000
const uint8_t 	REG_I_ON_14				= 0x60;	//	RegIOn14 ON intensity register for I/O[14] 1111 1111
const uint8_t 	REG_OFF_14				= 0x61;	//	RegOff14 OFF time/intensity register for I/O[14] 0000 0000
const uint8_t 	REG_T_RISE_14			= 0x62;	//	RegTRise14 Fade in register for I/O[14] 0000 0000
const uint8_t 	REG_T_FALL_14			= 0x63;	//	RegTFall14 Fade out register for I/O[14] 0000 0000
const uint8_t 	REG_T_ON_15				= 0x64;	//	RegTOn15 ON time register for I/O[15] 0000 0000
const uint8_t 	REG_I_ON_15				= 0x65;	//	RegIOn15 ON intensity register for I/O[15] 1111 1111
const uint8_t 	REG_OFF_15				= 0x66;	//	RegOff15 OFF time/intensity register for I/O[15] 0000 0000
const uint8_t 	REG_T_RISE_15			= 0x67;	//	RegTRise15 Fade in register for I/O[15] 0000 0000
const uint8_t 	REG_T_FALL_15			= 0x68;	//	RegTFall15 Fade out register for I/O[15] 0000 0000
// 	Miscellaneous		
const uint8_t 	REG_HIGH_INPUT_B		= 0x69;	//	RegHighInputB High input enable register _ I/O[15_8] (Bank B) 0000 0000
const uint8_t 	REG_HIGH_INPUT_A		= 0x6A;	//	RegHighInputA High input enable register _ I/O[7_0] (Bank A) 0000 0000
//  Software Reset		
const uint8_t 	REG_RESET				= 0x7D;	//	RegReset Software reset register 0000 0000
const uint8_t 	REG_TEST_1				= 0x7E;	//	RegTest1 Test register 0000 0000
const uint8_t 	REG_TEST_2				= 0x7F;	//	RegTest2 Test register 0000 0000

const uint8_t REG_I_ON[16] = {REG_I_ON_0, REG_I_ON_1, REG_I_ON_2, REG_I_ON_3,
					REG_I_ON_4, REG_I_ON_5, REG_I_ON_6, REG_I_ON_7,
					REG_I_ON_8, REG_I_ON_9, REG_I_ON_10, REG_I_ON_11,
					REG_I_ON_12, REG_I_ON_13, REG_I_ON_14, REG_I_ON_15};
					
const uint8_t REG_T_ON[16] = {REG_T_ON_0, REG_T_ON_1, REG_T_ON_2, REG_T_ON_3,
					REG_T_ON_4, REG_T_ON_5, REG_T_ON_6, REG_T_ON_7,
					REG_T_ON_8, REG_T_ON_9, REG_T_ON_10, REG_T_ON_11,
					REG_T_ON_12, REG_T_ON_13, REG_T_ON_14, REG_T_ON_15};
					
const uint8_t REG_OFF[16] = {REG_OFF_0, REG_OFF_1, REG_OFF_2, REG_OFF_3,
					REG_OFF_4, REG_OFF_5, REG_OFF_6, REG_OFF_7,
					REG_OFF_8, REG_OFF_9, REG_OFF_10, REG_OFF_11,
					REG_OFF_12, REG_OFF_13, REG_OFF_14, REG_OFF_15};

const uint8_t REG_T_RISE[16] = {0xFF, 0xFF, 0xFF, 0xFF,
					REG_T_RISE_4, REG_T_RISE_5, REG_T_RISE_6, REG_T_RISE_7,
					0xFF, 0xFF, 0xFF, 0xFF,
					REG_T_RISE_12, REG_T_RISE_13, REG_T_RISE_14, REG_T_RISE_15};
					
const uint8_t REG_T_FALL[16] = {0xFF, 0xFF, 0xFF, 0xFF,
					REG_T_FALL_4, REG_T_FALL_5, REG_T_FALL_6, REG_T_FALL_7,
					0xFF, 0xFF, 0xFF, 0xFF,
					REG_T_FALL_12, REG_T_FALL_13, REG_T_FALL_14, REG_T_FALL_15};

// End