Linux 驱动学习笔记1 -- HelloWorld
来源:互联网 发布:windows 10内核源代码 编辑:程序博客网 时间:2024/04/29 03:53
想学习一下驱动,于是找了一个实例HelloWorld,编写自己的第一个驱动程序
1、环境搭建
安装ubuntu系统,打开终端,以root权限进入,命令如下
bory@borya:~$ sudo -s
查看自己linux内核包
root@borya:~# apt-cache search linux-sourcelinux-source - Linux kernel source with Ubuntu patcheslinux-source-3.0.0 - Linux kernel source for version 3.0.0 with Ubuntu patches
本机的内核包是 linux-source-3.0.0
接着下载内核源码包
root@borya:~# apt-get install linux-source-3.0.0
下载完成后,先cs到/usr/src目录,再解压linux-source-3.0.0.tar.bz2
root@borya:~# cd /usr/src/root@borya:/usr/src# lslinux-headers-3.0.0-12 linux-source-3.0.0 vboxguest-4.1.16linux-headers-3.0.0-12-generic linux-source-3.0.0.tar.bz2root@borya:/usr/src# tar jxvf linux-source-3.0.0.tar.bz2
接下来编译 oldconfig
root@borya:/usr/src/linux-source-3.0.0# make oldconfig
再编译 bzImage,这个大概需要1个多小时
root@borya:/usr/src/linux-source-3.0.0# make bzImage
继续编译modules,也需要1个多小时
root@borya:/usr/src/linux-source-3.0.0# make modules
最后是安装modules
root@borya:/usr/src/linux-source-3.0.0# make modules_install
到目前为止,环境已经搭建完毕,下面是我们第一个驱动程序HelloWorld
2、运行驱动程序HelloWorld
在自己任意工作目录下,新建一个目录test。
编写hello.c
#include "linux/init.h"#include "linux/module.h"static int hello_init(void){ printk(KERN_ALERT "Hello World linux_driver_module\n"); return 0;}static void hello_exit(void){ printk(KERN_ALERT "This is first step linux_driver_module\n");}module_init(hello_init);module_exit(hello_exit);
下面编写Makefile文件
ifneq ($(KERNELRELEASE),)obj-m := hello.oelseKERNELDIR ?= /lib/modules/$(shell uname -r)/buildPWD := $(shell pwd)default: $(MAKE) -C $(KERNELDIR) M=$(PWD) modulesendif
解释一下,$(shell uname -r)是指你在终端输入shell命令uname -r输出的内容,实际是一个目录名,$(shell pwd)是指当前路径
最后一步就是make了
bory@borya:~/driver/hello$ make
你可以ls查看一下make以后多了哪些文件
当然还不够,我们还没有看到属性的HelloWorld。用insmod命令将hello.ko装载到内核中
bory@borya:~/driver/hello$ insmod ./hello.ko
好像没有HelloWorld的啊,好,我们进入日志文件看看,打开/var/log/syslog就会看到
Jul 9 21:30:36 borya kernel: [20377.621046] Hello World linux_driver_module
卸载hello
root@borya:~/driver/hello$rmmod ./hello.ko
再次打开/var/log/syslog就看到最后一行
Jul 9 22:06:51 borya kernel: [22551.983955] This is first step linux_driver_module
到此位置,linux第一个驱动程序完美结束!
- Linux 驱动学习笔记1 -- HelloWorld
- 驱动学习笔记(一)HelloWorld
- linux驱动学习笔记1
- linux驱动学习笔记1
- python学习笔记-(1)linux下的helloworld
- Linux 驱动学习笔记
- linux驱动学习笔记
- linux设备驱动--HelloWorld
- linux设备驱动--HelloWorld
- linux设备驱动--HelloWorld
- helloworld - linux驱动
- linux设备驱动--HelloWorld
- Linux驱动-HelloWorld
- Linux驱动开发HelloWorld
- linux驱动之helloworld
- linux驱动 -helloworld
- helloworld驱动学习
- android学习笔记1:HelloWorld
- 精妙的SQL语句
- 周颂·丝衣
- 优化Linux的内核参数来提高服务器并发处理能力
- Myeclipse知识
- __cdecl,__stdcall,__fastcall,__pascal
- Linux 驱动学习笔记1 -- HelloWorld
- TabControl.TabCount 属性
- Eclipse下安装Flex插件
- Linux Web服务器网站故障分析常用的命令
- 导出类引起的 DLL Hell
- 关于JQUERY里的AJAX缓存和同步异步问题
- [sql server] 行转列问题总结1 - 行转列
- 安装Tomcat提示Failed to install Tomcat6 service...的解决办法
- DLL 导出类的问题