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/makectxt.c
          +++ new/usr/src/lib/libc/i386/gen/makectxt.c
↓ open down ↓ 17 lines elided ↑ open up ↑
  18   18   *
  19   19   * CDDL HEADER END
  20   20   */
  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) 1988 AT&T */
  28      -/*        All Rights Reserved   */
       28 +/*        All Rights Reserved   */
  29   29  
       30 +/*
       31 + * Copyright 2023 Oxide Computer Company
       32 + */
       33 +
  30   34  #pragma weak _makecontext = makecontext
  31   35  
  32   36  #include "lint.h"
  33   37  #include <stdarg.h>
  34   38  #include <ucontext.h>
  35   39  #include <sys/stack.h>
       40 +#include <sys/auxv.h>
       41 +#include <errno.h>
       42 +#include "libc.h"
  36   43  
  37   44  /*
  38   45   * The ucontext_t that the user passes in must have been primed with a
  39   46   * call to getcontext(2), have the uc_stack member set to reflect the
  40   47   * stack which this context will use, and have the uc_link member set
  41   48   * to the context which should be resumed when this context returns.
  42   49   * When makecontext() returns, the ucontext_t will be set to run the
  43   50   * given function with the given parameters on the stack specified by
  44   51   * uc_stack, and which will return to the ucontext_t specified by uc_link.
  45   52   */
↓ open down ↓ 62 lines elided ↑ open up ↑
 108  115  }
 109  116  
 110  117  
 111  118  static void
 112  119  resumecontext(void)
 113  120  {
 114  121          ucontext_t uc;
 115  122  
 116  123          (void) getcontext(&uc);
 117  124          (void) setcontext(uc.uc_link);
      125 +}
      126 +
      127 +/*
      128 + * This is the ISA-specific allocation logic for allocating and setting up an
      129 + * extended ucontext_t. In particular, right now we need to allocate and add
      130 + * space for the UC_XSAVE member if we have the appropriate hardware support.
      131 + * The i386 / amd64 versions could be consolidated in a single x86 impl, but we
      132 + * don't have that right now.
      133 + */
      134 +ucontext_t *
      135 +ucontext_alloc(uint32_t flags)
      136 +{
      137 +        boolean_t do_xsave = B_FALSE;
      138 +        size_t to_alloc = sizeof (ucontext_t);
      139 +        ucontext_t *ucp;
      140 +
      141 +        if (flags != 0) {
      142 +                errno = EINVAL;
      143 +                return (NULL);
      144 +        }
      145 +
      146 +        /*
      147 +         * This value isn't really 100% accurate. The xsave size is basically
      148 +         * the worst case that we can have. The XMM / xsave structures aren't
      149 +         * included in here, but are going to be enough to cover this. We can
      150 +         * probably try to do a little better and should consider asking the
      151 +         * kernel for something more accurate. In particular, the problem with
      152 +         * tis is that it doesn't account for the right size of future-looking
      153 +         * dynamic things, but then again neither does rtld. We'll deal with
      154 +         * this when we have support for the xfd MSR and actually use it. For
      155 +         * more information see uts/intel/os/fpu.c's big theory statement.
      156 +         */
      157 +        switch (___getauxval(AT_SUN_FPTYPE)) {
      158 +        case AT_386_FPINFO_XSAVE:
      159 +        case AT_386_FPINFO_XSAVE_AMD:
      160 +                do_xsave = B_TRUE;
      161 +                to_alloc += ___getauxval(AT_SUN_FPSIZE);
      162 +                break;
      163 +        default:
      164 +                break;
      165 +        }
      166 +
      167 +        ucp = calloc(1, to_alloc);
      168 +        if (ucp == NULL) {
      169 +                return (NULL);
      170 +        }
      171 +
      172 +        if (do_xsave) {
      173 +                uintptr_t addr = (uintptr_t)ucp;
      174 +                ucp->uc_xsave = addr + sizeof (ucontext_t);
      175 +        }
      176 +
      177 +        return (ucp);
      178 +}
      179 +
      180 +void
      181 +ucontext_free(ucontext_t *ucp)
      182 +{
      183 +        free(ucp);
 118  184  }
    
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX