MiniGUI ial 移植指南

MiniGUI ial 移植指南
2.1 ial的定义
ial是一个通用的抽象输入接口,可以输入统一的数据的结构,也就是说在MiniGUI的核心代码里输入的数据的格式是固定的,不管输入设备是鼠标 还是触摸屏。简单地讲, 就是不管MiniGUI移植到什么操作系统之上,ial在MiniGUI中的代码是相同的,只需重新写入ial接口到操作系统设备之间的代码,这也就是所 谓的移植,这个类似与操作系统以下的驱动。驱动是为了连接系统内核和各种硬件,而ial是为了连接MiniGU和不同的操作系统,如果MiniGUI不需 要移植,也就没有必要定义ial接口。
2.2 ial中的INPUT数据结构
ial中的INPUT数据结构是移植的关键所在,这个结构体里面有好多指向函数的指针,ial初始化的时候从MiniGUI内核会送出一个 INPUT结构的数据指针, 用户把自己编写的各种函数指针赋给它,这样MiniGUI就可以间接调用用户的函数,这个方法特别类似Linux下驱动的编写方法。这个数据在 src/include/ial.h 定义:
 typedef struct tagINPUT
 {
    char*   id;
    // Initialization and termination
    BOOL (*init_input) (struct tagINPUT *input, const char* mdev, const char* mtype);
    void (*term_input) (void);
    // Mouse operations
    int  (*update_mouse) (void);
    void (*get_mouse_xy) (int* x, int* y);
    void (*set_mouse_xy) (int x, int y);
    int  (*get_mouse_button) (void);
    void (*set_mouse_range) (int minx, int miny, int maxx, int maxy);
    void (*suspend_mouse) (void);
    int (*resume_mouse) (void);
    // Keyboard operations
    int  (*update_keyboard) (void);
    const char* (*get_keyboard_state) (void);
    void (*suspend_keyboard) (void);
    int (*resume_keyboard) (void);
    void (*set_leds) (unsigned int leds);
    // Event
 #ifdef _LITE_VERSION
    int (*wait_event) (int which, int maxfd, fd_set *in, fd_set *out, fd_set *except,
            struct timeval *timeout);
 #else
    int (*wait_event) (int which, fd_set *in, fd_set *out, fd_set *except,
  char mdev [MAX_PATH + 1];
  }INPUT;
可以看到这个结构体里面的内容主要可以分为两大类:键盘和鼠标,还有一个等待函数,这个函数的作用就是从设备中读取数据,包括鼠标和键盘的数据。
2.3 工作流程
MiniGUI初始化的时候会调用ial的初始化函数。以2410的为例:
 BOOL Init2410Input (INPUT* input, const char* mdev, const char* mtype)
 input就是从内核传递出来的INPUT 结构数据,
 mdev是设备的路径,
 mtype是设备类型。
下面是源码:
   BOOL Init2410Input (INPUT* input, const char* mdev, const char* mtype)
   {
      ts = open (mdev, O_RDONLY); //打开 操作系统的设备文件,
    if (ts update_mouse = mouse_update;  //注册自己的update_mouse 函数
    input->get_mouse_xy = mouse_getxy;   // 注册自己的get_mouse_xy 函数
    input->set_mouse_xy = NULL;                     // 触摸屏不需要这个函数,所以指为 NULL
    input->get_mouse_button = mouse_getbutton; //得到鼠标的按钮状态
    input->set_mouse_range = NULL;  //这个一般也没用
    input->wait_event = wait_event;  //这个是必备的,内核就是利用这个函数接收数据。
    mousex = 0;
    mousey = 0;
    ts_event.x = ts_event.y = ts_event.pressure = 0;
    return TRUE;
    }
和这个函数相对应的是void Term2410Input(void),这个类似C++里面的析构函数,在退出的时候作一些释放资源的动作,源码为:
  void Term2410Input(void)
  {
    if (ts >= 0)
        close(ts);  //关闭设备文件
  }
大家可能会问,系统是靠这两个函数把自己的函数传递给系统,那么系统又是怎样调用这两个函数的呢。从这两个函数的名字可以看出,它们不是标准的, 在文件src/ial/ial.c也可以看到
  #ifdef _SMDK2410_IAL
    {"SMDK2410", Init2410Input, Term2410Input},
  #endif
表示:如果打开宏_SMDK2410_IAL并且ial_engine为“SMDK2410”就调用这两个函数,而且ial_engine是在 MiniGUI.cfg里,或者在src/sysres/mgetc-xxx.c文件里被指定的,前者是非内嵌的,后者是内嵌的。
2.4 注册的子函数的功能
static int wait_event (int which, fd_set *in, fd_set *out, fd_set *except, struct timeval *timeout)
由于这个函数同时处理键盘和者鼠标的信息,所以在这个函数里用到了select函数,主要是为了解决i/o复用的问题。wait_event() 主要是读取数据,处理数据,如何处理根据自己的清况去写。
static int mouse_getbutton(void)
源码:
 static int mouse_getbutton(void)
 {
    return ts_event.pressure;
 }
这个函数一般返回鼠标的键值,4代表左键。ts_event.pressure已经在wait_event函数里被处理过了。
static int mouse_update
源码:
 static int mouse_update(void)
 {
     return 1;
  }
对于触摸屏,这个函数一般是直接返回。
static void mouse_getxy
 static void mouse_getxy(int *x, int* y)
 {
    if (mousex  239) mousex = 239;
    if (mousey > 319) mousey = 319;
    *x = mousex;
    *y = mousey;
 }
这个函数返回鼠标的坐标值在wait_event中被处理。
如果需要参考一个完整功能的例子,可以参考 src/ial/native/native.c 文件,它是一个全功能的例子,输入包括键盘和鼠标,而且用户还可以根据自己的要求来设计。

  

时间: 2024-11-05 11:36:03

MiniGUI ial 移植指南的相关文章

腾讯物联网操作系统TencentOS tiny线上移植大赛,王者机器人、QQ公仔、定制开发板等礼品等

一.产品介绍 TencentOS tiny是腾讯面向物联网领域开发的实时操作系统,具有低功耗,低资源占用,模块化,安全可靠等特点,可有效提升物联网终端产品开发效率.TencentOS tiny 提供精简的 RTOS 内核,内核组件可裁剪可配置,可快速移植到多种主流 MCU (如STM32全系列)及模组芯片上.而且,基于RTOS内核提供了丰富的物联网组件,内部集成主流物联网协议栈(如 CoAP/MQTT/TLS/DTLS/LoRaWAN/NB-IoT 等),可助力物联网终端设备及业务快速接入腾讯云

物联网江湖 第四回 - Zephyr 微风渐起

文/王嘉宇 本文与之前的两篇侧重点稍有不同,前两篇文章着重介绍的是谷歌与微软的物联网操作系统的战略层面.到Zephyr这个新兴起的物联网操作系统,我想从一个不一样的角度来分析它.因此本文将着重分析一下Linux基金会主导的开源社区的组织构成及其开发者网站的建设思路. Zephyr简介 Zephyr是一款Linux基金会主导研发的实时操作系统,针对KB级别智能硬件.以开放源码的形式提供给使用者和开发者,遵守Apache2.0协议. 发布时间 - 2016年2月 官网 - https://www.z

ucos任务控制块详解

Ucos实现多任务的基础包括几个方面:任务控制块,任务堆栈,中断,任务优先级,一一说起 首先,任务控制块的结构如下 //系统在运行一个任务的时候,按照任务的优先级获取任务控制块,再在任务堆栈中获得任务代码指针 typedef struct os_tcb {//任务控制块 OS_STK          *OSTCBStkPtr;           /*指向任务堆栈栈顶的指针*/ #if OS_TASK_CREATE_EXT_EN > 0u void            *OSTCBExtPt

u-boot启动流程分析(1)_平台相关部分

转自:http://www.wowotech.net/u-boot/boot_flow_1.html 1. 前言 本文将结合u-boot的“board—>machine—>arch—>cpu”框架,介绍u-boot中平台相关部分的启动流程.并通过对启动流程的简单分析,掌握u-boot移植的基本方法. 注1:本文所使用的u-boot版本,是2016/4/23从u-boot官网(git://git.denx.de/u-boot.git)导入的一个快照,具体可参考“https://github

把php上传sae问题要使用IO

应用移植指南 一,为什么要移植应用 SAE禁止IO写操作,代码目录不能写入.这意味着普通程序的上传图片.生成缓存等操作都不能在SAE上正常运行,这时候你需要对这些代码进行修改后才能让你的程序运行在SAE上. SAE为什么要禁止IO写操作? SAE采用分布式架构设计, 应用代码将部署在多台前端服务器上, 每次访问请求可能到达不同服务器.(如下图): 假设现在有A.B.C.D四台服务器.用户上传一张图片到A服务器,第二次访问请求可能到达B服务器,此时将无法获取保存在A服务器上的图片. SAE使用Me

GCC 4.9.0 发布,提升 C++11 和 C++14 特性

from :http://www.oschina.net/news/51084/gcc-4-9-0 GCC 4.9.0 发布,此版本是个主要版本更新,包括了 GCC 4.8.x 系列和之前的 GCC 版本都没有的新特性,新特性非常之多.下载地址:http://gcc.gnu.org/mirrors.html 警告 移除 mudflap 运行时检查器,mudflap 选项保留,但没有任何效果. 对一些很多老的系统和一些不维护的平台的支持在 4.9 版本中声明为过世的,下一个版本将永久删除,例如 S

Qt官方教程翻译——QML Applications

附网址:http://qt-project.org/doc/qt-5/qmlapplications.html QML Applications QML是一种声明式语言,它提供了一组接口用来描述视觉组件以及他们的互动和相关性.它是一个高度可读的语言,并且被设计成使组件以一个动态的方式相互连接.同时它使组件很容易被复用以及创建定制的用户界面.使用QtQuick模块,设计者和开发者可以很容易使用QML建立流体动画的用户界面,并将这些界面连接到后端的C++库上面. What is QML? QML是一

uboot2011.09源代码ReadMe译文

# # (C) Copyright 2000 - 2011 # Wolfgang Denk, DENX Software Engineering, [email protected] #查看建立这个工程的文件列表人 # #这个程序是自由软件,你可以重新分配它或者修改它在GNU通用公共许可证以由自由软件基#金会发布:第二版或者任何之后的版本. #本程序是分布在希望它是有用的,但没有任何保证:甚至没有隐含保证. #查看 GNU通用公共许可证对于更多的细节. #你应该收到一份GNU通用公共许可证随着这

GCC 4.9.0 公布,提升 C++11 和 C++14 特性

from :http://www.oschina.net/news/51084/gcc-4-9-0 GCC 4.9.0 公布,此版本号是个主要版本号更新,包含了 GCC 4.8.x 系列和之前的 GCC 版本号都没有的新特性,新特性很之多.下载地址:http://gcc.gnu.org/mirrors.html 警告 移除 mudflap 执行时检查器,mudflap 选项保留,但没有不论什么效果. 对一些非常多老的系统和一些不维护的平台的支持在 4.9 版本号中声明为过世的,下一个版本号将永久