SkyEye建模之方法介绍篇

SkyEye建模框架介绍

SkyEye模型与硬件开发板,图1-1-1是一块普通的硬件开发板,上面有一些比较常见的设备,包括复杂的CPU、USB口、网口、SD卡控制器等,以及简单的蜂鸣器,键盘等设备。我们试想这样一个问题,真实硬件显而易见,包括所有外设的内存地址、寄存器等信息都可以通过硬件手册得知。那么如何用软件的形式(理论上也就是数据)把它直观的表达成我们日常可以理解的东西呢?

图1-1-1 真实硬件开发板

SkyEye通过json文件来对真实硬件开发板进行描述,可以理解为一个json文件对应于一块真实的硬件开发板。大体结构我们参照图1-1-2来进行讲解:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
图1-1-2 SkyEye中的json框图

xx名称:开发人员根据实际需要自定义,可为任意值;
每一个设备由base表示其属于什么类型,有四种取值:mach表示该对象为一块板子 cpu表示该对象对CPU核,device表示该对象为一个设备 linker表示该对象为连接器,也就是说SkyEye表示的硬件开发板上所有的设备包括外设,CPU,整块开发板,连接线等均由上述四个类型之一来表示。
class的值表示该设备有哪一类来实例化。上一篇文章中讲到所有独立外设都是一个dll,SkyEye加载外设时通过动态调用dll的方式加载到SkyEye。可理解为一个class对应于一个动态dll。这里的e300_core,ram,leon2_uart,image等都是通过SkyEye建模生成的具有一定规范名称的dll,因此class对象后面的值必须是已经通过建模实现的模型。
剩余image里面的size对象以及串口中的skyeye_uart_intf对象,前者目前暂时理解为image这一设备的一个属性,具体用法我们后面介绍;skyeye_uart_inft先简单理解为一根连线,串口需要通过这根连线连接到终端”uart_term_0”上。
关于这一些知识点我们之后再补充。

总的来说就是通过json文件把整块硬件开发板以数据格式的形式表示出来,其中地址总线中有一个对象为memory_space,该对象后面的值表示地址总线上连接有多少设备,这些设备对应硬件开发板中的外设,以及设备的地址映射关系。其中图1-1-2中uart_0后跟的0x30000000表示串口在内存中的地址,0x20表示其所占的长度。实际配置时根据自身需要来对这些值进行设置。该图简单连接了一块RAM以及用于显示输出的虚拟串口。

接着需要对memory_space中连接的这些设备进行一个补充说明:

比如RAM占多少地址空间长度;如果是需要发送中断的设备,比如网卡、定时器等,还需要设置其中断号是多少。这些便是上面提到的属性。
也就是说不同的设备有它自带的不同属性,需要在建模时进行设定。

  1. 既然需要发送中断,网卡和中断之间如何建立联系?SkyEye提供接口的概念来解决这一问题,我们还是用一张图来对两个或者多个不同设备之间的数据通信进行说明:
    图1-1-3 SkyEye简单硬件开发板模型图
    例如图1-1-3中,某时刻网卡需要发送中断,首先通过之前提到的接口,将中断信息发送给中断控制器IPIC,中断控制器接收到数据后,再将中断处理的请求发送给CPU,最后CPU响应并处理设备发起的中断。

接口的概念这里先简单理解即可,总结起来就是由于每个模块在实现时相互独立,通过接口可以实现独立模块之间的相互连接并进行数据传输。具体怎么实现在之后的实际编写建模过程再进行说明。

SkyEye模型与设备寄存器

开发板由CPU、外设、各种总线等一堆元器件组成。但实际我们使用时仅仅关心外设如何使用;而外设其底层也就是通过操作不同的寄存器来完成不同的功能。因此SkyEye建模说到底最关心的还是底层寄存器的如何运转。

下图是MPC8378官方手册中关于GPIO的所有寄存器:

图1-2-1 MPC8378寄存器组
如某一时刻需要从GPIO的某一管脚读取数据,首先需要在驱动中设置GPIO方向寄存器为输出,然后再经过中断等其他操作从该管脚读取数据。设置GPIO方向为输出,相当于往该寄存器中某一个管脚位写“1”。写入1的这个过程可以被SkyEye的模型所获取,模型再根据写入的值实现相应的逻辑。之后驱动再发起读操作读取数据,该过程与写操作类似。整个过程可以参考图1-2-2:
图1-2-2 驱动与硬件设备之间的关系图

SkyEye建模工具介绍

SkyEye使用建模工具来创建前面提到的各种外设模型。

