public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* might_sleep() in copy_{from,to}_user and friends?
@ 2002-11-01 12:02 Arnd Bergmann
  2002-11-01 10:10 ` Jaroslav Kysela
  2002-11-01 10:51 ` Andrew Morton
  0 siblings, 2 replies; 8+ messages in thread
From: Arnd Bergmann @ 2002-11-01 12:02 UTC (permalink / raw)
  To: kernel-janitor-discuss, Linux Kernel; +Cc: Jaroslav Kysela

I have been looking for more places in 2.5 that can be marked 
might_sleep() and noticed that all the functions in asm/uaccess.h
are not marked although they sleep if the memory they access
has to be paged in.

After adding might_sleep() in ten places in asm-i386/uaccess.h
and arch/i386/lib/usercopy.c, I have been running this kernel
for about two weeks. So far, I have found only one place where
the kernel actually hits this and that one is trivially
fixable (maintainer cc'd, fix see below).

The question is if we can expect to find more bugs like
that if we have might_sleep() in uaccess.h or if the 
extra cycles and the work of changing ~100 places (for all
architectures) are just not worth it.

	Arnd <><

===== sound/core/pcm_native.c 1.17 vs edited =====
--- 1.17/sound/core/pcm_native.c	Sun Oct 13 21:19:17 2002
+++ edited/sound/core/pcm_native.c	Fri Nov  1 12:43:38 2002
@@ -2014,8 +2014,6 @@
 			n = snd_pcm_playback_hw_avail(runtime);
 		else
 			n = snd_pcm_capture_avail(runtime);
-		if (put_user(n, res))
-			err = -EFAULT;
 		break;
 	case SNDRV_PCM_STATE_XRUN:
 		err = -EPIPE;
@@ -2026,6 +2024,9 @@
 		break;
 	}
 	spin_unlock_irq(&runtime->lock);
+	if (!ret)
+		if (put_user(n, res))
+			err = -EFAULT;
 	return err;
 }
 		


^ permalink raw reply	[flat|nested] 8+ messages in thread
* Re: might_sleep() in copy_{from,to}_user and friends?
@ 2002-11-01 13:47 Manfred Spraul
  2002-11-01 16:49 ` Arnd Bergmann
  0 siblings, 1 reply; 8+ messages in thread
From: Manfred Spraul @ 2002-11-01 13:47 UTC (permalink / raw)
  To: Arnd Bergmann; +Cc: linux-kernel

Arnd wrote:
> I have been looking for more places in 2.5 that can be marked 
> might_sleep() and noticed that all the functions in asm/uaccess.h
> are not marked although they sleep if the memory they access
> has to be paged in.
> 

Good idea.
There is some abuse of __get_user to identify bad pointers:
show_registers in the oops codepath, mm/slab.c in the /proc/slabinfo code.

Could you omit the test from the __ versions?

--
	Manfred


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

end of thread, other threads:[~2002-11-01 22:32 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-11-01 12:02 might_sleep() in copy_{from,to}_user and friends? Arnd Bergmann
2002-11-01 10:10 ` Jaroslav Kysela
2002-11-01 10:51 ` Andrew Morton
2002-11-01 14:13   ` Dave Jones
2002-11-01 14:42   ` Arnd Bergmann
2002-11-01 22:34   ` Randy.Dunlap
  -- strict thread matches above, loose matches on Subject: below --
2002-11-01 13:47 Manfred Spraul
2002-11-01 16:49 ` Arnd Bergmann

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