Go to the documentation of this file.
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
uart_t uart
Definition: ble3.h:179
pin_name_t tx_pin
Definition: ble3.h:194
pin_name_t cts
Definition: ble3.h:199
pin_name_t rx_pin
Definition: ble3.h:193
int32_t ble3_generic_read(ble3_t *ctx, char *data_buf, uint16_t max_len)
Generic read function.
digital_out_t rst
Definition: ble3.h:170
#define BLE3_RETVAL
Definition: ble3.h:65
digital_out_t rts
Definition: ble3.h:171
bool uart_blocking
Definition: ble3.h:205
Click configuration structure definition.
Definition: ble3.h:189
Click ctx object definition.
Definition: ble3.h:166
uart_data_bits_t data_bit
Definition: ble3.h:206
void ble3_generic_write(ble3_t *ctx, char *data_buf, uint16_t len)
Generic write function.
uart_stop_bits_t stop_bit
Definition: ble3.h:208
pin_name_t rts
Definition: ble3.h:200
#define DRV_TX_BUFFER_SIZE
Definition: ble3.h:154
uart_parity_t parity_bit
Definition: ble3.h:207
digital_in_t cts
Definition: ble3.h:175
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.
uint32_t baud_rate
Definition: ble3.h:204
pin_name_t rst
Definition: ble3.h:198