stm32: Add an MACH_STM32F4x5 alias for F405, F407, and F429 chips
The F405, F407, and F429 chips are in the same series and almost all code definitions should apply to all chips in that series. Implement the alias and fix defintions in adc.c and Kconfig that were only applying to a subset of that series. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
c1136bef10
commit
e3905eb241
|
@ -37,12 +37,15 @@ choice
|
|||
config MACH_STM32F405
|
||||
bool "STM32F405"
|
||||
select MACH_STM32F4
|
||||
select MACH_STM32F4x5
|
||||
config MACH_STM32F407
|
||||
bool "STM32F407"
|
||||
select MACH_STM32F4
|
||||
select MACH_STM32F4x5
|
||||
config MACH_STM32F429
|
||||
bool "STM32F429"
|
||||
select MACH_STM32F4
|
||||
select MACH_STM32F4x5
|
||||
config MACH_STM32F446
|
||||
bool "STM32F446"
|
||||
select MACH_STM32F4
|
||||
|
@ -72,6 +75,8 @@ config MACH_STM32F2
|
|||
bool
|
||||
config MACH_STM32F4
|
||||
bool
|
||||
config MACH_STM32F4x5 # F405, F407, F429 series
|
||||
bool
|
||||
config MACH_STM32H7
|
||||
bool
|
||||
config HAVE_STM32_USBFS
|
||||
|
@ -106,7 +111,7 @@ config CLOCK_FREQ
|
|||
default 72000000 if MACH_STM32F103
|
||||
default 120000000 if MACH_STM32F207
|
||||
default 84000000 if MACH_STM32F401
|
||||
default 168000000 if MACH_STM32F405 || MACH_STM32F407 || MACH_STM32F429
|
||||
default 168000000 if MACH_STM32F4x5
|
||||
default 180000000 if MACH_STM32F446
|
||||
default 480000000 if MACH_STM32H750
|
||||
|
||||
|
@ -117,7 +122,7 @@ config FLASH_SIZE
|
|||
default 0x20000 if MACH_STM32F070 || MACH_STM32F072
|
||||
default 0x10000 if MACH_STM32F103 # Flash size of stm32f103x8 (64KiB)
|
||||
default 0x40000 if MACH_STM32F2 || MACH_STM32F401
|
||||
default 0x80000 if MACH_STM32F405 || MACH_STM32F407 || MACH_STM32F429 || MACH_STM32F446
|
||||
default 0x80000 if MACH_STM32F4x5 || MACH_STM32F446
|
||||
default 0x20000 if MACH_STM32H7 # Flash size of stm32h750 (128KiB)
|
||||
|
||||
config RAM_START
|
||||
|
@ -132,7 +137,7 @@ config RAM_SIZE
|
|||
default 0x5000 if MACH_STM32F103 # Ram size of stm32f103x8 (20KiB)
|
||||
default 0x20000 if MACH_STM32F207
|
||||
default 0x10000 if MACH_STM32F401
|
||||
default 0x20000 if MACH_STM32F405 || MACH_STM32F407 || MACH_STM32F429 || MACH_STM32F446
|
||||
default 0x20000 if MACH_STM32F4x5 || MACH_STM32F446
|
||||
default 0x20000 if MACH_STM32H7
|
||||
|
||||
config STACK_SIZE
|
||||
|
@ -145,7 +150,7 @@ config STACK_SIZE
|
|||
######################################################################
|
||||
|
||||
choice
|
||||
prompt "Bootloader offset" if MACH_STM32F207 || MACH_STM32F401 || MACH_STM32F407 || MACH_STM32F405 || MACH_STM32F446 || MACH_STM32F103 || MACH_STM32F070
|
||||
prompt "Bootloader offset" if MACH_STM32F1 || MACH_STM32F2 || MACH_STM32F4 || MACH_STM32F070
|
||||
config STM32_FLASH_START_2000
|
||||
bool "8KiB bootloader (stm32duino)" if MACH_STM32F103 || MACH_STM32F070
|
||||
config STM32_FLASH_START_5000
|
||||
|
@ -153,20 +158,20 @@ choice
|
|||
config STM32_FLASH_START_7000
|
||||
bool "28KiB bootloader" if MACH_STM32F103
|
||||
config STM32_FLASH_START_8000
|
||||
bool "32KiB bootloader" if MACH_STM32F207 || MACH_STM32F407 || MACH_STM32F446
|
||||
bool "32KiB bootloader" if MACH_STM32F207 || MACH_STM32F4x5 || MACH_STM32F446
|
||||
config STM32_FLASH_START_8800
|
||||
bool "34KiB bootloader (Chitu v6 Bootloader)" if MACH_STM32F103
|
||||
config STM32_FLASH_START_20200
|
||||
bool "128KiB bootloader with 512 byte offset (Prusa Buddy)" if MACH_STM32F407
|
||||
bool "128KiB bootloader with 512 byte offset (Prusa Buddy)" if MACH_STM32F4x5
|
||||
config STM32_FLASH_START_C000
|
||||
bool "48KiB bootloader (MKS Robin Nano V3)" if MACH_STM32F407
|
||||
bool "48KiB bootloader (MKS Robin Nano V3)" if MACH_STM32F4x5
|
||||
config STM32_FLASH_START_10000
|
||||
bool "64KiB bootloader" if MACH_STM32F103 || MACH_STM32F446
|
||||
|
||||
config STM32_FLASH_START_800
|
||||
bool "2KiB bootloader (HID Bootloader)" if MACH_STM32F103
|
||||
config STM32_FLASH_START_4000
|
||||
bool "16KiB bootloader (HID Bootloader)" if MACH_STM32F207 || MACH_STM32F401 || MACH_STM32F405 || MACH_STM32F407 || MACH_STM32F103
|
||||
bool "16KiB bootloader (HID Bootloader)" if MACH_STM32F207 || MACH_STM32F401 || MACH_STM32F4x5 || MACH_STM32F103
|
||||
|
||||
config STM32_FLASH_START_0000
|
||||
bool "No bootloader"
|
||||
|
|
|
@ -26,13 +26,13 @@ static const uint8_t adc_pins[] = {
|
|||
|
||||
#if CONFIG_MACH_STM32F1
|
||||
ADC_TEMPERATURE_PIN,
|
||||
#elif CONFIG_MACH_STM32F2 || CONFIG_MACH_STM32F405 || CONFIG_MACH_STM32F407
|
||||
#elif CONFIG_MACH_STM32F2 || CONFIG_MACH_STM32F4x5
|
||||
ADC_TEMPERATURE_PIN, 0x00, 0x00,
|
||||
#elif CONFIG_MACH_STM32F446
|
||||
0x00, 0x00, ADC_TEMPERATURE_PIN,
|
||||
#endif
|
||||
|
||||
#if CONFIG_MACH_STM32F405 || CONFIG_MACH_STM32F407 || CONFIG_MACH_STM32F446
|
||||
#if CONFIG_MACH_STM32F4x5 || CONFIG_MACH_STM32F446
|
||||
0x00, 0x00, 0x00, 0x00,
|
||||
GPIO('F', 6), GPIO('F', 7), GPIO('F', 8), GPIO('F', 9),
|
||||
GPIO('F', 10), GPIO('F', 3), 0x00, 0x00,
|
||||
|
@ -83,7 +83,7 @@ gpio_adc_setup(uint32_t pin)
|
|||
// Determine which ADC block to use
|
||||
ADC_TypeDef *adc = ADC1;
|
||||
uint32_t adc_base = ADC1_BASE;
|
||||
#if CONFIG_MACH_STM32F405 || CONFIG_MACH_STM32F407 || CONFIG_MACH_STM32F446
|
||||
#if CONFIG_MACH_STM32F4x5 || CONFIG_MACH_STM32F446
|
||||
if (chan >= 19) {
|
||||
// On the STM32F4, some ADC channels are only available from ADC3
|
||||
adc = ADC3;
|
||||
|
|
|
@ -144,8 +144,7 @@ enable_clock_stm32f20x(void)
|
|||
static void
|
||||
enable_clock_stm32f40x(void)
|
||||
{
|
||||
#if CONFIG_MACH_STM32F405 || CONFIG_MACH_STM32F407 \
|
||||
|| CONFIG_MACH_STM32F401 || CONFIG_MACH_STM32F429
|
||||
#if CONFIG_MACH_STM32F401 || CONFIG_MACH_STM32F4x5
|
||||
uint32_t pll_base = (CONFIG_STM32_CLOCK_REF_25M) ? 1000000 : 2000000;
|
||||
uint32_t pllp = (CONFIG_MACH_STM32F401) ? 4 : 2;
|
||||
uint32_t pll_freq = CONFIG_CLOCK_FREQ * pllp, pllcfgr;
|
||||
|
@ -222,8 +221,7 @@ clock_setup(void)
|
|||
// Configure and enable PLL
|
||||
if (CONFIG_MACH_STM32F207)
|
||||
enable_clock_stm32f20x();
|
||||
else if (CONFIG_MACH_STM32F405 || CONFIG_MACH_STM32F407
|
||||
|| CONFIG_MACH_STM32F401 || CONFIG_MACH_STM32F429)
|
||||
else if (CONFIG_MACH_STM32F401 || CONFIG_MACH_STM32F4x5)
|
||||
enable_clock_stm32f40x();
|
||||
else
|
||||
enable_clock_stm32f446();
|
||||
|
|
Loading…
Reference in New Issue