linux2.6.32.2 mini2440平台移植--LCD 背光驱动

发布者:GHR2596最新更新时间:2022-10-17 来源: csdn关键字:linux2  6  mini2440  平台移植  LCD  背光驱动 手机看文章 扫描二维码
随时随地手机看文章

1.3.1 LCD 背光控制原理


到目前为止,我们一直都在命令行下移植,查看结果,在 mini2440/micro2440 开发板中,LCD 背光是通过 CPU 的 LCD_PWR 引脚来控制的,从原理图中可以看出,它对应于 GPG4 。


当 LCD_PWR  输出为高电平"1"时,将打开背光;当输出为低电平"0"时,将关闭背光(注意:这里只是打开和关闭背光,而并没有背光亮度的调节作用)。


1.3.2  在内核中添加背光驱动程序


现在,我们需要增加一个简单的背光驱动,以便能够通过软件便可简单的控制背光的开关。我们要达到的目的是:在命令终端通过向背光设备发送偶数比如"0"便可关闭背光,发送奇数比如"1"便可打开背光,这样使用起来就方便多了,而不需要专门的应用程序控制它,提示:LCD 背光设备文件:/dev/backlight


在命令行种输入:echo 0 > /dev/backlight 可以关闭 LCD 背光。


在命令行种输入:echo 1 > /dev/backlight 可以打开 LCD 背光。


为了实现这点,我们在 linux-2.6.32.2/drivers/video 目录增加一个 mini2440_backlight.c


文件,内容如下:


//以下头文件可能并不是每一个都必须的,但多余的并不会影响驱动程序的内容


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#include


#undef DEBUG


//#define DEBUG


#ifdef DEBUG


#define DPRINTK(x...) {printk(__FUNCTION__"(%d): ",__LINE__);printk(##x);}


#else


#define DPRINTK(x...) (void)(0)


#endif


//定义背光驱动的名称为 backligh,将会出现在/dev/backlight


#define DEVICE_NAME      "backlight"


//定义背光变量 bl_state,以记录背光的开关状态


static unsigned int bl_state;


//设置背光开关的函数,主要是翻转背光变量 bl_state


static inline void set_bl(int state)


{


bl_state = !!state; //翻转 bl_state 变量


s3c2410_gpio_setpin(S3C2410_GPG(4), bl_state); //把结果写入背光所用的寄存器 GPG4


}


//获取背光状态


static inline unsigned int get_bl(void)


{


return bl_state;


}


//从应用程序读取参数,并传递到内核中


static ssize_t dev_write(struct file *file, const char *buffer, size_t count, loff_t * ppos)


{


unsigned char ch;


int ret;


if (count == 0) {


return count;


}


//使用 copy_from_user 函数从用户层/应用层读取参数


ret = copy_from_user(&ch, buffer, sizeof ch) ? -EFAULT : 0;


if (ret) {


return ret;


}


ch &= 0x01; //判断奇数还是偶数


set_bl(ch); //设置背光状态


return count;


}


//把内核参数传递给用户层/应用层的读函数


static ssize_t dev_read(struct file *filp, char *buffer, size_t count, loff_t *ppos)


{


int ret;


unsigned char str[] = {'0', '1' };


if (count == 0) {


return 0;


}


//使用 copy_to_user 函数把内核参数传递到用户层/应用层


ret = copy_to_user(buffer, str + get_bl(), sizeof(unsigned char) ) ? -EFAULT : 0;


if (ret) {


return ret;


}


return sizeof(unsigned char);


}


//设备操作集


static struct file_operations dev_fops = {


owner:     THIS_MODULE,


read:dev_read,


write:      dev_write,


};


static struct miscdevice misc = {


.minor = MISC_DYNAMIC_MINOR,


.name = DEVICE_NAME,


.fops = &dev_fops,


};


//设备初始化,内核启动时就有效


static int __init dev_init(void)


{


int ret;


ret = misc_register(&misc);


printk (DEVICE_NAME"tinitializedn");


//初始化背光所用的端口 GPG4 为输出


s3c2410_gpio_cfgpin(S3C2410_GPG(4), S3C2410_GPIO_OUTPUT);


//启动内核时打开背光


set_bl(1);


return ret;


}


static void __exit dev_exit(void)


{


misc_deregister(&misc);


}


module_init(dev_init); //注册背光驱动模块


module_exit(dev_exit); //卸载背光驱动模块


MODULE_LICENSE("GPL");


MODULE_AUTHOR("FriendlyARM Inc.");


