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,一经查实,立即删除!

相关文章

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

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

MCDC — 修正判定条件覆盖

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

FMI在仿真软件SkyEye中的应用

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

c#ovalshape_【原创】C# 实现拖拉控件改变位置与大小(SamWang)(附源代码下载)

前言:很多时候我们需要在运行时,动态地改变控件的位置以及大小,以获得更好的布局。比如说实际项目中的可自定义的报表、可自定义的单据等诸如此类。它们有个特点就是允许客户或者二次开发人员设计它们需要的界面设置功能。本人以前也做过可自…

jmeter提取mysql数据_通过jmeter读取数据库数据,并取值作为请求的入参

为提升测试技能,督促自己学习。故写了这篇文章。测试小白一枚,最近感觉达到了自己认为的瓶颈期。总是有想法,想突破,但是无从入手。工具类用过fiddler、jmeter、charels、postman..大体接口测试工具,均多多少少使用过。…

如何快速上手mysql_mysql快速上手3

上一章给大家说的是数据库的视图,存储过程等等操作,这章主要讲索引,以及索引注意事项,如果想看前面的文章,url如下:索引简介索引是对数据库表中一个或多个列(例如,employee 表的姓名 (name) 列)…

c mysql 免安装版_MySQL5.6免安装版环境配置图文教程

MySQL是一个小巧玲珑但功能强大的数据库,目前十分流行。但是官网给出的安装包有两种格式,一个是msi格式,一个是zip格式的。很多人下了zip格式的解压发现没有setup.exe,面对一堆文件一头雾水,不知如何安装。下面小编将介…

MDL锁导致mysql夯住_MySQL MetaData Lock 案例分享

前言:今天开发童鞋遇到一个奇怪的问题,在测试环境里面执行drop database dbname发现一直夯住不动,等了很久也没有执行,于是问题就到我这里了一、什么是MetaData Lock?MetaData Lock即元数据锁,在数据库中元…

docker 分布式管理群集_Coolpy7分布式物联网MQTT集群搭建

Coolpy7分布式技术,支持多个Coolpy7 Core提供跨数据中心(多活)模式组建群集,支持群集零手动维护(基于Gossip分布式协议作为群集节点状态维护)。Coolpy7从版本号V7.3.2.3开始支持本功能。请到Coolpy7之github项目release下载相关版本https://github.com/C…

vue 数值 拼接字符串_【Vue原理】Compile - 白话版

写文章不容易,点个赞呗兄弟 专注 Vue 源码分享,文章分为白话版和 源码版,白话版助于理解工作原理,源码版助于了解内部详情,让我们一起学习吧 研究基于 Vue版本 【2.5.17】如果你觉得排版难看,请点击 下面链…

gpio驱动蜂鸣器出现破音_五款蜂鸣器驱动电路原理图

蜂鸣器驱动电路图一:典型的蜂鸣器驱动电路,蜂鸣器驱动电路一般包含:一个三极管、一个蜂鸣器、一个续流二极管、一个滤波电容。1、蜂鸣器:发声元件,在其两端施加直流电压(有源蜂鸣器)或者方波(无源蜂鸣器)就可以发声&am…

mysql 多项式_mysql主从复制原理及实现

一.主从复制原理利用MySQL提供的Replication,其实就是Slave从Master获取Binary log文件,然后再本地镜像的执行日志中记录的操作。由于主从复制的过程是异步的,因此Slave和Master之间的数据有可能存在延迟的现象,此时只能保证数据最…