ESC_UP的框架

2024-08-31 00:08
文章标签 框架 esc

本文主要是介绍ESC_UP的框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Frame of Esc_up.cpp

首先是在nuttshell中给esc_up_main传入参数,如果传入的参数是'start update',那么会新建一个ESC_UP类,然后初始化这个类,在init函数里面首先配置管脚并且复位所有的电调,然后在init函数里面还有一个start函数,在这个start函数里面就是创建了一个task_main的任务,

在task_main里面主要是有一个switch语句,刚开始_up_fsm的初始值是UP_IDLE,这时候进入switch的UP_IDLE分支,

UP_IDLE分支:在里面会把_up_fsm赋值成UP_START,然后接下来就会进入switch的UP_START分支。

UP_START分支:在这里面用一个set_cur_motor()函数。这个函数把电调1的reset管教拉高,这样电调1就开始运行,然后把_up_fsm 赋值为 UP_SEND_UPCMD,这样接着进入switch的UP_SEND_UPCMD分支。

UP_SEND_UPCMD分支:这里面首先发送CMD_ENTER_UPDATE_MODE给电调的bootloader,然后赋值_up_fsm 为 UP_SEND_PROGCMD,然后就会进入switch的case UP_SEND_PROGCMD分支。

UP_SEND_PROGCMD分支:这里面是CMD_FLASH_PROGRAM发送给电调的bootloader,然后又赋值_up_fsm = UP_CHK_BUZY,然后又会进入case UP_CHK_BUZY分支。

UP_CHK_BUZY分支:然后检查电调是否空闲,如果空闲,那么就赋值_up_fsm = UP_GET_FIRMWARE,然后进入UP_GET_FIRMWARE分支。

UP_GET_FIRMWARE分支:这个分支里面首先调用get_firmware()函数,这个函数里面又调用了read_addr_len函数从prog文件中读取地址和长度。

read_addr_len函数(1)如果读取到的起始地址不是零:那么首先读取起始地址然后就读取程序块的长度,然后返回值为FM_CONT,然后继续调用read_firmware函数从文件中读取程序块,读取程序块的时候,每次读取6个字符的ASCII码,其中读到的第3个和第6个是空格字符,然后把读到的ASCII码转换成相应的16进制数,然后读取完一个程序块之后要计算出校验码,然后首先把读取到的32位地址分两次发给bootloader,然后再把长度len发送给bootloader,然后赋值_up_fsm = UP_SEND_FMDATA,然后再到UP_SEND_FMDATA分支,然后把读取到的程序块发送给bootloader,最后发送前面计算出来的校验码,然后又赋值_up_fsm = UP_CHK_BUZY,然后进入UP_CHK_BUZY分支,检查电调是否空闲,如果空闲,那么就赋值_up_fsm = UP_GET_FIRMWARE,然后就又进入UP_GET_FIRMWARE分支开始接受下一个程序块。

read_addr_len函数(2)如果接收到的起始地址是0那么说明程序块接受完毕,那么就继续读取8个字节的数据作为程序的入口地址,其中前面四个字节保存在了updata_firmware.len里面了,后面四个字节放在了data[0]里面,然后这个时候返回值为FM_END。然后也是同样把读取到的起始地址和长度发送给bootloader。这个时候的起始地址是0,长度实际上是电调程序入口地址的前面两个字节,由于返回值是FM_END,这个时候就会把data[0]发送给bootloader,也就是把电调程序入口地址的后面两个字节发送给bootloader,然后接着到UP_END分支,复位当前的电调,然后如果电调还没有全部升级完,那么就会赋值_up_fsm = UP_START继续升级下一个电调,如果所有的电调都已经升级完,这个时候在nuttshell就会一直打印……………。

 

这篇关于ESC_UP的框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1122323

相关文章

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

Yii框架relations的使用

通过在 relations() 中声明这些相关对象,我们就可以利用强大的 Relational ActiveRecord (RAR) 功能来访问资讯的相关对象,例如它的作者和评论。不需要自己写复杂的 SQL JOIN 语句。 前提条件 在组织数据库时,需要使用主键与外键约束才能使用ActiveReocrd的关系操作; 场景 申明关系 两张表之间的关系无非三种:一对多;一对一;多对多; 在

laravel框架实现redis分布式集群原理

在app/config/database.php中配置如下: 'redis' => array('cluster' => true,'default' => array('host' => '172.21.107.247','port' => 6379,),'redis1' => array('host' => '172.21.107.248','port' => 6379,),) 其中cl