2019-07-29 06:15:54 +03:00
|
|
|
# Kconfig settings for STM32 processors
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2019-07-29 06:15:54 +03:00
|
|
|
if MACH_STM32
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2019-07-29 06:15:54 +03:00
|
|
|
config STM32_SELECT
|
2019-07-24 06:51:31 +03:00
|
|
|
bool
|
|
|
|
default y
|
2019-07-25 21:55:10 +03:00
|
|
|
select HAVE_GPIO
|
2021-12-20 05:30:33 +03:00
|
|
|
select HAVE_GPIO_ADC
|
2023-06-08 03:55:46 +03:00
|
|
|
select HAVE_GPIO_I2C if !MACH_STM32F031
|
2021-12-19 21:18:44 +03:00
|
|
|
select HAVE_GPIO_SPI if !MACH_STM32F031
|
2023-02-21 03:52:36 +03:00
|
|
|
select HAVE_GPIO_SDIO if MACH_STM32F4
|
2023-12-06 01:44:51 +03:00
|
|
|
select HAVE_GPIO_HARD_PWM if MACH_STM32F070 || MACH_STM32F072 || MACH_STM32F1 || MACH_STM32F4 || MACH_STM32F7 || MACH_STM32G0 || MACH_STM32H7
|
2020-05-25 07:27:18 +03:00
|
|
|
select HAVE_STRICT_TIMING
|
2019-11-25 08:25:57 +03:00
|
|
|
select HAVE_CHIPID
|
2021-10-29 00:10:10 +03:00
|
|
|
select HAVE_STEPPER_BOTH_EDGE
|
2022-12-19 19:54:19 +03:00
|
|
|
select HAVE_BOOTLOADER_REQUEST
|
2023-06-08 18:20:59 +03:00
|
|
|
select HAVE_LIMITED_CODE_SIZE if MACH_STM32F031 || MACH_STM32F042
|
2019-07-24 06:51:31 +03:00
|
|
|
|
|
|
|
config BOARD_DIRECTORY
|
|
|
|
string
|
2019-07-29 06:15:54 +03:00
|
|
|
default "stm32"
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2021-03-18 20:20:54 +03:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Chip selection
|
|
|
|
######################################################################
|
|
|
|
|
2019-07-27 23:43:35 +03:00
|
|
|
choice
|
|
|
|
prompt "Processor model"
|
2019-07-28 21:40:41 +03:00
|
|
|
config MACH_STM32F103
|
|
|
|
bool "STM32F103"
|
2019-07-29 06:15:54 +03:00
|
|
|
select MACH_STM32F1
|
2020-06-23 17:52:15 +03:00
|
|
|
config MACH_STM32F207
|
|
|
|
bool "STM32F207"
|
|
|
|
select MACH_STM32F2
|
2021-02-01 03:41:53 +03:00
|
|
|
config MACH_STM32F401
|
|
|
|
bool "STM32F401"
|
|
|
|
select MACH_STM32F4
|
2019-07-27 23:43:35 +03:00
|
|
|
config MACH_STM32F405
|
|
|
|
bool "STM32F405"
|
2019-07-29 06:15:54 +03:00
|
|
|
select MACH_STM32F4
|
2021-10-07 02:48:03 +03:00
|
|
|
select MACH_STM32F4x5
|
2019-07-27 23:43:35 +03:00
|
|
|
config MACH_STM32F407
|
|
|
|
bool "STM32F407"
|
2019-07-29 06:15:54 +03:00
|
|
|
select MACH_STM32F4
|
2021-10-07 02:48:03 +03:00
|
|
|
select MACH_STM32F4x5
|
2021-02-19 04:12:32 +03:00
|
|
|
config MACH_STM32F429
|
|
|
|
bool "STM32F429"
|
|
|
|
select MACH_STM32F4
|
2021-10-07 02:48:03 +03:00
|
|
|
select MACH_STM32F4x5
|
2019-07-27 23:43:35 +03:00
|
|
|
config MACH_STM32F446
|
|
|
|
bool "STM32F446"
|
2019-07-29 06:15:54 +03:00
|
|
|
select MACH_STM32F4
|
2023-03-06 03:15:43 +03:00
|
|
|
config MACH_STM32F765
|
|
|
|
bool "STM32F765"
|
|
|
|
select MACH_STM32F7
|
2021-02-03 20:23:17 +03:00
|
|
|
config MACH_STM32F031
|
|
|
|
bool "STM32F031"
|
|
|
|
select MACH_STM32F0
|
2019-09-17 04:39:29 +03:00
|
|
|
config MACH_STM32F042
|
|
|
|
bool "STM32F042"
|
|
|
|
select MACH_STM32F0
|
2021-10-13 18:25:41 +03:00
|
|
|
select MACH_STM32F0x2
|
2019-09-16 18:45:36 +03:00
|
|
|
config MACH_STM32F070
|
|
|
|
bool "STM32F070"
|
|
|
|
select MACH_STM32F0
|
2021-06-28 03:35:34 +03:00
|
|
|
config MACH_STM32F072
|
|
|
|
bool "STM32F072"
|
|
|
|
select MACH_STM32F0
|
2021-10-13 18:25:41 +03:00
|
|
|
select MACH_STM32F0x2
|
2023-01-03 20:43:46 +03:00
|
|
|
config MACH_STM32G070
|
|
|
|
bool "STM32G070"
|
|
|
|
select MACH_STM32G0
|
|
|
|
select MACH_STM32G07x
|
|
|
|
config MACH_STM32G071
|
|
|
|
bool "STM32G071"
|
|
|
|
select MACH_STM32G0
|
|
|
|
select MACH_STM32G07x
|
2022-12-13 00:14:09 +03:00
|
|
|
config MACH_STM32G0B0
|
|
|
|
bool "STM32G0B0"
|
|
|
|
select MACH_STM32G0
|
|
|
|
select MACH_STM32G0Bx
|
2021-12-19 03:11:17 +03:00
|
|
|
config MACH_STM32G0B1
|
|
|
|
bool "STM32G0B1"
|
|
|
|
select MACH_STM32G0
|
2022-12-13 00:14:09 +03:00
|
|
|
select MACH_STM32G0Bx
|
2022-09-22 07:45:51 +03:00
|
|
|
config MACH_STM32G431
|
|
|
|
bool "STM32G431"
|
|
|
|
select MACH_STM32G4
|
2022-11-23 06:29:44 +03:00
|
|
|
config MACH_STM32H723
|
|
|
|
bool "STM32H723"
|
|
|
|
select MACH_STM32H7
|
2021-10-28 06:25:21 +03:00
|
|
|
config MACH_STM32H743
|
|
|
|
bool "STM32H743"
|
|
|
|
select MACH_STM32H7
|
2021-05-30 03:19:39 +03:00
|
|
|
config MACH_STM32H750
|
|
|
|
bool "STM32H750"
|
|
|
|
select MACH_STM32H7
|
2021-04-22 23:44:39 +03:00
|
|
|
config MACH_STM32L412
|
|
|
|
bool "STM32L412"
|
|
|
|
select MACH_STM32L4
|
2023-04-07 19:20:14 +03:00
|
|
|
config MACH_N32G452
|
|
|
|
bool "Nation N32G452"
|
|
|
|
select MACH_N32G45x
|
|
|
|
select MACH_STM32F1
|
|
|
|
config MACH_N32G455
|
|
|
|
bool "Nation N32G455"
|
|
|
|
select MACH_N32G45x
|
|
|
|
select MACH_STM32F1
|
2019-07-27 23:43:35 +03:00
|
|
|
endchoice
|
|
|
|
|
2022-06-20 19:37:23 +03:00
|
|
|
config MACH_STM32F103x6
|
|
|
|
depends on LOW_LEVEL_OPTIONS && MACH_STM32F103
|
|
|
|
bool "Only 10KiB of RAM (for rare stm32f103x6 variant)"
|
|
|
|
|
2019-09-16 18:45:36 +03:00
|
|
|
config MACH_STM32F0
|
|
|
|
bool
|
2019-07-29 06:15:54 +03:00
|
|
|
config MACH_STM32F1
|
2019-07-28 21:40:41 +03:00
|
|
|
bool
|
2020-06-23 17:52:15 +03:00
|
|
|
config MACH_STM32F2
|
|
|
|
bool
|
2019-07-29 06:15:54 +03:00
|
|
|
config MACH_STM32F4
|
2019-07-28 21:40:41 +03:00
|
|
|
bool
|
2023-03-06 03:15:43 +03:00
|
|
|
config MACH_STM32F7
|
|
|
|
bool
|
2021-12-19 03:11:17 +03:00
|
|
|
config MACH_STM32G0
|
|
|
|
bool
|
2023-01-03 20:43:46 +03:00
|
|
|
config MACH_STM32G07x
|
|
|
|
bool
|
2022-12-13 00:14:09 +03:00
|
|
|
config MACH_STM32G0Bx
|
|
|
|
bool
|
2022-09-22 07:45:51 +03:00
|
|
|
config MACH_STM32G4
|
|
|
|
bool
|
2021-05-30 03:19:39 +03:00
|
|
|
config MACH_STM32H7
|
|
|
|
bool
|
2021-10-13 18:25:41 +03:00
|
|
|
config MACH_STM32F0x2 # F042, F072 series
|
|
|
|
bool
|
|
|
|
config MACH_STM32F4x5 # F405, F407, F429 series
|
|
|
|
bool
|
2021-04-22 23:44:39 +03:00
|
|
|
config MACH_STM32L4
|
|
|
|
bool
|
2023-04-07 19:20:14 +03:00
|
|
|
config MACH_N32G45x
|
|
|
|
bool
|
2019-07-29 01:26:22 +03:00
|
|
|
config HAVE_STM32_USBFS
|
|
|
|
bool
|
2022-12-15 19:44:12 +03:00
|
|
|
default y if MACH_STM32F0x2 || MACH_STM32G0Bx || MACH_STM32L4 || MACH_STM32G4
|
2023-04-07 19:20:14 +03:00
|
|
|
default y if (MACH_STM32F1 || MACH_STM32F070) && !STM32_CLOCK_REF_INTERNAL
|
2019-08-12 05:40:28 +03:00
|
|
|
config HAVE_STM32_USBOTG
|
|
|
|
bool
|
2023-03-06 03:15:43 +03:00
|
|
|
default y if MACH_STM32F2 || MACH_STM32F4 || MACH_STM32F7 || MACH_STM32H7
|
2021-03-18 20:20:54 +03:00
|
|
|
config HAVE_STM32_CANBUS
|
|
|
|
bool
|
2022-01-08 06:17:26 +03:00
|
|
|
default y if MACH_STM32F1 || MACH_STM32F2 || MACH_STM32F4x5 || MACH_STM32F446 || MACH_STM32F0x2
|
2022-06-01 17:43:45 +03:00
|
|
|
config HAVE_STM32_FDCANBUS
|
|
|
|
bool
|
2022-12-13 00:14:09 +03:00
|
|
|
default y if MACH_STM32G0B1 || MACH_STM32H7 || MACH_STM32G4
|
2022-06-09 04:03:11 +03:00
|
|
|
config HAVE_STM32_USBCANBUS
|
|
|
|
bool
|
|
|
|
depends on HAVE_STM32_USBFS || HAVE_STM32_USBOTG
|
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
2023-04-07 19:20:14 +03:00
|
|
|
depends on !MACH_STM32F1
|
2022-06-09 04:03:11 +03:00
|
|
|
default y
|
2019-07-28 21:40:41 +03:00
|
|
|
|
2019-07-27 23:43:35 +03:00
|
|
|
config MCU
|
|
|
|
string
|
2021-02-03 20:23:17 +03:00
|
|
|
default "stm32f031x6" if MACH_STM32F031
|
2019-09-17 04:39:29 +03:00
|
|
|
default "stm32f042x6" if MACH_STM32F042
|
2019-09-16 18:45:36 +03:00
|
|
|
default "stm32f070xb" if MACH_STM32F070
|
2021-06-28 03:35:34 +03:00
|
|
|
default "stm32f072xb" if MACH_STM32F072
|
2019-10-23 22:49:00 +03:00
|
|
|
default "stm32f103xe" if MACH_STM32F103
|
2020-06-23 17:52:15 +03:00
|
|
|
default "stm32f207xx" if MACH_STM32F207
|
2021-02-01 03:41:53 +03:00
|
|
|
default "stm32f401xc" if MACH_STM32F401
|
2019-07-28 21:40:41 +03:00
|
|
|
default "stm32f405xx" if MACH_STM32F405
|
|
|
|
default "stm32f407xx" if MACH_STM32F407
|
2021-02-19 04:12:32 +03:00
|
|
|
default "stm32f429xx" if MACH_STM32F429
|
2019-07-28 21:40:41 +03:00
|
|
|
default "stm32f446xx" if MACH_STM32F446
|
2023-03-06 03:15:43 +03:00
|
|
|
default "stm32f765xx" if MACH_STM32F765
|
2023-01-03 20:43:46 +03:00
|
|
|
default "stm32g070xx" if MACH_STM32G070
|
|
|
|
default "stm32g071xx" if MACH_STM32G071
|
2022-12-13 00:14:09 +03:00
|
|
|
default "stm32g0b0xx" if MACH_STM32G0B0
|
2021-12-19 03:11:17 +03:00
|
|
|
default "stm32g0b1xx" if MACH_STM32G0B1
|
2022-09-22 07:45:51 +03:00
|
|
|
default "stm32g431xx" if MACH_STM32G431
|
2022-11-23 06:29:44 +03:00
|
|
|
default "stm32h723xx" if MACH_STM32H723
|
2021-10-28 06:25:21 +03:00
|
|
|
default "stm32h743xx" if MACH_STM32H743
|
2021-05-30 03:19:39 +03:00
|
|
|
default "stm32h750xx" if MACH_STM32H750
|
2021-04-22 23:44:39 +03:00
|
|
|
default "stm32l412xx" if MACH_STM32L412
|
2023-04-07 19:20:14 +03:00
|
|
|
default "stm32f103xe" if MACH_N32G45x
|
2019-07-27 23:43:35 +03:00
|
|
|
|
2019-07-24 06:51:31 +03:00
|
|
|
config CLOCK_FREQ
|
|
|
|
int
|
2019-09-16 18:45:36 +03:00
|
|
|
default 48000000 if MACH_STM32F0
|
2020-02-14 20:10:10 +03:00
|
|
|
default 64000000 if MACH_STM32F103 && STM32_CLOCK_REF_INTERNAL
|
2019-07-28 21:40:41 +03:00
|
|
|
default 72000000 if MACH_STM32F103
|
2020-06-23 17:52:15 +03:00
|
|
|
default 120000000 if MACH_STM32F207
|
2021-02-01 03:41:53 +03:00
|
|
|
default 84000000 if MACH_STM32F401
|
2021-10-07 02:48:03 +03:00
|
|
|
default 168000000 if MACH_STM32F4x5
|
2021-02-19 19:29:12 +03:00
|
|
|
default 180000000 if MACH_STM32F446
|
2023-03-06 03:15:43 +03:00
|
|
|
default 216000000 if MACH_STM32F765
|
2021-12-19 03:11:17 +03:00
|
|
|
default 64000000 if MACH_STM32G0
|
2022-09-22 07:45:51 +03:00
|
|
|
default 150000000 if MACH_STM32G431
|
2021-11-21 02:09:29 +03:00
|
|
|
default 400000000 if MACH_STM32H7 # 400Mhz is max Klipper currently supports
|
2021-04-22 23:44:39 +03:00
|
|
|
default 80000000 if MACH_STM32L412
|
2023-04-07 19:20:14 +03:00
|
|
|
default 64000000 if MACH_N32G45x && STM32_CLOCK_REF_INTERNAL
|
|
|
|
default 128000000 if MACH_N32G45x
|
2019-07-27 23:43:35 +03:00
|
|
|
|
|
|
|
config FLASH_SIZE
|
|
|
|
hex
|
2021-02-03 20:23:17 +03:00
|
|
|
default 0x4000 if MACH_STM32F031
|
2019-09-17 04:39:29 +03:00
|
|
|
default 0x8000 if MACH_STM32F042
|
2021-06-28 03:35:34 +03:00
|
|
|
default 0x20000 if MACH_STM32F070 || MACH_STM32F072
|
2021-04-22 23:44:39 +03:00
|
|
|
default 0x10000 if MACH_STM32F103 || MACH_STM32L412 # Flash size of stm32f103x8 (64KiB)
|
2022-11-23 06:29:44 +03:00
|
|
|
default 0x40000 if MACH_STM32F2 || MACH_STM32F401 || MACH_STM32H723
|
2021-10-07 02:48:03 +03:00
|
|
|
default 0x80000 if MACH_STM32F4x5 || MACH_STM32F446
|
2022-12-13 00:14:09 +03:00
|
|
|
default 0x20000 if MACH_STM32G0 || MACH_STM32G431
|
2021-10-28 06:25:21 +03:00
|
|
|
default 0x20000 if MACH_STM32H750
|
2023-03-06 03:15:43 +03:00
|
|
|
default 0x200000 if MACH_STM32H743 || MACH_STM32F765
|
2023-04-07 19:20:14 +03:00
|
|
|
default 0x20000 if MACH_N32G45x
|
2019-07-27 23:43:35 +03:00
|
|
|
|
2022-11-03 19:41:28 +03:00
|
|
|
config FLASH_BOOT_ADDRESS
|
|
|
|
hex
|
|
|
|
default 0x8000000
|
|
|
|
|
2019-08-21 20:52:43 +03:00
|
|
|
config RAM_START
|
|
|
|
hex
|
|
|
|
default 0x20000000
|
|
|
|
|
2019-07-27 23:43:35 +03:00
|
|
|
config RAM_SIZE
|
|
|
|
hex
|
2021-02-03 20:23:17 +03:00
|
|
|
default 0x1000 if MACH_STM32F031
|
2019-09-17 04:39:29 +03:00
|
|
|
default 0x1800 if MACH_STM32F042
|
2021-06-28 03:35:34 +03:00
|
|
|
default 0x4000 if MACH_STM32F070 || MACH_STM32F072
|
2022-06-20 19:37:23 +03:00
|
|
|
default 0x2800 if MACH_STM32F103x6
|
|
|
|
default 0x5000 if MACH_STM32F103 && !MACH_STM32F103x6 # Ram size of stm32f103x8
|
2022-09-22 07:45:51 +03:00
|
|
|
default 0x8000 if MACH_STM32G431
|
2021-04-22 23:44:39 +03:00
|
|
|
default 0xa000 if MACH_STM32L412
|
2020-06-23 17:52:15 +03:00
|
|
|
default 0x20000 if MACH_STM32F207
|
2021-02-01 03:41:53 +03:00
|
|
|
default 0x10000 if MACH_STM32F401
|
2021-10-07 02:48:03 +03:00
|
|
|
default 0x20000 if MACH_STM32F4x5 || MACH_STM32F446
|
2023-03-06 03:15:43 +03:00
|
|
|
default 0x80000 if MACH_STM32F765
|
2023-01-03 20:43:46 +03:00
|
|
|
default 0x9000 if MACH_STM32G07x
|
2022-12-13 00:14:09 +03:00
|
|
|
default 0x24000 if MACH_STM32G0Bx
|
2022-10-22 03:50:09 +03:00
|
|
|
default 0x20000 if MACH_STM32H7
|
2023-04-07 19:20:14 +03:00
|
|
|
default 0x10000 if MACH_N32G45x
|
2019-07-27 23:43:35 +03:00
|
|
|
|
|
|
|
config STACK_SIZE
|
|
|
|
int
|
|
|
|
default 512
|
2019-07-24 06:51:31 +03:00
|
|
|
|
2021-11-24 19:15:22 +03:00
|
|
|
config STM32F103GD_DISABLE_SWD
|
|
|
|
bool "Disable SWD at startup (for GigaDevice stm32f103 clones)"
|
|
|
|
depends on MACH_STM32F103 && LOW_LEVEL_OPTIONS
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
The GigaDevice clone of the STM32F103 may not be able to
|
|
|
|
reliably disable SWD at run-time. This can prevent the PA13
|
|
|
|
and PA14 pins from being available. Selecting this option
|
|
|
|
disables SWD at startup and thus makes these pins available.
|
|
|
|
|
2022-12-15 19:23:28 +03:00
|
|
|
config STM32_DFU_ROM_ADDRESS
|
|
|
|
hex
|
|
|
|
default 0 if !USB
|
|
|
|
default 0x1fffc400 if MACH_STM32F042
|
|
|
|
default 0x1fffc800 if MACH_STM32F072
|
2023-03-06 03:15:43 +03:00
|
|
|
default 0x1fff0000 if MACH_STM32F4 || MACH_STM32F7 || MACH_STM32G0 || MACH_STM32G4 || MACH_STM32L4
|
2022-12-15 19:23:28 +03:00
|
|
|
default 0x1ff09800 if MACH_STM32H7
|
|
|
|
default 0
|
|
|
|
|
2021-03-18 20:20:54 +03:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Bootloader
|
|
|
|
######################################################################
|
|
|
|
|
2019-07-29 01:26:22 +03:00
|
|
|
choice
|
2021-12-19 03:11:17 +03:00
|
|
|
prompt "Bootloader offset"
|
2019-07-29 01:26:22 +03:00
|
|
|
config STM32_FLASH_START_2000
|
2023-04-07 19:20:14 +03:00
|
|
|
bool "8KiB bootloader" if MACH_STM32F1 || MACH_STM32F070 || MACH_STM32G0 || MACH_STM32F0x2
|
2020-06-20 20:30:10 +03:00
|
|
|
config STM32_FLASH_START_5000
|
|
|
|
bool "20KiB bootloader" if MACH_STM32F103
|
2019-07-29 01:26:22 +03:00
|
|
|
config STM32_FLASH_START_7000
|
2023-04-07 19:20:14 +03:00
|
|
|
bool "28KiB bootloader" if MACH_STM32F1
|
2021-05-21 02:12:09 +03:00
|
|
|
config STM32_FLASH_START_8000
|
2023-03-06 03:15:43 +03:00
|
|
|
bool "32KiB bootloader" if MACH_STM32F1 || MACH_STM32F2 || MACH_STM32F4 || MACH_STM32F7
|
2020-08-30 19:59:28 +03:00
|
|
|
config STM32_FLASH_START_8800
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "34KiB bootloader" if MACH_STM32F103
|
2021-06-06 22:51:35 +03:00
|
|
|
config STM32_FLASH_START_20200
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "128KiB bootloader with 512 byte offset" if MACH_STM32F4x5
|
2024-01-23 02:55:34 +03:00
|
|
|
config STM32_FLASH_START_9000
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "36KiB bootloader" if MACH_STM32F1
|
2021-02-20 17:37:43 +03:00
|
|
|
config STM32_FLASH_START_C000
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "48KiB bootloader" if MACH_STM32F4x5
|
2020-03-21 19:24:25 +03:00
|
|
|
config STM32_FLASH_START_10000
|
2023-11-01 19:26:12 +03:00
|
|
|
bool "64KiB bootloader" if MACH_STM32F103 || MACH_STM32F4
|
2021-05-21 02:12:09 +03:00
|
|
|
|
2020-10-12 17:48:33 +03:00
|
|
|
config STM32_FLASH_START_800
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "2KiB bootloader" if MACH_STM32F103
|
2022-06-09 01:25:10 +03:00
|
|
|
config STM32_FLASH_START_1000
|
|
|
|
bool "4KiB bootloader" if MACH_STM32F1 || MACH_STM32F0
|
2020-10-12 17:48:33 +03:00
|
|
|
config STM32_FLASH_START_4000
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "16KiB bootloader" if MACH_STM32F207 || MACH_STM32F401 || MACH_STM32F4x5 || MACH_STM32F103 || MACH_STM32F072
|
2021-10-28 06:25:21 +03:00
|
|
|
config STM32_FLASH_START_20000
|
2024-01-23 02:58:41 +03:00
|
|
|
bool "128KiB bootloader" if MACH_STM32H743 || MACH_STM32H723 || MACH_STM32F7
|
2020-10-12 17:48:33 +03:00
|
|
|
|
2019-07-29 01:26:22 +03:00
|
|
|
config STM32_FLASH_START_0000
|
|
|
|
bool "No bootloader"
|
|
|
|
endchoice
|
2022-12-15 02:44:07 +03:00
|
|
|
config FLASH_APPLICATION_ADDRESS
|
2019-07-29 01:26:22 +03:00
|
|
|
hex
|
2020-04-24 21:29:56 +03:00
|
|
|
default 0x8000800 if STM32_FLASH_START_800
|
2022-06-09 01:25:10 +03:00
|
|
|
default 0x8001000 if STM32_FLASH_START_1000
|
2019-08-21 20:52:43 +03:00
|
|
|
default 0x8002000 if STM32_FLASH_START_2000
|
2020-04-25 21:20:25 +03:00
|
|
|
default 0x8004000 if STM32_FLASH_START_4000
|
2020-06-20 20:30:10 +03:00
|
|
|
default 0x8005000 if STM32_FLASH_START_5000
|
2019-08-21 20:52:43 +03:00
|
|
|
default 0x8007000 if STM32_FLASH_START_7000
|
|
|
|
default 0x8008000 if STM32_FLASH_START_8000
|
2020-08-30 19:59:28 +03:00
|
|
|
default 0x8008800 if STM32_FLASH_START_8800
|
2024-01-23 02:55:34 +03:00
|
|
|
default 0x8009000 if STM32_FLASH_START_9000
|
2021-02-20 17:37:43 +03:00
|
|
|
default 0x800C000 if STM32_FLASH_START_C000
|
2020-03-21 19:24:25 +03:00
|
|
|
default 0x8010000 if STM32_FLASH_START_10000
|
2021-10-28 06:25:21 +03:00
|
|
|
default 0x8020000 if STM32_FLASH_START_20000
|
2021-06-06 22:51:35 +03:00
|
|
|
default 0x8020200 if STM32_FLASH_START_20200
|
2019-08-21 20:52:43 +03:00
|
|
|
default 0x8000000
|
2019-07-29 01:26:22 +03:00
|
|
|
|
2019-12-10 05:03:05 +03:00
|
|
|
config ARMCM_RAM_VECTORTABLE
|
|
|
|
bool
|
2022-12-15 02:44:07 +03:00
|
|
|
default y if MACH_STM32F0 && FLASH_APPLICATION_ADDRESS != 0x8000000
|
2019-12-10 05:03:05 +03:00
|
|
|
default n
|
|
|
|
|
2021-03-18 20:20:54 +03:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Clock
|
|
|
|
######################################################################
|
|
|
|
|
2019-07-26 06:50:12 +03:00
|
|
|
choice
|
2019-07-29 05:42:41 +03:00
|
|
|
prompt "Clock Reference" if LOW_LEVEL_OPTIONS
|
|
|
|
config STM32_CLOCK_REF_8M
|
2019-12-18 19:13:26 +03:00
|
|
|
bool "8 MHz crystal"
|
2019-11-25 22:00:30 +03:00
|
|
|
config STM32_CLOCK_REF_12M
|
2019-12-18 19:13:26 +03:00
|
|
|
bool "12 MHz crystal"
|
2019-11-25 22:00:30 +03:00
|
|
|
config STM32_CLOCK_REF_16M
|
2019-12-18 19:13:26 +03:00
|
|
|
bool "16 MHz crystal"
|
2021-04-22 23:44:39 +03:00
|
|
|
config STM32_CLOCK_REF_20M
|
|
|
|
bool "20 MHz crystal"
|
2023-03-06 03:15:43 +03:00
|
|
|
config STM32_CLOCK_REF_24M
|
|
|
|
bool "24 MHz crystal"
|
2021-02-19 04:12:32 +03:00
|
|
|
config STM32_CLOCK_REF_25M
|
|
|
|
bool "25 MHz crystal"
|
2019-07-29 05:42:41 +03:00
|
|
|
config STM32_CLOCK_REF_INTERNAL
|
2019-07-26 06:50:12 +03:00
|
|
|
bool "Internal clock"
|
|
|
|
endchoice
|
2019-11-25 22:00:30 +03:00
|
|
|
config CLOCK_REF_FREQ
|
|
|
|
int
|
2021-02-19 04:12:32 +03:00
|
|
|
default 25000000 if STM32_CLOCK_REF_25M
|
2023-03-06 03:15:43 +03:00
|
|
|
default 24000000 if STM32_CLOCK_REF_24M
|
2021-04-22 23:44:39 +03:00
|
|
|
default 20000000 if STM32_CLOCK_REF_20M
|
2019-11-25 22:00:30 +03:00
|
|
|
default 16000000 if STM32_CLOCK_REF_16M
|
|
|
|
default 12000000 if STM32_CLOCK_REF_12M
|
|
|
|
default 1 if STM32_CLOCK_REF_INTERNAL
|
|
|
|
default 8000000
|
2019-07-26 06:50:12 +03:00
|
|
|
|
2021-01-18 20:47:59 +03:00
|
|
|
config STM32F0_TRIM
|
|
|
|
int "Internal clock trim override" if LOW_LEVEL_OPTIONS && MACH_STM32F0 && STM32_CLOCK_REF_INTERNAL && !USBSERIAL
|
|
|
|
default 16
|
|
|
|
help
|
|
|
|
Specify the internal clock trim value. Setting this can be
|
|
|
|
useful if the factory default internal clock is not accurate.
|
|
|
|
Default is 16 (use factory default). Each increment increases
|
|
|
|
the clock rate by ~240KHz.
|
|
|
|
|
2021-03-18 20:20:54 +03:00
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Communication inteface
|
|
|
|
######################################################################
|
|
|
|
|
2019-07-29 05:27:32 +03:00
|
|
|
choice
|
2021-03-18 20:20:54 +03:00
|
|
|
prompt "Communication interface"
|
|
|
|
config STM32_USB_PA11_PA12
|
|
|
|
bool "USB (on PA11/PA12)" if HAVE_STM32_USBFS || HAVE_STM32_USBOTG
|
|
|
|
select USBSERIAL
|
|
|
|
config STM32_USB_PA11_PA12_REMAP
|
|
|
|
bool "USB (on PA9/PA10)" if LOW_LEVEL_OPTIONS && MACH_STM32F042
|
|
|
|
select USBSERIAL
|
2021-10-28 06:43:47 +03:00
|
|
|
config STM32_USB_PB14_PB15
|
|
|
|
bool "USB (on PB14/PB15)"
|
2022-11-23 06:29:44 +03:00
|
|
|
depends on MACH_STM32H743 || MACH_STM32H750
|
2021-10-28 06:43:47 +03:00
|
|
|
select USBSERIAL
|
2019-07-29 05:27:32 +03:00
|
|
|
config STM32_SERIAL_USART1
|
2021-03-18 20:20:54 +03:00
|
|
|
bool "Serial (on USART1 PA10/PA9)"
|
|
|
|
select SERIAL
|
2021-05-25 04:17:51 +03:00
|
|
|
config STM32_SERIAL_USART1_ALT_PB7_PB6
|
2021-08-01 20:23:45 +03:00
|
|
|
bool "Serial (on USART1 PB7/PB6)" if LOW_LEVEL_OPTIONS
|
2021-05-25 04:17:51 +03:00
|
|
|
select SERIAL
|
2019-07-29 05:27:32 +03:00
|
|
|
config STM32_SERIAL_USART2
|
2021-03-18 20:20:54 +03:00
|
|
|
bool "Serial (on USART2 PA3/PA2)" if LOW_LEVEL_OPTIONS
|
|
|
|
select SERIAL
|
2021-05-25 04:06:04 +03:00
|
|
|
config STM32_SERIAL_USART2_ALT_PA15_PA14
|
2022-09-22 07:45:51 +03:00
|
|
|
bool "Serial (on USART2 PA15/PA14)" if LOW_LEVEL_OPTIONS && (MACH_STM32F0 || MACH_STM32G4)
|
|
|
|
select SERIAL
|
|
|
|
config STM32_SERIAL_USART2_ALT_PB4_PB3
|
|
|
|
bool "Serial (on USART2 PB4/PB3)" if LOW_LEVEL_OPTIONS && MACH_STM32G4
|
2021-03-18 20:20:54 +03:00
|
|
|
select SERIAL
|
2021-05-25 04:17:51 +03:00
|
|
|
config STM32_SERIAL_USART2_ALT_PD6_PD5
|
2021-05-26 06:03:43 +03:00
|
|
|
bool "Serial (on USART2 PD6/PD5)" if LOW_LEVEL_OPTIONS && !MACH_STM32F0
|
2021-05-25 04:17:51 +03:00
|
|
|
select SERIAL
|
2019-07-29 05:27:32 +03:00
|
|
|
config STM32_SERIAL_USART3
|
2021-05-25 04:17:51 +03:00
|
|
|
bool "Serial (on USART3 PB11/PB10)" if LOW_LEVEL_OPTIONS
|
2021-05-26 05:13:09 +03:00
|
|
|
depends on !MACH_STM32F0 && !MACH_STM32F401
|
2021-03-18 20:20:54 +03:00
|
|
|
select SERIAL
|
2021-05-25 04:06:04 +03:00
|
|
|
config STM32_SERIAL_USART3_ALT_PD9_PD8
|
2021-05-25 04:17:51 +03:00
|
|
|
bool "Serial (on USART3 PD9/PD8)" if LOW_LEVEL_OPTIONS
|
2021-05-26 05:13:09 +03:00
|
|
|
depends on !MACH_STM32F0 && !MACH_STM32F401
|
2021-03-18 20:20:54 +03:00
|
|
|
select SERIAL
|
2021-10-28 06:25:21 +03:00
|
|
|
config STM32_SERIAL_UART4
|
|
|
|
bool "Serial (on UART4 PA0/PA1)"
|
|
|
|
depends on MACH_STM32H7
|
|
|
|
select SERIAL
|
2023-04-19 18:47:18 +03:00
|
|
|
config STM32_SERIAL_USART5
|
|
|
|
bool "Serial (on USART5 PD2/PD3)" if LOW_LEVEL_OPTIONS
|
|
|
|
depends on MACH_STM32G0Bx
|
|
|
|
select SERIAL
|
2021-03-18 20:20:54 +03:00
|
|
|
config STM32_CANBUS_PA11_PA12
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PA11/PA12)"
|
2022-06-11 05:48:53 +03:00
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
|
|
|
config STM32_CANBUS_PA11_PA12_REMAP
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PA9/PA10)" if LOW_LEVEL_OPTIONS
|
|
|
|
depends on HAVE_STM32_CANBUS && MACH_STM32F042
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-09-22 07:45:51 +03:00
|
|
|
config STM32_CANBUS_PA11_PB9
|
|
|
|
bool "CAN bus (on PA11/PB9)"
|
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PB8_PB9
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PB8/PB9)" if LOW_LEVEL_OPTIONS
|
2022-06-11 05:48:53 +03:00
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PI9_PH13
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PI9/PH13)" if LOW_LEVEL_OPTIONS
|
|
|
|
depends on HAVE_STM32_CANBUS && MACH_STM32F4
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PB5_PB6
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PB5/PB6)" if LOW_LEVEL_OPTIONS
|
|
|
|
depends on HAVE_STM32_CANBUS && MACH_STM32F4
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PB12_PB13
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PB12/PB13)" if LOW_LEVEL_OPTIONS
|
2023-01-12 10:47:08 +03:00
|
|
|
depends on (HAVE_STM32_CANBUS && MACH_STM32F4) || HAVE_STM32_FDCANBUS
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PD0_PD1
|
2022-01-08 06:17:26 +03:00
|
|
|
bool "CAN bus (on PD0/PD1)" if LOW_LEVEL_OPTIONS
|
2022-08-24 00:53:35 +03:00
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
2021-03-18 20:20:54 +03:00
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_MMENU_CANBUS_PB0_PB1
|
2022-06-01 17:59:10 +03:00
|
|
|
bool "CAN bus (on PB0/PB1)"
|
2022-06-01 17:43:45 +03:00
|
|
|
depends on HAVE_STM32_FDCANBUS
|
2022-06-01 17:59:10 +03:00
|
|
|
select CANSERIAL
|
2022-08-24 00:53:35 +03:00
|
|
|
config STM32_MMENU_CANBUS_PD12_PD13
|
|
|
|
bool "CAN bus (on PD12/PD13)"
|
|
|
|
depends on HAVE_STM32_FDCANBUS
|
|
|
|
select CANSERIAL
|
|
|
|
config STM32_MMENU_CANBUS_PC2_PC3
|
|
|
|
bool "CAN bus (on PC2/PC3)"
|
|
|
|
depends on HAVE_STM32_FDCANBUS
|
|
|
|
select CANSERIAL
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_USBCANBUS_PA11_PA12
|
|
|
|
bool "USB to CAN bus bridge (USB on PA11/PA12)"
|
|
|
|
depends on HAVE_STM32_USBCANBUS
|
|
|
|
select USBCANBUS
|
|
|
|
endchoice
|
|
|
|
choice
|
|
|
|
prompt "CAN bus interface" if USBCANBUS
|
|
|
|
config STM32_CMENU_CANBUS_PB8_PB9
|
|
|
|
bool "CAN bus (on PB8/PB9)"
|
|
|
|
config STM32_CMENU_CANBUS_PI9_PH13
|
|
|
|
bool "CAN bus (on PI9/PH13)"
|
|
|
|
depends on HAVE_STM32_CANBUS && MACH_STM32F4
|
|
|
|
config STM32_CMENU_CANBUS_PB5_PB6
|
|
|
|
bool "CAN bus (on PB5/PB6)"
|
2023-05-17 22:42:50 +03:00
|
|
|
depends on (HAVE_STM32_CANBUS && MACH_STM32F4) || (HAVE_STM32_FDCANBUS && MACH_STM32G0B1)
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_CMENU_CANBUS_PB12_PB13
|
|
|
|
bool "CAN bus (on PB12/PB13)"
|
2023-01-12 10:47:08 +03:00
|
|
|
depends on (HAVE_STM32_CANBUS && MACH_STM32F4) || HAVE_STM32_FDCANBUS
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_CMENU_CANBUS_PD0_PD1
|
|
|
|
bool "CAN bus (on PD0/PD1)"
|
2022-08-24 00:53:35 +03:00
|
|
|
depends on HAVE_STM32_CANBUS || HAVE_STM32_FDCANBUS
|
2022-06-09 04:03:11 +03:00
|
|
|
config STM32_CMENU_CANBUS_PB0_PB1
|
|
|
|
bool "CAN bus (on PB0/PB1)"
|
|
|
|
depends on HAVE_STM32_FDCANBUS
|
2022-08-24 00:53:35 +03:00
|
|
|
config STM32_CMENU_CANBUS_PD12_PD13
|
|
|
|
bool "CAN bus (on PD12/PD13)"
|
|
|
|
depends on HAVE_STM32_FDCANBUS
|
|
|
|
config STM32_CMENU_CANBUS_PC2_PC3
|
|
|
|
bool "CAN bus (on PC2/PC3)"
|
|
|
|
depends on HAVE_STM32_FDCANBUS
|
2019-07-29 05:27:32 +03:00
|
|
|
endchoice
|
2021-03-18 20:20:54 +03:00
|
|
|
|
2022-06-09 04:03:11 +03:00
|
|
|
|
|
|
|
config STM32_CANBUS_PB8_PB9
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PB8_PB9 || STM32_CMENU_CANBUS_PB8_PB9
|
|
|
|
config STM32_CANBUS_PI9_PH13
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PI9_PH13 || STM32_CMENU_CANBUS_PI9_PH13
|
|
|
|
config STM32_CANBUS_PB5_PB6
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PB5_PB6 || STM32_CMENU_CANBUS_PB5_PB6
|
|
|
|
config STM32_CANBUS_PB12_PB13
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PB12_PB13 || STM32_CMENU_CANBUS_PB12_PB13
|
|
|
|
config STM32_CANBUS_PD0_PD1
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PD0_PD1 || STM32_CMENU_CANBUS_PD0_PD1
|
|
|
|
config STM32_CANBUS_PB0_PB1
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PB0_PB1 || STM32_CMENU_CANBUS_PB0_PB1
|
2022-08-24 00:53:35 +03:00
|
|
|
config STM32_CANBUS_PD12_PD13
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PD12_PD13 || STM32_CMENU_CANBUS_PD12_PD13
|
|
|
|
config STM32_CANBUS_PC2_PC3
|
|
|
|
bool
|
|
|
|
default y if STM32_MMENU_CANBUS_PC2_PC3 || STM32_CMENU_CANBUS_PC2_PC3
|
2022-06-09 04:03:11 +03:00
|
|
|
|
2019-07-24 06:51:31 +03:00
|
|
|
endif
|