百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

全志V3S开发板驱动示例(linux demo驱动开发)

csdh11 2024-12-30 03:06 3 浏览

1.前言

本文描述了基于全志V3S开发板的简单驱动程序测试应用程序的设计流程。我们设计的驱动程序和测试程序极其简单,适合初学者上手学习。

软件运行的硬件环境是基于V3S开发板中的全志V3S处理器,该处理器集成了一个1.2GHz工作主频的单ARM CortexTM-A7 核,芯片内部集成了64MB DRAM 存储器。


软件设计是基于
linux3.4内核

2.设计流程概述

设计的步骤依次是:

步骤一:编写一个demo_driver.c的驱动程序。

步骤二:编写makefile文件。

步骤三:编写一个demo_app.c的应用程序。

步骤四:在V3S开发板中安装demo_driver驱动程序,并测试demo_app应用程序。

linux系统是一个分层结构,我们设计的demo_driver位于内核中的驱动部分,demo_app位于用户级。

3.编写驱动程序

编写一个demo_driver.c的驱动程序,驱动程序源码如下:

/**
*********************************************************************************************************
*                                        		demo_driver
*                                      (c) Copyright 2021-2031
*                                         All Rights Reserved
*
* @File    : 
* @By      : liwei
* @Version : V0.01
* 
*********************************************************************************************************
**/

/**********************************************************************************************************
Includes 
**********************************************************************************************************/
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/init.h>

/**********************************************************************************************************
Define
**********************************************************************************************************/
#define    DRIVER_MAJOR     188
#define    DEVICE_NAME     "demo_driver"


/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static int demo_open(struct inode *inode, struct file *file)
{	
	printk(KERN_EMERG "======================demo_open======================\n");
	return 0;
}
/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static ssize_t demo_write(struct file *file, const char __user * buf, size_t count, loff_t *ppos)
{
    printk(KERN_EMERG "======================demo_write======================\n");
    return 0;
}
/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static ssize_t demo_read(struct file *file,  char __user * buf, size_t count, loff_t *ppos)
{
    printk(KERN_EMERG "======================demo_read ======================\n");  
    return 0;
}
/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static int demo_close(struct inode *inode, struct file *file)
{
    printk(KERN_EMERG "======================demo_close ======================\n");
    return 0;
}

/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static struct file_operations demo_flops = 
{
	.owner  =   THIS_MODULE,
	.open   =   demo_open,     
	.write  =   demo_write,
	.read 	=  	demo_read,
	.release =  demo_close,
};

/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static int __init demo_init(void)
{
    int ret;
 		
	//注册设备
    ret = register_chrdev(DRIVER_MAJOR,DEVICE_NAME, &demo_flops);

    if (ret < 0) 
	{
      printk(KERN_EMERG DEVICE_NAME " can't register major number.\n");
      return ret;
    }
	else
	{
		printk(KERN_EMERG DEVICE_NAME " ======================demo init======================\n");
	}

    return 0;
}
/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
static void __exit demo_exit(void)
{
    unregister_chrdev(DRIVER_MAJOR, DEVICE_NAME);
    printk(KERN_EMERG DEVICE_NAME " ======================demoexit======================\n");
}


module_init(demo_init);
module_exit(demo_exit);
MODULE_LICENSE("GPL");
/***********************************************END*******************************************************/

编译驱动程序依赖linux内核源码环境,需要把驱动C文件放在linux源码目录中,通过编译linux内核的方式得到驱动ko文件。


为了得到驱动ko,我们在easyboard/corelinux/v3ssdk/linux-3.4/drivers/char目录下面
创建一个demo_driver的文件夹,并把demo_driver.c程序拷贝到demo_driver的文件夹中。

4.编写makefile

我们通过编译linux内核的方式得到驱动ko文件,为了在编译内核时得到相应的驱动,我们需要在linux-3.4内核代码中增加和修改Makefile文件(Makefile的作用指定了工程编译的方法和步骤)。
首先我们
修改easyboard/corelinux/v3ssdk/linux-3.4/drivers/char目录下Makefile文件,在Makefile文件内容最末行加入一行代码:

