Created
April 1, 2019 20:26
-
-
Save Elijahg/d3c7db79d68ad06c0324fb8c0994975d to your computer and use it in GitHub Desktop.
Example of multiple interrupt firings
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#include <stdio.h> | |
#include "freertos/FreeRTOS.h" | |
#include "freertos/task.h" | |
#include "esp_log.h" | |
#include "driver/touch_pad.h" | |
#include "soc/rtc_cntl_reg.h" | |
#include "soc/sens_reg.h" | |
static const char* TAG = "Touch pad"; | |
#define TOUCH_THRESH_NO_USE (0) | |
#define TOUCHPAD_FILTER_TOUCH_PERIOD (10) | |
static bool s_pad_activated[TOUCH_PAD_MAX]; | |
static uint32_t s_pad_init_val[TOUCH_PAD_MAX]; | |
static void tp_example_read_task(void *pvParameter) | |
{ | |
int show_message=1; | |
touch_trigger_mode_t triggerMode; | |
while (1) { | |
//interrupt mode, enable touch interrupt | |
touch_pad_intr_enable(); | |
for (int i = 2; i < TOUCH_PAD_MAX; i++) { | |
if (s_pad_activated[i] == true) { | |
ESP_LOGI(TAG, "T%d activated!", i); | |
// Wait a while for the pad being released | |
vTaskDelay(20 / portTICK_PERIOD_MS); | |
// Clear information on pad activation | |
s_pad_activated[i] = false; | |
// Reset the counter triggering a message | |
// that application is running | |
} | |
} | |
vTaskDelay(10 / portTICK_PERIOD_MS); | |
// If no pad is touched, every couple of seconds, show a message | |
// that application is running | |
if (show_message++ % 500 == 0) { | |
touch_pad_get_trigger_mode(&triggerMode); | |
if (triggerMode==TOUCH_TRIGGER_BELOW){ | |
ESP_LOGI(TAG, "Switching trigger mode to ABOVE"); | |
touch_pad_set_trigger_mode(TOUCH_TRIGGER_ABOVE); | |
} else { | |
ESP_LOGI(TAG, "Switching trigger mode to BELOW"); | |
touch_pad_set_trigger_mode(TOUCH_TRIGGER_BELOW); | |
} | |
} | |
} | |
} | |
/* | |
Handle an interrupt triggered when a pad is touched. | |
Recognize what pad has been touched and save it in a table. | |
*/ | |
static void tp_example_rtc_intr(void * arg) | |
{ | |
uint32_t pad_intr = touch_pad_get_status(); | |
//clear interrupt | |
touch_pad_clear_status(); | |
for (int i = 2; i < TOUCH_PAD_MAX; i++) { | |
if ((pad_intr >> i) & 0x01) { | |
s_pad_activated[i] = true; | |
} | |
} | |
} | |
void app_main() | |
{ | |
// Initialize touch pad peripheral, it will start a timer to run a filter | |
ESP_LOGI(TAG, "Initializing touch pad"); | |
touch_pad_init(); | |
// If use interrupt trigger mode, should set touch sensor FSM mode at 'TOUCH_FSM_MODE_TIMER'. | |
touch_pad_set_fsm_mode(TOUCH_FSM_MODE_TIMER); | |
touch_pad_set_trigger_mode(TOUCH_TRIGGER_BELOW); | |
// Set reference voltage for charging/discharging | |
// For most usage scenarios, we recommend using the following combination: | |
// the high reference valtage will be 2.7V - 1V = 1.7V, The low reference voltage will be 0.5V. | |
touch_pad_set_voltage(TOUCH_HVOLT_2V7, TOUCH_LVOLT_0V5, TOUCH_HVOLT_ATTEN_1V); | |
// Init touch pad IO | |
for (int i = 2;i< TOUCH_PAD_MAX;i++) { | |
//init RTC IO and mode for touch pad. | |
touch_pad_config(i, TOUCH_THRESH_NO_USE); | |
} | |
// Set thresh hold | |
uint16_t touch_value; | |
for (int i = 2; i<TOUCH_PAD_MAX; i++) { | |
//read filtered value | |
touch_pad_read(i, &touch_value); | |
s_pad_init_val[i] = touch_value; | |
ESP_LOGI(TAG, "test init: touch pad [%d] val is %d", i, touch_value); | |
//set interrupt threshold. | |
ESP_ERROR_CHECK(touch_pad_set_thresh(i, touch_value * 0.95)); | |
} | |
// Register touch interrupt ISR | |
touch_pad_isr_register(tp_example_rtc_intr, NULL); | |
// Start a task to show what pads have been touched | |
xTaskCreate(&tp_example_read_task, "touch_pad_read_task", 2048, NULL, 5, NULL); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
please can u help me,
I am working on an esp32 microcontroller and I have to light a led on this microncontroller with 2 capacitive sensors. I am sending you the following code that I have written, but this code does not work, can you please help me.
/*the main steps of this work
Initialization of touch pad driver
Configuration of touch pad GPIO pins
Taking measurements
Adjusting parameters of measurements
Filtering measurements
Touch detection methods
Setting up interrupts to report touch detection
Waking up from Sleep mode on interrupt*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "freertos/queue.h"
#include "driver/touch_pad.h"
#include "esp_log.h"
#include "soc/rtc_periph.h"
#include "soc/sens_periph.h"
#include "sdkconfig.h"
#include "driver/gpio.h"
/*#define GPIO_OUTPUT_IO_0 2 // defined as output IO Number
#define GPIO_OUTPUT_IO_1
#define GPIO_OUTPUT_PIN_SEL ((1ULL<<GPIO_OUTPUT_IO_0) | (1ULL<<GPIO_OUTPUT_IO_1)) //// Open pin flag ,1UL To open ,0UL To close
#define GPIO_INPUT_T0 4 // Connected to GPIO 4
#define GPIO_INPUT_T5 14 // connected to GPIO 14
#define GPIO_INPUT_PIN_SEL ((1ULL<<GPIO_INPUT_T0) | (1ULL<<GPIO_INPUT_T5))
*/
#define TOUCH_BUTTON_NUM 2
#define TOUCH_CHANGE_CONFIG 0
// #define TOUCH_PAD_MAX 10
#define TOUCH_THRESH_NO_USE (0)
#define TOUCH_PAD_NO_CHANGE (-1)
#define TOUCH_FILTER_MODE_EN (1)
#define TOUCHPAD_FILTER_TOUCH_PERIOD (10)
#define TOUCH_THRESH_PERCENT (80)
#define LED_PIN 2
static const char *TAG = "touch read";
static bool s_pad_activated[TOUCH_BUTTON_NUM];
static uint32_t s_pad_init_val[TOUCH_BUTTON_NUM];
static xQueueHandle touchQueueStatic;
/*
Read values sensed at all available touch pads.
Use 2 / 3 of read value as the threshold
to trigger interrupt when the pad is touched.
Note: this routine demonstrates a simple way
to configure activation threshold for the touch pads.
Do not touch any pads when this routine
is running (on application start).
*/
static void tp_example_set_thresholds(void)
{
uint16_t touch_value;
for (int i = 0; i < TOUCH_BUTTON_NUM; i++)
{
//read filtered value
touch_pad_read_filtered(i, &touch_value);
s_pad_init_val[i] = touch_value;
ESP_LOGI(TAG, "test init: touch pad [%d] val is %d", i, touch_value);
//set interrupt threshold.
ESP_ERROR_CHECK(touch_pad_set_thresh(i, touch_value * 2 / 3));
}
/*
Check if any of touch pads has been activated
by reading a table updated by rtc_intr()
If so, then print it out on a serial monitor.
Clear related entry in the table afterwards
In interrupt mode, the table is updated in touch ISR.
In filter mode, we will compare the current filtered value with the initial one.
If the current filtered value is less than 80% of the initial value, we can
regard it as a 'touched' event.
When calling touch_pad_init, a timer will be started to run the filter.
This mode is designed for the situation that the pad is covered
by a 2-or-3-mm-thick medium, usually glass or plastic.
The difference caused by a 'touch' action could be very small, but we can still use
filter mode to detect a 'touch' event.
*/
static void tp_example_read_task(void *pvParameter)
{
static int show_message;
int change_mode = 0;
int filter_mode = 1;
//touch_trigger_mode_t triggerMode;
// if (triggerMode==TOUCH_TRIGGER_BELOW)
// {
// ESP_LOGI(TAG, "Switching trigger mode to ABOVE");
//
// touch_pad_set_trigger_mode(TOUCH_TRIGGER_ABOVE);
// }
// else {
// ESP_LOGI(TAG, "Switching trigger mode to BELOW");
//
// touch_pad_set_trigger_mode(TOUCH_TRIGGER_BELOW);
// }
// Change mode if no pad is touched for a long time.
// We can compare the two different mode.
if (change_mode++ % 2000 == 0) {
filter_mode = !filter_mode;
ESP_LOGW(TAG, "Change mode...%s", filter_mode == 0 ? "interrupt mode" : "filter mode");
}
}
/*Handle an interrupt triggered when a pad is touched.
Recognize what pad has been touched and save it in a table.
*/
static void tp_example_rtc_intr (void *arg)
//static void tp_example_rtc_intr(void)
{
BaseType_t xHigherPriorityTaskWoken;
/* We have not woken a task at the start of the ISR. */
xHigherPriorityTaskWoken = pdFALSE;
uint32_t pad_intr = touch_pad_get_status();
//clear interrupt
touch_pad_clear_status();
for (int i = 0; i < TOUCH_BUTTON_NUM; i++) {
if ((pad_intr >> i) & 0x01) {
xQueueSendFromISR(touchQueueStatic, (void *)i, NULL);
s_pad_activated[i] = true;
}
}
}
// Before reading touch pad, we need to initialize the RTC IO.
}
{
*/
}
}