From 845757ee52655420ce56bd5d58b1d4f6eb436312 Mon Sep 17 00:00:00 2001 From: elimisback Date: Thu, 26 May 2022 11:43:40 -0500 Subject: [PATCH 1/3] Add new env Add a new env for BTT SKR Mini E3 V3. This new env allows uploading firmware in platformio over usb. --- Marlin/src/pins/pins.h | 2 +- ini/stm32g0.ini | 9 +++++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/Marlin/src/pins/pins.h b/Marlin/src/pins/pins.h index 82c91290c24c..814d8a6569bf 100644 --- a/Marlin/src/pins/pins.h +++ b/Marlin/src/pins/pins.h @@ -538,7 +538,7 @@ #elif MB(BTT_SKR_MINI_E3_V2_0) #include "stm32f1/pins_BTT_SKR_MINI_E3_V2_0.h" // STM32F1 env:STM32F103RC_btt env:STM32F103RC_btt_USB env:STM32F103RE_btt env:STM32F103RE_btt_USB env:STM32F103RC_btt_maple env:STM32F103RC_btt_USB_maple env:STM32F103RE_btt_maple env:STM32F103RE_btt_USB_maple #elif MB(BTT_SKR_MINI_E3_V3_0) - #include "stm32g0/pins_BTT_SKR_MINI_E3_V3_0.h" // STM32G0 env:STM32G0B1RE_btt + #include "stm32g0/pins_BTT_SKR_MINI_E3_V3_0.h" // STM32G0 env:STM32G0B1RE_btt env:STM32G0B1RE_btt_xfer #elif MB(BTT_SKR_MINI_MZ_V1_0) #include "stm32f1/pins_BTT_SKR_MINI_MZ_V1_0.h" // STM32F1 env:STM32F103RC_btt env:STM32F103RC_btt_USB env:STM32F103RC_btt_maple env:STM32F103RC_btt_USB_maple #elif MB(BTT_SKR_E3_DIP) diff --git a/ini/stm32g0.ini b/ini/stm32g0.ini index e6094c1e312d..1b57b5d41b76 100644 --- a/ini/stm32g0.ini +++ b/ini/stm32g0.ini @@ -36,3 +36,12 @@ build_flags = ${stm32_variant.build_flags} -DSTEP_TIMER_IRQ_PRIO=0 upload_protocol = stlink debug_tool = stlink + +# +# Custom upload to SD via Marlin with Binary Protocol +# +[env:STM32G0B1RE_btt_xfer] +extends = env:STM32G0B1RE_btt +extra_scripts = ${env:STM32G0B1RE_btt.extra_scripts} + pre:buildroot/share/scripts/upload.py +upload_protocol = custom From 9ac5d6af302fdfb56983584b2a465f4ef3cb7d7c Mon Sep 17 00:00:00 2001 From: Scott Lahteine Date: Sat, 28 May 2022 15:14:39 -0500 Subject: [PATCH 2/3] Update stm32g0.ini --- ini/stm32g0.ini | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ini/stm32g0.ini b/ini/stm32g0.ini index 1b57b5d41b76..18d245c92063 100644 --- a/ini/stm32g0.ini +++ b/ini/stm32g0.ini @@ -41,7 +41,7 @@ debug_tool = stlink # Custom upload to SD via Marlin with Binary Protocol # [env:STM32G0B1RE_btt_xfer] -extends = env:STM32G0B1RE_btt -extra_scripts = ${env:STM32G0B1RE_btt.extra_scripts} - pre:buildroot/share/scripts/upload.py -upload_protocol = custom +extends = env:STM32G0B1RE_btt +extra_scripts = ${env:STM32G0B1RE_btt.extra_scripts} + pre:buildroot/share/scripts/upload.py +upload_protocol = custom From 43cefdcd325b893943c95ee2c7205523c1ad3f6f Mon Sep 17 00:00:00 2001 From: Scott Lahteine Date: Sat, 28 May 2022 15:20:50 -0500 Subject: [PATCH 3/3] sanity-check upload.py requirements --- Marlin/src/inc/SanityCheck.h | 5 +++++ ini/stm32f1.ini | 1 + ini/stm32g0.ini | 1 + 3 files changed, 7 insertions(+) diff --git a/Marlin/src/inc/SanityCheck.h b/Marlin/src/inc/SanityCheck.h index eb442d58b8fb..ab4643f86771 100644 --- a/Marlin/src/inc/SanityCheck.h +++ b/Marlin/src/inc/SanityCheck.h @@ -4137,3 +4137,8 @@ static_assert(_PLUS_TEST(4), "HOMING_FEEDRATE_MM_M values must be positive."); #elif ENABLED(DISABLE_JTAG) && !defined(JTAG_DISABLE) #error "DISABLE_JTAG is not supported for the selected MCU/Board." #endif + +// Check requirements for upload.py +#if ENABLED(XFER_BUILD) && !BOTH(BINARY_FILE_TRANSFER, CUSTOM_FIRMWARE_UPLOAD) + #error "BINARY_FILE_TRANSFER and CUSTOM_FIRMWARE_UPLOAD are required for custom upload." +#endif diff --git a/ini/stm32f1.ini b/ini/stm32f1.ini index 6bf6a1cb851c..7493e3682ce5 100644 --- a/ini/stm32f1.ini +++ b/ini/stm32f1.ini @@ -138,6 +138,7 @@ upload_protocol = jlink # [STM32F103Rx_creality_xfer] extends = STM32F103Rx_creality +build_flags = ${STM32F103Rx_creality.build_flags} -DXFER_BUILD extra_scripts = ${STM32F103Rx_creality.extra_scripts} pre:buildroot/share/scripts/upload.py upload_protocol = custom diff --git a/ini/stm32g0.ini b/ini/stm32g0.ini index 18d245c92063..b6074d3af8d0 100644 --- a/ini/stm32g0.ini +++ b/ini/stm32g0.ini @@ -42,6 +42,7 @@ debug_tool = stlink # [env:STM32G0B1RE_btt_xfer] extends = env:STM32G0B1RE_btt +build_flags = ${env:STM32G0B1RE_btt.build_flags} -DXFER_BUILD extra_scripts = ${env:STM32G0B1RE_btt.extra_scripts} pre:buildroot/share/scripts/upload.py upload_protocol = custom