I'd like to see something like:
struct block_device_operations {
        /* ... */
        int (*dump) (kdev_t, char *, size_t, loff_t *);
};
This would allow projects such as LKCD to use a specific dump
device associated to a block device driver.  This dump driver
writes data out directly to disk at a specific offset.  The
reason for having it in the block_device_operations table is
to directly attach it to the lower-level disk driver rather
than going through the file_operations table.  In theory, I'd
also like to see something similar for character devices, but
there is no table mechanism for this currently beyond
file_operations.
Then we could add our own IDE dump function pointer into ide_fops,
for example, and inevitably put our code into the IDE disk driver
without changing the rest of the driver functionality, but allowing
direct writes to the disk.  The same would apply to SCSI disks.
Then all maintainers can approve the dump mechanisms before
including them into any driver release.
It would also mean that dumping wouldn't be allowed to devices
that don't have a dump function pointer, which is better than
trying to use the standard write() path for all devices.
The patch for the function pointer is the easy part, the dump
function pointer code is obviously more significant.  Either
way, I can get started on those.
The arguments to dump can be different, it's the purpose that
I'm concerned with.  Any other suggestion is fine ...
Thoughts?
--Matt
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/