您的位置 首页 方案

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

一、开发环境主机:VMWare–Fedora9开发板:Mini2440–64MBNand编译器:arm-linux-gcc-4.3.2二、实现步骤1.硬件原理图分析。由原理图…

一、开发环境

  • 机:VMWare–Fedora 9
  • 开发板:Mini2440–64MB Nand
  • 编译器:arm-linux-gcc-4.3.2

二、完成过程

1. 硬件原理图剖析。由原理图得知LED电路是共阳极的,并分别由2440的GPB5、GPB6、GPB7、GPB8口操控的

2. 去掉内核已有的LED驱动设置,由于IO口与mini2440开发板的不一致,底子就不能操控板上的LED。

#gedit arch/arm/plat-s3c24xx/common-smdk.c //注释掉以下内容

staticstructplatform_device __initdata*smdk_devs[]={
&s3c_device_nand,

};

void__init smdk_machine_init(void)
{

if(machine_is_smdk2443())
smdk_nand_info.twrph0=50;

s3c_device_nand.dev.platform_data=&smdk_nand_info;

platform_add_devices(smdk_devs,ARRAY_SIZE(smdk_devs));

s3c_pm_init();
}

3. 编写合适mini2440开发板的LED驱动,代码如下,文件称号:my2440_leds.c

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

#defineDEVICE_NAME“my2440_leds”//设备称号
#defineLED_MAJOR231//主设备号
#defineLED_ON1//LED亮状况
#defineLED_OFF0//LED灭状况

staticunsignedlongled_table[]=//操控LED的IO口
{
S3C2410_GPB5,
S3C2410_GPB6,
S3C2410_GPB7,
S3C2410_GPB8,
};

staticunsignedintled_cfg_table[]=//LED IO口的形式
{
S3C2410_GPB5_OUTP,
S3C2410_GPB6_OUTP,
S3C2410_GPB7_OUTP,
S3C2410_GPB8_OUTP,
};

staticintleds_open(structinode*inode,structfile*file)
{
return0;
}

staticintleds_ioctl(structinode*inode,structfile*file,
unsignedintcmd,unsignedlongarg)
{
//检测是第几个LED,因开发板上只要4个,索引从0开端
if(arg<0||arg>3)
{
return-EINVAL;
}

//判别LED要碑文哪种状况
switch(cmd)
{
caseLED_ON:
{
s3c2410_gpio_setpin(led_table[arg],~(LED_ON));
break;
}
caseLED_OFF:
{
s3c2410_gpio_setpin(led_table[arg],~(LED_OFF));
break;
}
default:
{
return-EINVAL;
}
}

return0;
}

staticstructfile_operations leds_fops=
{
.owner=THIS_MODULE,
.open=leds_open,
.ioctl=leds_ioctl,
};

staticint__init led_init(void)
{
intret,i;

for(i=0;i<4;i++)
{
//初始化各IO口为输出形式
s3c2410_gpio_cfgpin(led_table[i],led_cfg_table[i]);

//由原理图可知LED电路是共阳极的(即各IO口输出低电平0才会点亮)
//这儿初始化为1,不让LED点亮
s3c2410_gpio_setpin(led_table[i],~(LED_OFF));
}

//注册LED设备为字符设备
ret=register_chrdev(LED_MAJOR,DEVICE_NAME,&leds_fops);

if(ret<0)
{
printk(DEVICE_NAME” register falid!\n”);
returnret;
}
}

staticvoid__exit led_exit(void)
{
//刊出设备
unregister_chrdev(LED_MAJOR,DEVICE_NAME);
}

module_init(led_init);
module_exit(led_exit);

MODULE_L%&&&&&%ENSE(“GPL”);
MODULE_AUTHOR(“Huang Gang”);
MODULE_DESCRIPTION(“My2440 led driver”);

4. 把LED驱动代码布置到内核中去

#cp -f my2440_leds.c /linux-2.6.30.4/drivers/char //把驱动源码复制到内核驱动的字符设备下

#gedit /linux-2.6.30.4/drivers/char/Kconfig //增加LED设备装备

config MY2440_LEDS
tristate “My2440 Leds Device”
depends on ARCH_S3C2440
default y
—help—
My2440 User Leds

#gedit /linux-2.6.30.4/drivers/char/Makefile //增加LED设备装备

obj-$(CONFIG_MY2440_LEDS)+= my2440_leds.o

5. 装备内核,挑选LED设备选项

#make menuconfig

Device Drivers —>
Character devices —>
<*>My2440 Leds Device (NEW)

6. 编译内核并下载到开发板上,检查已加载的设备:#cat /proc/devices,能够看到my2440_leds的主设备号为231

7. 编写应用程序测验LED驱动,文件名:leds_test.c

#include
#include
#include
#include

intmain(intargc,char**argv)
{
intturn,index,fd;

//检测输入的参数合法性
if(argc!=3||sscanf(argv[2],“%d”,&index)!=1||index<1||index>4)
{
printf(“Usage: leds_test on|off 1|2|3|4\n”);
exit(1);
}

if(strcmp(argv[1],“on”)==0)
{
turn=1;
}
elseif(strcmp(argv[1],“off”)==0)
{
turn=0;
}
else
{
printf(“Usage: leds_test on|off 1|2|3|4\n”);
exit(1);
}

//翻开LED设备
fd=open(“/dev/my2440_leds”,0);

if(fd<0)
{
printf(“Open Led Device Faild!\n”);
exit(1);
}

//IO操控
ioctl(fd,turn,index1);

//封闭LED设备
close(fd);

return0;
}

8. 在开发主机上穿插编译测验应用程序,并复制到文件体系的/usr/sbin目录下,然后从头编译文件体系下载到开发板上

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

9. 在开发板上的文件体系中创立一个LED设备的节点,然后运转测验程序,效果图如下,观测开发板上的LED灯,能够看到每一步的操作对应的LED会点亮或许平息

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/fangan/264535.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部