WIP: common board init

This commit is contained in:
Daniel Agar
2022-05-04 18:04:45 -04:00
parent 2cc25f0763
commit a1fa3cc699
25 changed files with 176 additions and 419 deletions
@@ -46,3 +46,9 @@ add_subdirectory(../stm32_common/version version)
add_subdirectory(px4io_serial)
add_subdirectory(watchdog)
px4_add_library(arch_init
init.cpp
)
target_link_libraries(arch_init PRIVATE px4_layer)
@@ -0,0 +1,147 @@
/****************************************************************************
*
* Copyright (c) 2022 PX4 Development Team. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name PX4 nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
****************************************************************************/
#include "board_config.h"
#include <px4_platform_common/px4_config.h>
#include <px4_platform/gpio.h>
#include <lib/systemlib/px4_macros.h>
extern "C" __EXPORT void stm32_boardinitialize(void)
{
#if defined(BOARD_HAS_ON_RESET)
// Reset PWM first thing
board_on_reset(-1);
#endif // BOARD_HAS_ON_RESET
#if defined(PX4_GPIO_INIT_LIST)
// configure pins
static constexpr uint32_t gpio_init_list[] = PX4_GPIO_INIT_LIST;
for (const auto &gpio : gpio_init_list) {
px4_arch_configgpio(gpio);
}
#endif // PX4_GPIO_INIT_LIST
board_control_spi_sensors_power_configgpio();
// I2C
#if defined(CONFIG_STM32F7_I2C1)
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C1_SCL));
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C1_SDA));
#endif // CONFIG_STM32F7_I2C1
#if defined(CONFIG_STM32F7_I2C2)
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C2_SCL));
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C2_SDA));
#endif // CONFIG_STM32F7_I2C2
#if defined(CONFIG_STM32F7_I2C3)
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C3_SCL));
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C3_SDA));
#endif // CONFIG_STM32F7_I2C3
#if defined(CONFIG_STM32F7_I2C4)
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C4_SCL));
px4_arch_configgpio(PX4_MAKE_GPIO_OUTPUT_CLEAR(GPIO_I2C4_SDA));
#endif // CONFIG_STM32F7_I2C4
// SPI
#if defined(CONFIG_STM32F7_SPI1)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI1_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI1_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI1_MOSI));
#endif // CONFIG_STM32F7_SPI1
#if defined(CONFIG_STM32F7_SPI2)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI2_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI2_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI2_MOSI));
#endif // CONFIG_STM32F7_SPI2
#if defined(CONFIG_STM32F7_SPI3)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI3_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI3_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI3_MOSI));
#endif // CONFIG_STM32F7_SPI3
#if defined(CONFIG_STM32F7_SPI4)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI4_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI4_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI4_MOSI));
#endif // CONFIG_STM32F7_SPI4
#if defined(CONFIG_STM32F7_SPI5)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI5_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI5_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI5_MOSI));
#endif // CONFIG_STM32F7_SPI5
#if defined(CONFIG_STM32F7_SPI6)
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI6_SCK));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI6_MISO));
px4_arch_configgpio(PX4_GPIO_PIN_OFF(GPIO_SPI6_MOSI));
#endif // CONFIG_STM32F7_SPI6
// CAN
#if defined(GPIO_CAN1_TX) && defined(GPIO_CAN1_RX)
px4_arch_configgpio(GPIO_CAN1_TX);
px4_arch_configgpio(GPIO_CAN1_RX);
# if defined(GPIO_CAN1_SILENT_S0)
px4_arch_configgpio(GPIO_CAN1_SILENT_S0);
# endif // GPIO_CAN1_SILENT_S0
#endif // GPIO_CAN1_TX && GPIO_CAN1_RX
#if defined(GPIO_CAN2_TX) && defined(GPIO_CAN2_RX)
px4_arch_configgpio(GPIO_CAN2_TX);
px4_arch_configgpio(GPIO_CAN2_RX);
# if defined(GPIO_CAN2_SILENT_S0)
px4_arch_configgpio(GPIO_CAN2_SILENT_S0);
# endif // GPIO_CAN2_SILENT_S0
#endif // GPIO_CAN2_TX && GPIO_CAN2_RX
#if defined(GPIO_CAN3_TX) && defined(GPIO_CAN3_RX)
px4_arch_configgpio(GPIO_CAN3_TX);
px4_arch_configgpio(GPIO_CAN3_RX);
# if defined(GPIO_CAN3_SILENT_S0)
px4_arch_configgpio(GPIO_CAN3_SILENT_S0);
# endif // GPIO_CAN3_SILENT_S0
#endif // GPIO_CAN3_TX && GPIO_CAN3_RX
#if defined(CONFIG_STM32F7_OTGFS)
// configure USB interfaces
stm32_configgpio(GPIO_OTGFS_VBUS);
#endif // CONFIG_STM32F7_OTGFS
#if defined(CONFIG_ARCH_LEDS)
// configure LEDs
board_autoled_initialize();
#endif // CONFIG_ARCH_LEDS
}