mini2440上LEDS的驱动程序(含测试程序)

发布者:幸福如愿最新更新时间:2024-06-24 来源: elecfans关键字:mini2440  LEDS  驱动程序 手机看文章 扫描二维码
随时随地手机看文章

leds_drv.h


[cpp]

  1. #ifndef _MEMDEV_H_   

  2. #define _MEMDEV_H_   

  3. #include    

  4. /* 定义幻数 */  

  5. #define MEMDEV_IOC_MAGIC  'k'   

  6. /* 定义命令 */  

  7. #define MEMDEV_IOC_ON   _IO(MEMDEV_IOC_MAGIC, 1)   

  8. #define MEMDEV_IOC_OFF _IO(MEMDEV_IOC_MAGIC, 2)   

  9. #define MEMDEV_IOC_MAXNR 2   

  10. #define LED_ON  0   

  11. #define LED_OFF 1   

  12. #endif                          /* _MEMDEV_H_ */  

leds_drv.c



[cpp]

  1. #include    

  2. #include    

  3. #include    

  4. #include    

  5. #include    

  6. #include    

  7. #include    

  8. #include    

  9. #include    

  10. #include    

  11. #include    

  12. #include    

  13. #include    

  14. #include    

  15. #include    

  16. #include    

  17. #include    

  18. #include    

  19. #include    

  20. #include    

  21. #include    

  22. #include    

  23. #include    

  24. #include    

  25. #include    

  26. #include    

  27. #include    

  28. #include    

  29. #include    

  30. #include    

  31.   

  32. #include 'leds_drv.h'   

  33.   

  34. #define DEVICE_NAME 'leds'   

  35.   

  36. static unsigned long led_table[] = {  

  37.     S3C2410_GPB(5),  

  38.     S3C2410_GPB(6),  

  39.     S3C2410_GPB(7),  

  40.     S3C2410_GPB(8),  

  41. };  

  42.   

  43. static unsigned int led_cfg_table[] = {  

  44.     S3C2410_GPIO_OUTPUT,  

  45.     S3C2410_GPIO_OUTPUT,  

  46.     S3C2410_GPIO_OUTPUT,  

  47.     S3C2410_GPIO_OUTPUT,  

  48. };  

  49.   

  50. static int s3c2440_leds_ioctl(struct inode *inode,  

  51.                               struct file *file, unsigned int cmd, unsigned long arg)  

  52. {  

  53.   

  54.     /* 检测命令的有效性 */  

  55.     if (_IOC_TYPE(cmd) != MEMDEV_IOC_MAGIC)  

  56.         return -EINVAL;  

  57.     if (_IOC_NR(cmd) > MEMDEV_IOC_MAXNR)  

  58.         return -EINVAL;  

  59.   

  60.     /* 根据命令,执行相应的操作 */  

  61.     switch (cmd)  

  62.     {  

  63.       case MEMDEV_IOC_OFF:  

  64.           s3c2410_gpio_setpin(led_table[arg], LED_OFF);  

  65.           return 0;  

  66.   

  67.       case MEMDEV_IOC_ON:  

  68.           s3c2410_gpio_setpin(led_table[arg], LED_ON);  

  69.           return 0;  

  70.       default:  

  71.           return -EINVAL;  

  72.     }  

  73. }  

  74.   

  75. /*文件操作结构体*/  

  76. static struct file_operations dev_fops = {  

  77.     .owner = THIS_MODULE,  

  78.     .ioctl = s3c2440_leds_ioctl,  

  79. };  

  80.   

  81. static struct miscdevice misc = {  

  82.     .minor = MISC_DYNAMIC_MINOR,  

  83.     .name = DEVICE_NAME,  

  84.     .fops = &dev_fops,  

  85. };  

  86.   

  87. static int __init dev_init(void)  

  88. {  

  89.     int ret;  

  90.   

  91.     int i;  

  92.     /*设置GPIO控制寄存器,GPIO设置为输出模式,默认下灯全灭 */  

  93.     for (i = 0; i < 4; i++)  

  94.     {  

  95.         s3c2410_gpio_cfgpin(led_table[i], led_cfg_table[i]);  

  96.         s3c2410_gpio_setpin(led_table[i], 1);  

  97.     }  

  98.     /*注册混杂型字符设备驱动 */  

  99.     ret = misc_register(&misc);  

  100.   

  101.     printk(DEVICE_NAME 'tinitializedn');  

  102.   

  103.     return ret;  

  104. }  

  105.   

  106. static void __exit dev_exit(void)  

  107. {  

  108.     /*注销混杂型字符设备驱动 */  

  109.     misc_deregister(&misc);  

  110. }  

  111.   

  112. module_init(dev_init);  

  113. module_exit(dev_exit);  

  114.   

  115. MODULE_AUTHOR('Cried Devil');  

  116. MODULE_LICENSE('GPL');  