然后把背光配置选项加入内核配置菜单,打开 linux-2.6.32.2/drivers/video/Kconfig,在如下位置加入:


config FB_S3C2410_DEBUG


bool "S3C2410 lcd debug messages"


depends on FB_S3C2410


help


Turn on debugging messages. Note that you can set/unset at run time


through sysfs


//在里加入 MINI2440 的背光驱动配置


config BACKLIGHT_MINI2440


tristate "Backlight support for mini2440 from FriendlyARM"


depends on MACH_MINI2440 && FB_S3C2410


help


backlight driver for MINI2440 from FriendlyARM


config FB_SM501


tristate "Silicon Motion SM501 framebuffer support"


depends on FB && MFD_SM501


select FB_CFB_FILLRECT


select FB_CFB_COPYAREA


select FB_CFB_IMAGEBLIT


再打开 linux-2.6.32.2/drivers/video/Makefile,根据配置定义加入驱动目标文件,如下:


# the test framebuffer is last


obj-$(CONFIG_FB_VIRTUAL)


 


#video output switch sysfs driver


+= vfb.o


obj-$(CONFIG_VIDEO_OUTPUT_CONTROL) += output.o


 


obj-$(CONFIG_BACKLIGHT_MINI2440) += mini2440_backlight.o


这样,我们就在内核中移植好了 mini2440 的背光驱动,在内核源代码根目录执行:


make menuconfig,依次选择如下子菜单:


Device Drivers    --->


Graphics support    --->


<*> Support for frame buffer devices    --->


就可以找到该配置选项,在这里,按空格选中我们刚刚加入的 mini2440 配置项,然后退出保存内核配置菜单,在命令行执行:make zImage


将生成 arch/arm/boot/zImage,使用 supervivi 的"k"功能把它烧写到开发板中,可以在启动时看到如图所示的企鹅图像,这说明我们已经点亮了背光,只不过 LCD 驱动还有些问题,下一节我们将会详细的介绍如何移植 LCD 驱动。


关键字:linux2  6  mini2440  平台移植  LCD  背光驱动 引用地址:linux2.6.32.2 mini2440平台移植--LCD 背光驱动

上一篇:linux 2.6.32.2 mini2440平台移植--触摸屏驱动移植
下一篇:linux2.6.32.2 mini2440平台移植-- 激活 RTC 驱动

推荐阅读最新更新时间:2024-11-20 04:55

STM32的启动过程是怎么样的?
分享这篇文章,谈一下STM32启动流程。如果读者朋友已经有过汇编相关基础,能够够好理解本文内容。汇编语言是比C语言更接近机器底层的编程语言,能让我们更好的理解和操纵硬件底层。 STM32三种启动模式 下好程序后,重启芯片时,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存,这就是所谓的启动过程。 STM32上电或者复位后,代码区始终从0x00000000开始,其实就是将存储空间的地址映射到0x00000000中。三种启动模式如下: 从主闪存存储器启动,将主Flash地址0x08000000映射到0x00000000,这样代码启动之后就相当于从0x08000000开始。主闪存存储器是STM32内置的Flash,作为芯片内
[单片机]
STM<font color='red'>32</font>的启动过程是怎么样的?
LCD和相机总线方案中的功率转折点
当今手机的一个共同发展趋势是LCD和相机总线的串行化,这是为了降低柔性PCB 成本,节省 PCB 空间,以及减少 EMI 组件。然而,在串行方案设计方面,人们可能认为:这些串行化方案会增加额外的功耗,原因是增加了器件。本文将阐明若能降低基带驱动输出,使其配合串化器输入的较低驱动需求,那么串行化方案能够降低链路功耗。设计人员如能了解 LCD 或相机总线的这一 “功率转折” 点,就能降低设计功耗。 串行化趋势: 随着手机需要实现的功能越来越多,且外形越来越复杂,人们开始采用串行化技术来达到手机的设计目标。采用串行化技术就可使用较窄的柔性PCB (FPCB),减少PCB空间,省去一些不必要的 EMI 组件,通过使用较小的连接器来提高
[嵌入式]
美女iPhone 6s借给别人定位 还回来变模型机
    美女,我手机被盗了,麻烦借你手机定下位行吗?”   这句话你要是信了就上当了。。。   据长沙晚报报道,昨日,在长沙火车站附近网吧玩游戏的谭女士,看着眼前一脸焦虑和可怜的男子,出于同情将自己的苹果手机借出。一来二去,谭女士猛然发现,自己的手机不知何时被调包成了塑料模型机。   当日凌晨4时,谭女士在长沙火车站走廊上的网吧玩电脑游戏,才买的iPhone 6S放在电脑桌前插着数据线充电。一男青年称手机被偷了,想借她的手机定下位,在谭女士的眼皮底下摆弄了几分钟将手机放回原处。   过了20多分钟,男青年再次向谭女士借手机。10多分钟后,男青年将手机放在电脑桌上离开网吧。几分钟后,谭女士顺手拿起手机,发现手机被调包成
