2016-09-27 10:30:07 +10:00
|
|
|
/* Blink Example
|
|
|
|
|
|
|
|
This example code is in the Public Domain (or CC0 licensed, at your option.)
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, this
|
|
|
|
software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "driver/gpio.h"
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
|
2019-06-23 11:54:31 +10:00
|
|
|
/* Can use project configuration menu (idf.py menuconfig) to choose the GPIO to blink,
|
2016-09-27 10:30:07 +10:00
|
|
|
or you can edit the following line and set a number here.
|
|
|
|
*/
|
|
|
|
#define BLINK_GPIO CONFIG_BLINK_GPIO
|
|
|
|
|
2019-02-23 17:58:48 +05:30
|
|
|
void app_main()
|
2016-09-27 10:30:07 +10:00
|
|
|
{
|
|
|
|
/* Configure the IOMUX register for pad BLINK_GPIO (some pads are
|
|
|
|
muxed to GPIO on reset already, but some default to other
|
|
|
|
functions and need to be switched to GPIO. Consult the
|
|
|
|
Technical Reference for a list of pads and their default
|
|
|
|
functions.)
|
|
|
|
*/
|
|
|
|
gpio_pad_select_gpio(BLINK_GPIO);
|
|
|
|
/* Set the GPIO as a push/pull output */
|
|
|
|
gpio_set_direction(BLINK_GPIO, GPIO_MODE_OUTPUT);
|
|
|
|
while(1) {
|
|
|
|
/* Blink off (output low) */
|
2019-02-23 17:58:48 +05:30
|
|
|
printf("Turning off the LED\n");
|
2016-09-27 10:30:07 +10:00
|
|
|
gpio_set_level(BLINK_GPIO, 0);
|
2016-12-22 12:42:21 +11:00
|
|
|
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
2016-09-27 10:30:07 +10:00
|
|
|
/* Blink on (output high) */
|
2019-02-23 17:58:48 +05:30
|
|
|
printf("Turning on the LED\n");
|
2016-09-27 10:30:07 +10:00
|
|
|
gpio_set_level(BLINK_GPIO, 1);
|
2016-12-22 12:42:21 +11:00
|
|
|
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
2016-09-27 10:30:07 +10:00
|
|
|
}
|
|
|
|
}
|