give basic on/off BLE signaling
debouncing could be better
This commit is contained in:
parent
e2f7b6a391
commit
e3f35e4389
1 changed files with 13 additions and 11 deletions
|
@ -17,24 +17,26 @@ static void IRAM_ATTR gpio_isr_handler(void* arg) {
|
||||||
|
|
||||||
static void gpio_task(void* arg) {
|
static void gpio_task(void* arg) {
|
||||||
uint32_t io_num;
|
uint32_t io_num;
|
||||||
uint8_t on = 1;
|
uint8_t state = 0;
|
||||||
uint8_t off = 0;
|
int8_t last_level = -1;
|
||||||
|
|
||||||
for(;;) {
|
for(;;) {
|
||||||
if(xQueueReceive(gpio_evt_queue, &io_num, portMAX_DELAY)) {
|
if(xQueueReceive(gpio_evt_queue, &io_num, portMAX_DELAY)) {
|
||||||
uint8_t level = gpio_get_level(io_num);
|
uint8_t level = gpio_get_level(io_num);
|
||||||
|
|
||||||
|
if(level == last_level) continue;
|
||||||
|
last_level = level;
|
||||||
|
|
||||||
printf("GPIO[%d] intr, val: %d\n", io_num, level);
|
printf("GPIO[%d] intr, val: %d\n", io_num, level);
|
||||||
|
|
||||||
|
if(state == 0)
|
||||||
|
vTaskDelay(10 / portTICK_RATE_MS);
|
||||||
|
|
||||||
pumps_run();
|
pumps_run();
|
||||||
|
|
||||||
ble_send_notification((void*)&on, 1);
|
state = !state;
|
||||||
|
|
||||||
// just a wee debounce
|
ble_send_notification((void*)&state, 1);
|
||||||
vTaskDelay(500 / portTICK_PERIOD_MS);
|
|
||||||
|
|
||||||
ble_send_notification((void*)&off, 1);
|
|
||||||
|
|
||||||
xQueueReset(gpio_evt_queue);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,7 +44,7 @@ static void gpio_task(void* arg) {
|
||||||
void user_button_init() {
|
void user_button_init() {
|
||||||
gpio_config_t io_conf;
|
gpio_config_t io_conf;
|
||||||
|
|
||||||
io_conf.intr_type = GPIO_PIN_INTR_NEGEDGE;
|
io_conf.intr_type = GPIO_PIN_INTR_ANYEDGE;
|
||||||
io_conf.mode = GPIO_MODE_INPUT;
|
io_conf.mode = GPIO_MODE_INPUT;
|
||||||
io_conf.pin_bit_mask = (1ULL << GPIO_USER_BUTTON);
|
io_conf.pin_bit_mask = (1ULL << GPIO_USER_BUTTON);
|
||||||
io_conf.pull_down_en = 0;
|
io_conf.pull_down_en = 0;
|
||||||
|
@ -54,5 +56,5 @@ void user_button_init() {
|
||||||
xTaskCreate(gpio_task, "gpio_task", 4096, NULL, 10, NULL);
|
xTaskCreate(gpio_task, "gpio_task", 4096, NULL, 10, NULL);
|
||||||
|
|
||||||
gpio_install_isr_service(0);
|
gpio_install_isr_service(0);
|
||||||
gpio_isr_handler_add(GPIO_USER_BUTTON, gpio_isr_handler, (void*) 0);
|
gpio_isr_handler_add(GPIO_USER_BUTTON, gpio_isr_handler, (void*)GPIO_USER_BUTTON);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue