+ i386-math-emu-fix-must_checks.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled

     i386/math-emu: fix must_checks

has been added to the -mm tree.  Its filename is

     i386-math-emu-fix-must_checks.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: i386/math-emu: fix must_checks
From: Randy Dunlap <rdunlap@xxxxxxxxxxxx>

Fix __must_check warnings in i386/math-emu.

Signed-off-by: Randy Dunlap <rdunlap@xxxxxxxxxxxx>
Cc: Andi Kleen <ak@xxxxxx>
Cc: Chuck Ebbert <76306.1226@xxxxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 arch/i386/math-emu/fpu_emu.h    |    1 +
 arch/i386/math-emu/fpu_entry.c  |    3 ++-
 arch/i386/math-emu/fpu_system.h |    1 +
 arch/i386/math-emu/load_store.c |    2 ++
 arch/i386/math-emu/reg_ld_str.c |   15 ++++++++++-----
 5 files changed, 16 insertions(+), 6 deletions(-)

diff -puN arch/i386/math-emu/fpu_emu.h~i386-math-emu-fix-must_checks arch/i386/math-emu/fpu_emu.h
--- a/arch/i386/math-emu/fpu_emu.h~i386-math-emu-fix-must_checks
+++ a/arch/i386/math-emu/fpu_emu.h
@@ -57,6 +57,7 @@
 #define TAG_Special	Const(2)	/* De-normal, + or - infinity,
 					   or Not a Number */
 #define TAG_Empty	Const(3)	/* empty */
+#define TAG_Error	Const(0x80)	/* probably need to abort */
 
 #define LOADED_DATA	Const(10101)	/* Special st() number to identify
 					   loaded data (not on stack). */
diff -puN arch/i386/math-emu/fpu_entry.c~i386-math-emu-fix-must_checks arch/i386/math-emu/fpu_entry.c
--- a/arch/i386/math-emu/fpu_entry.c~i386-math-emu-fix-must_checks
+++ a/arch/i386/math-emu/fpu_entry.c
@@ -742,7 +742,8 @@ int save_i387_soft(void *s387, struct _f
   S387->fcs &= ~0xf8000000;
   S387->fos |= 0xffff0000;
 #endif /* PECULIAR_486 */
-  __copy_to_user(d, &S387->cwd, 7*4);
+  if (__copy_to_user(d, &S387->cwd, 7*4))
+    return -1;
   RE_ENTRANT_CHECK_ON;
 
   d += 7*4;
diff -puN arch/i386/math-emu/fpu_system.h~i386-math-emu-fix-must_checks arch/i386/math-emu/fpu_system.h
--- a/arch/i386/math-emu/fpu_system.h~i386-math-emu-fix-must_checks
+++ a/arch/i386/math-emu/fpu_system.h
@@ -68,6 +68,7 @@
 
 #define FPU_access_ok(x,y,z)	if ( !access_ok(x,y,z) ) \
 				math_abort(FPU_info,SIGSEGV)
+#define FPU_abort		math_abort(FPU_info, SIGSEGV)
 
 #undef FPU_IGNORE_CODE_SEGV
 #ifdef FPU_IGNORE_CODE_SEGV
diff -puN arch/i386/math-emu/load_store.c~i386-math-emu-fix-must_checks arch/i386/math-emu/load_store.c
--- a/arch/i386/math-emu/load_store.c~i386-math-emu-fix-must_checks
+++ a/arch/i386/math-emu/load_store.c
@@ -227,6 +227,8 @@ int FPU_load_store(u_char type, fpu_addr
     case 027:      /* fild m64int */
       clear_C1();
       loaded_tag = FPU_load_int64((long long __user *)data_address);
+      if (loaded_tag == TAG_Error)
+	return 0;
       FPU_settag0(loaded_tag);
       break;
     case 030:     /* fstenv  m14/28byte */
diff -puN arch/i386/math-emu/reg_ld_str.c~i386-math-emu-fix-must_checks arch/i386/math-emu/reg_ld_str.c
--- a/arch/i386/math-emu/reg_ld_str.c~i386-math-emu-fix-must_checks
+++ a/arch/i386/math-emu/reg_ld_str.c
@@ -244,7 +244,8 @@ int FPU_load_int64(long long __user *_s)
 
   RE_ENTRANT_CHECK_OFF;
   FPU_access_ok(VERIFY_READ, _s, 8);
-  copy_from_user(&s,_s,8);
+  if (copy_from_user(&s,_s,8))
+    FPU_abort;
   RE_ENTRANT_CHECK_ON;
 
   if (s == 0)
@@ -907,7 +908,8 @@ int FPU_store_int64(FPU_REG *st0_ptr, u_
 
   RE_ENTRANT_CHECK_OFF;
   FPU_access_ok(VERIFY_WRITE,d,8);
-  copy_to_user(d, &tll, 8);
+  if (copy_to_user(d, &tll, 8))
+    FPU_abort;
   RE_ENTRANT_CHECK_ON;
 
   return 1;
@@ -1336,7 +1338,8 @@ u_char __user *fstenv(fpu_addr_modes add
       I387.soft.fcs &= ~0xf8000000;
       I387.soft.fos |= 0xffff0000;
 #endif /* PECULIAR_486 */
-      __copy_to_user(d, &control_word, 7*4);
+      if (__copy_to_user(d, &control_word, 7*4))
+	FPU_abort;
       RE_ENTRANT_CHECK_ON;
       d += 0x1c;
     }
@@ -1359,9 +1362,11 @@ void fsave(fpu_addr_modes addr_modes, u_
   FPU_access_ok(VERIFY_WRITE,d,80);
 
   /* Copy all registers in stack order. */
-  __copy_to_user(d, register_base+offset, other);
+  if (__copy_to_user(d, register_base+offset, other))
+    FPU_abort;
   if ( offset )
-    __copy_to_user(d+other, register_base, offset);
+    if (__copy_to_user(d+other, register_base, offset))
+      FPU_abort;
   RE_ENTRANT_CHECK_ON;
 
   finit();
_

Patches currently in -mm which might be from rdunlap@xxxxxxxxxxxx are

origin.patch
ext4-enable.patch
jbd2-enable.patch
extents_comment_fix.patch
git-acpi.patch
acpi-fix-printk-format-warnings.patch
w1-kconfig-fix.patch
pcmcia-ds-must_check-fixes.patch
acx1xx-wireless-driver.patch
fix-module-taint-flags-listing-in-oops-panic.patch
kernel-doc-fix-function-name-in-usercopyc.patch
uaccessh-match-kernel-doc-and-function-names.patch
i386-math-emu-fix-must_checks.patch
kernel-doc-drop-various-inline-qualifiers.patch
fs-cache-cachefiles-a-cache-that-backs-onto-a-mounted-filesystem-cachefiles-printk-format-warning.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux