嵌入式Linux之我行——LCD背光驱动在2440上的实例开发

发布者:岭南布衣最新更新时间:2016-04-27 来源: eefocus关键字:Linux  LCD  背光驱动 手机看文章 扫描二维码
随时随地手机看文章
一、开发环境
  • 主  机:VMWare--Fedora 9
  • 开发板:Mini2440--64MB Nand
  • 编译器:arm-linux-gcc-4.3.2

二、实现步骤

1. 硬件原理图分析。由原理图得知LCD的背光是由2440的GPG4口控制的

嵌入式Linux之我行——LCD背光驱动在2440上的实例开发 <wbr>转

2. 编写背光驱动。文件名为my2440_backlight.c
 

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

#include 
#include 
#include 
#include 
#include 
#include 
#include 

#define DEVICE_NAME "backlight" //设备名称
#define DEVICE_MINOR //次设备号,这里我们将设备注册为misc设备,这种设备的主设备号都为10

static int my2440_backlight_ioctl(struct inode *inode,

                                  struct file *file,

                                  unsigned int cmd,

                                  unsigned long arg)
{
    switch(cmd)
    {
        case 0:

            //当接收的命令为0时,就将GPG4引脚设为低电平,关闭背光
            s3c2410_gpio_setpin(S3C2410_GPG4, 0); 
            printk(DEVICE_NAME " turn off!\n");
            return 0;
        case 1:

            //当接收的命令为1时,就将GPG4引脚设为高电平,开启背光
            s3c2410_gpio_setpin(S3C2410_GPG4, 1); 
            printk(DEVICE_NAME " turn on!\n");
            return 0;
        default:
            return -EINVAL;
    }
}

static struct file_operations dev_fops 
{
    .owner THIS_MODULE,
    .ioctl my2440_backlight_ioctl, //这里只使用控制IO口的方式来控制背光
};

static struct miscdevice misc =
{
    .minor DEVICE_MINOR,
    .name DEVICE_NAME,
    .fops &dev_fops,
};

static int __init dev_init(void)
{
    int ret;

    ret misc_register(&misc); //注册成misc设备

    if(ret 0)
    {
        printk("Register misc device fiald!");
        return ret;
    }

    //将GPG4口配置成输出口
    s3c2410_gpio_cfgpin(S3C2410_GPG4, S3C2410_GPG4_OUTP); 

    return ret;
}

static void __exit dev_exit(void)
{
    misc_deregister(&misc); //注销该misc设备
}

module_init(dev_init);
module_exit(dev_exit);

MODULE_LICENSE("GPL");
MODULE_AUTHOR("Huang Gang");
MODULE_DESCRIPTION("Backlight control for my2440");


3. 将驱动添加到内核中,这里我们将采用静态加载的方法。

   将my2440_backlight.c复制到内核drivers/video/backlight/目录下

#cp -f my2440_backlight.c linux-2.6.30.4/drivers/video/backlight/

 

   修改backlight/目录下的Kconfig文件,添加背光选项

#gedit linux-2.6.30.4/drivers/video/backlight/Kconfig

config MY2440_LCD_BACKLIGHT
    tristate "My2440 LCD Backlight Controls"
    depends on BACKLIGHT_LCD_SUPPORT
    default y

 

   修改backlight/目录下的Makefile文件,在最后一行添加

#gedit linux-2.6.30.4/drivers/video/backlight/Makefile

obj-$(CONFIG_MY2440_LCD_BACKLIGHT) += my2440_backlight.o

 

4. 配置内核选项,选中上面添加的配置项

Device Drivers --->
    Graphics support ---> 
        [*] Backlight & LCD device support ---> 
            --- Backlight & LCD device support 
            <*> My2440 LCD Backlight Controls (NEW) 
            < > Lowlevel LCD controls 
            < > Lowlevel Backlight controls


5. 重新编译内核并下载到开发板上,在开发板/dev/目录下建立设备的节点。设备名为backlight,主设备号为10,次设备号为5,在驱动源码里有注释

 

#mknod /dev/backlight c 10 5

 

6. 编写应用程序测试背光驱动,文件名为backlight_test.c

