summaryrefslogtreecommitdiff
path: root/include/linux/wait.h
diff options
context:
space:
mode:
authorJens Axboe <axboe@suse.de>2003-12-16 16:12:29 -0800
committerJens Axboe <axboe@suse.de>2003-12-16 16:12:29 -0800
commitf75da5af1c0b41783c8bb078d0ce7a03cc9be826 (patch)
treeb4c5ac457d69db469d740b5ff50141c06934ed3f /include/linux/wait.h
parent314dc1544cc8f810bbe7afe5fcc61260d5ae46cb (diff)
[PATCH] CDROM_SEND_PACKET bug
I just found Yet Another Bug in scsi_ioctl - CDROM_SEND_PACKET puts a kernel pointer in hdr->cmdp, where sg_io() expects to find user address. This worked up until recently because of the memcpy bug, but now it doesn't because we do the proper copy_from_user(). This fix undoes the user copy code from sg_io, and instead makes the SG_IO ioctl copy it locally. This makes SG_IO and CDROM_SEND_PACKET agree on the calling convention, and everybody is happy. I've tested that both cdrecord -dev=/dev/hdc -inq and cdrecord -dev=ATAPI:/dev/hdc -inq works now. The former will use SG_IO, the latter CDROM_SEND_PACKET (and incidentally would work in both 2.4 and 2.6, if it wasn't for CDROM_SEND_PACKET sucking badly in 2.4).
Diffstat (limited to 'include/linux/wait.h')
0 files changed, 0 insertions, 0 deletions