Print this page
15254 %ymm registers not restored after signal handler
15367 x86 getfpregs() summons corrupting %xmm ghosts
15333 want x86 /proc xregs support (libc_db, libproc, mdb, etc.)
15336 want libc functions for extended ucontext_t
15334 want ps_lwphandle-specific reg routines
15328 FPU_CW_INIT mistreats reserved bit
15335 i86pc fpu_subr.c isn't really platform-specific
15332 setcontext(2) isn't actually noreturn
15331 need <sys/stdalign.h>
Change-Id: I7060aa86042dfb989f77fc3323c065ea2eafa9ad
Conflicts:
    usr/src/uts/common/fs/proc/prcontrol.c
    usr/src/uts/intel/os/archdep.c
    usr/src/uts/intel/sys/ucontext.h
    usr/src/uts/intel/syscall/getcontext.c

Split Close
Expand all
Collapse all
          --- old/usr/src/lib/libc/i386/gen/siglongjmp.c
          +++ new/usr/src/lib/libc/i386/gen/siglongjmp.c
↓ open down ↓ 20 lines elided ↑ open up ↑
  21   21  
  22   22  /*
  23   23   * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
  24   24   * Use is subject to license terms.
  25   25   */
  26   26  
  27   27  /*      Copyright (c) 1990, 1991 UNIX System Laboratories, Inc. */
  28   28  /*      Copyright (c) 1988 AT&T */
  29   29  /*        All Rights Reserved   */
  30   30  
       31 +/*
       32 + * Copyright 2023 Oxide Computer Company
       33 + */
       34 +
  31   35  #include "lint.h"
  32   36  #include <sys/types.h>
  33   37  #include <sys/ucontext.h>
  34   38  #include <setjmp.h>
  35   39  #include <ucontext.h>
       40 +#include <strings.h>
       41 +#include <upanic.h>
  36   42  #include "libc.h"
  37   43  
  38   44  #pragma weak _siglongjmp = siglongjmp
  39   45  
  40   46  void
  41   47  siglongjmp(sigjmp_buf env, int val)
  42   48  {
       49 +        const char *msg = "siglongjmp(): setcontext() returned";
  43   50          ucontext_t *ucp = (ucontext_t *)env;
  44   51  
  45   52          if (val)
  46   53                  ucp->uc_mcontext.gregs[EAX] = val;
  47   54          else
  48   55                  ucp->uc_mcontext.gregs[EAX] = 1;
  49   56  
       57 +        /*
       58 +         * While unlikely, it is possible that setcontext() may fail for some
       59 +         * reason. If that happens, we will kill the process.
       60 +         */
  50   61          (void) setcontext(ucp);
       62 +        upanic(msg, strlen(msg) + 1);
  51   63  }
    
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX