当前位置:首页 > 嵌入式 > 嵌入式软件
[导读]基于uITRON操作系统的嵌入式GUI设计

    随着嵌入式系统技术的不断发展,各类嵌入式应用对人机交互界面的要求也越来越高,这就使得对嵌入式图形用户界面的需求越来越迫切。与一般系统上的图形用户界面相比,嵌入式系统图形用户界面要求轻型、占用资源少、高性能、高可靠性、可配置等特点。

  本设计是在东南大学国家专用集成电路系统工程技术研究中心自主研发的,并在遵循uITRON 3.0标准的RTOS-ASIX OS基础上设计出一套适合于手持设备、仪器仪表等应用的图形用户界面——ASIX Window。该图形用户界面采用面向对象的设计思想,基于消息循环和事件驱动机制,构建了比较完整的窗口系统,为用户提供了类Win32 API的用户编程接口。考虑到一般嵌入式应用的屏幕较小,以及嵌入式系统处理器与存储器容量的限制,ASIX Window在设计上放弃了窗口剪切等复杂特性,大大降低了系统的复杂性,减少了对系统资源的占用。由于采用基于控件的设计概念,ASIX Window非常适合裁减,可以根据用户的需求方便地增加或删减控件,增加了系统的可裁减性。该图形用户界面已成功应用于PDA,电子词典,税控收款机等多款产品设计中。

1  与操作系统内核的接口

  ASIX Window的整体架构是基于消息分发,消息循环以及消息处理之上的。整个ASIX OS平台的结构如图1所示。图1中,最底层的是系统的消息源,包括中断(键盘、触摸屏等)和定时器,一般将它们统称为中断源。中断发生后,进入中断处理程序,该中断处理程序维护其对应的缓冲区后(如果它需要缓冲区),设置事件发生(通过调用内核的事件标志系统调用)。因为系统任务是阻塞在这个事件标志上的,而且系统任务的优先级最高,系统任务将被内核调度运行,系统任务根据所发生事件的类型,来进行相应的处理。比如说,如果是笔中断事件,中断处理程序将笔的坐标信息存放在相应的缓冲区中,并设置相应的事件标志,系统任务将笔坐标的数据转换为相应活动区域(Active Area)的消息,并由系统任务将这个消息发送到当前需要该中断事件的任务中。LCD显示,键盘和笔中断一定是由前台任务(拥有屏幕的任务)接管的,其他外围设备所对应的中断源则由占用该资源的任务接管。

  每个任务都有一个自己的信箱(Mail Box),在每个信箱上都维护着一条消息队列,所有发往该任务的消息都连接在这个队列中。任务代码应该通过消息循环不断地从该队列中取消息并处理,如果消息队列为空,则该任务阻塞,由ASIX OS内核选择下一个就绪的高优先级任务运行。

  系统任务是内核的扩展,提供系统基本的服务功能和接口。它接管系统所有的中断资源并将相应的中断事件翻译成为相应的系统消息,并将该消息分发到对应的应用程序任务;系统任务同时维护系统中所有任务的信息,负责确定前台任务(拥有显示屏幕和用户输入焦点的任务,前台任务不一定是CPU正在运行的任务)以及前台任务的切换。系统任务阻塞在底层中断的事件标志上,系统任务拥有最高的优先级。

  在系统任务之上是服务任务。服务任务负责提供系统的其他扩展服务。服务任务没有屏幕显示(类似于Linux中的守护进程),服务任务阻塞在自己的消息队列上。服务任务拥有第二高的优先级。

按此在新窗口浏览图片
图1  ASIX OS的总体架构

  应用程序任务是用户使用的各个应用。应用任务阻塞在自己的消息队列上,所有的应用程序一般都应该拥有屏幕显示,所有的应用程序在同一优先级上。

