博客
关于我
嵌入式Linux驱动学习之LED控制:基于AT91SAM9261EK
阅读量:565 次
发布时间:2019-03-09

本文共 1848 字,大约阅读时间需要 6 分钟。

基于AT91SAM9261EK开发板的嵌入式Linux LED驱动开发

为了实现对AT91SAM9261EK开发板上的两个LED灯进行控制,本文将介绍如何编写一个基于Linux的最简单LED驱动程序。

(1)编写嵌入式Linux LED驱动驱动程序需要控制PA13和PA14两个GPIO引脚。低电平状态亮,高电平状态灭。我们可以参考网上成功的驱动示例,进行适当修改。

(2)驱动程序的编写与用户程序的开发驱动程序需要遵循以下步骤编写:

  • 定义相关宏
  • 导入必要的头文件
  • 实现模块初始化与卸载函数
  • 实现文件操作接口函数
  • 注册字符设备

如下的Makefile用于编译驱动程序:

obj-m += LED_TEST.oCURRENT_PATH := $(shell pwd)ARM_LINUX_KERNEL := /home/AT91/Kernel/linux-2.6.32.2all:    $(MAKE) -C $(ARM_LINUX_KERNEL) \    SUBDIRS=$(CurrentValue) \    modulesclean:    rm -rf *.cmd *.o *.ko *.mod.c *.symvers *.order

用户程序的实现需要与驱动程序配合使用。程序将实现对LED状态的控制功能,具体代码如下:

#include 
#include
#include
#include
#define LED_DEV "/dev/SAM9261-LED_TEST"int main(int argc, char **argv) { int fd, ret, led_num, led_status; if (argc != 3 || sscanf(argv[1], "%d", &led_num) != 1 || sscanf(argv[2], "%d", &led_status) != 1) { printf("Please input correct parameters!\n"); printf("Usage:\n%s
\n", argv[0]); printf("Options:\n"); printf(" led_num - 1 for red led, 0 for blue led.\n"); printf(" led_status - 1 for ON, 0 for OFF.\n"); exit(1); } if ((led_status != 1 && led_status != 0) || (led_num != 0 && led_num != 1)) { printf("Error: The parameter value must be '0' or '1'!\n"); exit(1); } fd = open(LED_DEV, O_RDWR); if (fd < 0) { printf("Fail to open device '%s'!\n", LED_DEV); exit(1); } ret = ioctl(fd, led_status, led_num); if (ret < 0) { printf("Fail calling ioctl!\n"); exit(1); } close(fd); return 0;}

用户程序的Makefile编写如下:

all:    arm-none-linux-gnueabi-gcc LED_TEST_APP.c -o LED_APPclean:    rm -rf *.o LED_APP

编译命令为:

make

可以通过以下步骤完成开发板上的测试和应用:

  • 使用insmod LED_TEST.ko加载驱动程序。
  • 执行用户程序LED_APP 1 1(开启第一个LED)。
  • 执行LED_APP 1 0(关闭第一个LED)。
  • 执行LED_APP 0 1(开启第二个LED)。
  • 执行LED_APP 0 0(关闭第二个LED)。
  • 为了卸载驱动程序,使用rmmod LED_TEST.ko命令。

    通过以上步骤,可以实现对开发板上的两个LED灯进行简单的控制。

    转载地址:http://yzfpz.baihongyu.com/

    你可能感兴趣的文章
    mysql 敲错命令 想取消怎么办?
    查看>>
    Mysql 整形列的字节与存储范围
    查看>>
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>