20240909-DXSPX-emb/RTCGet(可以跑的版本)/Src/Usr/BSP/usr_bsp_gpio.c

168 lines
6.7 KiB
C
Raw Normal View History

2024-09-11 09:03:46 +00:00
#include "usr_bsp_gpio.h"
#include "driverlib/gpio.h"
#include "driverlib/sysctl.h"
#include "inc/hw_memmap.h"
#include "inc/hw_ints.h"
/*
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>:<EFBFBD>û<EFBFBD>GPIO<EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD>
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>:
* ui32Port GPIO_PORTA_BASE, GPIO_PORTA_AHB_BASE,
* GPIO_PORTB_BASE, GPIO_PORTB_AHB_BASE,
* GPIO_PORTC_BASE, GPIO_PORTC_AHB_BASE,
* GPIO_PORTD_BASE, GPIO_PORTD_AHB_BASE,
* GPIO_PORTE_BASE, GPIO_PORTE_AHB_BASE,
* GPIO_PORTF_BASE, GPIO_PORTF_AHB_BASE,
* GPIO_PORTG_BASE, GPIO_PORTG_AHB_BASE,
* GPIO_PORTH_BASE, GPIO_PORTH_AHB_BASE,
* GPIO_PORTJ_BASE, GPIO_PORTJ_AHB_BASE,
* GPIO_PORTK_BASE,
* GPIO_PORTL_BASE,
* GPIO_PORTM_BASE,
* GPIO_PORTN_BASE,
* GPIO_PORTP_BASE,
* GPIO_PORTQ_BASE,
* GPIO_PORTR_BASE,
* GPIO_PORTS_BASE,
* GPIO_PORTT_BASE,
*
* ui8Pins GPIO_PIN_0, GPIO_PIN_1
* GPIO_PIN_2, GPIO_PIN_3
* GPIO_PIN_4, GPIO_PIN_5
* GPIO_PIN_6, GPIO_PIN_7
*
* ui32PinIO GPIO_DIR_MODE_IN, GPIO_DIR_MODE_OUT, GPIO_DIR_MODE_HW
*
* ui32PinType GPIO_PIN_TYPE_STD, GPIO_PIN_TYPE_STD_WPU, GPIO_PIN_TYPE_STD_WPD
* GPIO_PIN_TYPE_OD, GPIO_PIN_TYPE_ANALOG
* GPIO_PIN_TYPE_WAKE_HIGH, GPIO_PIN_TYPE_WAKE_LOW
*/
int8_t usr_bsp_gpio_init(uint32_t ui32Port, uint8_t ui8Pins, uint32_t ui32PinIO,
uint32_t ui32PinType)
{
if ((ui32Port == GPIO_PORTA_BASE) || (ui32Port == GPIO_PORTA_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOA);
} else if ((ui32Port == GPIO_PORTB_BASE) || (ui32Port == GPIO_PORTB_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOB);
} else if ((ui32Port == GPIO_PORTC_BASE) || (ui32Port == GPIO_PORTC_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOC);
} else if ((ui32Port == GPIO_PORTD_BASE) || (ui32Port == GPIO_PORTD_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOD);
} else if ((ui32Port == GPIO_PORTE_BASE) || (ui32Port == GPIO_PORTE_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOE);
} else if ((ui32Port == GPIO_PORTF_BASE) || (ui32Port == GPIO_PORTF_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOF);
} else if ((ui32Port == GPIO_PORTH_BASE) || (ui32Port == GPIO_PORTH_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOH);
} else if ((ui32Port == GPIO_PORTJ_BASE) || (ui32Port == GPIO_PORTJ_AHB_BASE)) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOJ);
} else if (ui32Port == GPIO_PORTK_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOK);
} else if (ui32Port == GPIO_PORTL_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOL);
} else if (ui32Port == GPIO_PORTM_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOM);
} else if (ui32Port == GPIO_PORTN_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPION);
} else if (ui32Port == GPIO_PORTP_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOP);
} else if (ui32Port == GPIO_PORTQ_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOQ);
} else if (ui32Port == GPIO_PORTR_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOR);
} else if (ui32Port == GPIO_PORTS_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOS);
} else if (ui32Port == GPIO_PORTT_BASE) {
SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOT);
} else {
return -1;
}
if (ui32PinIO == GPIO_DIR_MODE_IN) {
GPIODirModeSet(ui32Port, ui8Pins, ui32PinIO);
} else if (ui32PinIO == GPIO_DIR_MODE_OUT) {
GPIODirModeSet(ui32Port, ui8Pins, ui32PinIO);
GPIOPadConfigSet(ui32Port, ui8Pins, GPIO_STRENGTH_2MA, ui32PinType);
} else if (ui32PinIO == GPIO_DIR_MODE_HW){
GPIODirModeSet(ui32Port, ui8Pins, ui32PinIO);
} else {
return -1;
}
return 0;
}
/* <20><><EFBFBD><EFBFBD>:<3A><><EFBFBD><EFBFBD>GPIO<49><4F><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߵ͵<DFB5>ƽ
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>:
* ui32Port GPIO_PORTA_BASE, GPIO_PORTA_AHB_BASE,
* GPIO_PORTB_BASE, GPIO_PORTB_AHB_BASE,
* GPIO_PORTC_BASE, GPIO_PORTC_AHB_BASE,
* GPIO_PORTD_BASE, GPIO_PORTD_AHB_BASE,
* GPIO_PORTE_BASE, GPIO_PORTE_AHB_BASE,
* GPIO_PORTF_BASE, GPIO_PORTF_AHB_BASE,
* GPIO_PORTG_BASE, GPIO_PORTG_AHB_BASE,
* GPIO_PORTH_BASE, GPIO_PORTH_AHB_BASE,
* GPIO_PORTJ_BASE, GPIO_PORTJ_AHB_BASE,
* GPIO_PORTK_BASE,
* GPIO_PORTL_BASE,
* GPIO_PORTM_BASE,
* GPIO_PORTN_BASE,
* GPIO_PORTP_BASE,
* GPIO_PORTQ_BASE,
* GPIO_PORTR_BASE,
* GPIO_PORTS_BASE,
* GPIO_PORTT_BASE,
*
* ui8Pins GPIO_PIN_0, GPIO_PIN_1
* GPIO_PIN_2, GPIO_PIN_3
* GPIO_PIN_4, GPIO_PIN_5
* GPIO_PIN_6, GPIO_PIN_7
* out_mode USR_GPIO_OUT_HIGH, USR_GPIO_OUT_LOW
*/
int8_t usr_bsp_gpio_set_output(uint32_t ui32Port, uint8_t ui8Pins, int out_mode)
{
if ((ui32Port > GPIO_PORTT_BASE) || (ui8Pins > GPIO_PIN_7)) {
return -1;
}
if (out_mode == USR_GPIO_OUT_HIGH) {
GPIOPinWrite(ui32Port, ui8Pins, ui8Pins);
} else {
GPIOPinWrite(ui32Port, ui8Pins, ~ui8Pins);
}
return 0;
}
/* <20><><EFBFBD><EFBFBD>:<3A><>ȡGPIO<49><4F><EFBFBD><EFBFBD>ֵ
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>:
* ui32Port GPIO_PORTA_BASE, GPIO_PORTA_AHB_BASE,
* GPIO_PORTB_BASE, GPIO_PORTB_AHB_BASE,
* GPIO_PORTC_BASE, GPIO_PORTC_AHB_BASE,
* GPIO_PORTD_BASE, GPIO_PORTD_AHB_BASE,
* GPIO_PORTE_BASE, GPIO_PORTE_AHB_BASE,
* GPIO_PORTF_BASE, GPIO_PORTF_AHB_BASE,
* GPIO_PORTG_BASE, GPIO_PORTG_AHB_BASE,
* GPIO_PORTH_BASE, GPIO_PORTH_AHB_BASE,
* GPIO_PORTJ_BASE, GPIO_PORTJ_AHB_BASE,
* GPIO_PORTK_BASE,
* GPIO_PORTL_BASE,
* GPIO_PORTM_BASE,
* GPIO_PORTN_BASE,
* GPIO_PORTP_BASE,
* GPIO_PORTQ_BASE,
* GPIO_PORTR_BASE,
* GPIO_PORTS_BASE,
* GPIO_PORTT_BASE,
*
* ui8Pins GPIO_PIN_0, GPIO_PIN_1
* GPIO_PIN_2, GPIO_PIN_3
* GPIO_PIN_4, GPIO_PIN_5
* GPIO_PIN_6, GPIO_PIN_7
*/
uint8_t usr_bsp_gpio_get_input(uint32_t ui32Port, uint8_t ui8Pins)
{
if (ui8Pins == GPIOPinRead(ui32Port, ui8Pins)) {
return 1;
}
return 0;
}