当前位置:首页 > 单片机 > 单片机
[导读]1.查看用户手册led1、led2、led3、led4连接的分别是 GPK4、GPK5、GPK6、GPK72、查询6410芯片手册下面还需要3个步骤:1、设置GPIO为OUTPUT。将GPK4、GPK5、GPK6、GPK7设置为输出output=0001 即GPKCON0的19:28都配置为

1.查看用户手册

led1、led2、led3、led4连接的分别是 GPK4、GPK5、GPK6、GPK7

2、查询6410芯片手册

下面还需要3个步骤:

1、设置GPIO为OUTPUT。

将GPK4、GPK5、GPK6、GPK7设置为输出output=0001

即GPKCON0的19:28都配置为0001

2、设置GPIO的数据。

将GPKDATA的4:7位赋值为0

3、设置GPKUP为上拉。

将GPKUP的4:7位设置为10

3、代码

led_driver.c

#include/*它定义了模块的API、类型和宏(MODULE_LICENSE、MODULE_AUTHOR等等),所有的内核模块都必须包含这个头文件。*/

#include/*使用内核信息优先级时要包含这个文件,一般在使用printk函数时使用到优先级信息*/

#include

#include/*copy_to_user,copy_from_user*/

#include/*readlwritel*/

#include

#include

#include

#defineLED_MAJOR243

#defineLED_ON1

#defineLED_OFF0

#defineLED_1_ON2

#defineLED_1_OFF3

#defineLED_2_ON4

#defineLED_2_OFF5

#defineLED_3_ON6

#defineLED_3_OFF7

#defineLED_4_ON8

#defineLED_4_OFF9

staticintled_open(structinode*inode,structfile*filp)

{

unsignedtmp;

tmp=readl(S3C64XX_GPKCON);

tmp=(tmp&0x0000ffff)|0x1111ffff;

writel(tmp,S3C64XX_GPKCON);

printk("#########open######n");

return0;

}

staticintled_read(structfile*filp,char__user*buf,size_tcount,loff_t*f_pos)

{

returncount;

}

staticintled_write(structfile*filp,constchar__user*buf,size_tcount,loff_t*f_pos)

{

charwbuf[10];

unsignedtmp;

if(copy_from_user(wbuf,buf,count))

return-EFAULT;

switch(wbuf[0])

{

caseLED_ON:

tmp=readl(S3C64XX_GPKDAT);

tmp&=(0x0f);

writel(tmp,S3C64XX_GPKDAT);

printk("turnon!n");

break;

caseLED_OFF:

tmp=readl(S3C64XX_GPKDAT);

tmp|=(0xf0);

writel(tmp,S3C64XX_GPKDAT);

printk("turnoff!n");

break;

caseLED_1_ON:

tmp=readl(S3C64XX_GPKDAT);

tmp&=(0xef);

writel(tmp,S3C64XX_GPKDAT);

printk("turnoff!n");

break;

caseLED_1_OFF:

tmp=readl(S3C64XX_GPKDAT);

tmp|=(0xf0);

writel(tmp,S3C64XX_GPKDAT);

printk("turnon!n");

break;

caseLED_2_ON:

tmp=readl(S3C64XX_GPKDAT);

tmp&=(0xdf);

writel(tmp,S3C64XX_GPKDAT);

printk("turnoff!n");

break;

caseLED_2_OFF:

tmp=readl(S3C64XX_GPKDAT);

tmp|=(0xf0);

writel(tmp,S3C64XX_GPKDAT);

printk("turnon!n");

break;

caseLED_3_ON:

tmp=readl(S3C64XX_GPKDAT);

tmp&=(0xbf);

writel(tmp,S3C64XX_GPKDAT);

printk("turnoff!n");

break;

caseLED_3_OFF:

tmp=readl(S3C64XX_GPKDAT);

tmp|=(0xf0);

writel(tmp,S3C64XX_GPKDAT);

pri

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

嵌入式系统已经成为我们日常生活中不可或缺的一部分,它们存在于我们的手机、家用电器、汽车、医疗设备等各个领域。而Linux操作系统在嵌入式领域中也占据着重要地位。本文将深入探讨嵌入式Linux的特点和特性,以及如何学习这一...

关键字: 嵌入式系统 Linux操作系统 设备驱动

摘要:基于Linux字符设备操作接口和各类串行总线的共,性,按照分层的思想,抽象出各种总线的统一接口。统一接口的应用层API与底层的具体总线操作形式无关,而且便于应用系统的升级和移植。文中给出了一种多种串行总线统一接口的...

关键字: 统一接口 嵌入式系统 Linux 设备驱动 串行总线

通过一个最简单的LED驱动实例来展示字符设备驱动程序设计,开发及测试的整个过程。1.实验目的(1)了解LED原理及其与S3C2410的接口电路设计。(2)了解S3C2410芯片的I/O端口配置方法。(3)通过S3C2...

关键字: ARM LED 设备驱动

在自己的工作目录下建立helloworld_driver.c#include#include//代码遵守的license:BSDGPLMODULE_LICENSE("DualBSD/GPL");//代...

关键字: tiny6410 设备驱动

设备驱动程序是操作系统内核和机器硬件之间的接口,它为应用程序屏蔽硬件的细节,一般来说,Linux的设备驱动程序需要完成如下功能:  ·设备初始化、释放;  ·提供各类设备服务;  ·负责内核和设备之间的数据

关键字: arm处理器 Linux s3c2410 移植 设备驱动

在工作目录下建立helloworld.c文件#includemain(){printf("helloworld!\\n");}保存关闭后。编译helloworld文件:root@snail:/home...

关键字: 交叉编译 tiny6410

《嵌入式Linux初级实验s3c2410》设备驱动开发=硬件控制+内核API+内核驱动框架1.设备驱动和操作系统1.1无操作系统时的设备驱动在没有操作系统的情况下,设备驱动的接口直接提交给应用软件工程师,应用软件没有跨越

关键字: ARM 设备驱动

操作系统是通过各种驱动程序来驾驭硬件设备的,它为用户屏蔽了各种各样的设备,驱动硬件是操作系统最基本的功能,并且提供统一的操作方式。设备驱动程序是内核的一部分,硬件驱动程序是操作系统最基本的组成部分,在Linux内核源程序...

关键字: 基础教程 嵌入式linux 操作系统 设备驱动

设备驱动程序可以使用模块的方式动态加载到内核中去。加载模块的方式与以往的应用程序开发有很大的不同。以往在开发应用程序时都有一个main()函数作为程序的入口点,而在驱动开发时却没有main()函数,模块在调用insmod...

关键字: 基础教程 字符设备驱动 嵌入式linux 操作系统 设备驱动

FS2410开发板的S3C2410处理器具有117个多功能通用I/O(GPIO)端口管脚,包括GPIO 8个端口组,分别为GPA(23个输出端口)、GPB(11个输入/输出端口)、GPC(16个输入/输出端口)、GPD(...

关键字: 基础教程 嵌入式linux 操作系统 设备驱动 gpio驱动程序
关闭
关闭