My Marlin configs for Fabrikator Mini and CTC i3 Pro B

stm32_bootloader.py 1.2KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #
  2. # stm32_bootloader.py
  3. #
  4. import os,sys,shutil,marlin
  5. Import("env")
  6. from SCons.Script import DefaultEnvironment
  7. board = DefaultEnvironment().BoardConfig()
  8. #
  9. # Copy the firmware.bin file to build.firmware, no encryption
  10. #
  11. def noencrypt(source, target, env):
  12. firmware = os.path.join(target[0].dir.path, board.get("build.firmware"))
  13. shutil.copy(target[0].path, firmware)
  14. #
  15. # For build.offset define LD_FLASH_OFFSET, used by ldscript.ld
  16. #
  17. if 'offset' in board.get("build").keys():
  18. LD_FLASH_OFFSET = board.get("build.offset")
  19. marlin.relocate_vtab(LD_FLASH_OFFSET)
  20. # Get upload.maximum_ram_size (defined by /buildroot/share/PlatformIO/boards/VARIOUS.json)
  21. maximum_ram_size = board.get("upload.maximum_ram_size")
  22. for i, flag in enumerate(env["LINKFLAGS"]):
  23. if "-Wl,--defsym=LD_FLASH_OFFSET" in flag:
  24. env["LINKFLAGS"][i] = "-Wl,--defsym=LD_FLASH_OFFSET=" + LD_FLASH_OFFSET
  25. if "-Wl,--defsym=LD_MAX_DATA_SIZE" in flag:
  26. env["LINKFLAGS"][i] = "-Wl,--defsym=LD_MAX_DATA_SIZE=" + str(maximum_ram_size - 40)
  27. #
  28. # Only copy the file if there's no encrypt
  29. #
  30. board_keys = board.get("build").keys()
  31. if 'firmware' in board_keys and not 'encrypt' in board_keys:
  32. import marlin
  33. marlin.add_post_action(noencrypt)