字符设备驱动---点亮led---基于jz2440开发板

2024-02-06 06:48

本文主要是介绍字符设备驱动---点亮led---基于jz2440开发板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

First_drv.c内容如下:

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/delay.h>
#include <asm/uaccess.h>
#include <asm/irq.h>
#include <asm/io.h>
#include <asm/arch/regs-gpio.h>
#include <asm/hardware.h>

static struct class *firstdrv_class;
static struct class_device *firstdrv_class_devs;

volatile unsigned long *GPFCON = NULL;
volatile unsigned long *GPFDAT = NULL;

static int first_drv_open(struct inode *inode, struct file *file)
{
//printk("first_drv_open\n");
/*配置引脚GPF 4 5 6为输出*/
*GPFCON &= ~((3<< (4*2)) |(3<< (5*2)) |(3<< (6*2)));
*GPFCON |= ((1<< (4*2)) |(1<< (5*2)) |(1<< (6*2)));
return 0;
}

static ssize_t first_drv_write(struct file *file, const char __user *buf, size_t count, loff_t * ppos)
{
int val;
//printk("first_drv_write\n");
/*用户空间和内核空间之间的数据传递cope_to_user*/
copy_from_user(&val, buf, count);
if(val == 1)
{
                  //点灯

                *GPFDAT &= ~((1<<5) |(1<<6)|(1<<4));

      }
else
{
//灭灯
*GPFDAT |= ((1<<5) |(1<<6)|(1<<4));
}
return 0;
}
/* 这个结构是字符设备驱动程序的核心
 * 当应用程序操作设备文件时所调用的open、read、write等函数,
 * 最终会调用这个结构中指定的对应函数
 */
static struct file_operations first_drv_fops = {
    .owner  =   THIS_MODULE,    /* 这是一个宏,推向编译模块时自动创建的__this_module变量 */
    .open   =   first_drv_open,       
.write =    first_drv_write,   
};

 int major;
 /*
 * 执行insmod命令时就会调用这个函数 
 */
int first_drv_init(void)
{
major = register_chrdev(0,"first_drv",&first_drv_fops);  //注册,告诉内核
firstdrv_class = class_create(THIS_MODULE, "firstdrv");   //创建一个类

//if (IS_ERR(firstdrv_class))
//return PTR_ERR(firstdrv_class);
firstdrv_class_devs = class_device_create(firstdrv_class, NULL, MKDEV(major, 0), NULL, "xyz"); /* /dev/xyz */  
//在类下面创建一个设备

// if (unlikely(IS_ERR(firstdrv_class_devs)))
// return PTR_ERR(firstdrv_class_devs);
GPFCON = (volatile unsigned long *)ioremap(0x56000050,16);
GPFDAT = GPFCON+1;
return 0;
}
 /*
 * 执行rmmod命令时就会调用这个函数 
 */
static void first_drv_exit(void)
{
unregister_chrdev(major,"first_drv");  //卸载驱动
class_device_unregister(firstdrv_class_devs);
class_destroy(firstdrv_class);
iounmap(GPFCON);
}
module_init(first_drv_init);
module_exit(first_drv_exit);

MODULE_LICENSE("GPL");

测试文件firstdrvtest.c如下:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
/*
firstdrvtest on
firstdrvtest off
*/
int main(int argc , char **argv)
{
int fd;
int val = 1;
fd = open("/dev/xyz",O_RDWR);
if (fd < 0)
printf("cannt open!\n");
if(argc != 2)
{
printf("Usage :\n");
printf("%s <on/off>\n",argv[0]);
return 0;
}
if(strcmp(argv[1], "on") == 0)
{
val=1;
}

else

{

val=0;
}
       write(fd,&val,4);
return 0;

}

注:

led驱动文件编译的时候要制定头文件的目录,韦东山视频里在makefile中指定了编译好的内核目录。

这篇关于字符设备驱动---点亮led---基于jz2440开发板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/683462

相关文章

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

C# string转unicode字符的实现

《C#string转unicode字符的实现》本文主要介绍了C#string转unicode字符的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1. 获取字符串中每个字符的 Unicode 值示例代码:输出:2. 将 Unicode 值格式化

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo

开发板NFS挂载文件目录

文章目录 序NFS1. 安装 NFS 服务器和客户端在服务器上(NFS 服务器端)在客户端上(NFS 客户端) 2. 配置 NFS 服务器创建共享目录编辑 `/etc/exports` 文件启动 NFS 服务 3. 在客户端挂载 NFS 共享创建挂载点挂载 NFS 共享验证挂载 4. 设置开机自动挂载5. 解决权限问题 序 本节主要实现虚拟机(服务器)与开发板(客户端)通过N

string字符会调用new分配堆内存吗

gcc的string默认大小是32个字节,字符串小于等于15直接保存在栈上,超过之后才会使用new分配。