obj    += demo_driver/

这句代码的意思是:编译内核时,子目录demo_driver/下的文件也将进行编译。


我们在easyboard/corelinux/v3ssdk/linux-3.4/drivers/char/demo_driver中
创建一个Makefile文件,同时在Makefile文件中加入一行代码:

obj-m		+= demo_driver.o

这句代码的意思是:编译当前目录中的demo_driver.c文件,输出一个demo_driver.ko的驱动文件。


准备好demo_driver.c文件和Makefile文件后,我们
执行编译内核指令

./linux_docker_build.sh

内核编译需要等待10分钟左右。


经过上述一波操作,我们得到了
demo_driver.ko的驱动文件


到目前为止我们的代码设计工作
完成了50% ,如下图所示:

5.编写应用程序

编写一个demo_app.c的应用程序,程序源码如下:

/**
*********************************************************************************************************
*                                        		demo_driver
*                                      (c) Copyright 2021-2031
*                                         All Rights Reserved
*
* @File    : 
* @By      : liwei
* @Version : V0.01
* 
*********************************************************************************************************
**/

/**********************************************************************************************************
Includes 
**********************************************************************************************************/
#include <stdio.h> 
#include <string.h> 
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h> 
#include <fcntl.h> 
#include <unistd.h>



/***********************************************************************************************************
* @描述	:  
***********************************************************************************************************/
int main(int arvc, char *argv[])
{
	int fd;
	int value = 0;
	printf("==========demo_test==================\n");
	//打开驱动 
	fd = open("/dev/demo_driver",O_RDWR);

	while(1)
	{
		//执行驱动读操作
		read(fd,&value,4);
		sleep(1);
		//执行驱动写操作
		write(fd,&value,4);
		sleep(1);	
		
		printf("==========run==================\n");
	}
	return 0;

}
/***********************************************END*******************************************************/

将应用程序源码放在虚拟机的任意一个目录中如:/home/easyboard/work/demo

然后我们在终端中进入/home/easyboard/work/demo目录,在该目录下执行如下gcc编译指令

arm-buildroot-linux-gnueabihf-gcc -o demo_app demo_app.c

于是我们得到一个demo_app可执行文件


在虚拟机中我们利用交叉编译工具,直接编译即可得到V3S目标板的可执行文件。


到目前为止我们的代码设计工作
完成100%,如下图所示:

6.安装驱动及运行应用程序

经过上述操作,我们得到了demo_driver.ko和demo_app两个文件,我们使用SecureCRTPortable工具将这两个文件传输到V3S开发板中。(传输手段不限,用自己熟悉的方法将文件复制到开发板中即可)


完成文件传输后,我们需要先安装我们编译的驱动ko文件,然后运行测试程序,操作流程如下:

操作一:执行安装驱动指令:

insmod demo_driver.ko 


操作二:执行创建文件节点指令:

mknod /dev/demo_driver c 188 0

188的是设备号,我们在设计的驱动C文件中有如下定义:

/**********************************************************************************************************
Define
**********************************************************************************************************/
#define    DRIVER_MAJOR     188
#define    DEVICE_NAME     "demo_driver"

操作三(可选):执行查看驱动设备指令:

ls /dev

此时我们看到Linux内核中已经包含了我们驱动设备,如下图所示:

操作四:执行修改demo_app文件权限指令:

chmod 777 demo_app

操作五:执行运行demo_app指令:

./demo_app

demo_app运行结果如下:


注意:设备重启后,需要重新加载驱动!

7.总结

编译驱动程序依赖linux内核源码环境,我们设计的驱动文件放需要在linux源码目录中,同时编写Makefile文件,最终通过编译内核的方式得到驱动ko文件。

在虚拟机中使用交叉编译工具,可以编译得到可执行文件。

创作不易希望朋友们点赞,转发,评论,关注。
您的点赞,转发,评论,关注将是我持续更新的动力
作者:李巍
Github:liyinuoman2017
CSDN:liyinuo2017
今日头条:程序猿李巍