2  窗口管理

  ASIX Windows是基于消息驱动的图形用户接口。从ASIX Windows的角度来看,应用程序是由一组窗口和控件组成的,程序的功能是通过窗口的操作来实现的。控件是在 ASIX Windows中定制的具有特定功能的独立模块,例如:按钮、菜单、下拉框、软键盘等。在 ASIX Windows中,每一个控件在数据结构上都被描述为一个窗口(也就是说,在数据结构上,窗口和控件是一样的),不同的是,控件是作为某个窗口的子窗口。在数据结构上将窗口与控件统一,使得整个系统的结构更简单,对窗口的操作与对控件的操作可以统一到一起,这使得系统的编程接口可以统一到窗口的操作函数上。在 ASIX Windows中所有的窗口操作,不管是窗口或是控件,都使用这些统一的函数。系统通过下面这个统一的数据结构来对所有的控件进行管理。

typedef struct asix_window
{   struct asix_window  *prev;   //指向前一个兄弟窗口
  struct asix_window  *next;   //指向后一个兄弟窗口
  struct asix_window  *child;  //指向子窗口链表
  /*本窗口的相关ID */
  WNDCLASS    *wndclass;       //指向本窗口的窗口类
  U32    task_id;              //本窗口所属任务的任务号
    U32    wnd_id;               //本窗口ID号
  U32    parent_id;            //本窗口的父窗口ID号
  /*本窗口的位置、状态、风格以及窗口标题等*/
  U32    status;               //本窗口状态
  U16    x;                    //本窗口左上角X坐标
  U16    y;                    //本窗口左上角Y坐标
  U16    width;                //本窗口的宽度
  U16    hight;                //本窗口的高度
  char   *caption;             //本窗口标题 
  U32    style;                //本窗口风格
  /*指向本窗口私有数据结构的指针 */
  void   *ctrl_str;            //指向本窗口的私有数据结构
} ASIX_WINDOW;

  实际上,不同的控件拥有不同的功能和结构,所以它们的操作是不同的。为了拥有统一的操作函数接口,为每一个不同的窗口或控件定义了相应的窗口类,窗口类实际上是每种控件的模版,这个模版定义了与该控件相关的内容。当应用程序员调用CreatWindow函数创建某类控件时, CreatWindow查找该类控件的窗口类,并根据窗口类中的定义,调用与该控件相关的创建函数,进行实际的创建工作。然后CreatWindow填写相应的数据结构,描述该控件类的实例,并将其链接到系统窗口链表中去,以便后续的管理。利用窗口类描述不同控件设计的同时,可以将不同控件的开发独立于系统构架的实现,使得控件的开发可以独立进行。使用独立窗口类来描述每个控件的另一个好处是可以非常方便的对ASIX Window进行裁减。下面给出窗口类数据结构的定义。

typedef struct window_class
{   U8wndclass_id;        //窗口类的ID号
// CreateWindow() 调用本函数执行控件的具体创建
STATUS    (*create)(char *caption, U32 style, U16 x, U16 y, U16 width, U16 hight, U32 wndid, U32 menu, void **ctrl_str, void *exdata);
// DestroyWindow() 调用本函数执行控件的具体删除
STATUS    (*destroy)(void *ctrl_str);
// DefWindowProc() 调用本函数进行消息处理
STATUS    (*msg_proc)( U32 win_id, U16 asix_msg, U32 lparam,void *data, U16 wparam, void *reserved);
//GetMessage() 调用本函数进行底层消息的翻译与转换
STATUS    (*msg_trans)(void *ctrl_str, U16 msg_type, U32 areaId,P_U16 data, U32 size, PMSG trans_msg);
//RePaintWindow() 调用本函数重绘本窗口类控件
STATUS    (*repaint)(void *ctrl_str, U32 lparam);
//SetWindowText() 调用本函数设置本窗口类控件的标题
STATUS    (*caption)(void *ctrl_str, char *caption, void *exdata);
} WNDCLASS;

按此在新窗口浏览图片
图2  任务链表与窗口链表

  图2所示是系统中窗口链表的结构,系统还维护了一张任务链表,每个任务控制块(TCB)中都保留了指向本任务窗口链表的首指针。

