ESP32 - GPIO中断触发与事件回调

2019-08-26 05:37:56来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

ESP32 - GPIO中断触发与事件回调

 最近为项目增加了GPIO外部触发中断功能,原理是为GPIO32注册了上升沿触发事件,事件触发后,会向RTOS队列写入数据。在RTOS事件中检测到该队列中有新加入的事件,就读出,并执行相应代码。

#define GPIO_INPUT_IO_WAKEUP 32
#define GPIO_INPUT_PIN_SEL (1ULL<<GPIO_INPUT_IO_WAKEUP)
#define ESP_INTR_FLAG_DEFAULT 0

static void IRAM_ATTR gpio_isr_handler(void* arg)
{
    uint32_t gpio_num = (uint32_t) arg;
    xQueueSendFromISR(gpio_evt_queue, &gpio_num, NULL);
}

static void gpio_task_example(void* arg)
{
    uint32_t io_num;
    for(;;) {
        if(xQueueReceive(gpio_evt_queue, &io_num, portMAX_DELAY))
     { printf(
"GPIO[%d] intr, val: %d\n", io_num, gpio_get_level(io_num)); } } } void app_main() { gpio_config_t io_conf; io_conf.intr_type = GPIO_PIN_INTR_POSEDGE;//interrupt of rising edge io_conf.pin_bit_mask = GPIO_INPUT_PIN_SEL;//bit mask of the pins, use GPIO32 here io_conf.mode = GPIO_MODE_INPUT;//set as input mode io_conf.pull_up_en = 0;//enable pull-up mode gpio_config(&io_conf); //install gpio isr service gpio_install_isr_service(ESP_INTR_FLAG_DEFAULT); //hook isr handler for specific gpio pin gpio_isr_handler_add(GPIO_INPUT_IO_WAKEUP, gpio_isr_handler, (void*) GPIO_INPUT_IO_WAKEUP);   xTaskCreate(gpio_task_example, "gpio_task_example", 2048, NULL, 10, NULL);   while(1)   {        } }

 


原文链接:https://www.cnblogs.com/tokure/p/11398115.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:输入输出的优化问题

下一篇:C++ | 使用const std::map,map::[]时遇到的一个bug