[手机便携]
STM32 中断时间计算
定时中断发生的时间T: T = (arr+1)*(psc+1)/72M T=1/f 32的tclk已知 我们可以直接用这个tclk 去除我们设定的分频系数(psc+1) 也就是把tclk 分成了(psc+)份 这个分频系数的范围在1~65535 这样得到tclk/(psc+1)也就得到了定时器最终的频率 我们在倒过来 得到我们的周期(psc+1)/tclk 在乘上我们的装载值 也就得到我们想要的时间了 例
[单片机]
STM<font color='red'>32</font> 中断时间计算
STM32L151C8周期性从待机模式唤醒(RTC Wakeup Timer)
#include stm32l1xx.h #include system_stm32l1xx.h #include OLED.h #include delay.h void RtcWakeUpConfig(void); u8 RtcInit(void); u8 RtcConfig(void); int main() { DelayInit(); //延时初始化 RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE); //使能PWR时钟 if(PWR_GetFlagStatus(PWR_FLAG_SB)) //从待机模式唤醒 { PWR_Cle
[单片机]
STM<font color='red'>32</font>L151C8周期性从待机模式唤醒(RTC Wakeup Timer)
ADI公司的ADSP-BF532在监控系统的应用
   低成本/功率处理器驱动大力公司的DVR监控系统   现在,监控摄像机随处可见。视频监控系统被普遍安装在银行、商业、零售出口、家庭、幼儿园、制造厂和运输(机场/海港/公交)系统中。监控摄像机也常常用在餐馆和饮食街中,帮助管理以保持适当的卫生,并确保按操作流程进行。近几年,视频压缩技术的进步已引起视频设备的成本降低。这使得数字视频对于很多应用(包括被普遍应用的安全监控系统)变得非常有吸引力。         浙江大立科技有限公司. (简称大立) 是专攻红外线摄像机、数字录像机(DVR)等产品的科学研究、生产和销售的厂商。该公司用于监控应用的、富有价格竞争力的DV系列嵌入式视频产品,以其先进技术和系统稳定性而闻名,畅销中国
[安防电子]
基于MC56F8323的两相步进电机高速细分驱动模块
1 引言 步进电机定位准确且与数字电路接口连接非常方便,无需反馈就可实现准确的角位移,在数控机床等许多领域中得到了广泛应用。随着电子技术的发展,对步进电机细分控制技术的研究日趋深入,该技术不仅解决了步进电机步距角大的问题,提高了步进电机的分辨率,减弱或消除了步进电机的低频振动,而且也改善了电机的其他性能。从而使步进电机的应用范围进一步扩大,控制更加灵活。 2 步进电机细分驱动的基本原理 步进电机的细分功能采用数/模转换技术,用阶梯波驱动代替传统的方波驱动,使电机能以微步距“连续运动”。具体办法一般为:微处理器接收步进信号的输入,经内部识别处理后,查表得到电机的驱动电流大小。并将这个数值与当前步进电机的工作电流比较,满足条件电
[工业控制]
TLV32AC56/57音频信号处理器
    摘要: TLV320C56/57是美国TI公司生产的音频处理集成电路(VBAP),它的发送和接收通道采用独立的A/D和D/A,从而有效地克服了语音串扰问题,该产品有C、L两个系列,分别对应于不同的使用环境温度。片内集成有编译码电路、滤波器以及放大电路,可直接与话筒和扬声器接驳,其数字输入通道与所有的DSP兼容。时钟频率与CT2、PECT、GSM、PCS数据通信标准对应,适用于手提电话等通信设施。     关键词: 数字音频处理 发送 接收 TLV320AC56/57 1 概述 TLV320AC56/57音频处理集成电路(VBAP)内含发送和接收编译码电路以及发送、接收滤波器,可用于远距离语音通讯、
[嵌入式]
小广播
设计资源 培训 开发板 精华推荐

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

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

更多开源项目推荐
换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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