工作空间可以理解为建模所需的环境,例如在visual studio下编程可能会有一些我们不需要关心的文件,但实际工程编译时需要用到这些文件。工作空间的作用类似这些文件,使得开发人员不需要考虑环境的问题,只需要关心具体的模型实现。

创建工作空间

SkyEye提供两种方法创建工作空间,一种是在GUI界面中选择;另外SkyEye还提供命令行进行创建,指令为workspace-create + [工作空间名称]。图2-1-1和图2-1-2分别是创建工作空间的GUI表示和命令行表示。

注意:创建工作空间之后需要重启命令行工具,使新创建的工作空间生效。
图2-1-1 GUI界面创建工作空间

图2-1-2 命令行创建工作空间

下面对工作空间中包含的一些文件和文件夹做一些说明:

表1 工作空间文件说明表

更新工作空间

更新工作空间的指令为workspace-update + [目录],还可以通过图2-1-1中的切换工作目录。

我们用一个实际例子说明更新工作空间的作用,假设现在有两个工作空间,一个是MPC8378,另一个是TIC6713。且当前工作空间为MPC8378,如果在当前工作空间下运行包含TIC6713外设的二进制程序,SkyEye会提示无法找到和TIC6713外设相关的class。class我们上面提到过,每一个外设都是需要一个class来实例化。这个时候就需要通过更新工作空间的操作将工作空间替换到TIC6713所在的工作空间目录。其作用可参考图2-2-1:
图2-2-1 更新工作空间作用

创建设备

创建设备的命令为workspace-create-devoce + [设备名]。

图2-3-1 创建设备命令

创建完成后会在工作空间的module文件夹下生成三个文件,分别是:

设备名.c 设备名.h 设备名_moudle.c

.c文件中为所有需要实现的逻辑代码。

.h中为包括寄存器的定义在内的所有变量、宏定义、结构体等内容。

_module.c为SkyEye加载该模块的入口函数,不需要开发人员进行修改。

开发人员只需要考虑如何在.c文件中实现模型的逻辑代码即可,在实现完成后在工作空间根目录下执行make,代码会自动编译并生成动态dll文件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/566684.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

加密 lua_三、Lua相关知识