app-leds.c



[cpp]

  1. #include    

  2. #include    

  3. #include    

  4. #include    

  5. #include 'leds_drv.h'           /* 包含命令定义 */   

  6. int main(int argc, char **argv)  

  7. {  

  8.     int on;  

  9.     int fd;  

  10.     int num;  

  11.     if (argc != 3 ||  

  12.         sscanf(argv[1],  

  13.                '%d',  

  14.                &num) !=  

  15.         1 || sscanf(argv[2], '%d', &on) != 1 || on < 0 || on > 1 || num < 0 || num > 3)  

  16.     {  

  17.         fprintf(stderr, 'Usage:  %s   led_num   off|onn', argv[0]);  

  18.         fprintf(stderr, 'Usage:  %s   0|1|2|3   0|1n', argv[0]);  

  19.         fprintf(stderr, 'Ex   :  %s   0         1n', argv[0]);  

  20.         exit(1);  

  21.     }  

  22.     fd = open('/dev/leds', 0);  

  23.     if (fd < 0)  

  24.     {  

  25.         perror('open device leds');  

  26.         exit(1);  

  27.     }  

  28.   

  29.     if (on)  

  30.     {  

  31.         // printf('Turn on led %d!n', num);   

  32.         ioctl(fd, MEMDEV_IOC_ON, num);  

  33.     }  

  34.     else  

  35.     {  

  36.         // printf('Turn off led %d!n', num);   

  37.         ioctl(fd, MEMDEV_IOC_OFF, num);  

  38.     }  

  39.     close(fd);  

  40.     return 0;  

  41. }  

Makefile



[cpp]

  1. ifneq ($(KERNELRELEASE),)  

  2.   

  3. obj-m := leds_drv.o  

[1] [2]
关键字:mini2440  LEDS  驱动程序 引用地址:mini2440上LEDS的驱动程序(含测试程序)

上一篇:mini2440上SQLite操作
下一篇:mini2440上DS18B20的驱动程序(含简单测试)

推荐阅读最新更新时间:2024-11-11 08:36