相关推荐

ubuntu22.04安装NVIDIA、CUDA、CUDNN详细步骤

1.查看GPU及驱动版本号查看GPU:命令:lspci|grep-invidia查看驱动版本...

黑苹果10.13.6(17G66)如何升级到17G10021安装nVidia官方显卡驱动

近期从苹果AppStore下载的macOSHighSierra10.13.6系统安装文件版本号为17G66:对于使用nVidia显卡的用户来说是个不小的麻烦,因为这个版本号没有对应的NV官方驱...

能跑源码,还提供数据集:这里有一个入门企业级验证码识别项目

机器之心专栏作者:kerlomz网上关于验证码识别的开源项目众多,但大多是学术型文章或者仅仅是一个测试demo,那么企业级的验证码识别究竟是怎样的呢?1.前言网上关于验证么识别的开源项目众多,但大...

GPU卡驱动和CUDA安装教程

前置操作,禁用nouveau%新建一个配置文件sudovim/etc/modprobe.d/blacklist-nouveau.conf%在该配置文件中输入i,写入以下内容bl...

OpenCV下载和安装(包含所有平台)

在OpenCV官方网站可以下载最新的且完整的源码以及大部分的release版本源码。安装...

GPU 要下载哪个驱动?

安装正确合适的GPU驱动至关重要,关系着是否能正常使用GPU显示或者是加速运算等工作。各型号GPU皆可从NVIDIA官方网站下载到适合的GPU版本。通过选择GPU型号、操作系统,即可找到适合自己系统...

【Python深度学习系列】Win10下CUDA+cuDNN+Tensorflow安装与配置

这是我的第292篇...

Ubuntu 20.04 CUDA&amp;cuDNN安装方法

1、安装显卡驱动输入nvidia-smi命令查看支持的cuda版本如果有驱动显示以下信息:如果没有,则会显示以下信息:如果无法查看,则说明尚未安装nvidia驱动,点击附加驱动,选择对应版本的驱动即可...

windows下安装大模型加速包flash-attn

Flash-attn(FlashAttention),作为一种用于神经网络模型的注意力机制,在处理序列数据时有显著的优势,可以提高计算效率并减少内存使用,特别是Transformer模型。它通过优化...

NVIDIA App上线 映众显卡最佳实用工具箱

本周,NVIDIA发布了全新正式版的NVIDIAApp,带来了一系列优化和功能更新,让用户体验更加流畅。无论是游戏玩家还是内容创作者,这款App都能提供更便捷的操作和更强的性能。优化与整合:界面简洁,...

tensorflow GPU环境安装踩坑日记

前言:最近做一个TensorFlow的开源项目,用CPU跑的话,要消耗太多的时间,于是有了这篇配置GPU环境的踩坑日志...

小白也能搞定!Windows10上CUDA9.0+CUDNN7.0.5的完美安装教程

前言:为什么要在本地电脑安装CUDA,CUDA是什么的,用来做什么?我想,点击标题进来的小伙伴,应该都清楚这些。不管你是用来做什么,或者跟我一样为了跑Tensorflow的ObjectDe...

CUDA安装以及CUDNN安装-基于Windows10

PC端配置深度学习环境本身不太麻烦,但是如果想要使用GPU加速,那么就有点麻烦了。一是因为CUDA以及CUDNN的下载很麻烦,因为服务器在国外;二是因为各种版本的匹配问题,因为各种版本匹配的涉及到硬件...

腾讯版Sora开源后被提速8倍!官方点赞并预告:下月上新图生视频

提速8倍!速度更快、效果更好的混元视频模型——...

快贴——让iPhone与Windows之间的协作变得高效

写在前面:1.软件宣称采用了端对端加密技术,但本人不是开发者,所以不对软件的安全性做评价,仅从功能角度考虑,如果你手持iPhone,日常办公电脑是Windows,或者需要安卓手机与MAC电脑之间进行实...