3  消息传递与处理

  每个窗口(Form)都拥有自己的消息处理函数,该函数接收来自系统(包括窗口和控件)的消息并作相应的处理和动作。每一个窗口处理函数实际上就是一个消息循环,窗口函数通过取消息函数ASIXGetMessage()获得系统任务,并发送给该窗口的消息进行处理。ASIXGetMessage ()获得系统消息并进行相应的处理和消息转换(实际上是将底层操作系统所提供的硬件消息转换成ASIX Window的消息,该函数通过调用相应窗口类所定义的消息翻译函数msg_trans()实现消息的转换),然后窗口函数对消息进行分检并作相应的处理,这部分代码是用户自己定制的,实际上是用户程序处理来自窗口和控件的消息,用来实现该应用程序的功能。窗口函数调用ASIX Windows的控件消息处理函数DefWindowProc(),该函数是一个消息过滤器及转换器,它接管非用户的,属于控件自己的消息(这个消息可能来自用户的操作)。它首先扫描由取消息函数获得的消息,检查其中是否有属于 ASIX Windows控件的消息。如果该消息属于某个控件,则消息处理函数调用系统窗口链表中该控件所对应的窗口类所指明的消息处理函数,处理这个消息执行相应的动作并可能发出相应的消息(例如,当用户点击某按钮时,控件消息处理函数将接管该点击事件,并执行按钮被点击的动画,同时发送一条该按钮被点击的消息)。

4  图形接口

  ASIX Window的图形接口设计引入了硬件抽象层的概念,图形函数(Graphic API)不直接操纵硬件,而是通过调用硬件抽象层提供的一组基本函数来作具体的图形绘制工作。硬件抽象层函数将按照设备相关的格式将要显示的内容首先填写到系统内存的一片缓冲区(VRAM)中, 然后硬件抽象层的函数将根据传入的参数决定是否将数据复制到LCD控制器。如果所调用函数的应用任务当前拥有LCD(前台任务),则将数据送往LCD控制器,否则该函数仅仅将数据写入VRAM缓冲区(该任务是后台任务)。硬件抽象层还提供了一个叫做Refresh的函数,该函数将把当前VRAM中的内容复制到 LCD控制器的数据寄存器中。系统任务在应用任务切换的时候调用Refresh 函数,将切换进来的任务中所属VRAM的数据刷新到LCD中去,实现屏幕的切换,如图3所示。

按此在新窗口浏览图片
图3  ASIX Window的图形上下文

  为了避免图形函数重入时带来的问题,以及不同应用任务拥有不同屏幕以及相应属性的问题,在新的设计中采用了图形上下文(Graphic Context,简称GC)的结构。每个需要用到屏幕的应用任务都拥有自己的图形上下文,该结构中保存与硬件无关的显示属性,比如当前色、背景色、当前线宽、当前填充模式、光标的位置、闪烁频率、光标大小、显示缓冲区(VRAM)的头指针、物理屏幕在逻辑屏幕中的位置坐标等信息。

  实际上,这样的设计一方面可以实现逻辑屏幕的概念,即应用程序可以在比实际物理屏幕大的屏幕上绘制图形;另一方面,不管应用任务在前台(拥有 LCD)还是在后台(不拥有LCD),都可以进行图形函数的调用。如果是前台任务,绘制的图形会立刻显示在LCD上;如果是后台任务,图形被暂时“绘制” 到该任务的VRAM中,等下次该后台任务切换到前台时,系统任务(System Task)将调用Refresh 函数将该任务的VRAM刷新到LCD上。

结语

  根据以上内容,设计完成了ASIX Window GUI 的原型系统,并在PDA应用中采用了该GUI。为了方便应用程序员的开发,还在此基础上设计了基于MS VC++的GUI模拟器。图4所示是ASIX Window在PDA系统和模拟器上的应用。ASIX Window编译后的核心非常小巧,长度只有200 KB左右。在可移植性方面,该GUI已成功地移植到了68000、X86、ARM等处理器平台上。

按此在新窗口浏览图片
图4  ASIX Window在PDA上的应用以及模拟器截图

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