Windows CE S3C2440A下按键驱动程序编码分析

简介:     这些程序基于TQ2440平台,主要是实现键盘按键的运作,方便起见,只实现了上下左右四个按键。该部分硬件结构图如下;          从硬件图可以看出,按键连接EINT1、EINT2、EINT4和EINT0四个中断引脚。

    这些程序基于TQ2440平台,主要是实现键盘按键的运作,方便起见,只实现了上下左右四个按键。该部分硬件结构图如下;

    image

     从硬件图可以看出,按键连接EINT1、EINT2、EINT4和EINT0四个中断引脚。在WindowsCE中,我们只需要处理好这四个中断即可,如下详细介绍;

image    从这幅图中可以看出,EINT0~4的是由GPF0~4控制的,因此在驱动之前需要先配置这四个GPIO口,使其下降延触发,如下代码;

v_pIOPregs->GPFCON  &= ~(0x3 << 0);     /* Set EINT0(GPF0) as EINT0          */
v_pIOPregs->GPFCON  |=  (0x2 << 0);

v_pIOPregs->EXTINT0 &= ~(0x7 << 0);     /* Configure EINT0 as Falling Edge Mode */
v_pIOPregs->EXTINT0 |=  (0x2 << 0);

v_pIOPregs->GPFCON  &= ~(0x3 << 2);     /* Set EINT1(GPF0) as EINT1        */
v_pIOPregs->GPFCON  |=  (0x2 << 2);

v_pIOPregs->EXTINT0 &= ~(0x7 << 4);     /* Configure EINT1 as Falling Edge Mode   */
v_pIOPregs->EXTINT0 |=  (0x2 << 4);

v_pIOPregs->GPFCON  &= ~(0x3 << 4);    /* Set EINT2(GPF2) as EINT                  */
v_pIOPregs->GPFCON  |=  (0x2 << 4);

v_pIOPregs->EXTINT0 &= ~(0x7 << 8);   /* Configure EINT2 as Falling Edge Mode */
v_pIOPregs->EXTINT0 |=  (0x2 << 8);

v_pIOPregs->GPFCON  &= ~(0x3 << 8);  /* Set EINT0(GPF4) as EINT4       */
v_pIOPregs->GPFCON  |=  (0x2 << 8);

v_pIOPregs->EXTINT0 &= ~(0x7 << 16);   /* Configure EINT4 as Falling Edge Mod      */
v_pIOPregs->EXTINT0 |=  (0x2 << 16);

      配置好之后,进行中断处理线程,如下代码;

