public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] remember to check return value from __copy_to_user() in cdrom_read_cdda_old()
@ 2004-09-06 21:46 Jesper Juhl
  2004-09-07  8:02 ` Jens Axboe
  0 siblings, 1 reply; 13+ messages in thread
From: Jesper Juhl @ 2004-09-06 21:46 UTC (permalink / raw)
  To: Jens Axboe; +Cc: LKML


Hi,

Here's a patch to ensure that the return value from __copy_to_user() gets 
checked in cdrom_read_cdda_old().
I assume that returning -EFAULT if the copy fails to copy all bytes is an 
appropriate action, but please correct me if I'm wrong.

Signed-off-by: Jesper Juhl <juhl-lkml@dif.dk>

diff -up linux-2.6.9-rc1-bk13-orig/drivers/cdrom/cdrom.c linux-2.6.9-rc1-bk13/drivers/cdrom/cdrom.c
--- linux-2.6.9-rc1-bk13-orig/drivers/cdrom/cdrom.c	2004-08-24 20:44:01.000000000 +0200
+++ linux-2.6.9-rc1-bk13/drivers/cdrom/cdrom.c	2004-09-06 23:41:20.000000000 +0200
@@ -1959,7 +1959,10 @@ static int cdrom_read_cdda_old(struct cd
 		ret = cdrom_read_block(cdi, &cgc, lba, nr, 1, CD_FRAMESIZE_RAW);
 		if (ret)
 			break;
-		__copy_to_user(ubuf, cgc.buffer, CD_FRAMESIZE_RAW * nr);
+		if (__copy_to_user(ubuf, cgc.buffer, CD_FRAMESIZE_RAW * nr)) {
+			kfree(cgc.buffer);
+			return -EFAULT;
+		}
 		ubuf += CD_FRAMESIZE_RAW * nr;
 		nframes -= nr;
 		lba += nr;



I'm wondering if it would make sense to wrap this branch in unlikely() 
since it should rarely fail...?
I should also mention that I've only compile tested this so far.


--
Jesper Juhl


^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2004-09-07 11:43 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-09-06 21:46 [PATCH] remember to check return value from __copy_to_user() in cdrom_read_cdda_old() Jesper Juhl
2004-09-07  8:02 ` Jens Axboe
2004-09-07  9:32   ` Paul Mackerras
2004-09-07  9:34     ` Jens Axboe
2004-09-07  9:59       ` Andrew Morton
2004-09-07 10:09         ` Jens Axboe
2004-09-07 10:12           ` Andrew Morton
2004-09-07 10:15             ` Jens Axboe
2004-09-07 10:23       ` viro
2004-09-07 10:30         ` Jens Axboe
2004-09-07 10:45           ` viro
2004-09-07 11:42             ` Jens Axboe
2004-09-07  9:58     ` Jens Axboe

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox