1.GPIO输出控制
GPIO的输出:ESP8266的输出控制。在ESP8266引脚作为GPIO输出时,首先要配置GPIO为输出模式,这个和普通的32位单片机的IO输出是一样的,然后提供改变IO口的电平来控制输出模块的状态。在这里我用我自己手上的一款ESP8266的单片机为例。
1.1 GPIO的管脚定义
上表的解释说明(PGIO0为例):原理图引脚和PCB的丝印命名为GPIO0,它在ESP8266模块的第15个引脚,其功能引脚名称为GPIO0_U。【功能引脚名称详见文档:0D-ESP8266_PIN_List_Release_15-11-2014.xlsx,文档下载地址:http://wiki.ai-thinker.com/_media/esp8266/docs/0d-esp8266_pin_list_release_15-11-2014.xlsx 】
1.1.1 GPIO相关API函数
GPIO相关接口位于:ESP8266_NONOS_SDK/include/eagle_soc.h & gpio.h
使用示例可参考:ESP8266_NONOS_SDK/examples/IoT_Demo/user/user_plug.c
1.1.1.1 PIN_FUNC_SELECT()函数
函数原型:PIN_FUNC_SELECT(PIN_NAME, FUNC)
函数功能:将指定引脚设定为指定功能
形参:
PIN_NAME:指定引脚的引脚名称
形参可填参数为:3.3.1 GPIO引脚定义章节的” PERIPHS_IO_MUX_”+pin name
例如:GPIO0_U在这里就应该写为PERIPHS_IO_MUX_GPIO0_U
返回值:无
使用示例:PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO0_U, FUNC_GPIO0);
1.1.1.2 PIN_PULLUP_EN()函数
函数名称:PIN_PULLUP_EN(PIN_NAME)
函数功能:引脚上拉使能
形参:PIN_NAME:” PERIPHS_IO_MUX_”+pin name
示例:PIN_PULLUP_EN(PERIPHS_IO_MUX_GPIO4_U);
1.1.1.3 PIN_PULLUP_DIS()函数
函数名称:PIN_PULLUP_DIS (PIN_NAME)
函数功能:引脚上拉失能
形参:PIN_NAME:” PERIPHS_IO_MUX_”+pin name
示例:PIN_PULLUP_ DIS (PERIPHS_IO_MUX_GPIO4_U);
1.1.1.4 gpio_output_set()函数
函数名称:void gpio_output_set(uint32 set_mask,uint32 clear_mask,uint32 enable_mask,uint32 disable_mask)
函数功能:设置GPIO属性
形参:
uint32 set_mask :设置输出为高的位,对应位为1,输出高;对应位为0,不改变状态
uint32 clear_mask :设置输出为低的位,对应位为1,输出低;对应位为0,不改变状态
uint32 enable_mask :设置使能输出的位
uint32 disable_mask :设置使能输入的位
返回值:无
示例:
gpio_output_set(BIT12, 0, BIT12, 0);// #define BIT12 0x00001000 设置GPIO12输出高电平
gpio_output_set(0, BIT12, BIT12, 0): //设置GPIO12输出低电平
gpio_output_set(BIT12, BIT13, BIT12|BIT13, 0)://设置GPIO12输出高电平,GPIO13输出低电平
gpio_output_set(0, 0, 0, BIT12);//设置GPIO12为输入
1.2 测试代码
1.2.1 delay.c
/*
* 函数名称:void os_DelayMs(unsigned int data)
* 函数功能:毫秒延时函数
* 函数形参:unsigned int data:延时时间
* */
void os_DelayMs(uint32_t data)
{
//在系统里面已经对uint32进行了重命名了
//typedef unsigned int uint32_t;//c_types.h
uint32_t i,j;
for(i = 0; i < data; i ++)
{
for(j = 0; j < 1000; j ++)
{
os_delay_us(1);
}
}
}
1.2.2 user_main.c
void ICACHE_FLASH_ATTR user_init(void)
{
uart_init(9600,9600);//设置串口波特率
os_printf("=============================================\r\n");
os_printf("\t SDK version:\t%s", system_get_sdk_version());
os_printf("\r\n嵌入式陈工个人编辑资料\r\n未经本人同意请勿私自传播\r\n");
os_printf("\r\nGPIO输出测试代码\r\n");
os_printf("\r\nLED闪烁\r\n");
os_printf("=============================================\r\n");
//1.设置LED灯所对应的GPIO4口为IO口模式 -- 详见文档3.3.1.1章节
PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U, FUNC_GPIO4); // GPIO4设为IO口
//2.设置GPIO4初始化输出电平 -- 详见文档3.3.1.4和3.3.2.1章节
GPIO_OUTPUT_SET(GPIO_ID_PIN(4), 1);//将GPIO4初始化为高点平状态--》灯灭
while(1)
{
GPIO_OUTPUT_SET(GPIO_ID_PIN(4), 0);//点亮LED
// DelayMs(500);
os_DelayMs(500);
GPIO_OUTPUT_SET(GPIO_ID_PIN(4), 1);//熄灭LED
// DelayMs(500);
os_DelayMs(500);
}
}