Linux设备驱动

2021SC@SDUSC

项目环境:

  1. 树莓派4b
  2. Ubuntu Desktop 21.04

字符设备驱动:

只能一个字节一个字节的读写的设备,不能随机读取设备内存中的某一数据,读取数据需要按照先后顺序进行。字符设备是面向流的设备,常见的字符设备如鼠标、键盘、串口、控制台、 LED。 在本实验中,我们实现一个简单的字符设备驱动实验, 并在设备的打开操作中打印主次设备号 。

#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/types.h> /* size_t */
#include <linux/fcntl.h> /* O_ACCMODE */
#include <linux/vmalloc.h>
#include <linux/genhd.h>
#include <linux/blkdev.h>
#include <linux/buffer_head.h> /* invalidate_bdev */
#include <linux/bio.h>
#include <linux/hdreg.h>
#include <linux/slab.h>

#define MY_BLOCK_NAME "demo2_blodev"
#define MY_DEVICE_MAJOR COMPAQ_SMART2_MAJOR
#define MY_BLOCK_CAPACITY (512 * 1024)

struct block_device_operations blodev_fops = {
	.owner = THIS_MODULE};

static unsigned int do_request(struct request_queue *q, struct bio *bio);
static struct request_queue *blodev_queue;

unsigned char blodev_data[MY_BLOCK_CAPACITY];

static struct gendisk *blodev;

static int __init my_init(void)
{
	int ret;

	blodev_queue = blk_alloc_queue(GFP_KERNEL);
	blk_queue_make_request(blodev_queue, do_request);
	if (!blodev_queue)
	{
		ret = -ENOMEM;
		return ret;
	}

	blodev = alloc_disk(1);
	if (!blodev)
	{
		ret = -ENOMEM;
		blk_cleanup_queue(blodev_queue);
		return ret;
	}

	strcpy(blodev->disk_name, MY_BLOCK_NAME);
	blodev->major = MY_DEVICE_MAJOR;
	blodev->first_minor = 0;
	blodev->fops = &
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值