Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
stm32:peripherals:gpio_input [2016/02/25 08:52] – feur | stm32:peripherals:gpio_input [2022/12/28 08:15] (current) – ruan | ||
---|---|---|---|
Line 9: | Line 9: | ||
\\ {{gpio_input.svg}} \\ \\ | \\ {{gpio_input.svg}} \\ \\ | ||
- | ===== Programming | + | ===== Programming |
- | The code snippet bellow shows how to configure and use a GPIO pin as input. | + | ==== Enable Peripheral ==== |
- | <code c> | + | Make sure the peripheral is enabled: |
- | #include " | + | * Enable GPIOx in '' |
- | /* Configure GPIO pin A.10 as input. */ | + | ==== Setup input mode ==== |
- | GPIOA-> | + | |
- | GPIOA->PUPDR &= ~(0x3 << 20u); /* Clear existing | + | Configure the MODE and PUPDR register, for every pin that should act as digital input: |
- | GPIOA-> | + | * Write '' |
- | + | | |
- | /* Read from GPIO pin A.10. */ | + | |
- | uint32_t data = GPIOA-> | + | |
- | </ | + | |
\\ | \\ | ||
===== Configuration Registers ===== | ===== Configuration Registers ===== | ||
- | ==== MODER ==== | + | ==== GPIOx_MODER - GPIO port mode register |
- | + | ||
- | Mode register | + | |
\\ {{gpio_reg_common.svg}} \\ \\ | \\ {{gpio_reg_common.svg}} \\ \\ | ||
Line 38: | Line 32: | ||
|Pin x|00|Input mode (reset state)| | |Pin x|00|Input mode (reset state)| | ||
- | ==== PUPDR ==== | + | ==== GPIOx_PUPDR - GPIO port pull-up / pull-down register |
- | + | ||
- | Push-up / pull-down register | + | |
\\ {{gpio_reg_common.svg}} \\ \\ | \\ {{gpio_reg_common.svg}} \\ \\ | ||
Line 51: | Line 43: | ||
===== Data Registers ===== | ===== Data Registers ===== | ||
- | ==== IDR ==== | + | ==== GPIOx_IDR - Port input data register |
- | + | ||
- | Input data register | + | |
\\ {{gpio_reg_idr.svg}} \\ \\ | \\ {{gpio_reg_idr.svg}} \\ \\ | ||
- | * Register is read only | + | * Register is read only \\ \\ |
- | + | ||
- | ===== Legend ===== | + | |
- | \\ {{legende.svg}} \\ \\ |