#include 
#include 
#include 
#include 

int main(int argc, char **argv)
{
    int turn;
    int fd;
    
    //检测命令后面带的参数
    if(argc == || argc 2)
    {
        printf("Usage: backlight on|off!\n");
        exit(1);
    }
    
    //打开背光设备
    fd open("/dev/backlight", O_RDWR);
    
    if(fd 0)
    {
        printf("Open Backlight Device Faild!\n");
        exit(1);
    }
    
    //判断输入的参数
    if(strcmp(argv[1], "on") == 0)
    {
        turn 1;
    }
    else if(strcmp(argv[1], "off") == 0)
    {
        turn 0;
    }
    else
    {
        printf("Usage: backlight on|off!\n");
        exit(1);
    }
    
    //进行IO控制
    ioctl(fd, turn);

    //关闭背光设备
    close(fd);

    return 0;
}


7. 交叉编译应用程序,并下载到开发板的/usr/sbin/目录下

#arm-linux-gcc -o backlight_test backlight_test.c


8. 运行效果。执行应用程序时内核都会打印出背光状态信息,同时观察LCD的背光也得到了控制

关键字:Linux  LCD  背光驱动 引用地址:嵌入式Linux之我行——LCD背光驱动在2440上的实例开发

上一篇:嵌入式Linux之我行——深入理解DM9000在mini2440上的驱动
下一篇:嵌入式Linux之我行——LED驱动在2440上的实例开发

推荐阅读最新更新时间:2024-03-16 14:51

