[PATCH] SGI UV: uv_ptc_proc_write security hole

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Cliff Wickman
Date: Monday, June 23, 2008 - 6:32 am

From: Cliff Wickman <cpw@sgi.com>

Someone could write 0 bytes to /proc/sgi_uv/ptc_statistics,
causing
  optstr[count - 1] = '\0';
to write to who-knows-where.

(Andi Kleen noticed this need from a patch I sent for
 similar code in the ia64 world (sn2_ptc_proc_write()).)

(count less than zero is not possible here, as count is unsigned)

Diffed against 2.6.26-rc6

Signed-off-by: Cliff Wickman <cpw@sgi.com>
---
 arch/x86/kernel/tlb_uv.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Index: linux/arch/x86/kernel/tlb_uv.c
===================================================================
--- linux.orig/arch/x86/kernel/tlb_uv.c
+++ linux/arch/x86/kernel/tlb_uv.c
@@ -492,7 +492,7 @@ static ssize_t uv_ptc_proc_write(struct 
 	long newmode;
 	char optstr[64];
 
-	if (count > 64)
+	if (count == 0 || count > sizeof(optstr))
 		return -EINVAL;
 	if (copy_from_user(optstr, user, count))
 		return -EFAULT;
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH] SGI UV: uv_ptc_proc_write security hole, Cliff Wickman, (Mon Jun 23, 6:32 am)
Re: [PATCH] SGI UV: uv_ptc_proc_write security hole, Ingo Molnar, (Mon Jun 23, 2:13 pm)