一、lua语言基础1、metatable2、pairs、ipairs、table.sort3、table的内存(数组结构和哈希结构)4、字符串缓存(字符串常量是共享的。这个5.3版本有调整,40字节一下的短字符串才是共享的,长字符串还是保持独立内存&…

全数字实时仿真平台SkyEye目标码覆盖率关键技术

1. 研究背景 1.1零插桩目标码覆盖率统计技术 随着武器装备的复杂度的大幅度增加,运行在装备上的嵌入式系统也越来越复杂,功能迭代越来越多,代码中就可能就会存在部分无用代码,或者在执行过程中无法测试覆盖的分支,这…

MCDC — 修正判定条件覆盖

什么是MCDC? 答:修正判定条件覆盖-----程序中的每个输入和输出都至少被调用一次,在程序中的每一个条件必须产生所有可能的输出结果至少一次,并且每一个判定中的每一个条件必须能够独立影响一个判定的输出,即在其他条件…

python terminal调试_python执行命令行调试工具pdb

调试pdbpdb是基于命令行的调试工具,非常类似gnu的gdb(调试c/c)。命令简写命令作用breakb设置断点(用法,b :在第数字行设置断点。.........................................................)b 直接回车,查看所有断点continuec直接…

20以内分数化小数表_如何使用标准正态分布表?

正态分布这个概念在统计学中很常见,在做与正态分布有关计算的时候经常会用到标准正态分布表。如果知道一个数值的标准分数即z-score,就可以非常便捷地在标准正态分布表中查到该标准分数对应的概率值。任何数值,只要符合正态分布的规律&#x…

迪捷软件团队研发的国产替代MBSE系统建模仿真软件

近年来,系统工程的概念越来越火热。其中MBSE(基于模型的系统工程)是最受大家推崇的。在复杂系统和安全关键的开发领域,如果你不能说出一些跟MBSE有关的一些词儿,那么你是无法号称自己站在时代前沿的。 与传统的系统工程…

greendao删除其中一条_广东东莞将迎来一条新地铁,全长58公里,设24站,沿途市民有福了...

感谢大家阅读,在阅读之前,麻烦您先点击上面的“蓝色字体”,再点击“关注”,这样您就可以继续“免费”收到文章阅读了,每天都会有新鲜热门话题推送,完全是“免费订阅”哦,敬请放心关注阅读~ (内…

系统仿真平台SkyEye可替代国外Matlab/Sumlink等同类软件

传统的系统开发过程,都是由工程师根据项目需求书来编写代码完成系统的开发,但随着功能的扩充和版本的迭代,系统中庞大的代码量很难确保正确无误,给后期测试和仿真带来了很大的压力和成本,在航空航天、卫星系统、核电等…

不满6位补零 字符串_vb6.0中字符串中不足位数前面补0的方法

通过data获取图片拓展名//通过图片Data数据第一个字节 来获取图片扩展名- (NSString *)contentTypeForImageData:(NSData *)data {uint8_t c;[data getBytes:&c length:1];switch (c) {case 0xFF:return "jpeg";case 0x89:return "png";case 0x47:retu…

全数字实时仿真平台SkyEye故障注入测试

故障注入测试(Fault Injection Test),简称FIT,是一种可靠性验证技术,在安全关键领域,设备的可靠性与安全性是检验装备制造生产的重要指标之一,针对现有的安全关键领域工程可靠性验证方案中就包括…

js微信监听返回_JS监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法...

在实际的应用中,我们常常需要实现在移动app和浏览器中点击返回、后退、上一页等按钮实现自己的关闭页面、调整到指定页面或执行一些其它操作的需求,那在代码中怎样监听当点击微信、支付宝、百度糯米、百度钱包等app的返回按钮或者浏览器的上一页或后退按…

玻尔兹曼分布涨落_科学网—高分子统计物理漫谈-涨落耗散定理-2 - 苗兵的博文...

涨落耗散定理是平衡态统计物理的一个极为重要的结果,该定理将一个统计力学体系的涨落关联与其对外界刺激的响应用一个干净的等式联系了起来。有了该定理,测量响应就可以获得平衡态体系的关联性质,反之亦然。如果取静态极限,涨落耗…

全数字实时仿真平台SkyEye经典案例——卫星

1. SkyEye 简介 SkyEye,中文全称天目全数字实时仿真软件,是基于可视化建模的硬件行为级仿真平台,支持用户通过拖拽的方式对硬件进行行为级别的仿真和建模。采用基于LLVM的二进制加速技术,加上各种编译器的轻量级的优化技术&#…

pxc mysql mycat_Mycat+Pxc的配置

1 schema.xml配置文件Balance属性负载均称类型0:不开启读写分离机制,所有读操作都发送到当前可用的writeHost上1:全部的readHost与stand by writeHost参与select语句的负载均衡,简单的说,当双主双从模式(M1-S1,M2-S2 并…

全数字实时仿真平台SkyEye经典案例——空间站项目

1. SkyEye 简介 SkyEye,中文全称天目全数字实时仿真软件,是基于可视化建模的硬件行为级仿真平台,支持用户通过拖拽的方式对硬件进行行为级别的仿真和建模。采用基于LLVM的二进制加速技术,加上各种编译器的轻量级的优化技术&#…

mysql 索引合并_MySQL 索引合并(Index Merge)优化

本文问题什么是Index Merge?Index Merge的限制有哪些?如何查看语句是否使用了Index Merger?Index Merge有哪几种?分别适用于那些情景?如何控制优化器是否使用Index MergeIndex Merge 索引合并索引合并检索方法可以检索…

软件定义汽车带来的困境——如何破局?

目录 为什么软件定义汽车会掀起如此大的讨论热潮? 汽车软件的发展方向 软件开发商的挑战与机遇 近两年,关于汽车软件的讨论越来越多,国产替代的呼声也越来越高,软件定义汽车是业内非常火热的话题之一。 为什么软件定义汽车会掀起…

mysql中upper的用法_Oracle LOWER() 和 UPPER()函数的使用方法

Oracle LOWER() 和 UPPER()函数的使用方法一列返回行不区分大小写这是常见的做法,使列不区分大小写,以确保您所希望返回所有行。SELECT *FROM COURSESWHERE LOWER(education_delivery_method) classroom您可以使用Oracle的UPPER() or LOWER() 函数来在你…

FMI在仿真软件SkyEye中的应用

1.仿真技术的困境 随着科技的发展,我国在安全攸关领域对于嵌入式软件的应用日益广泛,并且对于软硬件的性能及可靠性等方面要求变得更高。面对各种复杂的系统设计所提供的设计和分析手段也逐渐完善,其中仿真技术在近几年越来越受到重视&#x…

mysql命令行cmd_CMD命令行操作MySQL

连接MySQL服务器:mysql -u用户名 -p密码mysql -u用户名 -pEnter Password:输入密码(无密码则直接回车)mysql -h主机名 -u用户名 -p密码 -D数据库名称退出:exit quit \q ctrlc显示帮助信息:\h取消本行命令:\c 取消当前…