From fcd03f5b4e13d16af5b792cd0db6e3110937898c Mon Sep 17 00:00:00 2001 From: ahiuchingau <20424172+ahiuchingau@users.noreply.github.com> Date: Mon, 15 Jul 2024 15:37:48 -0400 Subject: [PATCH] add motor pins --- .../include/stacker/stacker/errors.hpp | 2 +- stm32-modules/stacker/CMakeLists.txt | 5 +- stm32-modules/stacker/firmware/CMakeLists.txt | 4 +- .../firmware/host_comms_task/usbd_desc.c | 10 +- .../firmware/motor_control/motor_hardware.c | 60 ++++ stm32-modules/stacker/firmware/system/main.h | 32 +-- .../firmware/system/stm32g4xx_hal_conf.h | 266 +++++++++--------- .../stacker/firmware/system/stm32g4xx_it.c | 102 ++++++- .../stacker/firmware/system/stm32g4xx_it.h | 30 +- .../stacker/simulator/CMakeLists.txt | 22 ++ stm32-modules/stacker/simulator/main.cpp | 1 + 11 files changed, 364 insertions(+), 170 deletions(-) create mode 100644 stm32-modules/stacker/firmware/motor_control/motor_hardware.c create mode 100644 stm32-modules/stacker/simulator/CMakeLists.txt create mode 100644 stm32-modules/stacker/simulator/main.cpp diff --git a/stm32-modules/include/stacker/stacker/errors.hpp b/stm32-modules/include/stacker/stacker/errors.hpp index 995cf0a82..7840d98c8 100644 --- a/stm32-modules/include/stacker/stacker/errors.hpp +++ b/stm32-modules/include/stacker/stacker/errors.hpp @@ -19,7 +19,7 @@ enum class ErrorCode { auto errorstring(ErrorCode code) -> const char*; template - requires std::forward_iterator && std::sized_sentinel_for +requires std::forward_iterator && std::sized_sentinel_for constexpr auto write_into(Input start, Limit end, ErrorCode code) -> Input { const char* str = errorstring(code); return write_string_to_iterpair(start, end, str); diff --git a/stm32-modules/stacker/CMakeLists.txt b/stm32-modules/stacker/CMakeLists.txt index 6cc0cfb90..432ae6c1b 100644 --- a/stm32-modules/stacker/CMakeLists.txt +++ b/stm32-modules/stacker/CMakeLists.txt @@ -3,14 +3,13 @@ # This variable defines the name of the target for this subfolder. set(TARGET_MODULE_NAME "stacker") -#add_subdirectory(src) +add_subdirectory(src) if (${CMAKE_CROSSCOMPILING}) add_subdirectory(firmware) - add_subdirectory(src) else() add_subdirectory(tests) -# add_subdirectory(simulator) + add_subdirectory(simulator) endif() file(GLOB_RECURSE ${TARGET_MODULE_NAME}_SOURCES_FOR_FORMAT diff --git a/stm32-modules/stacker/firmware/CMakeLists.txt b/stm32-modules/stacker/firmware/CMakeLists.txt index a5849e2ac..1897448e8 100644 --- a/stm32-modules/stacker/firmware/CMakeLists.txt +++ b/stm32-modules/stacker/firmware/CMakeLists.txt @@ -7,6 +7,7 @@ add_STM32G4_freertos(${TARGET_MODULE_NAME}) add_STM32G4_usb(${TARGET_MODULE_NAME}) set(SYSTEM_DIR "${CMAKE_CURRENT_SOURCE_DIR}/system") +set(MOTOR_CONTROL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/motor_control") set(COMMS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/host_comms_task") set(COMMON_MCU_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../../common/STM32G491") set(COMMON_SRC_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../../common/src") @@ -15,7 +16,8 @@ set(GDBINIT_PATH "${CMAKE_CURRENT_BINARY_DIR}/../../common/STM32G491/gdbinit") # Add source files that should be checked by clang-tidy here set(${TARGET_MODULE_NAME}_FW_LINTABLE_SRCS ${COMMS_DIR}/usb_hardware.c - ) + ${MOTOR_CONTROL_DIR}/motor_hardware.c + ) # Add source files that should NOT be checked by clang-tidy here set(${TARGET_MODULE_NAME}_FW_NONLINTABLE_SRCS diff --git a/stm32-modules/stacker/firmware/host_comms_task/usbd_desc.c b/stm32-modules/stacker/firmware/host_comms_task/usbd_desc.c index 608e0bf5e..477b23067 100644 --- a/stm32-modules/stacker/firmware/host_comms_task/usbd_desc.c +++ b/stm32-modules/stacker/firmware/host_comms_task/usbd_desc.c @@ -26,16 +26,14 @@ /* Private typedef -----------------------------------------------------------*/ /* Private define ------------------------------------------------------------*/ -// TODO(frank 05-06-2022): Uncomment these VID/PID definitions and replace -// the temporary values that replicate the Gen1 tempdeck. -//#define USBD_VID 0x04D8 -//#define USBD_PID 0xed8c +// TODO(alise): Uncomment these VID/PID definitions and replace +// the temporary values with the actual values for the shuttle #define USBD_VID 0x04D8 /* same as Gen1 TD */ #define USBD_PID 0xee93 /* same as Gen1 TD */ #define USBD_LANGID_STRING 0x0409 /* Replace '0xbbb' with your device language ID */ #define USBD_MANUFACTURER_STRING "Opentrons" /* Add your manufacturer string */ -#define USBD_PRODUCT_HS_STRING "Tempdeck HS" /* Add your product High Speed string */ -#define USBD_PRODUCT_FS_STRING "Tempdeck FS" /* Add your product Full Speed string */ +#define USBD_PRODUCT_HS_STRING "Stacker HS" /* Add your product High Speed string */ +#define USBD_PRODUCT_FS_STRING "Stacker FS" /* Add your product Full Speed string */ #define USBD_CONFIGURATION_HS_STRING "Serial Config HS" /* Add your configuration High Speed string */ #define USBD_INTERFACE_HS_STRING "Serial Interface HS" /* Add your Interface High Speed string */ #define USBD_CONFIGURATION_FS_STRING "Serial Config FS" /* Add your configuration Full Speed string */ diff --git a/stm32-modules/stacker/firmware/motor_control/motor_hardware.c b/stm32-modules/stacker/firmware/motor_control/motor_hardware.c new file mode 100644 index 000000000..2020eeb26 --- /dev/null +++ b/stm32-modules/stacker/firmware/motor_control/motor_hardware.c @@ -0,0 +1,60 @@ +#include "stm32g4xx_hal.h" + +/******************* Motor Z *******************/ + +/** Motor hardware **/ +#define Z_STEP_PIN (GPIO_PIN_2) +#define Z_STEP_PORT (GPIOC) +#define Z_DIR_PIN (GPIO_PIN_1) +#define Z_DIR_PORT (GPIOC) +#define Z_EN_PIN (GPIO_PIN_3) +#define Z_EN_PORT (GPIOA) +#define Z_N_BRAKE_PIN(GPIO_PIN_7) +#define Z_N_BRAKE_PORT(GPIOB) + +/** Limit switches **/ +/* Note: Photointerrupters limit switches */ +#define Z_MINUS_LIMIT_PIN (GPIO_PIN_3) +#define Z_MINUS_LIMIT_PORT (GPIOC) +#define Z_PLUS_LIMIT_PIN (GPIO_PIN_0) +#define Z_PLUS_LIMIT_PORT (GPIOA) + + +/******************* Motor X *******************/ + +/** Motor hardware **/ +#define X_STEP_PIN (GPIO_PIN_7) +#define X_STEP_PORT (GPIOA) +#define X_DIR_PIN (GPIO_PIN_6) +#define X_DIR_PORT (GPIOA) +#define X_EN_PIN (GPIO_PIN_4) +#define X_EN_PORT (GPIOA) +#define X_N_BRAKE_PIN(GPIO_PIN_9) +#define X_N_BRAKE_PORT(GPIOB) + + +/** Limit switches **/ +/* Note: Photointerrupters limit switches */ +#define X_MINUS_LIMIT_PIN (GPIO_PIN_1) +#define X_MINUS_LIMIT_PORT (GPIOA) +#define X_PLUS_LIMIT_PIN (GPIO_PIN_2) +#define X_PLUS_LIMIT_PORT (GPIOA) + + +/******************* Motor L *******************/ + +/** Motor hardware **/ +#define L_STEP_PIN (GPIO_PIN_1) +#define L_STEP_PORT (GPIOB) +#define L_DIR_PIN (GPIO_PIN_0) +#define L_DIR_PORT (GPIOB) +#define L_EN_PIN (GPIO_PIN_4) +#define L_EN_PORT (GPIOA) + + +/** Limit switches **/ +/* Note: Mechanical limit switches */ +#define L_N_HELD_PIN (GPIO_PIN_5) +#define L_N_HELD_PORT (GPIOB) +#define L_N_RELEASED_PIN (GPIO_PIN_11) +#define L_N_RELEASED_PORT (GPIO_PIN_C) diff --git a/stm32-modules/stacker/firmware/system/main.h b/stm32-modules/stacker/firmware/system/main.h index a5c2edc06..c3a9dcb56 100644 --- a/stm32-modules/stacker/firmware/system/main.h +++ b/stm32-modules/stacker/firmware/system/main.h @@ -1,21 +1,21 @@ /* USER CODE BEGIN Header */ /** - ****************************************************************************** - * @file : main.h - * @brief : Header for main.c file. - * This file contains the common defines of the application. - ****************************************************************************** - * @attention - * - * Copyright (c) 2024 STMicroelectronics. - * All rights reserved. - * - * This software is licensed under terms that can be found in the LICENSE file - * in the root directory of this software component. - * If no LICENSE file comes with this software, it is provided AS-IS. - * - ****************************************************************************** - */ + ****************************************************************************** + * @file : main.h + * @brief : Header for main.c file. + * This file contains the common defines of the application. + ****************************************************************************** + * @attention + * + * Copyright (c) 2024 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ /* USER CODE END Header */ /* Define to prevent recursive inclusion -------------------------------------*/ diff --git a/stm32-modules/stacker/firmware/system/stm32g4xx_hal_conf.h b/stm32-modules/stacker/firmware/system/stm32g4xx_hal_conf.h index dc95060bb..de81d6b87 100644 --- a/stm32-modules/stacker/firmware/system/stm32g4xx_hal_conf.h +++ b/stm32-modules/stacker/firmware/system/stm32g4xx_hal_conf.h @@ -1,21 +1,21 @@ /* USER CODE BEGIN Header */ /** - ****************************************************************************** - * @file stm32g4xx_hal_conf.h - * @author MCD Application Team - * @brief HAL configuration file - ****************************************************************************** + ****************************************************************************** + * @file stm32g4xx_hal_conf.h + * @author MCD Application Team + * @brief HAL configuration file + ****************************************************************************** * @attention - * - * Copyright (c) 2019 STMicroelectronics. - * All rights reserved. - * - * This software is licensed under terms that can be found in the LICENSE file - * in the root directory of this software component. - * If no LICENSE file comes with this software, it is provided AS-IS. - * - ****************************************************************************** - */ + * + * Copyright (c) 2019 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ /* USER CODE END Header */ /* Define to prevent recursive inclusion -------------------------------------*/ @@ -23,7 +23,7 @@ #define STM32G4xx_HAL_CONF_H #ifdef __cplusplus - extern "C" { +extern "C" { #endif /* Exported types ------------------------------------------------------------*/ @@ -31,12 +31,12 @@ /* ########################## Module Selection ############################## */ /** - * @brief This is the list of modules to be used in the HAL driver - */ + * @brief This is the list of modules to be used in the HAL driver + */ #define HAL_MODULE_ENABLED - /*#define HAL_ADC_MODULE_ENABLED */ +/*#define HAL_ADC_MODULE_ENABLED */ /*#define HAL_COMP_MODULE_ENABLED */ /*#define HAL_CORDIC_MODULE_ENABLED */ /*#define HAL_CRC_MODULE_ENABLED */ @@ -74,124 +74,137 @@ #define HAL_PWR_MODULE_ENABLED #define HAL_CORTEX_MODULE_ENABLED -/* ########################## Register Callbacks selection ############################## */ +/* ########################## Register Callbacks selection + * ############################## */ /** - * @brief This is the list of modules where register callback can be used - */ -#define USE_HAL_ADC_REGISTER_CALLBACKS 0U -#define USE_HAL_COMP_REGISTER_CALLBACKS 0U -#define USE_HAL_CORDIC_REGISTER_CALLBACKS 0U -#define USE_HAL_CRYP_REGISTER_CALLBACKS 0U -#define USE_HAL_DAC_REGISTER_CALLBACKS 0U -#define USE_HAL_EXTI_REGISTER_CALLBACKS 0U -#define USE_HAL_FDCAN_REGISTER_CALLBACKS 0U -#define USE_HAL_FMAC_REGISTER_CALLBACKS 0U -#define USE_HAL_HRTIM_REGISTER_CALLBACKS 0U -#define USE_HAL_I2C_REGISTER_CALLBACKS 0U -#define USE_HAL_I2S_REGISTER_CALLBACKS 0U -#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U -#define USE_HAL_LPTIM_REGISTER_CALLBACKS 0U -#define USE_HAL_NAND_REGISTER_CALLBACKS 0U -#define USE_HAL_NOR_REGISTER_CALLBACKS 0U -#define USE_HAL_OPAMP_REGISTER_CALLBACKS 0U -#define USE_HAL_PCD_REGISTER_CALLBACKS 0U -#define USE_HAL_QSPI_REGISTER_CALLBACKS 0U -#define USE_HAL_RNG_REGISTER_CALLBACKS 0U -#define USE_HAL_RTC_REGISTER_CALLBACKS 0U -#define USE_HAL_SAI_REGISTER_CALLBACKS 0U -#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U -#define USE_HAL_SMBUS_REGISTER_CALLBACKS 0U -#define USE_HAL_SPI_REGISTER_CALLBACKS 0U -#define USE_HAL_SRAM_REGISTER_CALLBACKS 0U -#define USE_HAL_TIM_REGISTER_CALLBACKS 0U -#define USE_HAL_UART_REGISTER_CALLBACKS 0U -#define USE_HAL_USART_REGISTER_CALLBACKS 0U -#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U - -/* ########################## Oscillator Values adaptation ####################*/ + * @brief This is the list of modules where register callback can be used + */ +#define USE_HAL_ADC_REGISTER_CALLBACKS 0U +#define USE_HAL_COMP_REGISTER_CALLBACKS 0U +#define USE_HAL_CORDIC_REGISTER_CALLBACKS 0U +#define USE_HAL_CRYP_REGISTER_CALLBACKS 0U +#define USE_HAL_DAC_REGISTER_CALLBACKS 0U +#define USE_HAL_EXTI_REGISTER_CALLBACKS 0U +#define USE_HAL_FDCAN_REGISTER_CALLBACKS 0U +#define USE_HAL_FMAC_REGISTER_CALLBACKS 0U +#define USE_HAL_HRTIM_REGISTER_CALLBACKS 0U +#define USE_HAL_I2C_REGISTER_CALLBACKS 0U +#define USE_HAL_I2S_REGISTER_CALLBACKS 0U +#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U +#define USE_HAL_LPTIM_REGISTER_CALLBACKS 0U +#define USE_HAL_NAND_REGISTER_CALLBACKS 0U +#define USE_HAL_NOR_REGISTER_CALLBACKS 0U +#define USE_HAL_OPAMP_REGISTER_CALLBACKS 0U +#define USE_HAL_PCD_REGISTER_CALLBACKS 0U +#define USE_HAL_QSPI_REGISTER_CALLBACKS 0U +#define USE_HAL_RNG_REGISTER_CALLBACKS 0U +#define USE_HAL_RTC_REGISTER_CALLBACKS 0U +#define USE_HAL_SAI_REGISTER_CALLBACKS 0U +#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U +#define USE_HAL_SMBUS_REGISTER_CALLBACKS 0U +#define USE_HAL_SPI_REGISTER_CALLBACKS 0U +#define USE_HAL_SRAM_REGISTER_CALLBACKS 0U +#define USE_HAL_TIM_REGISTER_CALLBACKS 0U +#define USE_HAL_UART_REGISTER_CALLBACKS 0U +#define USE_HAL_USART_REGISTER_CALLBACKS 0U +#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U + +/* ########################## Oscillator Values adaptation + * ####################*/ /** - * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. - * This value is used by the RCC HAL module to compute the system frequency - * (when HSE is used as system clock source, directly or through the PLL). - */ -#if !defined (HSE_VALUE) - #define HSE_VALUE (8000000UL) /*!< Value of the External oscillator in Hz */ -#endif /* HSE_VALUE */ - -#if !defined (HSE_STARTUP_TIMEOUT) - #define HSE_STARTUP_TIMEOUT (100UL) /*!< Time out for HSE start up, in ms */ -#endif /* HSE_STARTUP_TIMEOUT */ + * @brief Adjust the value of External High Speed oscillator (HSE) used in your + * application. This value is used by the RCC HAL module to compute the system + * frequency (when HSE is used as system clock source, directly or through the + * PLL). + */ +#if !defined(HSE_VALUE) +#define HSE_VALUE (8000000UL) /*!< Value of the External oscillator in Hz */ +#endif /* HSE_VALUE */ + +#if !defined(HSE_STARTUP_TIMEOUT) +#define HSE_STARTUP_TIMEOUT (100UL) /*!< Time out for HSE start up, in ms */ +#endif /* HSE_STARTUP_TIMEOUT */ /** - * @brief Internal High Speed oscillator (HSI) value. - * This value is used by the RCC HAL module to compute the system frequency - * (when HSI is used as system clock source, directly or through the PLL). - */ -#if !defined (HSI_VALUE) - #define HSI_VALUE (16000000UL) /*!< Value of the Internal oscillator in Hz*/ -#endif /* HSI_VALUE */ + * @brief Internal High Speed oscillator (HSI) value. + * This value is used by the RCC HAL module to compute the system + * frequency (when HSI is used as system clock source, directly or through the + * PLL). + */ +#if !defined(HSI_VALUE) +#define HSI_VALUE (16000000UL) /*!< Value of the Internal oscillator in Hz*/ +#endif /* HSI_VALUE */ /** - * @brief Internal High Speed oscillator (HSI48) value for USB FS and RNG. - * This internal oscillator is mainly dedicated to provide a high precision clock to - * the USB peripheral by means of a special Clock Recovery System (CRS) circuitry. - * When the CRS is not used, the HSI48 RC oscillator runs on it default frequency - * which is subject to manufacturing process variations. - */ -#if !defined (HSI48_VALUE) - #define HSI48_VALUE (48000000UL) /*!< Value of the Internal High Speed oscillator for USB FS/RNG in Hz. - The real value my vary depending on manufacturing process variations.*/ -#endif /* HSI48_VALUE */ + * @brief Internal High Speed oscillator (HSI48) value for USB FS and RNG. + * This internal oscillator is mainly dedicated to provide a high + * precision clock to the USB peripheral by means of a special Clock Recovery + * System (CRS) circuitry. When the CRS is not used, the HSI48 RC oscillator + * runs on it default frequency which is subject to manufacturing process + * variations. + */ +#if !defined(HSI48_VALUE) +#define HSI48_VALUE \ + (48000000UL) /*!< Value of the Internal High Speed oscillator for USB \ + FS/RNG in Hz. The real value my vary depending on \ + manufacturing process variations.*/ +#endif /* HSI48_VALUE */ /** - * @brief Internal Low Speed oscillator (LSI) value. - */ -#if !defined (LSI_VALUE) + * @brief Internal Low Speed oscillator (LSI) value. + */ +#if !defined(LSI_VALUE) /*!< Value of the Internal Low Speed oscillator in Hz -The real value may vary depending on the variations in voltage and temperature.*/ -#define LSI_VALUE (32000UL) /*!< LSI Typical Value in Hz*/ -#endif /* LSI_VALUE */ +The real value may vary depending on the variations in voltage and +temperature.*/ +#define LSI_VALUE (32000UL) /*!< LSI Typical Value in Hz*/ +#endif /* LSI_VALUE */ /** - * @brief External Low Speed oscillator (LSE) value. - * This value is used by the UART, RTC HAL module to compute the system frequency - */ -#if !defined (LSE_VALUE) -#define LSE_VALUE (32768UL) /*!< Value of the External Low Speed oscillator in Hz */ -#endif /* LSE_VALUE */ + * @brief External Low Speed oscillator (LSE) value. + * This value is used by the UART, RTC HAL module to compute the system + * frequency + */ +#if !defined(LSE_VALUE) +#define LSE_VALUE \ + (32768UL) /*!< Value of the External Low Speed oscillator in Hz */ +#endif /* LSE_VALUE */ -#if !defined (LSE_STARTUP_TIMEOUT) -#define LSE_STARTUP_TIMEOUT (5000UL) /*!< Time out for LSE start up, in ms */ -#endif /* LSE_STARTUP_TIMEOUT */ +#if !defined(LSE_STARTUP_TIMEOUT) +#define LSE_STARTUP_TIMEOUT (5000UL) /*!< Time out for LSE start up, in ms */ +#endif /* LSE_STARTUP_TIMEOUT */ /** - * @brief External clock source for I2S and SAI peripherals - * This value is used by the I2S and SAI HAL modules to compute the I2S and SAI clock source - * frequency, this source is inserted directly through I2S_CKIN pad. - */ -#if !defined (EXTERNAL_CLOCK_VALUE) -#define EXTERNAL_CLOCK_VALUE (12288000UL) /*!< Value of the External oscillator in Hz*/ -#endif /* EXTERNAL_CLOCK_VALUE */ + * @brief External clock source for I2S and SAI peripherals + * This value is used by the I2S and SAI HAL modules to compute the I2S + * and SAI clock source frequency, this source is inserted directly through + * I2S_CKIN pad. + */ +#if !defined(EXTERNAL_CLOCK_VALUE) +#define EXTERNAL_CLOCK_VALUE \ + (12288000UL) /*!< Value of the External oscillator in Hz*/ +#endif /* EXTERNAL_CLOCK_VALUE */ /* Tip: To avoid modifying this file each time you need to use different HSE, === you can define the HSE value in your toolchain compiler preprocessor. */ /* ########################### System Configuration ######################### */ /** - * @brief This is the HAL system configuration section - */ + * @brief This is the HAL system configuration section + */ -#define VDD_VALUE (3300UL) /*!< Value of VDD in mv */ -#define TICK_INT_PRIORITY (15UL) /*!< tick interrupt priority (lowest by default) */ -#define USE_RTOS 0U -#define PREFETCH_ENABLE 0U -#define INSTRUCTION_CACHE_ENABLE 1U -#define DATA_CACHE_ENABLE 1U +#define VDD_VALUE (3300UL) /*!< Value of VDD in mv */ +#define TICK_INT_PRIORITY \ + (15UL) /*!< tick interrupt priority (lowest by default) */ +#define USE_RTOS 0U +#define PREFETCH_ENABLE 0U +#define INSTRUCTION_CACHE_ENABLE 1U +#define DATA_CACHE_ENABLE 1U /* ########################## Assert Selection ############################## */ /** - * @brief Uncomment the line below to expanse the "assert_param" macro in the - * HAL drivers code - */ + * @brief Uncomment the line below to expanse the "assert_param" macro in the + * HAL drivers code + */ /* #define USE_FULL_ASSERT 1U */ /* ################## SPI peripheral configuration ########################## */ @@ -201,12 +214,12 @@ The real value may vary depending on the variations in voltage and temperature.* * Deactivated: CRC code cleaned from driver */ -#define USE_SPI_CRC 0U +#define USE_SPI_CRC 0U /* Includes ------------------------------------------------------------------*/ /** - * @brief Include module's header file - */ + * @brief Include module's header file + */ #ifdef HAL_RCC_MODULE_ENABLED #include "stm32g4xx_hal_rcc.h" @@ -357,16 +370,17 @@ The real value may vary depending on the variations in voltage and temperature.* #endif /* HAL_WWDG_MODULE_ENABLED */ /* Exported macro ------------------------------------------------------------*/ -#ifdef USE_FULL_ASSERT +#ifdef USE_FULL_ASSERT /** - * @brief The assert_param macro is used for function's parameters check. - * @param expr: If expr is false, it calls assert_failed function - * which reports the name of the source file and the source - * line number of the call that failed. - * If expr is true, it returns no value. - * @retval None - */ -#define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) + * @brief The assert_param macro is used for function's parameters check. + * @param expr: If expr is false, it calls assert_failed function + * which reports the name of the source file and the source + * line number of the call that failed. + * If expr is true, it returns no value. + * @retval None + */ +#define assert_param(expr) \ + ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) /* Exported functions ------------------------------------------------------- */ void assert_failed(uint8_t *file, uint32_t line); #else diff --git a/stm32-modules/stacker/firmware/system/stm32g4xx_it.c b/stm32-modules/stacker/firmware/system/stm32g4xx_it.c index 91425bb50..362e4fa16 100644 --- a/stm32-modules/stacker/firmware/system/stm32g4xx_it.c +++ b/stm32-modules/stacker/firmware/system/stm32g4xx_it.c @@ -260,6 +260,104 @@ void LPUART1_IRQHandler(void) /* USER CODE END LPUART1_IRQn 1 */ } -/* USER CODE BEGIN 1 */ +/** + * @brief This function handles EXTI line0 interrupt. + */ +void EXTI0_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI0_IRQn 0 */ + + /* USER CODE END EXTI0_IRQn 0 */ + + /* USER CODE BEGIN EXTI0_IRQn 1 */ + + /* USER CODE END EXTI0_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line1 interrupt. + */ +void EXTI1_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI1_IRQn 0 */ + + /* USER CODE END EXTI1_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_1); + /* USER CODE BEGIN EXTI1_IRQn 1 */ + + /* USER CODE END EXTI1_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line2 interrupt. + */ +void EXTI2_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI2_IRQn 0 */ + + /* USER CODE END EXTI2_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_2); + /* USER CODE BEGIN EXTI2_IRQn 1 */ + + /* USER CODE END EXTI2_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line3 interrupt. + */ +void EXTI3_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI3_IRQn 0 */ + + /* USER CODE END EXTI3_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_3); + /* USER CODE BEGIN EXTI3_IRQn 1 */ + + /* USER CODE END EXTI3_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line4 interrupt. + */ +void EXTI4_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI4_IRQn 0 */ + + /* USER CODE END EXTI4_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_4); + /* USER CODE BEGIN EXTI4_IRQn 1 */ + + /* USER CODE END EXTI4_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line[9:5] interrupts. + */ +void EXTI9_5_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI9_5_IRQn 0 */ + + /* USER CODE END EXTI9_5_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_5); + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_6); + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_7); + /* USER CODE BEGIN EXTI9_5_IRQn 1 */ + + /* USER CODE END EXTI9_5_IRQn 1 */ +} + +/** + * @brief This function handles EXTI line[15:10] interrupts. + */ +void EXTI15_10_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI15_10_IRQn 0 */ + + /* USER CODE END EXTI15_10_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_11); + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_12); + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_13); + /* USER CODE BEGIN EXTI15_10_IRQn 1 */ -/* USER CODE END 1 */ + /* USER CODE END EXTI15_10_IRQn 1 */ +} \ No newline at end of file diff --git a/stm32-modules/stacker/firmware/system/stm32g4xx_it.h b/stm32-modules/stacker/firmware/system/stm32g4xx_it.h index f7ade76d6..76c165409 100644 --- a/stm32-modules/stacker/firmware/system/stm32g4xx_it.h +++ b/stm32-modules/stacker/firmware/system/stm32g4xx_it.h @@ -1,20 +1,20 @@ /* USER CODE BEGIN Header */ /** - ****************************************************************************** - * @file stm32g4xx_it.h - * @brief This file contains the headers of the interrupt handlers. - ****************************************************************************** - * @attention - * - * Copyright (c) 2024 STMicroelectronics. - * All rights reserved. - * - * This software is licensed under terms that can be found in the LICENSE file - * in the root directory of this software component. - * If no LICENSE file comes with this software, it is provided AS-IS. - * ****************************************************************************** - */ + * @file stm32g4xx_it.h + * @brief This file contains the headers of the interrupt handlers. + ****************************************************************************** + * @attention + * + * Copyright (c) 2024 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ /* USER CODE END Header */ /* Define to prevent recursive inclusion -------------------------------------*/ @@ -22,7 +22,7 @@ #define __STM32G4xx_IT_H #ifdef __cplusplus - extern "C" { +extern "C" { #endif /* Private includes ----------------------------------------------------------*/ diff --git a/stm32-modules/stacker/simulator/CMakeLists.txt b/stm32-modules/stacker/simulator/CMakeLists.txt new file mode 100644 index 000000000..babef127b --- /dev/null +++ b/stm32-modules/stacker/simulator/CMakeLists.txt @@ -0,0 +1,22 @@ +add_executable( + ${TARGET_MODULE_NAME}-simulator + main.cpp +) + +target_link_libraries( + ${TARGET_MODULE_NAME}-simulator + PRIVATE ${TARGET_MODULE_NAME}-core + Boost::boost pthread + Boost::program_options + pthread +) +target_include_directories( + ${TARGET_MODULE_NAME}-simulator + PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/../../include/${TARGET_MODULE_NAME} + PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/../../include/common +) + + +set_target_properties(${TARGET_MODULE_NAME}-simulator + PROPERTIES CXX_STANDARD 20 + CXX_STANDARD_REQUIRED TRUE) diff --git a/stm32-modules/stacker/simulator/main.cpp b/stm32-modules/stacker/simulator/main.cpp new file mode 100644 index 000000000..95166bcaa --- /dev/null +++ b/stm32-modules/stacker/simulator/main.cpp @@ -0,0 +1 @@ +auto main() -> int { return 0; }