Component library for PCA9546A. The PCA9546A is a quad bidirectional translating switch controlled via the I2C-bus. The SCL/SDA upstream pair fans out to four downstream pairs, or channels. Any individual SCx/SDx channel or combination of channels can be selected, determined by the contents of the programmable control register.
Diff: PCA9546A.h
- Revision:
- 0:2d50d8bba33e
diff -r 000000000000 -r 2d50d8bba33e PCA9546A.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PCA9546A.h Mon Feb 23 06:07:04 2015 +0000
@@ -0,0 +1,132 @@
+/**
+ * PCA9546A library
+ *
+ * @author Tedd OKANO
+ * @version 0.1
+ * @date Feb-2015
+ *
+ * PCA9546A: an I2C bus switch control library
+ *
+ * The PCA9546A is a quad bidirectional translating switch controlled
+ * via the I2C-bus. The SCL/SDA upstream pair fans out to four downstream
+ * pairs, or channels. Any individual SCx/SDx channel or combination of
+ * channels can be selected, determined by the contents of the programmable
+ * control register.
+ *
+ * For more information about PCA9546A:
+ * http://www.nxp.com/documents/data_sheet/PCA9546A.pdf
+ *
+ */
+
+#ifndef MBED_PCA9546A_H
+#define MBED_PCA9546A_H
+
+#include "mbed.h"
+
+/** PCA9546A class
+ *
+ * PCA9546A: an I2C bus switch control library
+ *
+ * The PCA9546A is a quad bidirectional translating switch controlled
+ * via the I2C-bus. The SCL/SDA upstream pair fans out to four downstream
+ * pairs, or channels. Any individual SCx/SDx channel or combination of
+ * channels can be selected, determined by the contents of the programmable
+ * control register.
+ *
+ * For more information about PCA9546A:
+ * http://www.nxp.com/documents/data_sheet/PCA9546A.pdf
+ *
+ * Example:
+ * @code
+ * #include "mbed.h"
+ * #include "LM75B.h"
+ * #include "PCA9546A.h"
+ *
+ * PCA9546A i2c_sw( p28, p27, 0xE0 );
+ *
+ * int main()
+ * {
+ * // all PCA9546A's downstream ports are OFF after power-up and hardware-reset
+ *
+ * i2c_sw.on( 0 ); // turn-ON the channel 0
+ *
+ * LM75B tmp0( p28, p27 ); // making instance after a branch of I2C bus (which is connecting the LM75B) enabled
+ *
+ * i2c_sw.off( 0 ); // turn-OFF the channel 0
+ * i2c_sw.on( 1 ); // turn-ON the channel 1
+ *
+ * LM75B tmp1( p28, p27 ); // making instance after a branch of I2C bus (which is connecting the LM75B) enabled
+ *
+ * while(1) {
+ *
+ * i2c_sw.off( 1 ); // turn-OFF the channel 1
+ * i2c_sw.on( 0 ); // turn-ON the channel 0
+ * printf( "%.3f\r\n", tmp0.read() );
+ *
+ * i2c_sw.off( 0 ); // turn-OFF the channel 0
+ * i2c_sw.on( 1 ); // turn-ON the channel 1
+ * printf( "%.3f\r\n", tmp1.read() );
+ *
+ * wait( 1.0 );
+ * }
+ * }
+ * @endcode
+ */
+
+class PCA9546A
+{
+public:
+
+ /** Create a PCA9546A instance connected to specified I2C pins with specified address
+ *
+ * @param sda I2C-bus SDA pin
+ * @param scl I2C-bus SCL pin
+ * @param i2c_address I2C-bus address (default: 0xE0)
+ */
+ PCA9546A( PinName sda, PinName scl, char i2c_address = 0xE0 );
+
+ /** Create a PCA9546A instance connected to specified I2C pins with specified address
+ *
+ * @param &i2c_ I2C object (instance)
+ * @param i2c_address I2C-bus address (default: 0xE0)
+ */
+ PCA9546A( I2C &i2c_, char i2c_address = 0xE0 );
+
+ /** Destructor of PCA9546A
+ */
+ ~PCA9546A();
+
+ /** Turning-ON a channel
+ *
+ * Switching a channel ON
+ *
+ * @param channel channel number
+ */
+ void on( char channel );
+
+ /** Turning-OFF a channel
+ *
+ * Switching a channel OFF
+ *
+ * @param channel channel number
+ */
+ void off( char channel );
+
+ /** Switching by bit pattern
+ *
+ * Switch setting by bit pattern.
+ * Set '1' for ON, set '0' for OFF
+ * LSB is channel 0. Channels 1, 2 and 3 are mapped in shifted position from LSB
+ *
+ * @param pattern ON/OFF bit pattern for channels
+ */
+ void bitpattern( char pattern );
+
+private:
+ I2C *i2c_p;
+ I2C &i2c;
+ char i2c_addr;
+ char enable_pattern;
+};
+
+#endif // MBED_PCA9546A_H
\ No newline at end of file
PCA9546A: 4-channel I2C switch