Go to the documentation of this file.
38 #include "mikrosdk_version.h"
41 #if mikroSDK_GET_VERSION < 20800ul
42 #include "rcu_delays.h"
48 #include "drv_digital_out.h"
49 #include "drv_digital_in.h"
51 #include "drv_spi_master.h"
63 #define HBRIDGE3_MAP_MIKROBUS( cfg, mikrobus ) \
64 cfg.pwm = MIKROBUS( mikrobus, MIKROBUS_PWM ); \
65 cfg.dir = MIKROBUS( mikrobus, MIKROBUS_AN ); \
66 cfg.dis = MIKROBUS( mikrobus, MIKROBUS_RST ); \
67 cfg.cs = MIKROBUS( mikrobus, MIKROBUS_CS ); \
68 cfg.sdo = MIKROBUS( mikrobus, MIKROBUS_MISO ); \
69 cfg.sdi = MIKROBUS( mikrobus, MIKROBUS_MOSI ); \
70 cfg.sck = MIKROBUS( mikrobus, MIKROBUS_SCK )
77 #define HBRIDGE3_RETVAL uint8_t
79 #define HBRIDGE3_OK 0x00
80 #define HBRIDGE3_INIT_ERROR 0xFF
87 #define HBRIDGE3_DEF_FREQ 20000
94 #define HBRIDGE3_CMD_RD_DIA 0x00
95 #define HBRIDGE3_CMD_RES_DIA 0x80
96 #define HBRIDGE3_CMD_RD_REV 0x20
97 #define HBRIDGE3_CMD_RD_CTRL 0x60
98 #define HBRIDGE3_CMD_WR_CTRL 0xE0
99 #define HBRIDGE3_CMD_WR_CTRL_RD_DIA 0xC0
106 #define HBRIDGE3_CTRL_VIA_PWM_DIR 0x00
107 #define HBRIDGE3_CTRL_VIA_SPI 0x80
108 #define HBRIDGE3_SPI_ENA_OUT 0x40
109 #define HBRIDGE3_SPI_DIS_OUT 0x00
110 #define HBRIDGE3_SPI_DIR_1 0x00
111 #define HBRIDGE3_SPI_DIR_2 0x20
112 #define HBRIDGE3_SPI_PWM_0 0x00
113 #define HBRIDGE3_SPI_PWM_1 0x01
289 #endif // _HBRIDGE3_H_
void hbridge3_set_duty_cycle(hbridge3_t *ctx, float duty_cycle)
Generic sets PWM duty cycle.
void hbridge3_cfg_setup(hbridge3_cfg_t *cfg)
Config Object Initialization function.
uint16_t pwm_period
Definition: hbridge3.h:141
void hbridge3_pwm_start(hbridge3_t *ctx)
Start PWM module.
pin_name_t sck
Definition: hbridge3.h:156
pin_name_t sdo
Definition: hbridge3.h:154
pwm_t pwm
Definition: hbridge3.h:137
void hbridge3_cs_set(hbridge3_t *ctx, uint8_t pin_state)
Setting CS pin state.
pin_name_t sdi
Definition: hbridge3.h:155
spi_master_chip_select_polarity_t cs_polarity
Definition: hbridge3.h:169
digital_out_t dis
Definition: hbridge3.h:130
spi_master_mode_t spi_mode
Definition: hbridge3.h:168
digital_out_t dir
Definition: hbridge3.h:129
Click ctx object definition.
Definition: hbridge3.h:126
uint32_t dev_pwm_freq
Definition: hbridge3.h:166
digital_out_t cs
Definition: hbridge3.h:131
void hbridge3_dir_set(hbridge3_t *ctx, uint8_t pin_state)
Setting AN pin state.
HBRIDGE3_RETVAL hbridge3_init(hbridge3_t *ctx, hbridge3_cfg_t *cfg)
Initialization function.
pin_name_t cs
Definition: hbridge3.h:162
void hbridge3_pwm_stop(hbridge3_t *ctx)
Stop PWM module.
void hbridge3_dis_set(hbridge3_t *ctx, uint8_t pin_state)
Setting RST pin state.
Click configuration structure definition.
Definition: hbridge3.h:150
uint32_t pwm_freq
Definition: hbridge3.h:142
uint8_t hbridge3_spi(hbridge3_t *ctx, uint8_t spi_command)
Sending SPI command.
uint32_t spi_speed
Definition: hbridge3.h:167
pin_name_t dis
Definition: hbridge3.h:161
#define HBRIDGE3_RETVAL
Definition: hbridge3.h:77
spi_master_t spi
Definition: hbridge3.h:135
pin_name_t dir
Definition: hbridge3.h:160
void hbridge3_default_cfg(hbridge3_t *ctx, float duty_cycle)
Click Default Configuration function.
pin_name_t chip_select
Definition: hbridge3.h:136
pin_name_t pwm
Definition: hbridge3.h:153