ACPI: Fix bound checks for copy_from_user in the acpi /proc code
authorArjan van de Ven <arjan@linux.intel.com>
Sat, 26 Sep 2009 18:50:25 +0000 (20:50 +0200)
committerLen Brown <len.brown@intel.com>
Sat, 3 Oct 2009 04:59:12 +0000 (00:59 -0400)
The ACPI /proc write() code takes an unsigned length argument like any write()
function, but then assigned it to a *signed* integer called "len".
Only after this is a sanity check for len done to make it not larger than 4.

Due to the type change a len < 0 is in principle also possible; this patch
adds a check for this.

Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
Signed-off-by: Len Brown <len.brown@intel.com>
drivers/acpi/proc.c

index d0d550d22a6d43a14ccecec6658e9fb2773d6b70..f8b6f555ba52ba328d43efca6c5926831a663d06 100644 (file)
@@ -398,6 +398,8 @@ acpi_system_write_wakeup_device(struct file *file,
 
        if (len > 4)
                len = 4;
+       if (len < 0)
+               return -EFAULT;
 
        if (copy_from_user(strbuf, buffer, len))
                return -EFAULT;