/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _STM32F4XX_GPIO_H_
#define _STM32F4XX_GPIO_H_
#ifdef __cplusplus
extern "C" {
#endif
#include <stdint.h>
#define GPIO_HANDLE_OFFSET 1 /* to make sure that 0 stays an invalid number */
#define GPIO_PORTA 0
#define GPIO_PORTB 1
#define GPIO_PORTC 2
#define GPIO_PORTD 3
#define GPIO_PORTE 4
#define GPIO_PORTF 5
#define GPIO_PORTG 6
#define GPIO_PORTH 7
#define GPIO_PORTI 8
#define GPIO_PORT_SHIFT 4
/*
* This is a shorthand to specify a GPIO by port and number.
* Use GPIO_PA(5) for the Nucleo green LED LD2.
*/
#define GPIO_PA(x) ((GPIO_PORTA << GPIO_PORT_SHIFT) + (x))
#define GPIO_PB(x) ((GPIO_PORTB << GPIO_PORT_SHIFT) + (x))
#define GPIO_PC(x) ((GPIO_PORTC << GPIO_PORT_SHIFT) + (x))
#define GPIO_PD(x) ((GPIO_PORTD << GPIO_PORT_SHIFT) + (x))
#define GPIO_PE(x) ((GPIO_PORTE << GPIO_PORT_SHIFT) + (x))
#define GPIO_PF(x) ((GPIO_PORTF << GPIO_PORT_SHIFT) + (x))
#define GPIO_PG(x) ((GPIO_PORTG << GPIO_PORT_SHIFT) + (x))
#define GPIO_PH(x) ((GPIO_PORTH << GPIO_PORT_SHIFT) + (x))
#define GPIO_PI(x) ((GPIO_PORTI << GPIO_PORT_SHIFT) + (x))
#define GPIO_PIN_MASK 0xf
enum StmGpioAltFunc
{
GPIO_AF00 = 0,
GPIO_AF01,
GPIO_AF02,
GPIO_AF03,
GPIO_AF04,
GPIO_AF05,
GPIO_AF06,
GPIO_AF07,
GPIO_AF08,
GPIO_AF09,
GPIO_AF10,
GPIO_AF11,
GPIO_AF12,
GPIO_AF13,
GPIO_AF14,
GPIO_AF15,
GPIO_AF_SYS = GPIO_AF00,
GPIO_AF_TIM1 = GPIO_AF01,
GPIO_AF_TIM2 = GPIO_AF01,
GPIO_AF_TIM3 = GPIO_AF02,
GPIO_AF_TIM4 = GPIO_AF02,
GPIO_AF_TIM5 = GPIO_AF02,
GPIO_AF_TIM9 = GPIO_AF03,
GPIO_AF_TIM10 = GPIO_AF03,
GPIO_AF_TIM11 = GPIO_AF03,
GPIO_AF_I2C1 = GPIO_AF04,
GPIO_AF_I2C2_A = GPIO_AF04,
GPIO_AF_I2C3_A = GPIO_AF04,
GPIO_AF_SPI1 = GPIO_AF05,
GPIO_AF_I2S1 = GPIO_AF05,
GPIO_AF_SPI2_A = GPIO_AF05,
GPIO_AF_I2S2_A = GPIO_AF05,
GPIO_AF_SPI3_A = GPIO_AF05,
GPIO_AF_I2S3_A = GPIO_AF05,
GPIO_AF_SPI2_B = GPIO_AF06,
GPIO_AF_I2S2_B = GPIO_AF06,
GPIO_AF_SPI3_B = GPIO_AF06,
GPIO_AF_I2S3_B = GPIO_AF06,
GPIO_AF_SPI4_B = GPIO_AF06,
GPIO_AF_I2S4_B = GPIO_AF06,
GPIO_AF_SPI5_B = GPIO_AF06,
GPIO_AF_I2S5_B = GPIO_AF06,
GPIO_AF_SPI3_C = GPIO_AF07,
GPIO_AF_I2S3_C = GPIO_AF07,
GPIO_AF_USART1 = GPIO_AF07,
GPIO_AF_USART2 = GPIO_AF07,
GPIO_AF_USART6 = GPIO_AF08,
GPIO_AF_I2C2_B = GPIO_AF09,
GPIO_AF_I2C3_B = GPIO_AF09,
GPIO_AF_OTG1 = GPIO_AF10,
GPIO_AF_SDIO = GPIO_AF12,
GPIO_AF_EVENT = GPIO_AF15,
};
enum StmGpioSpeed /* CL (pF) 50, 50, 10, 10 */
{ /* VDD (V) >= 2.7, 1.7, 2.7, 1.7 */
GPIO_SPEED_LOW = 0, /* Max (MHz) 4, 2, 8, 4 */
GPIO_SPEED_MEDIUM, /* 25, 12.5, 50, 20 */
GPIO_SPEED_FAST, /* 50, 25, 100, 50 */
GPIO_SPEED_HIGH, /* 100, 50, 180, 100 */
};
void gpioBitbangedUartOut(uint32_t chr);
#ifdef __cplusplus
}
#endif
#endif