IntEvent = CreateEvent(NULL, FALSE, FALSE, NULL);   
    if (!IntEvent)
    {
        RETAILMSG(1, (TEXT("ERROR: kEYBD: Failed to create event./r/n")));
        return FALSE;
    }

    IRQ = 1; //IRQ_EINT1;
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &IRQ, sizeof(UINT32), &g_KeySysIntr[0], sizeof(UINT32), NULL))
    {
        RETAILMSG(1, (TEXT("ERROR: kEYBD: Failed to request sysintr value./r/n")));
        return FALSE;
    }

    IRQ = 32; //IRQ_EINT4;
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &IRQ, sizeof(UINT32), &g_KeySysIntr[1], sizeof(UINT32), NULL))
    {
        RETAILMSG(1, (TEXT("ERROR: kEYBD: Failed to request sysintr value./r/n")));
        return FALSE;
    }

    IRQ = 2; //IRQ_EINT2;
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &IRQ, sizeof(UINT32), &g_KeySysIntr[2], sizeof(UINT32), NULL))
    {
        RETAILMSG(1, (TEXT("ERROR: kEYBD: Failed to request sysintr value./r/n")));
        return FALSE;
    }

    IRQ = 0; //IRQ_EINT0;
    if (!KernelIoControl(IOCTL_HAL_REQUEST_SYSINTR, &IRQ, sizeof(UINT32), &g_KeySysIntr[3], sizeof(UINT32), NULL))
    {
        RETAILMSG(1, (TEXT("ERROR: kEYBD: Failed to request sysintr value./r/n")));
        return FALSE;
    }

    if (!InterruptInitialize(g_KeySysIntr[0], IntEvent, NULL, 0))
    {
        RETAILMSG(1,(TEXT("Fail to initialize userkey interrupt event/r/n")));
        return FALSE;
    }
    if (!InterruptInitialize(g_KeySysIntr[1], IntEvent, NULL, 0))
    {
        RETAILMSG(1,(TEXT("Fail to initialize userkey interrupt event/r/n")));
        return FALSE;
    }
    if (!InterruptInitialize(g_KeySysIntr[2], IntEvent, NULL, 0))
    {
        RETAILMSG(1,(TEXT("Fail to initialize userkey interrupt event/r/n")));
        return FALSE;
    }
    if (!InterruptInitialize(g_KeySysIntr[3], IntEvent, NULL, 0))
    {
        RETAILMSG(1,(TEXT("Fail to initialize userkey interrupt event/r/n")));
        return FALSE;
    }

    while(1)
    {
        WaitForSingleObject(IntEvent, INFINITE);
        RETAILMSG(0,(L"INTMASK=%X, EINTMASK=%X, GPGCON=%X/r/n", v_pINTRregs->INTMSK, v_pIOPregs->EINTMASK, v_pIOPregs->GPFCON));

        //EINT1 - K1 - VK_UP - 0x26
        if(v_pINTRregs->INTMSK & (1<        {
            RETAILMSG(1,(TEXT("[Key1 - UP]/r/n")));
            keybd_event(VK_UP ,0x26, 0, 0);
            Sleep(30);
            keybd_event(VK_UP ,0x26, KEYEVENTF_KEYUP, 0);
            InterruptDone(g_KeySysIntr[0]);
        }

        //EINT4 - K2 - VK_DOWN - 0x28
        if(v_pIOPregs->EINTMASK & (1<        {
            RETAILMSG(1,(TEXT("[Key2 - DOWN]/r/n")));
            keybd_event(VK_DOWN ,0x28, 0, 0);
            Sleep(30);
            keybd_event(VK_DOWN ,0x28, KEYEVENTF_KEYUP, 0);
            InterruptDone(g_KeySysIntr[1]);
        }

        //EINT2 - K3 - VK_LEFT - 0x25
        if(v_pINTRregs->INTMSK & (1<        {
            RETAILMSG(1,(TEXT("[K3 - LEFT]/r/n")));
            keybd_event(VK_LEFT ,0x25, 0, 0);
            Sleep(30);
            keybd_event(VK_LEFT ,0x25, KEYEVENTF_KEYUP, 0);
            InterruptDone(g_KeySysIntr[2]);
        }
        //EINT0 - K4 - VK_RIGHT - 0x27
        if(v_pINTRregs->INTMSK & (1<        {
            RETAILMSG(1,(TEXT("[K4 - RIGHT]/r/n")));
            keybd_event(VK_RIGHT ,0x27, 0, 0);
            Sleep(30);
            keybd_event(VK_RIGHT ,0x27, KEYEVENTF_KEYUP, 0);
            InterruptDone(g_KeySysIntr[3]);
        }
    }

目录
相关文章
|
8月前
|
消息中间件 编译器 API
Windows窗口程序
Windows窗口程序
|
4月前
|
Windows Python
python获取windows机子上运行的程序名称
python获取windows机子上运行的程序名称
|
4月前
|
小程序 Windows
MASM32编写的程序在Windows 7,10下运行正常,但在Win XP下运行时只闻其声不见其形的故障
MASM32编写的程序在Windows 7,10下运行正常,但在Win XP下运行时只闻其声不见其形的故障
|
3月前
|
安全 API C#
C# 如何让程序后台进程不被Windows任务管理器强制结束
C# 如何让程序后台进程不被Windows任务管理器强制结束
82 0
|
4月前
|
安全 网络安全 API
基于WMI更新Windows系统信息采集程序sysInfo的一些收获
基于WMI更新Windows系统信息采集程序sysInfo的一些收获
|
5月前
|
自然语言处理 Linux Windows
Cmder - 想让你的windows下 cmd 和 SecureCRT 操作 Linux 一样帅吗 附字符集编码 chcp 936、chcp 65001
Cmder - 想让你的windows下 cmd 和 SecureCRT 操作 Linux 一样帅吗 附字符集编码 chcp 936、chcp 65001
58 1
|
5月前
|
JavaScript Windows
electron程序运行在某些 windows 上白屏
electron程序运行在某些 windows 上白屏
|
5月前
|
Linux Windows Python
最新 Windows\Linux 后台运行程序注解
本文介绍了在Windows和Linux系统后台运行程序的方法,包括Linux系统中使用nohup命令和ps命令查看进程,以及Windows系统中通过编写bat文件和使用PowerShell启动隐藏窗口的程序,确保即使退出命令行界面程序也继续在后台运行。
|
5月前
|
Windows
【Azure 环境】在Windows环境中抓取网络包(netsh trace)后,如何转换为Wireshark格式以便进行分析
【Azure 环境】在Windows环境中抓取网络包(netsh trace)后,如何转换为Wireshark格式以便进行分析
110 0
|
8月前
|
Windows
LabVIEW启用/禁用Windows屏幕保护程序
LabVIEW启用/禁用Windows屏幕保护程序
81 4
LabVIEW启用/禁用Windows屏幕保护程序