嵌入式驱动篇--Hello测试驱动

编写测试Hello测试驱动

#include <linux/init.h>
#include <linux/module.h>

static int __init hello_init(void){
	printk(KERN_ALERT"Hello,world!\n");
	return 0;
}
module_init(hello_init);

static void __exit hello_exit(void){
	printk(KERN_ALERT"Goodbye,cruel world\n");
}
module_exit(hello_exit);

MODULE_AUTHOR("Barry Song <21cnbao@gmail.com>");
MODULE_LICENSE("GPL v2");
MODULE_DESCRIPTION("A simple Hello world Module");
MODULE_ALIAS("a simplest module");

编写Makefile

rpi3b_path=~/rpi3b
toolchain_path=$(rpi3b_path)/toolchain
toolchain_source=$(toolchain_path)/toolchain-rpi32b
cross_compile=$(toolchain_source)/bin/arm-linux-gnueabihf-			
kernel_verber=linux-rpi-4.19.y
kernel_path=$(rpi3b_path)/kernel
kernel_source=$(kernel_path)/$(kernel_verber)

obj-m := hello.o
PWD := $(shell pwd)
KDIR := $(kernel_source)
all :
	make -C $(KDIR) M=$(PWD) modules ARCH=arm COMPILE=$(cross_compile)

clean:
	rm -rf *.ko *.o *.mod.o *.mod.c *.symvers modul*

编译生成驱动 hello.ko
在这里插入图片描述

测试1:动态安装 hello.ko 驱动(sudo insmod hello.ko),然后使用 dmesg 命令打印日志查看
测试2:动态卸载 hello.ko 驱动(sudo rmmod hello.ko),然后使用 dmesg 命令打印日志查看

pi@raspberrypi:~ $ sudo insmod hello.ko
pi@raspberrypi:~ $ 
pi@raspberrypi:~ $ dmesg
......
[104837.097547] rpi_firmware_get_throttled: 12 callbacks suppressed
[104837.097555] Under-voltage detected! (0x00050005)
[104847.497515] rpi_firmware_get_throttled: 12 callbacks suppressed
[104847.497522] Voltage normalised (0x00000000)
[104849.577556] Under-voltage detected! (0x00050005)
[104862.057525] Voltage normalised (0x00000000)
[104864.137577] Under-voltage detected! (0x00050005)
[104874.537545] Voltage normalised (0x00000000)
[104936.084765] Hello,world!
pi@raspberrypi:~ $ sudo rmmod hello.ko
pi@raspberrypi:~ $ 
pi@raspberrypi:~ $ dmesg
......
[104837.097547] rpi_firmware_get_throttled: 12 callbacks suppressed
[104837.097555] Under-voltage detected! (0x00050005)
[104847.497515] rpi_firmware_get_throttled: 12 callbacks suppressed
[104847.497522] Voltage normalised (0x00000000)
[104849.577556] Under-voltage detected! (0x00050005)
[104862.057525] Voltage normalised (0x00000000)
[104864.137577] Under-voltage detected! (0x00050005)
[104874.537545] Voltage normalised (0x00000000)
[104936.084765] Hello,world!
[105002.237668] Goodbye,cruel world
pi@raspberrypi:~ $ 
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值