Go to the documentation of this file.
35 #include "drv_digital_out.h"
36 #include "drv_digital_in.h"
37 #include "drv_i2c_master.h"
38 #include "drv_spi_master.h"
61 #define MUX5_REG_DIR0 0x00
62 #define MUX5_REG_DIR1 0x01
63 #define MUX5_REG_DIR2 0x02
64 #define MUX5_REG_DIR3 0x03
65 #define MUX5_REG_SHDW0 0x10
66 #define MUX5_REG_SHDW1 0x11
67 #define MUX5_REG_SHDW2 0x12
68 #define MUX5_REG_SHDW3 0x13
69 #define MUX5_REG_CMD_A 0x14
70 #define MUX5_REG_CMD_B 0x15
88 #define MUX5_I2C_DRIVER 0
89 #define MUX5_SPI_DRIVER 1
90 #define MUX5_DRIVER_SEL MUX5_I2C_DRIVER
96 #define MUX5_CHANNEL_1 0x0001
97 #define MUX5_CHANNEL_2 0x0002
98 #define MUX5_CHANNEL_3 0x0004
99 #define MUX5_CHANNEL_4 0x0008
100 #define MUX5_CHANNEL_5 0x0010
101 #define MUX5_CHANNEL_6 0x0020
102 #define MUX5_CHANNEL_7 0x0040
103 #define MUX5_CHANNEL_8 0x0080
104 #define MUX5_CHANNEL_9 0x0100
105 #define MUX5_CHANNEL_10 0x0200
106 #define MUX5_CHANNEL_11 0x0400
107 #define MUX5_CHANNEL_12 0x0800
108 #define MUX5_CHANNEL_13 0x1000
109 #define MUX5_CHANNEL_14 0x2000
110 #define MUX5_CHANNEL_15 0x4000
111 #define MUX5_CHANNEL_16 0x8000
112 #define MUX5_CHANNEL_ALL 0xFFFF
118 #define MUX5_CHANNEL_STATE_HIGH_Z 0
119 #define MUX5_CHANNEL_STATE_COM_A 1
120 #define MUX5_CHANNEL_STATE_COM_B 2
121 #define MUX5_CHANNEL_STATE_COM_AB 3
128 #define MUX5_DEVICE_ADDRESS_0 0x4C
129 #define MUX5_DEVICE_ADDRESS_1 0x4D
139 #define MUX5_SET_DATA_SAMPLE_EDGE SET_SPI_DATA_SAMPLE_EDGE
140 #define MUX5_SET_DATA_SAMPLE_MIDDLE SET_SPI_DATA_SAMPLE_MIDDLE
158 #define MUX5_MAP_MIKROBUS( cfg, mikrobus ) \
159 cfg.scl = MIKROBUS( mikrobus, MIKROBUS_SCL ); \
160 cfg.sda = MIKROBUS( mikrobus, MIKROBUS_SDA ); \
161 cfg.miso = MIKROBUS( mikrobus, MIKROBUS_MISO ); \
162 cfg.mosi = MIKROBUS( mikrobus, MIKROBUS_MOSI ); \
163 cfg.sck = MIKROBUS( mikrobus, MIKROBUS_SCK ); \
164 cfg.cs = MIKROBUS( mikrobus, MIKROBUS_CS ); \
165 cfg.com_b = MIKROBUS( mikrobus, MIKROBUS_AN ); \
166 cfg.sd = MIKROBUS( mikrobus, MIKROBUS_RST ); \
167 cfg.com_a = MIKROBUS( mikrobus, MIKROBUS_INT )
183 #if ( MUX5_DRIVER_SEL == MUX5_SPI_DRIVER )
185 pin_name_t chip_select;
277 #if ( MUX5_DRIVER_SEL == MUX5_I2C_DRIVER )
err_t mux5_init(mux5_t *ctx, mux5_cfg_t *cfg)
MUX 5 initialization function.
uint8_t i2c_address
Definition: mux5.h:212
struct mux5_s mux5_t
MUX 5 Click context object.
digital_out_t sd
Definition: mux5.h:178
pin_name_t com_a
Definition: mux5.h:209
i2c_master_t i2c
Definition: mux5.h:187
pin_name_t mosi
Definition: mux5.h:204
This file contains SPI specific macros, functions, etc.
void mux5_disable_device(mux5_t *ctx)
MUX 5 disable device function.
pin_name_t cs
Definition: mux5.h:206
@ MUX5_ERROR
Definition: mux5.h:227
err_t mux5_i2c_read_register(mux5_t *ctx, uint8_t reg, uint8_t *data_out)
MUX 5 I2C read register function.
err_t mux5_set_channels_state(mux5_t *ctx, uint16_t ch_mask, uint8_t ch_state)
MUX 5 set channels state function.
uint32_t spi_speed
Definition: mux5.h:214
pin_name_t scl
Definition: mux5.h:201
uint16_t ch_a
Definition: mux5.h:190
uint8_t slave_address
Definition: mux5.h:188
pin_name_t sck
Definition: mux5.h:205
digital_in_t com_b
Definition: mux5.h:180
pin_name_t com_b
Definition: mux5.h:207
uint8_t mux5_get_com_b_pin(mux5_t *ctx)
MUX 5 get com b pin function.
uint32_t i2c_speed
Definition: mux5.h:211
pin_name_t sda
Definition: mux5.h:202
spi_master_chip_select_polarity_t cs_polarity
Definition: mux5.h:216
pin_name_t miso
Definition: mux5.h:203
digital_in_t com_a
Definition: mux5.h:181
spi_master_mode_t spi_mode
Definition: mux5.h:215
uint8_t mux5_get_com_a_pin(mux5_t *ctx)
MUX 5 get com a pin function.
err_t mux5_i2c_write_register(mux5_t *ctx, uint8_t reg, uint8_t data_in)
MUX 5 I2C write register function.
void mux5_enable_device(mux5_t *ctx)
MUX 5 enable device function.
pin_name_t sd
Definition: mux5.h:208
@ MUX5_OK
Definition: mux5.h:226
uint16_t ch_b
Definition: mux5.h:191
void mux5_cfg_setup(mux5_cfg_t *cfg)
MUX 5 configuration object setup function.
MUX 5 Click context object.
Definition: mux5.h:177
MUX 5 Click configuration object.
Definition: mux5.h:200
err_t mux5_default_cfg(mux5_t *ctx)
MUX 5 default configuration function.
mux5_return_value_t
MUX 5 Click return value data.
Definition: mux5.h:225