gpt4 book ai didi

c - 试图在 Linux 上关闭 sleep

转载 作者:IT王子 更新时间:2023-10-29 00:07:02 25 4
gpt4 key购买 nike

我需要调查/测试 Linux 上某些代码在 close 可能被信号处理程序(有或没有 SA_RESTART)中断的情况下的行为。让 close 系统调用休眠一段可测量的时间窗口最方便的设置是什么,在此期间我可以尝试用信号触发进程?一些想法:

  • 故意缓慢/无响应的 NFS 安装
  • 自定义 FUSE 驱动程序

但是由于这些设置起来有点麻烦,我想知道是否有更多现成的东西可以提供所需的行为。

最佳答案

如果没有人有更好的主意...

您可以实现自己的字符设备驱动程序。从 Linux Device Drivers (3rd edition) 中第 3 章的模板开始,并调整它除了在 close() 上阻塞一段时间外什么都不做。 (您可以使用第 7 章中的 msleepmsleep_interruptible 来进行阻塞。)

实际上,如果没有其他人提出其他建议,我可能可以通过调整我已有的一些现有代码来快速完成它。您多久需要它?

[编辑]

好的,试试这个...

生成文件:

ifneq ($(KERNELRELEASE),)
obj-m := closer.o

else
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)

default: modules

%:
$(MAKE) -C $(KERNELDIR) M=$(PWD) "$@"

.PHONY: default
endif

closer.c:

#include <linux/init.h>
#include <linux/module.h>
#include <linux/miscdevice.h>
#include <linux/delay.h>
#include <linux/fs.h>

MODULE_DESCRIPTION("Block-on-close driver");
MODULE_AUTHOR("Nemo <nemo@self-evident.org>");
MODULE_LICENSE("GPL");
#define VERSION "20110705"
MODULE_VERSION(VERSION);

#define MY_NAME "closer"

int my_open(struct inode *, struct file *);
int my_release(struct inode *, struct file *);
ssize_t my_read(struct file *, char __user *, size_t, loff_t *);
ssize_t my_write(struct file *, const char __user *, size_t, loff_t *);

static struct file_operations my_fops = {
.owner = THIS_MODULE,
.open = my_open,
.read = my_read,
.write = my_write,
.release = my_release,
};

static struct miscdevice my_dev;

int __init
my_init(void)
{
int err = 0;

printk(KERN_INFO "%s: loading version %s\n", MY_NAME, VERSION);

my_dev.minor = MISC_DYNAMIC_MINOR;
my_dev.name = MY_NAME;
my_dev.fops = &my_fops;
err = misc_register(&my_dev);

if (err)
printk(KERN_ERR "%s: misc_register failed, error %d\n", MY_NAME, err);

return err;
}

int
my_open(struct inode *inode, struct file *filp)
{
return 0;
}

ssize_t
my_read(struct file *file, char __user *p, size_t n, loff_t *off) {
return 0;
}

ssize_t
my_write(struct file *file, const char __user *p, size_t n, loff_t *off) {
return n;
}

int
my_release(struct inode *inode, struct file *filp)
{
int err = 0;
/* 10 second sleep, interruptible. */
if (msleep_interruptible(10 * 1000) > 0)
err = -EINTR;

return err;
}

void __exit
my_exit(void)
{
misc_deregister(&my_dev);
printk(KERN_INFO "%s: unloaded\n", MY_NAME);
}

module_init(my_init);
module_exit(my_exit);

使用“insmod closer.o”加载模块。如果你有一个相当现代/完整的 Linux 环境,udev 将自动唤醒并生成/dev/closer。如果没有,您可以自己创 build 备节点:

mknod /dev/closer c `tr : ' ' </sys/class/misc/closer/dev`

(即/sys/class/misc/closer/dev 表示要使用的major:minor。)

像/dev/null一样读写工作;即,任何读取都为 EOF,任何写入均成功。

我已经验证“cat close() 中阻塞了 10 秒。我还没有创建一个测试来捕获 SIGINT(或其他)并验证它是否实际导致 EINTR

基于 2.6.32 内核构建。让我知道它如何为您服务。

关于c - 试图在 Linux 上关闭 sleep ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6811039/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com