1. 28 3月, 2006 1 次提交
    • J
      [PATCH] uml: fix segfault on signal delivery · 98c18238
      Jeff Dike 提交于
      This fixes a process segfault where a signal was being delivered such that a
      new stack page needed to be allocated to hold the signal frame.  This was
      tripping some logic in the page fault handler which wouldn't allocate the page
      if the faulting address was more that 32 bytes lower than the current stack
      pointer.  Since a signal frame is greater than 32 bytes, this exercised that
      case.
      
      It's fixed by updating the SP in the pt_regs before starting to copy the
      signal frame.  Since those are the registers that will be copied on to the
      stack, we have to be careful to put the original SP, not the new one which
      points to the signal frame, on the stack.
      Signed-off-by: NJeff Dike <jdike@addtoit.com>
      Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      98c18238
  2. 05 9月, 2005 1 次提交
  3. 15 7月, 2005 1 次提交
    • P
      [PATCH] uml: fix lvalue for gcc4 · bcb01b8a
      Paolo 'Blaisorblade' Giarrusso 提交于
            Russell King <rmk+lkml@arm.linux.org.uk>
      
      This construct is refused by GCC 4, so here's the (corrected) fix.  Thanks to
      Russell for noticing a stupid mistake I did when first sending this.
      
      As he noted, the code is largely suboptimal however it currently works, and
      will be fixed shortly.  Just read the access_ok check on fp which is NULL, or
      the pointer arithmetic below which should be done with a cast to void*:
      
       	frame = (struct rt_sigframe __user *)
       		round_down(stack_top - sizeof(struct rt_sigframe), 16) - 8;
      
      The code shows clearly that has been taken from
      arch/x86_64/kernel/signal.c:setup_rt_frame(), maybe in a bit of a hurry.
      Signed-off-by: NPaolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
      Cc: Jeff Dike <jdike@addtoit.com>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      bcb01b8a
  4. 07 5月, 2005 1 次提交
  5. 06 5月, 2005 1 次提交
    • B
      [PATCH] uml: S390 preparation, abstract host page fault data · c578455a
      Bodo Stroesser 提交于
      This patch removes the arch-specific fault/trap-infos from thread and
      skas-regs.
      
      It adds a new struct faultinfo, that is arch-specific defined in
      sysdep/faultinfo.h.
      
      The structure is inserted in thread.arch and thread.regs.skas and
      thread.regs.tt
      
      Now, segv and other trap-handlers can copy the contents from regs.X.faultinfo
      to thread.arch.faultinfo with one simple assignment.
      
      Also, the number of macros necessary is reduced to
      
      FAULT_ADDRESS(struct faultinfo)
          extracts the faulting address from faultinfo
      
      FAULT_WRITE(struct faultinfo)
          extracts the "is_write" flag
      
      SEGV_IS_FIXABLE(struct faultinfo)
          is true for the fixable segvs, i.e. (TRAP == 14)
          on i386
      
      UPT_FAULTINFO(regs)
          result is (struct faultinfo *) to the faultinfo
          in regs->skas.faultinfo
      
      GET_FAULTINFO_FROM_SC(struct faultinfo, struct sigcontext *)
          copies the relevant parts of the sigcontext to
          struct faultinfo.
      
      On SIGSEGV, call user_signal() instead of handle_segv(), if the architecture
      provides the information needed in PTRACE_FAULTINFO, or if PTRACE_FAULTINFO is
      missing, because segv-stub will provide the info.
      
      The benefit of the change is, that in case of a non-fixable SIGSEGV, we can
      give user processes a SIGSEGV, instead of possibly looping on pagefault
      handling.
      
      Since handle_segv() sikked arch_fixup() implicitly by passing ip==0 to segv(),
      I changed segv() to call arch_fixup() only, if !is_user.
      Signed-off-by: NBodo Stroesser <bstroesser@fujitsu-siemens.com>
      Signed-off-by: NJeff Dike <jdike@addtoit.com>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      c578455a
  6. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4