当前位置:首页 > 嵌入式 > 嵌入式云IOT技术圈
[导读]点击上方「嵌入式云IOT技术圈」,选择「置顶公众号」第一时间查看嵌入式笔记!    写这篇文章之前默认各位的VSCodePlatfromIO以及Marlin的开发环境都已搭建成功,如果不懂怎么搭建开发环境的,请移步Marlin官方,查看官方文档讲解:marlinfw.org   ...

点击上方「嵌入式云IOT技术圈」,选择「置顶公众号」第一时间查看嵌入式笔记!


     写这篇文章之前默认各位的VSCode PlatfromIO以及Marlin的开发环境都已搭建成功,如果不懂怎么搭建开发环境的,请移步Marlin官方,查看官方文档讲解:

marlinfw.org    3D 打印进入国内算是比较晚的,所以在百度上学习和参考的资料都比较少,并且大部分的技术文章基本上都只是讲怎么配置,其它的内容其实非常少,包括对源代码的分析等等。以下是我自己学习爬坑总结的将一个全新的开发板适配到Marlin固件经验:

1、下载最新的Marlin官方固件

然后对固件进行解压:

2、移植Marlin2.x到野火STM32F103ZET6开发板

2.1、导入该工程到Visual Studio Code

2.2、添加硬件平台编号

    要让Marlin能够识别到硬件平台,我们需要在  boards.h 中定义相应的板级编号,如下所示:

/Marlin/src/core/boards.h

2.3、为新板创建新的引脚分配文件

/Marlin/src/pins/stm32f1/    由于野火的这款开发板是 STM32F1 系列,Marlin已经做了相应的支持,所以我们直接在这个上面这个路径下创建一个文件 pins_WildFire_V1.h ,然后找到这个目录下另外一个相同芯片相似的引脚配置文件复制过来即可,接下来的工作就是修改管脚:

    在前面我们看到,Marlin固件支持的一款MKS_ROBIN的主控芯片就是 STM32F103ZET6 ,所以我们找到这款芯片的引脚分配文件,然后将这个文件里的所有代码复制到 pins_WildFire_V1.h 中去:

#define BOARD_MKS_ROBIN 4011 // MKS Robin (STM32F103ZET6)

将这个文件里的所有代码复制到 pins_WildFire_V1.h 中去:

2.4、配置板级编译环境并绑定硬件平台

2.4.1、绑定编号与管脚的关系

/Marlin/pins/pins.h

2.4.2、python脚本编写

    这部分主要是为了让 buildroot 构建环境的时候能够准确的匹配到具体的硬件平台,指定固件名称并告诉固件上传的时候要链接到MCU上的哪个地址。

/buildroot/share/PlatformIO/scripts/新建一个python脚本 wildfire_v1.py ,把链接地址、链接脚本名称、最终生成的文件按以下格式写入:

## buildroot/share/PlatformIO/scripts/wildfire_v1.py#import marlinmarlin.prepare_robin("0x08007000""wildfire_v1.ld","wildfire.bin")

2.4.3、链接脚本编写

    链接脚本在2.4.2中已经在python脚本中指定,当系统进行编译时,会找到这个链接文件。

/buildroot/share/PlatformIO/ldscripts/    新建一个链接脚本 wildfire_v1.ld ,按链接脚本的格式编写各个段:

MEMORY{ ram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K - 40 rom (rx) : ORIGIN = 0x08007000, LENGTH = 512K - 28K}/* Provide memory region aliases for common.inc */REGION_ALIAS("REGION_TEXT", rom);REGION_ALIAS("REGION_DATA", ram);REGION_ALIAS("REGION_BSS", ram);REGION_ALIAS("REGION_RODATA", rom);/* Let common.inc handle the real work. */INCLUDE common.inc

2.4.4、新板环境适配

    由于 Marlin2.0 已经支持 STM32F1 系列,也为 STM32F1 系列编写了相应的 ini 配置文件,我们只需要参考这个文件里的配置脚本,然后照葫芦画瓢即可。

/ini/stm32f1.ini    添加新板环境适配,以下的section以及ini配置属于platformio的部分,感兴趣可以去了解,后续会写一篇文章专门来讲解:

## wildfire_v1 (STM32F103ZET6)#[env:wildfire_v1]platform    = ${common_stm32f1.platform}extends    = common_stm32f1board     = genericSTM32F103ZEextra_scripts = ${common_stm32f1.extra_scripts}buildroot/share/PlatformIO/scripts/wildfire_v1.py #指定用哪个python脚本进行构建build_flags  = ${common_stm32f1.build_flags}-DSS_TIMER=4 -DSTM32_XL_DENSITYdebug_tool   = stlinkupload_protocol = stlink

3、配置并下载Marlin 2. x 固件

/Marlin/Configuration.h3.1、修改串口号

    STM32 没有串口0,我们需要改下串口号为1,否则Marlin编译的时候会报错,当然也可以修改为其它的串口号,只要硬件平台支持就可以。

3.2、修改串口波特率

通常,把串口波特率修改为115200就可以了。

3.3、设置主板

将主板改为我们在 2.1 章节里的那个宏

3.4、将移植好的Marlin固件进行编译

关掉Visual Studio Code,重新打开进行编译,可以看到,编译成功!

编译好的固件的位置在这里:

然后点击Upload,上传到 STM32 开发板成功:

然后打开串口调试助手,发现没有任何信息输出:

    这是因为没有 bootloader 的原因,因为 app 的地址是从 0x8007000 开始运行的,而 MCU 是从0x8000000 开始运行的,所以我们需要一个启动程序,启动的直接将地址指向 0x8007000 ,这样Marlin固件就可以跑起来了。

4、编写bootloader 启动程序

由于在链接地址中,我们已经指定了地址:

    所以直接将编译好的 Marlin 固件上传到 STM32 开发板是无法执行成功的,所以我们需要编写一个bootloader ,用于启动并跳转地址到 0x8007000 这个地址,这样 Marlin 固件才能跑起来。

    思考一下,为什么Marlin要这么做?

这是是为了后期 3D 打印机的 IAP 固件升级功能,可以实现线下更新固件

接下来我们就来实现这个 bootloader 。

4.1、 STM32CubeMX 配置

4.1.1、时钟配置


4.1.2、指定 SWD 为调试端口


4.1.3、定义一个LED提示灯


4.1.4、生成基础工程


然后打开这个工程进行代码编写

4.1.5、编写 bootloader 代码

定义公共变量和宏

typedef  void (*pFunction)(void);//APP在内部FLASH的起始地址#define APP_RUNING_ADDRESS  0x8007000main函数编写如下:

/** * @brief The application entry point. * @retval int */int main(void){ /* USER CODE BEGIN 1 */ //uint8_t timeout = 3 ; uint32_t JumpAddress; pFunction Jump_To_Application; /* USER CODE END 1 */
/* MCU Configuration--------------------------------------------------------*/
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */ HAL_Init();
/* USER CODE BEGIN Init */
/* USER CODE END Init */
/* Configure the system clock */ SystemClock_Config();
/* USER CODE BEGIN SysInit */
/* USER CODE END SysInit */
/* Initialize all configured peripherals */ MX_GPIO_Init(); /* USER CODE BEGIN 2 */ //判断在0x8007000区域有没有APP,如果有则跳转到APP代码区 if (((*(__IO uint32_t*)APP_RUNING_ADDRESS)
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