基于mini2440的USB视频采集
在嵌入式系统中,视频采集主要采用两种接口:一种是标准摄像头接口,一种是USB接口(USB1.1)。标准的摄像头接口,接口复杂,但传输速度快,适合高质量视频采集,而USB接口,接口简单,但有性能瓶颈,只能用于低质量的视频采集。mini2440开发板采用的是S3C2440芯片,S3C2440自带了一个OHCI的USB1.1主机接口和一个CMOS摄像头标准接口。所以mini2440开发板的两种视频采集方式都可以,这里主要介绍基于USB接口的视频采集。因为前一段时间编写了主机上基于GTK的USB视频采集程序,现在需要将其移植到开发板上。 根据主机与开发板环境的不同,需要移植的部分主要就是视频显示部分。在主机上视频显示程序是调用GTK的
[单片机]
AD9850驱动程序--MSP430版本详解
前段时间忙着画板子搞运放搞滤波了,程序更新的少,发现MSP430不是太好用,尤其Timer,不过也与我使用内部晶振有关,产生正玄波之前用MSP430发出PWM,再进行滤波变为正弦波太麻烦了,这次改用DDS芯片,今天板子回来一会就调了出来很方便。 AD9850为一款DDS芯片,这里不做什么详细介绍了,有两种接口:serial 和 parrel,两种接口驱动均完成 1 /* 2 * AD9850.h 3 * 4 * Created on: 2013-7-12 5 * Author: Allen 6 */ 7 8 #ifndef AD9850_H_ 9 #define AD9850_H_ 10 11 #include 12 #inc
[嵌入式]
STM32 UART串口驱动程序
示例1.通过UART1进行数据发送 UART 1 的初始化 /** * @brief UART1 Initialise. * @param None. * @retval None. */ void UART1_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); //UART1 选择对应UART的RCC时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GP
[单片机]
嵌入式linux内核制作方法
制作嵌入式平台的linux内核的方法和制作PC(x86)的平台的linux内核基本一致,下面介绍如何制作用于mini2440开发板的内核。 1. 清除原有的配置和中间文件(在linux内核目录下执行命令,本文以linux-2.6.29为例) #pwd /home/guoqian/4-3-1/linux-2.6.29 #make distclean 2. 配置内核 #cp mini2440_defconfig ../../../.config 将内核文件下的/arch/arm/configs配置文件mini2440_defconfig复制到内核文件的根目录下,并重命名为隐藏文件.config。注意,所有的配
[单片机]
mini2440的SDRAM分析
首先是2440的存储控制器: 暂时不管是从nand启动还是nor启动,因为我现在只关注内存,从上图可以看到由2440的Memory Controller可以寻址的范围是0x0000,0000---0x4000,0000,总共是1G,这1G又分为8个bank,bank0-bank7,每个bank为128M, 8*128M=1G。其中bank0-bank5这6个bank是只能接SROM,那么什么是SROM,2440数据手册的221页说明了,SROM是ROM或者SRAM。    通用存储设备: 内存存储设备的存储方式:ROM,RAM ROM(Read-Only Memory):只读存储器,是一种只能读出事先所存数据的固态半导体存储器
[单片机]
<font color='red'>mini2440</font>的SDRAM分析
基于PCI总线的双DSP系统及WDM驱动程序设计
1 硬件设计 1.1 PCI总线控制芯片PCI2040 PCI总线是一种不依附于某个具体处理器的局部总线,它支持32位或64位的总线宽度,频率通常是33MHz,目前最快的PCI2.0总线工作频率是66MHz。工作在33MHz、32位时,理论上最大数据传输速率能达到133MB/s。它支持猝发工作方式,提高了传输速度,支持即插即用,PCI部件和驱动程序可以在各种不同的平台上运行 。 实现PCI总线协议一般有两种方法,一是用FPGA设计实现,但PCI协议比较复杂,因此难度较大;二是采用PCI总线控制芯片,如AMCC公司的S5933、PLX公司的PCI9080等通用的PCI接口芯片。TI公司专门推出了针对PCI总线和DSP接口的芯片
[嵌入式]
一起学mini2440裸机开发(十一)--mini2440定时器0中断实验
在前边讲解系统时钟和定时器时,曾给出一个实验,实现的功能是:使用定时器0的功能,使LED每秒钟闪烁一次,当时是使用查询方式实现的,现在使用中断方式实现上述功能。 下图为我的工程文件布局: 下面贴出我的代码,你也可以去这里下载, http://download.csdn.net/detail/mybelief321/5457371 下载下来之后,直接编译,点击Flash/Download ,下载到nor flash中运行。 main.c文件 #include led.h #include timer.h #include isrservice.h #include interrupt.h unsigne
[单片机]
一起学<font color='red'>mini2440</font>裸机开发(十一)--<font color='red'>mini2440</font>定时器0中断实验
T6963C的51单片机驱动程序
#include stdio.h #include intrins.h #include reg52.h #include math.h #include absacc.h #include string.h #include Test.h /* 地址定义 */ #define d_c_add XBYTE //数据口 命令口 /* 常数定义 */ #define uchar unsigned char #define uint unsigned int /* T6963C 命令定义 */ #define LCD_CUR_POS 0x21 /* 光标位置设置(只有设置到有效显示地址并打开显示时才看到) */ #def
[单片机]
小广播
设计资源 培训 开发板 精华推荐

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

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

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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