Module Name: src Committed By: riastradh Date: Mon Mar 28 12:39:10 UTC 2022
Modified Files: src/sys/kern: subr_devsw.c src/sys/miscfs/specfs: spec_vnops.c src/sys/sys: conf.h Log Message: driver(9): New devsw d_cancel op to interrupt I/O before close. If specified, when revoking a device node or closing its last open node, specfs will: 1. Call d_cancel, which should return promptly without blocking. 2. Wait for all concurrent d_read/write/ioctl/&c. to drain. 3. Call d_close. Otherwise, specfs will: 1. Call d_close. 2. Wait for all concurrent d_read/write/ioctl/&c. to drain. This fallback is problematic because often parts of d_close rely on concurrent devsw operations to have completed already, so it is up to each driver to have its own mechanism for waiting, and the extra step in (2) is almost redundant. But it is still important to ensure that devsw operations are not active by the time a module tries to invoke devsw_detach, because only d_open is protected against that. The signature of d_cancel matches d_close, mostly so we don't raise questions about `why is this different?'; the lwp argument is not useful but we should remove it from open/cancel/close all at the same time. The only way d_cancel should fail, if it does at all, is with ENODEV, meaning the driver doesn't support cancelling outstanding I/O, and will take responsibility for that in d_close. I would make it return void and only have bdev_cancel and cdev_cancel possibly return ENODEV so specfs can detect whether a driver supports it, but this would break the pattern around devsw operation types. Drivers are allowed to omit it from struct bdevsw, struct cdevsw -- if so, it is as if they used a function that just returns ENODEV. XXX kernel ABI change to struct bdevsw/cdevsw requires bump To generate a diff of this commit: cvs rdiff -u -r1.43 -r1.44 src/sys/kern/subr_devsw.c cvs rdiff -u -r1.209 -r1.210 src/sys/miscfs/specfs/spec_vnops.c cvs rdiff -u -r1.159 -r1.160 src/sys/sys/conf.h Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.