mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-26 01:17:51 +08:00
WIP: common board init
This commit is contained in:
@@ -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
|
||||
}
|
||||
Reference in New Issue
Block a user