天天看點

ESP8266學習——GPIO EXTI按鍵初始化GPIO_0中斷設定中斷函數整體代碼

GPIO EXTI

  • 按鍵初始化
  • GPIO_0中斷設定
  • 中斷函數
  • 整體代碼

按鍵初始化

// 初始化按鍵(BOOT == GPIO0)
	//-----------------------------------------------------------------------------
	PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO0_U,	FUNC_GPIO0);	// GPIO_0作為GPIO口
	GPIO_DIS_OUTPUT(GPIO_ID_PIN(0));						// GPIO_0失能輸出(預設)
//	PIN_PULLUP_DIS(PERIPHS_IO_MUX_GPIO0_U);					// GPIO_0失能上拉(預設)
//	PIN_PULLUP_EN(PERIPHS_IO_MUX_GPIO0_U);					// GPIO_0使能上拉

           

GPIO_0中斷設定

(ets_isr_t) 為強制類型轉換,

// GPIO_0中斷設定
	//----------------------------------------------------------------------------------
	ETS_GPIO_INTR_DISABLE();										// 關閉GPIO中斷功能
	ETS_GPIO_INTR_ATTACH((ets_isr_t)GPIO_INTERRUPT,NULL);			// 注冊中斷回調函數
	gpio_pin_intr_state_set(GPIO_ID_PIN(0),GPIO_PIN_INTR_NEGEDGE);	// GPIO_0下降沿中斷
	ETS_GPIO_INTR_ENABLE();											// 打開GPIO中斷功能

           

中斷觸發方式的設定

語句 中斷觸發方式
GPIO_PIN_INTR_DISABLE = 0 不觸發中斷
GPIO_PIN_INTR_POSEDGE = 1 上升沿中斷
GPIO_PIN_INTR_NEGEDGE = 2 下降沿中斷
GPIO_PIN_INTR_ANYEDGE = 3 雙邊沿中斷
GPIO_PIN_INTR_LOLEVEL = 4 低電平中斷
GPIO_PIN_INTR_HILEVEL = 5 高電平中斷

中斷函數

// GPIO中斷函數【注意:中斷函數前不要有"ICACHE_FLASH_ATTR"宏】
//=============================================================================
void GPIO_INTERRUPT(void)
{
	u32	S_GPIO_INT;		// 所有IO口的中斷狀态
	u32 F_GPIO_0_INT;	// GPIO_0的中斷狀态

	// 讀取GPIO中斷狀态
	//---------------------------------------------------
	S_GPIO_INT = GPIO_REG_READ(GPIO_STATUS_ADDRESS);

	// 清除中斷狀态位(如果不清除狀态位,則會持續進入中斷)
	//----------------------------------------------------
	GPIO_REG_WRITE(GPIO_STATUS_W1TC_ADDRESS, S_GPIO_INT);


	F_GPIO_0_INT = S_GPIO_INT & (0x01<<0);	// 擷取GPIO_0中斷狀态

	// 判斷是否是KEY中斷(未做消抖)
	//------------------------------------------------------------
	if(F_GPIO_0_INT)	// GPIO_0的下降沿中斷
	{
		F_LED = !F_LED;

		GPIO_OUTPUT_SET(GPIO_ID_PIN(4),F_LED);	// LED狀态翻轉
	}
}
           
GPIO_STATUS_W1TC_ADDRESS 當我們向某一位寫1的時候,将會清除GPIO中斷标志位

整體代碼

#include "ets_sys.h"
#include "osapi.h"

#include "user_interface.h"

#include "user_config.h"		// 使用者配置
#include "c_types.h"			// 變量類型
#include "eagle_soc.h"			// GPIO函數、宏定義
#include "ets_sys.h"			// 回調函數
#include "os_type.h"			// os_XXX
#include "osapi.h"  			// os_XXX、軟體定時器
#include "user_interface.h" 	// 系統接口、system_param_xxx接口、WIFI、RateContro
// 宏定義
//==================================================================================
#define		ProjectName		"GPIO_EXTI"			// 工程名宏定義
//==================================================================================


// 全局變量
//==================================================================================
u8 F_LED = 0;		// LED狀态标志位
//==================================================================================


