2 ******************************************************************************
3 * @addtogroup PIOS PIOS Core hardware abstraction layer
5 * @addtogroup PIOS_GPIO GPIO Functions
6 * @brief STM32 Hardware GPIO handling code
10 * @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2012.
11 * @brief GPIO functions, init, toggle, on & off.
12 * @see The GNU Public License (GPL) Version 3
14 *****************************************************************************/
16 * This program is free software; you can redistribute it and/or modify
17 * it under the terms of the GNU General Public License as published by
18 * the Free Software Foundation; either version 3 of the License, or
19 * (at your option) any later version.
21 * This program is distributed in the hope that it will be useful, but
22 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
23 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
26 * You should have received a copy of the GNU General Public License along
27 * with this program; if not, write to the Free Software Foundation, Inc.,
28 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
33 #ifdef PIOS_INCLUDE_GPIO
35 #include <pios_gpio_priv.h>
38 * Initialises all the GPIO's
40 int32_t PIOS_GPIO_Init(uint32_t *gpios_dev_id
, const struct pios_gpio_cfg
*cfg
)
43 *gpios_dev_id
= (uint32_t)cfg
;
45 for (uint8_t i
= 0; i
< cfg
->num_gpios
; i
++) {
46 const struct pios_gpio
*gpio
= &(cfg
->gpios
[i
]);
48 /* Enable the peripheral clock for the GPIO */
49 switch ((uint32_t)gpio
->pin
.gpio
) {
51 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA
, ENABLE
);
54 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB
, ENABLE
);
57 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC
, ENABLE
);
60 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD
, ENABLE
);
63 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOE
, ENABLE
);
66 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF
, ENABLE
);
69 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOG
, ENABLE
);
72 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOH
, ENABLE
);
75 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOI
, ENABLE
);
83 GPIO_PinAFConfig(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
, gpio
->remap
);
86 GPIO_Init(gpio
->pin
.gpio
, &gpio
->pin
.init
);
88 PIOS_GPIO_Off(*gpios_dev_id
, i
);
96 * \param[in] GPIO GPIO id
98 void PIOS_GPIO_On(uint32_t gpios_dev_id
, uint8_t gpio_id
)
100 const struct pios_gpio_cfg
*gpio_cfg
= (const struct pios_gpio_cfg
*)gpios_dev_id
;
102 PIOS_Assert(gpio_cfg
);
104 if (gpio_id
>= gpio_cfg
->num_gpios
) {
105 /* GPIO index out of range */
109 const struct pios_gpio
*gpio
= &(gpio_cfg
->gpios
[gpio_id
]);
111 if (gpio
->active_low
) {
112 GPIO_ResetBits(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
);
114 GPIO_SetBits(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
);
120 * \param[in] GPIO GPIO id
122 void PIOS_GPIO_Off(uint32_t gpios_dev_id
, uint8_t gpio_id
)
124 const struct pios_gpio_cfg
*gpio_cfg
= (const struct pios_gpio_cfg
*)gpios_dev_id
;
126 PIOS_Assert(gpio_cfg
);
128 if (gpio_id
>= gpio_cfg
->num_gpios
) {
129 /* GPIO index out of range */
133 const struct pios_gpio
*gpio
= &(gpio_cfg
->gpios
[gpio_id
]);
135 if (gpio
->active_low
) {
136 GPIO_SetBits(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
);
138 GPIO_ResetBits(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
);
144 * \param[in] GPIO GPIO id
146 void PIOS_GPIO_Toggle(uint32_t gpios_dev_id
, uint8_t gpio_id
)
148 const struct pios_gpio_cfg
*gpio_cfg
= (const struct pios_gpio_cfg
*)gpios_dev_id
;
150 PIOS_Assert(gpio_cfg
);
152 if (gpio_id
>= gpio_cfg
->num_gpios
) {
153 /* GPIO index out of range */
157 const struct pios_gpio
*gpio
= &(gpio_cfg
->gpios
[gpio_id
]);
159 if (GPIO_ReadOutputDataBit(gpio
->pin
.gpio
, gpio
->pin
.init
.GPIO_Pin
) == Bit_SET
) {
160 if (gpio
->active_low
) {
161 PIOS_GPIO_On(gpios_dev_id
, gpio_id
);
163 PIOS_GPIO_Off(gpios_dev_id
, gpio_id
);
166 if (gpio
->active_low
) {
167 PIOS_GPIO_Off(gpios_dev_id
, gpio_id
);
169 PIOS_GPIO_On(gpios_dev_id
, gpio_id
);
174 #endif /* PIOS_INCLUDE_GPIO */