38#include "drv_digital_out.h"
39#include "drv_digital_in.h"
53#define BLE3_MAP_MIKROBUS( cfg, mikrobus ) \
54 cfg.tx_pin = MIKROBUS( mikrobus, MIKROBUS_TX ); \
55 cfg.rx_pin = MIKROBUS( mikrobus, MIKROBUS_RX ); \
56 cfg.rst = MIKROBUS( mikrobus, MIKROBUS_RST ); \
57 cfg.cts = MIKROBUS( mikrobus, MIKROBUS_CS ); \
58 cfg.rts = MIKROBUS( mikrobus, MIKROBUS_INT )
65#define BLE3_RETVAL uint8_t
68#define BLE3_INIT_ERROR 0xFF
75#define BLE3_PARSER_NO_ERROR 0x00
76#define BLE3_PARSER_ERROR_REF 0x01
77#define BLE3_PARSER_ERROR_CMD 0x02
78#define BLE3_PARSER_ERROR_DATA 0x04
85#define BLE3_STATUS_DEVICE_READY 1
86#define BLE3_STATUS_ACT_NETWORK_AND_BROKER 4
87#define BLE3_STATUS_ACT_NETWORK 2
88#define BLE3_STATUS_ACT_BROKER 3
89#define BLE3_STATUS_DEVICE_BUSY 0
96#define BLE3_MODULE_POWER_ON 1
97#define BLE3_MODULE_POWER_OFF 0
104#define BLE3_SINGLE_CMD_AT "AT"
105#define BLE3_SINGLE_CMD_AT_W "AT+W"
106#define BLE3_SINGLE_CMD_AT_R "AT+R"
107#define BLE3_SINGLE_CMD_ATE0 "ATE0"
108#define BLE3_SINGLE_CMD_ATE1 "ATE1"
109#define BLE3_SINGLE_CMD_AT_RST "AT+RST"
110#define BLE3_SINGLE_CMD_AT_CRST "AT+CRST"
111#define BLE3_SINGLE_CMD_AT_GMR "AT+GMR"
112#define BLE3_SINGLE_CMD_AT_GMSTA "AT+GMSTA"
113#define BLE3_SINGLE_CMD_AT_PUB "AT+PUB"
115#define BLE3_SINGLE_CMD_SET_AT_LRSP_1 "AT+LRSP=1"
116#define BLE3_SINGLE_CMD_SET_AT_LRSP_0 "AT+LRSP=0"
117#define BLE3_SINGLE_CMD_SET_AT_CEN_1 "AT+CEN=1"
118#define BLE3_SINGLE_CMD_SET_AT_CEN_0 "AT+CEN=0"
119#define BLE3_SINGLE_CMD_SET_AT_NWC_1 "AT+NWC=1"
120#define BLE3_SINGLE_CMD_SET_AT_NWC_0 "AT+NWC=0"
121#define BLE3_SINGLE_CMD_SET_AT_BRC_1 "AT+BRC=1"
122#define BLE3_SINGLE_CMD_SET_AT_BRC_0 "AT+BRC=0"
123#define BLE3_SINGLE_CMD_SET_AT_GPEN_0 "AT+GPEN=0"
124#define BLE3_SINGLE_CMD_SET_AT_GPEN_1 "AT+GPEN=1"
126#define BLE3_SINGLE_CMD_GET_AT_LRSP "AT+LRSP?"
127#define BLE3_SINGLE_CMD_GET_AT_CEN "AT+CEN?"
128#define BLE3_SINGLE_CMD_GET_AT_NWC "AT+NWC?"
129#define BLE3_SINGLE_CMD_GET_AT_BRC "AT+BRC?"
130#define BLE3_SINGLE_CMD_GET_AT_GPEN "AT+GPEN?"
131#define BLE3_SINGLE_CMD_GET_AT_NWCR "AT+NWCR?"
132#define BLE3_SINGLE_CMD_GET_AT_BRCR "AT+BRCR?"
133#define BLE3_SINGLE_CMD_GET_AT_DSET "AT+DSET?"
135#define BLE3_SINGLE_CMD_TEST_AT_LRSP "AT+LRSP=?"
136#define BLE3_SINGLE_CMD_TEST_AT_CEN "AT+CEN=?"
137#define BLE3_SINGLE_CMD_TEST_AT_NWC "AT+NWC=?"
138#define BLE3_SINGLE_CMD_TEST_AT_BRC "AT+BRC=?"
139#define BLE3_SINGLE_CMD_TEST_AT_GPEN "AT+GPEN=?"
140#define BLE3_SINGLE_CMD_TEST_AT_NWCR "AT+NWCR=?"
141#define BLE3_SINGLE_CMD_TEST_AT_BRCR "AT+BRCR=?"
142#define BLE3_SINGLE_CMD_TEST_AT_DSET "AT+DSET=?"
144#define BLE3_MULTI_CMD_AT_DSET "AT+DSET"
145#define BLE3_MULTI_CMD_AT_BRCR "AT+BRCR"
146#define BLE3_MULTI_CMD_AT_NWCR "AT+NWCR"
153#define DRV_RX_BUFFER_SIZE 100
154#define DRV_TX_BUFFER_SIZE 100
#define DRV_RX_BUFFER_SIZE
Definition: ble3.h:153
#define DRV_TX_BUFFER_SIZE
Definition: ble3.h:154
#define BLE3_RETVAL
Definition: ble3.h:65
int32_t ble3_generic_read(ble3_t *ctx, char *data_buf, uint16_t max_len)
Generic read function.
void ble3_generic_write(ble3_t *ctx, char *data_buf, uint16_t len)
Generic write function.
void ble3_cfg_setup(ble3_cfg_t *cfg)
Config Object Initialization function.
BLE3_RETVAL ble3_init(ble3_t *ctx, ble3_cfg_t *cfg)
Initialization function.
Click configuration structure definition.
Definition: ble3.h:190
pin_name_t rts
Definition: ble3.h:200
uint32_t baud_rate
Definition: ble3.h:204
pin_name_t cts
Definition: ble3.h:199
bool uart_blocking
Definition: ble3.h:205
uart_data_bits_t data_bit
Definition: ble3.h:206
pin_name_t tx_pin
Definition: ble3.h:194
pin_name_t rx_pin
Definition: ble3.h:193
uart_stop_bits_t stop_bit
Definition: ble3.h:208
uart_parity_t parity_bit
Definition: ble3.h:207
pin_name_t rst
Definition: ble3.h:198
Click ctx object definition.
Definition: ble3.h:167
digital_out_t rts
Definition: ble3.h:171
uart_t uart
Definition: ble3.h:179
digital_in_t cts
Definition: ble3.h:175
digital_out_t rst
Definition: ble3.h:170