STM32F407VGT
General-purpose I/Os (GPIO)
 1. GPIO introduction
  Each general purpose I/O port has
 o four 32bits configuration registers (GPIOx_MODER, GPIOx_OTYPER, GPIOx_OSPEEDR
 and GPIOx_PUPDR),
 o tow 32bits data registers(GPIOx_IDR and GPIOx_ODR)
 o a 32 bit set/reset register (GPIOx_BSRR),
 o a 32-bit loking register (GPIOx_LCKR) and
 o tow 32 bit alternate function selection register (GPIOx_AFRH and GPIOx_AFRL)
 2. GPIO main features
  Up to 16 I/Os under control
2.1. Output Mode
2.1.1. Output states :open drain + pull-up
  Open drain + pull-up
2.2.2. Push-pull
  When the pin output logic one, the transistor connected to the power supply is turned on,
 the other transistor is turned off. It provides an electric current to the external circuit
 connected to the output pin,
  When logic zero is outputted, the transistor connected to the ground is turned on
2.2.3. Open drain
  When the pin is configured as output, the value written to the output data register
 (GPIOx_ODR) is output on the I/O pin. It is possible to use the output driver in push-pull
 mode or open drain (only the N-MOS is actived when 0 is output).
2.2.4. Input mode
 o Pull-up
 o Pull-down
 o Flotting
3. I/O port control registers
  Each of the GPIOs has Four (4) 32-bit memory-mapped control registers
 o GPIOx_MODER to select I/O direction(input, output, AF,analog)
 o GPIOx_OTYPER to select output type (push pull or open drain)
 o GPIOx_OSPEEDR speed
 o GPIOx_PUPD to select (pull-up/ pull-down whatever the I/O direction)
4. I/O port data registers
  Each of the GPIOs has tow (2) 16-bit memory-mapped data registers : input and output
 registres
 o GPIOx_ODR : stores the data to be output it is read/write accessible
 o GPIOx_IDR :stored into the input data register a read only register
5. I/O data bitwise handling
  The bit set reset register (GPIOx_BSRR) is a 32-bit register which allows the application set
 and reset each individual bit in the output data register (GPIOx_ODR). The bit set reset
 register has twice (2fois) the size of GPIOx_ODR.
  To each bit in GPIOx_ODR, correspond tow control bits in GPIOx_BSRR : BSRR(i) and
 BSRR(i+size). When written to 1 bit BSRR(i) sets the corresponding ORD(i) bit.when we
 wiritten 1 to bit BSRR(i+size) resets the ODR(i) corresponding bit
6. I/O alternate function input /output
  Tow (2) registers are provided to select one out of the sixteen alternate function input/
 output of the sixteen alternate function input/outputs available for each I/O.
  With these registers, you can connect an alternate function to some other pin as required
 by your application. This means that a number of possible functions are multiplexed on
 each GPIO using the GPIOx_AFRL and GPIOx_AFRH alternate function registers. The
 application can thus select any one of the possible functions for each GPIO.
  The AF select signal being common to the alternate function input and alternate function
 output, a signal channel is selected for the alternate function input/output for one I/O.
7. Input configuration
  When the I/O port is programmed as input
 o The output buffer is disabled
 o The Shimitt triger input is actived
 o The pull-up and pull-down resistors are actived depending on the value in the
 GPIO_PUPDR register
 o The data present on the I/O pin are sampled into the input data register evry AHB1
 clock cycle
 o A read access to the input data register provides the I/O
8. Output configuration
  When the I/O is programmed as output
 o The output buffer is enabled
  Open drain mode : A « 0 » in the output register activates the N-MOS
 whereas a « 1 » in the output register leaves the port in Hi-Z (the P-MOS is
 never activated)
  Push pull mode : A « 0 » in the output register activated the N-MOS whereas
 a « 1 » in the output register activates P-MOS
 o The Shimitt triger input is actived
 o The weak up pull-up and pull-down resistors are activated or not depending on the
 value in the GPIOx_PUPRD register
 o The data present on the I/O pin are sampled (echantionnée) into the input data
 register even AHB1 cycle clock
 o A read access to the input data register gets the I/O state
 o A read access to the output data register gets the last written value
9. Alternate function configuration
  When the I/O port is programmed as alternate function
 o The output buffer can be configured as open-drain or push-pull
 o The output buffer is driven by the signal coming from the peripheral (transmitter
 enable and data)
 o The schmitt trigger input is activated
 o The weak up pull-up and pull-down resistors are activated or not depending on the
 value in the GPIOx_PUPRD register
 o The data present on the I/O pin are sampled (echantionnée) into the input data
 register even AHB1 cycle clock
 o A read access to the input data register gets the I/O state
10. Analog configuration
  When the I/O port is programmed as analog
 o The output buffer is disabled
 o The Schmitt trigger input is desactivated, providing zero consumption for every analog
 value of the I/O pin. The output of Schmitt trigger is forced to constant value (0)
 o The weak pull-up and pull-down resistors are disabled
 o Read access to the input data register gets the value « 0 »
11. Using the OSC32_IN/OSC32_OUT pins as GPIO PC14/PC15
 port pins
  The LSE oscillator pins OSC32_IN and OSC32_OUT can be used as general purpose PC14 and
 PC15 I/Os, respectively, when the LSE oscillator is off.
  The PC14 and PC15 I/Os are only configured as LSE oscillator pins OSC32_IN and
 OSC32_OUT when the LSE oscllator is ON.
  This is done by setting the LSEON bit in the RCC_BDCR register. The LSE has priority over the
 GPIO function.
12. Using the OSC_IN/OSC_OUT pins as GPIO PH0/PH1 port pins
  The HSE oscillator pins OSC_IN/OSC_OUT can be used as general perpuse PH0/PH1
 I/Os, respectively, when the HSE oscillator is off. (after reset, the HSE oscillator is off).
 The PH0/PH1 I/Os are only configured as OSC_IN/OSC_OUT HSE oscillator pins when
 the HSE oscillator is ON. This is done by setting the HSEON bit in the RCC_CR register.
 The HSE has prioriry over the GPIO function.