/******************************************************************************
 * FunctionName : user_rf_cal_sector_set
 * Description  : SDK just reversed 4 sectors, used for rf init data and paramters.
 *                We add this function to force users to set rf cal sector, since
 *                we don't know which sector is free in user's application.
 *                sector map for last several sectors : ABCCC
 *                A : rf cal
 *                B : rf init data
 *                C : sdk parameters
 * Parameters   : none
 * Returns      : rf cal sector
*******************************************************************************/
uint32 ICACHE_FLASH_ATTR
user_rf_cal_sector_set(void)
{
    enum flash_size_map size_map = system_get_flash_size_map();
    uint32 rf_cal_sec = 0;

    switch (size_map) {
        case FLASH_SIZE_4M_MAP_256_256:
            rf_cal_sec = 128 - 5;
            break;

        case FLASH_SIZE_8M_MAP_512_512:
            rf_cal_sec = 256 - 5;
            break;

        case FLASH_SIZE_16M_MAP_512_512:
            rf_cal_sec = 512 - 5;
            break;
        case FLASH_SIZE_16M_MAP_1024_1024:
            rf_cal_sec = 512 - 5;
            break;

        case FLASH_SIZE_32M_MAP_512_512:
            rf_cal_sec = 1024 - 5;
            break;
        case FLASH_SIZE_32M_MAP_1024_1024:
            rf_cal_sec = 1024 - 5;
            break;

        case FLASH_SIZE_64M_MAP_1024_1024:
            rf_cal_sec = 2048 - 5;
            break;
        case FLASH_SIZE_128M_MAP_1024_1024:
            rf_cal_sec = 4096 - 5;
            break;
        default:
            rf_cal_sec = 0;
            break;
    }

    return rf_cal_sec;
}


void ICACHE_FLASH_ATTR
user_rf_pre_init(void)
{
}

void GPIO_INTERRUPT(void)
{
	u32 S_GPIO_INT;		//所有IO口的中斷狀态
	u32 F_GPIO_0_INT;	//GPIO_0中斷狀态

	//讀取GPIO中斷狀态
	S_GPIO_INT = GPIO_REG_READ(GPIO_STATUS_ADDRESS);

	//清除中斷狀态位(如果不清除狀态位,則會持續進入中斷)
	GPIO_REG_WRITE(GPIO_STATUS_W1TC_ADDRESS,S_GPIO_INT);


	F_GPIO_0_INT = S_GPIO_INT & (0X01<<0);		//擷取GPIO_0中斷狀态

	//判斷是否是KEY中斷(未消抖)
	if(F_GPIO_0_INT)
	{
		F_LED = !F_LED;

		GPIO_OUTPUT_SET(GPIO_ID_PIN(4),F_LED);	//LED狀态翻轉
	}

}
/******************************************************************************
 * FunctionName : user_init
 * Description  : entry of user application, init user function here
 * Parameters   : none
 * Returns      : none
*******************************************************************************/
void ICACHE_FLASH_ATTR
user_init(void)
{
	PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U,	FUNC_GPIO4);	// GPIO_4設為IO口
	GPIO_OUTPUT_SET(GPIO_ID_PIN(4),1);						// GPIO_4 = 1

	// 初始化按鍵(BOOT == GPIO0)
	//-----------------------------------------------------------------------------
	PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO0_U,	FUNC_GPIO0);	// GPIO_0作為GPIO口
	GPIO_DIS_OUTPUT(GPIO_ID_PIN(0));						// GPIO_0失能輸出(預設)
//	PIN_PULLUP_DIS(PERIPHS_IO_MUX_GPIO0_U);					// GPIO_0失能上拉(預設)
//	PIN_PULLUP_EN(PERIPHS_IO_MUX_GPIO0_U);					// GPIO_0使能上拉


	// GPIO_0中斷設定
	//----------------------------------------------------------------------------------
	ETS_GPIO_INTR_DISABLE();										// 關閉GPIO中斷功能
	ETS_GPIO_INTR_ATTACH((ets_isr_t)GPIO_INTERRUPT,NULL);			// 注冊中斷回調函數
	gpio_pin_intr_state_set(GPIO_ID_PIN(0),GPIO_PIN_INTR_NEGEDGE);	// GPIO_0下降沿中斷
	ETS_GPIO_INTR_ENABLE();											// 打開GPIO中斷功能

}


           

繼續閱讀