基于S3C2410的TFT-LCD驱动电路设计
引言 随着电子技术的迅猛发展,具有耗电少、亮度高、体积小等特点的液晶显示器被广泛应用于嵌入式系统中。S3C2410是三星公司开发的一款以ARM920T为核心的16/32位嵌入式处理器。它主要面向手持设备以及高性价比、低功耗的应用。LTS350Q1-PE1是三星电子公司生产的一款非晶硅有源矩阵TFT-LCD,它具有功耗低、亮度高和体积小等特点,目前在嵌入式设备中应用非常广泛。 基于S3C2410,采用LTS350Q1-PE1作为显示设备可以构成一个基于嵌入式平台的液晶显示系统,如图1所示,该系统可以满足大多数嵌入式手持设备的功能要求。但是,要想S3C2410的LCD控制器可以正确有效地控制TFT-LCD,需要设计两者之间
[应用]
基于嵌入式Linux的RFID安检系统的设计
RFID(射频识别)是一种非接触式的自动识别技术,它通过射频信号自动识别目标对象并获取相关数据,识别工作无需人工干预,可工作于各种恶劣环境下。RFID技术可识别高速运动物体并可同时识别多个标签, 操作快捷方便。非接触IC卡是目前RFID系统中最常用的一种电子标签,它诞生于20世纪90年代初,是世界上最近几年发展起来的一项新技术,它成功地将射频识技术和IC卡技术结合起来,解决了无源(卡中无电源)和免接触这一难题,是电子器件领域的一大突破。由于存在着磁卡和接触式IC卡不可比拟的优点,使之一经问世,便立即引起广泛的关注,并以惊人的速度得到推广应用,如我国的第二代公民身份证、公交卡、ETC免停车付费卡等。可以说RFID技术越来越多地应用到
[嵌入式]
基于S3C2440的嵌入式Linux驱动——SPI子系统解读(一)
本文将介绍SPI子系统。内核版本为2.6.30。如有错误欢迎指正。 预备知识要求:1.SPI总线 2. platfrom平台 3. sysfs子系统 4. 阅读过LDD3第3,5,6,7,9,10,11章的内容。 NOTE:如果没有看过LDD3的相关内容,直接看内核源码将非常吃力!!! PC主机:Ubuntu 和 redhat 9.0 目标板:TQ2440开发板 cpu:s3c2440 linux内核:2.6.30 0.引言 本系列文章对Linux设备模型中的SPI子系统进行讲解。SPI子系统的讲解将分为4个部分。 第一部分,即本篇文章,将对S
[单片机]
探讨选择实时操作系统(RTOS)的要点
对许多嵌入式项目来说,系统设计师都倾向于选择实时操作系统(RTOS)。但RTOS总是必要的吗?答案是取决于具体的应用,因此了解我们要达到什么目标是决定RTOS是必要的还是花瓶的关键。 一般来说,在采用非实时操作系统(non-RTOS)的任何场合,也都可采用RTOS。但是,要找到一款具有完全相同应用编程接口(API)的匹配RTOS就相当困难了。因此,许多传统的操作系统(OS)在其内嵌入了一个RTOS。例如,Lynux-Works LynxOS和Bluecat Linux共享一个Linux API。LynxOS是一款硬RTOS,而Bluecat是Linux的一个衍生产品。 Linux继续在努力改善其实时性能,但其最长中断时延仍
[嵌入式]
ARM在嵌入式linux内核裁剪与移植的应用
微处理器用一片或少数几片大规模集成电路组成的中央处理器。这些电路执行控制部件和算术逻辑部件的功能。微处理器与传统的中央处理器相比,具有体积小,重量轻和容易模块化等优点。微处理器的基本组成部分有:寄存器堆、运算器、时序控制电路,以及数据和地址总线。微处理器能完成取指令、执行指令,以及与外界存储器和逻辑部件交换信息等操作,是微型计算机的运算控制部分。它可与存储器和外围电路芯片组成微型计算机。但这些专用操作系统都是商业化产品,其高昂的价格使许多低端产品的小公司望而却步;而且,源代码封闭性也大大限制了开发者的积极性。而Linux的开放性,使得许多人都认为Linux非常适合多数Intemet设备。Linux操作系统可以支持不同的设备和不同的
[单片机]
一 ARM9(S3C2440)的中断系统——程序实例讲解
下面的程序讲解是基于FL2440开发板的程序讲解,有不对的地方希望大家能够指教 中断控制程序编写步骤 主程序 1.先清除中断源挂起寄存器( SRCPND SRCPND)和中断挂起寄存器( INTPND),可用 rSRCPND= rSRCPND 和rINTPND=rINTPND =来完成; 2.设中断模式,这里使用通用中断,rINTMOD=0x00000000因上电或复位时rINTMOD是清 0的,这步也可以不做。 3.I/O 口初始化,有些中断源要通过 I/O 口向 CPU 申请中断,如外部中断 0(EXTINT0通过 )F口的 GPF0 、外部中断11(EXTINT11)通过G口的 GPG3 向CPU 申请中断,此时两个口的控
[单片机]
s3c2440学习之路-012-1 Undefined未定义中断
1 未定义中断的原理 1.1 ARM的指令组成 ARM的指令是由32位组成的,是有一定的组成格式的,如果不符合组成格式的话,那就这条指令就无法被识别,就是未定义指令了。指令的 ~ 是条件位,当条件位为1110B时,就表明该指令一定背执行。这里特别指出 ~ 是因为后面的例子种将会使用到。 1.2 执行未定中断的过程 当发现未定义指令时ARM会做什么呢,如同s3c2440学习之路-012-0 异常中断基础知识 的1.4 小节所说的, 程序会自动跳到0x4的位置去执行代码。 具体的执行过程如下: 执行某条命令,发现不符合ARM的命令格式,产生未定义异常 发生异常时硬件的处理,即进入异常 2.1将返回地址保存在LR(R14)
[单片机]
s3c<font color='red'>2440</font>学习之路-012-1 Undefined未定义中断
S3C2440串口代码_函数_初始化_发送Byte_发送string_Printf
通常情况下都会将串口的初始化语句写进一个初始化函数Uart_Init()中: 1 void Uart_Init(int baud) 2 { 3 int i; 4 rUFCON0 = 0x0; //UART FIFO disable 5 rULCON0 = 0x3; //关闭红外传输模式而用Normal模式,No parity,1 stop,每帧8bits数据位 6 rUCON0 = 0x805; //先看 =10,UART时钟源为PCLK,那么 就没用了,置零,接收与发送的中断类型均为Pulse,禁止接收超时中断的产生,禁止接收错误中断的产生 7 //不采用loopback工
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved