diff --git a/README.md b/README.md index 9168639beb..f0775cdeab 100644 --- a/README.md +++ b/README.md @@ -401,6 +401,7 @@ User can add a STM32 based board following this [wiki](https://github.com/stm32d | :green_heart: | STM32L4S9ZIJx | Generic Board | *2.0.0* | | | :yellow_heart: | STM32L4S9ZIYx | Generic Board | **2.1.0** | | | :yellow_heart: | STM32L4R5ZIYx | Swan R5 | **2.1.0** | [Blues Wireless](https://blues.io/) | +| :green_heart: | STM32L433CBUx | [Rotray Encoder board] | *1.0.0* | | ### Generic STM32L5 boards diff --git a/boards.txt b/boards.txt index 43472518ac..d7c521d512 100644 --- a/boards.txt +++ b/boards.txt @@ -4507,6 +4507,14 @@ GenL4.build.flags.fp=-mfpu=fpv4-sp-d16 -mfloat-abi=hard GenL4.build.series=STM32L4xx GenL4.build.cmsis_lib_gcc=arm_cortexM4lf_math +#Rotary Encoder +GenL4.menu.pnum.Rotary_Encoder=Rotary Encoder +GenL4.menu.pnum.Rotary_Encoder.upload.maximum_size=262144 +GenL4.menu.pnum.Rotary_Encoder.upload.maximum_data_size=65536 +GenL4.menu.pnum.Rotary_Encoder.build.board=GENERIC_L433CCUX +GenL4.menu.pnum.Rotary_Encoder.build.product_line=STM32L433xx +GenL4.menu.pnum.Rotary_Encoder.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + # Swan R5 GenL4.menu.pnum.SWAN_R5=Swan R5 GenL4.menu.pnum.SWAN_R5.upload.maximum_size=2097152 diff --git a/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/boards_entry.txt b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/boards_entry.txt index a8d6639660..00a6f024bd 100644 --- a/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/boards_entry.txt +++ b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/boards_entry.txt @@ -51,3 +51,63 @@ GenL4.menu.pnum.GENERIC_L443CCUX.build.board=GENERIC_L443CCUX GenL4.menu.pnum.GENERIC_L443CCUX.build.product_line=STM32L443xx GenL4.menu.pnum.GENERIC_L443CCUX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) +# This file help to add generic board entry. +# upload.maximum_size and product_line have to be verified +# and changed if needed. +# See: https://github.com/stm32duino/wiki/wiki/Add-a-new-variant-%28board%29 + +# Generic L433CBTx +GenL4.menu.pnum.GENERIC_L433CBTX=Generic L433CBTx +GenL4.menu.pnum.GENERIC_L433CBTX.upload.maximum_size=131072 +GenL4.menu.pnum.GENERIC_L433CBTX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L433CBTX.build.board=GENERIC_L433CBTX +GenL4.menu.pnum.GENERIC_L433CBTX.build.product_line=STM32L433xx +GenL4.menu.pnum.GENERIC_L433CBTX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +# Generic L433CCTx +GenL4.menu.pnum.GENERIC_L433CCTX=Generic L433CCTx +GenL4.menu.pnum.GENERIC_L433CCTX.upload.maximum_size=262144 +GenL4.menu.pnum.GENERIC_L433CCTX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L433CCTX.build.board=GENERIC_L433CCTX +GenL4.menu.pnum.GENERIC_L433CCTX.build.product_line=STM32L433xx +GenL4.menu.pnum.GENERIC_L433CCTX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +# Generic L433CBUx +GenL4.menu.pnum.GENERIC_L433CBUX=Generic L433CBUx +GenL4.menu.pnum.GENERIC_L433CBUX.upload.maximum_size=131072 +GenL4.menu.pnum.GENERIC_L433CBUX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L433CBUX.build.board=GENERIC_L433CBUX +GenL4.menu.pnum.GENERIC_L433CBUX.build.product_line=STM32L433xx +GenL4.menu.pnum.GENERIC_L433CBUX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +# Generic L433CCUx +GenL4.menu.pnum.GENERIC_L433CCUX=Generic L433CCUx +GenL4.menu.pnum.GENERIC_L433CCUX.upload.maximum_size=262144 +GenL4.menu.pnum.GENERIC_L433CCUX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L433CCUX.build.board=GENERIC_L433CCUX +GenL4.menu.pnum.GENERIC_L433CCUX.build.product_line=STM32L433xx +GenL4.menu.pnum.GENERIC_L433CCUX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +# Generic L443CCTx +GenL4.menu.pnum.GENERIC_L443CCTX=Generic L443CCTx +GenL4.menu.pnum.GENERIC_L443CCTX.upload.maximum_size=262144 +GenL4.menu.pnum.GENERIC_L443CCTX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L443CCTX.build.board=GENERIC_L443CCTX +GenL4.menu.pnum.GENERIC_L443CCTX.build.product_line=STM32L443xx +GenL4.menu.pnum.GENERIC_L443CCTX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +# Generic L443CCUx +GenL4.menu.pnum.GENERIC_L443CCUX=Generic L443CCUx +GenL4.menu.pnum.GENERIC_L443CCUX.upload.maximum_size=262144 +GenL4.menu.pnum.GENERIC_L443CCUX.upload.maximum_data_size=65536 +GenL4.menu.pnum.GENERIC_L443CCUX.build.board=GENERIC_L443CCUX +GenL4.menu.pnum.GENERIC_L443CCUX.build.product_line=STM32L443xx +GenL4.menu.pnum.GENERIC_L443CCUX.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) + +#Rotary Encoder +GenL4.menu.pnum.Rotary_Encoder=Rotary Encoder +GenL4.menu.pnum.Rotary_Encoder.upload.maximum_size=262144 +GenL4.menu.pnum.Rotary_Encoder.upload.maximum_data_size=65536 +GenL4.menu.pnum.Rotary_Encoder.build.board=GENERIC_L433CCUX +GenL4.menu.pnum.Rotary_Encoder.build.product_line=STM32L433xx +GenL4.menu.pnum.Rotary_Encoder.build.variant=STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U) diff --git a/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/generic_clock.c b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/generic_clock.c index 3bf8af493c..9395bc8189 100644 --- a/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/generic_clock.c +++ b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/generic_clock.c @@ -22,8 +22,71 @@ */ WEAK void SystemClock_Config(void) { - /* SystemClock_Config can be generated by STM32CubeMX */ -#warning "SystemClock_Config() is empty. Default clock at reset is used." + RCC_OscInitTypeDef RCC_OscInitStruct = {0}; + RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; + RCC_PeriphCLKInitTypeDef PeriphClkInit = {0}; + + /** Configure LSE Drive Capability + */ + HAL_PWR_EnableBkUpAccess(); + __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_LOW); + /** Initializes the RCC Oscillators according to the specified parameters + * in the RCC_OscInitTypeDef structure. + */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSE | RCC_OSCILLATORTYPE_MSI; + RCC_OscInitStruct.LSEState = RCC_LSE_ON; + RCC_OscInitStruct.MSIState = RCC_MSI_ON; + RCC_OscInitStruct.MSICalibrationValue = 0; + RCC_OscInitStruct.MSIClockRange = RCC_MSIRANGE_6; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; + RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_MSI; + RCC_OscInitStruct.PLL.PLLM = 1; + RCC_OscInitStruct.PLL.PLLN = 40; + RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7; + RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2; + RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2; + if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) + { + Error_Handler(); + } + /** Initializes the CPU, AHB and APB buses clocks + */ + RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK + | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2; + RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; + RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; + RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1; + RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; + + if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK) + { + Error_Handler(); + } + PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USB; + PeriphClkInit.UsbClockSelection = RCC_USBCLKSOURCE_PLLSAI1; + PeriphClkInit.PLLSAI1.PLLSAI1Source = RCC_PLLSOURCE_MSI; + PeriphClkInit.PLLSAI1.PLLSAI1M = 1; + PeriphClkInit.PLLSAI1.PLLSAI1N = 24; + PeriphClkInit.PLLSAI1.PLLSAI1P = RCC_PLLP_DIV7; + PeriphClkInit.PLLSAI1.PLLSAI1Q = RCC_PLLQ_DIV2; + PeriphClkInit.PLLSAI1.PLLSAI1R = RCC_PLLR_DIV2; + PeriphClkInit.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_48M2CLK; + if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK) { + Error_Handler(); + } + /** Configure the main internal regulator output voltage + */ + if (HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK) { + Error_Handler(); + } + /** Enable MSI Auto calibration + */ + HAL_RCCEx_EnableMSIPLLMode(); + + /* GPIO Ports Clock Enable */ + __HAL_RCC_GPIOC_CLK_ENABLE(); + __HAL_RCC_GPIOA_CLK_ENABLE(); + __HAL_RCC_GPIOB_CLK_ENABLE(); } #endif /* ARDUINO_GENERIC_* */ diff --git a/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/ldscript.ld b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/ldscript.ld new file mode 100644 index 0000000000..d9ff10fcfa --- /dev/null +++ b/variants/STM32L4xx/L433C(B-C)(T-U)_L443CC(T-U)/ldscript.ld @@ -0,0 +1,177 @@ +/** + ****************************************************************************** + * @file LinkerScript.ld + * @author Auto-generated by STM32CubeIDE + * @brief Linker script for STM32L433CBUx Device from STM32L4 series + * 128Kbytes FLASH + * 64Kbytes RAM + * + * Set heap size, stack size and stack location according + * to application requirements. + * + * Set memory bank area and size if external memory is used + ****************************************************************************** + * @attention + * + *