de-linting of .s files

   1 /*
   2  * This file and its contents are supplied under the terms of the
   3  * Common Development and Distribution License ("CDDL"), version 1.0.
   4  * You may only use this file in accordance with the terms of version
   5  * 1.0 of the CDDL.
   6  *
   7  * A full copy of the text of the CDDL should have accompanied this
   8  * source.  A copy of the CDDL is also available via the Internet at
   9  * http://www.illumos.org/license/CDDL.
  10  */
  11 /*
  12  * Copyright 2019 Joyent, Inc.
  13  */
  14 
  15 /*
  16  * This file contains the trampolines that are used by KPTI in order to be
  17  * able to take interrupts/trap/etc while on the "user" page table.
  18  *
  19  * We don't map the full kernel text into the user page table: instead we
  20  * map this one small section of trampolines (which compiles to ~13 pages).
  21  * These trampolines are set in the IDT always (so they will run no matter
  22  * whether we're on the kernel or user page table), and their primary job is to
  23  * pivot us to the kernel %cr3 and %rsp without ruining everything.
  24  *
  25  * All of these interrupts use the amd64 IST feature when we have KPTI enabled,
  26  * meaning that they will execute with their %rsp set to a known location, even
  27  * if we take them in the kernel.
  28  *
  29  * Over in desctbls.c (for cpu0) and mp_pc.c (other cpus) we set up the IST
  30  * stack to point at &cpu->cpu_m.mcpu_kpti.kf_tr_rsp. You can see the mcpu_kpti
  31  * (a struct kpti_frame) defined in machcpuvar.h. This struct is set up to be
  32  * page-aligned, and we map the page it's on into both page tables. Using a
  33  * struct attached to the cpu_t also means that we can use %rsp-relative
  34  * addressing to find anything on the cpu_t, so we don't have to touch %gs or
  35  * GSBASE at all on incoming interrupt trampolines (which can get pretty hairy).
  36  *
  37  * This little struct is where the CPU will push the actual interrupt frame.
  38  * Then, in the trampoline, we change %cr3, then figure out our destination
  39  * stack pointer and "pivot" to it (set %rsp and re-push the CPU's interrupt
  40  * frame). Then we jump to the regular ISR in the kernel text and carry on as
  41  * normal.
  42  *
  43  * We leave the original frame and any spilled regs behind in the kpti_frame
  44  * lazily until we want to return to userland. Then, we clear any spilled
  45  * regs from it, and overwrite the rest with our iret frame. When switching
  46  * this cpu to a different process (in hat_switch), we bzero the whole region to
  47  * make sure nothing can leak between processes.
  48  *
  49  * When we're returning back to the original place we took the interrupt later
  50  * (especially if it was in userland), we have to jmp back to the "return
  51  * trampolines" here, since when we set %cr3 back to the user value, we need to
  52  * be executing from code here in these shared pages and not the main kernel
  53  * text again. Even though it should be fine to iret directly from kernel text
  54  * when returning to kernel code, we make things jmp to a trampoline here just
  55  * for consistency.
  56  *
  57  * Note that with IST, it's very important that we always must have pivoted
  58  * away from the IST stack before we could possibly take any other interrupt
  59  * on the same IST (unless it's an end-of-the-world fault and we don't care
  60  * about coming back from it ever).
  61  *
  62  * This is particularly relevant to the dbgtrap/brktrap trampolines, as they
  63  * regularly have to happen from within trampoline code (e.g. in the sysenter
  64  * single-step case) and then return to the world normally. As a result, these
  65  * two are IST'd to their own kpti_frame right above the normal one (in the same
  66  * page), so they don't clobber their parent interrupt.
  67  *
  68  * To aid with debugging, we also IST the page fault (#PF/pftrap), general
  69  * protection fault (#GP/gptrap) and stack fault (#SS/stktrap) interrupts to
  70  * their own separate kpti_frame. This ensures that if we take one of these
  71  * due to a bug in trampoline code, we preserve the original trampoline
  72  * state that caused the trap.
  73  *
  74  * NMI, MCE and dblfault interrupts also are taken on their own dedicated IST
  75  * stacks, since they can interrupt another ISR at any time. These stacks are
  76  * full-sized, however, and not a little kpti_frame struct. We only set %cr3 in
  77  * their trampolines (and do it unconditionally), and don't bother pivoting
  78  * away. We're either going into the panic() path, or we're going to return
  79  * straight away without rescheduling, so it's fine to not be on our real
  80  * kthread stack (and some of the state we want to go find it with might be
  81  * corrupt!)
  82  *
  83  * Finally, for these "special" interrupts (NMI/MCE/double fault) we use a
  84  * special %cr3 value we stash here in the text (kpti_safe_cr3). We set this to
  85  * point at the PML4 for kas early in boot and never touch it again. Hopefully
  86  * it survives whatever corruption brings down the rest of the kernel!
  87  *
  88  * Syscalls are different to interrupts (at least in the SYSENTER/SYSCALL64
  89  * cases) in that they do not push an interrupt frame (and also have some other
  90  * effects). In the syscall trampolines, we assume that we can only be taking
  91  * the call from userland and use swapgs and an unconditional overwrite of %cr3.
  92  * We do not do any stack pivoting for syscalls (and we leave SYSENTER's
  93  * existing %rsp pivot untouched) -- instead we spill registers into
  94  * %gs:CPU_KPTI_* as we need to.
  95  *
  96  * Note that the normal %cr3 values do not cause invalidations with PCIDE - see
  97  * hat_switch().
  98  */
  99 
 100 /*
 101  * The macros here mostly line up with what's in kdi_idthdl.s, too, so if you
 102  * fix bugs here check to see if they should be fixed there as well.
 103  */
 104 
 105 #include <sys/asm_linkage.h>
 106 #include <sys/asm_misc.h>
 107 #include <sys/regset.h>
 108 #include <sys/privregs.h>
 109 #include <sys/psw.h>
 110 #include <sys/machbrand.h>
 111 #include <sys/param.h>
 112 
 113 #if defined(__lint)
 114 
 115 #include <sys/types.h>
 116 #include <sys/thread.h>
 117 #include <sys/systm.h>
 118 
 119 #else   /* __lint */
 120 
 121 #include <sys/segments.h>
 122 #include <sys/pcb.h>
 123 #include <sys/trap.h>
 124 #include <sys/ftrace.h>
 125 #include <sys/traptrace.h>
 126 #include <sys/clock.h>
 127 #include <sys/model.h>
 128 #include <sys/panic.h>
 129 
 130 #if defined(__xpv)
 131 #include <sys/hypervisor.h>
 132 #endif
 133 
 134 #include "assym.h"
 135 
 136         .data
 137         DGDEF3(kpti_enable, 8, 8)
 138         .fill   1, 8, 1
 139 
 140 #if DEBUG
 141         .data
 142 _bad_ts_panic_msg:
 143         .string "kpti_trampolines.s: tr_iret_user but CR0.TS set"
 144 #endif
 145 
 146 .section ".text";
 147 .align MMU_PAGESIZE
 148 
 149 .global kpti_tramp_start
 150 kpti_tramp_start:
 151         nop
 152 
 153 /* This will be set by mlsetup, and then double-checked later */
 154 .global kpti_safe_cr3
 155 kpti_safe_cr3:
 156         .quad 0
 157         SET_SIZE(kpti_safe_cr3)
 158 
 159 /* startup_kmem() will overwrite this */
 160 .global kpti_kbase
 161 kpti_kbase:
 162         .quad KERNELBASE
 163         SET_SIZE(kpti_kbase)
 164 
 165 #define SET_KERNEL_CR3(spillreg)                \
 166         mov     %cr3, spillreg;                 \
 167         mov     spillreg, %gs:CPU_KPTI_TR_CR3;  \
 168         mov     %gs:CPU_KPTI_KCR3, spillreg;    \
 169         cmp     $0, spillreg;                   \
 170         je      2f;                             \
 171         mov     spillreg, %cr3;                 \
 172 2:
 173 
 174 #if DEBUG
 175 #define SET_USER_CR3(spillreg)                  \
 176         mov     %cr3, spillreg;                 \
 177         mov     spillreg, %gs:CPU_KPTI_TR_CR3;  \
 178         mov     %gs:CPU_KPTI_UCR3, spillreg;    \
 179         mov     spillreg, %cr3
 180 #else
 181 #define SET_USER_CR3(spillreg)                  \
 182         mov     %gs:CPU_KPTI_UCR3, spillreg;    \
 183         mov     spillreg, %cr3
 184 #endif
 185 
 186 #define PIVOT_KPTI_STK(spillreg)                \
 187         mov     %rsp, spillreg;                 \
 188         mov     %gs:CPU_KPTI_RET_RSP, %rsp;     \
 189         pushq   T_FRAMERET_SS(spillreg);        \
 190         pushq   T_FRAMERET_RSP(spillreg);       \
 191         pushq   T_FRAMERET_RFLAGS(spillreg);    \
 192         pushq   T_FRAMERET_CS(spillreg);        \
 193         pushq   T_FRAMERET_RIP(spillreg)
 194 
 195 
 196 #define INTERRUPT_TRAMPOLINE_P(errpush) \
 197         pushq   %r13;                           \
 198         pushq   %r14;                           \
 199         subq    $KPTI_R14, %rsp;                \
 200         /* Save current %cr3. */                \
 201         mov     %cr3, %r14;                     \
 202         mov     %r14, KPTI_TR_CR3(%rsp);        \
 203                                                 \
 204         cmpw    $KCS_SEL, KPTI_CS(%rsp);        \
 205         je      3f;                             \
 206 1:                                              \
 207         /* Change to the "kernel" %cr3 */       \
 208         mov     KPTI_KCR3(%rsp), %r14;          \
 209         cmp     $0, %r14;                       \
 210         je      2f;                             \
 211         mov     %r14, %cr3;                     \
 212 2:                                              \
 213         /* Get our cpu_t in %r13 */             \
 214         mov     %rsp, %r13;                     \
 215         and     $(~(MMU_PAGESIZE - 1)), %r13;   \
 216         subq    $CPU_KPTI_START, %r13;          \
 217         /* Use top of the kthread stk */        \
 218         mov     CPU_THREAD(%r13), %r14;         \
 219         mov     T_STACK(%r14), %r14;            \
 220         addq    $REGSIZE+MINFRAME, %r14;        \
 221         jmp     4f;                             \
 222 3:                                              \
 223         /* Check the %rsp in the frame. */      \
 224         /* Is it above kernel base? */          \
 225         mov     kpti_kbase, %r14;               \
 226         cmp     %r14, KPTI_RSP(%rsp);           \
 227         jb      1b;                             \
 228         /* Use the %rsp from the trap frame */  \
 229         mov     KPTI_RSP(%rsp), %r14;           \
 230         and     $(~0xf), %r14;                  \
 231 4:                                              \
 232         mov     %rsp, %r13;                     \
 233         /* %r14 contains our destination stk */ \
 234         mov     %r14, %rsp;                     \
 235         pushq   KPTI_SS(%r13);                  \
 236         pushq   KPTI_RSP(%r13);                 \
 237         pushq   KPTI_RFLAGS(%r13);              \
 238         pushq   KPTI_CS(%r13);                  \
 239         pushq   KPTI_RIP(%r13);                 \
 240         errpush;                                \
 241         mov     KPTI_R14(%r13), %r14;           \
 242         mov     KPTI_R13(%r13), %r13
 243 
 244 #define INTERRUPT_TRAMPOLINE_NOERR              \
 245         INTERRUPT_TRAMPOLINE_P(/**/)
 246 
 247 #define INTERRUPT_TRAMPOLINE                    \
 248         INTERRUPT_TRAMPOLINE_P(pushq KPTI_ERR(%r13))
 249 
 250 /*
 251  * This is used for all interrupts that can plausibly be taken inside another
 252  * interrupt and are using a kpti_frame stack (so #BP, #DB, #GP, #PF, #SS).
 253  *
 254  * We also use this for #NP, even though it uses the standard IST: the
 255  * additional %rsp checks below will catch when we get an exception doing an
 256  * iret to userspace with a bad %cs/%ss.  This appears as a kernel trap, and
 257  * only later gets redirected via kern_gpfault().
 258  *
 259  * We check for whether we took the interrupt while in another trampoline, in
 260  * which case we need to use the kthread stack.
 261  */
 262 #define DBG_INTERRUPT_TRAMPOLINE_P(errpush)     \
 263         pushq   %r13;                           \
 264         pushq   %r14;                           \
 265         subq    $KPTI_R14, %rsp;                \
 266         /* Check for clobbering */              \
 267         cmp     $0, KPTI_FLAG(%rsp);            \
 268         je      1f;                             \
 269         /* Don't worry, this totally works */   \
 270         int     $8;                             \
 271 1:                                              \
 272         movq    $1, KPTI_FLAG(%rsp);            \
 273         /* Save current %cr3. */                \
 274         mov     %cr3, %r14;                     \
 275         mov     %r14, KPTI_TR_CR3(%rsp);        \
 276                                                 \
 277         cmpw    $KCS_SEL, KPTI_CS(%rsp);        \
 278         je      4f;                             \
 279 2:                                              \
 280         /* Change to the "kernel" %cr3 */       \
 281         mov     KPTI_KCR3(%rsp), %r14;          \
 282         cmp     $0, %r14;                       \
 283         je      3f;                             \
 284         mov     %r14, %cr3;                     \
 285 3:                                              \
 286         /* Get our cpu_t in %r13 */             \
 287         mov     %rsp, %r13;                     \
 288         and     $(~(MMU_PAGESIZE - 1)), %r13;   \
 289         subq    $CPU_KPTI_START, %r13;          \
 290         /* Use top of the kthread stk */        \
 291         mov     CPU_THREAD(%r13), %r14;         \
 292         mov     T_STACK(%r14), %r14;            \
 293         addq    $REGSIZE+MINFRAME, %r14;        \
 294         jmp     6f;                             \
 295 4:                                              \
 296         /* Check the %rsp in the frame. */      \
 297         /* Is it above kernel base? */          \
 298         /* If not, treat as user. */            \
 299         mov     kpti_kbase, %r14;               \
 300         cmp     %r14, KPTI_RSP(%rsp);           \
 301         jb      2b;                             \
 302         /* Is it within the kpti_frame page? */ \
 303         /* If it is, treat as user interrupt */ \
 304         mov     %rsp, %r13;                     \
 305         and     $(~(MMU_PAGESIZE - 1)), %r13;   \
 306         mov     KPTI_RSP(%rsp), %r14;           \
 307         and     $(~(MMU_PAGESIZE - 1)), %r14;   \
 308         cmp     %r13, %r14;                     \
 309         je      2b;                             \
 310         /* Were we in trampoline code? */       \
 311         leaq    kpti_tramp_start, %r14;         \
 312         cmp     %r14, KPTI_RIP(%rsp);           \
 313         jb      5f;                             \
 314         leaq    kpti_tramp_end, %r14;           \
 315         cmp     %r14, KPTI_RIP(%rsp);           \
 316         ja      5f;                             \
 317         /* If we were, change %cr3: we might */ \
 318         /* have interrupted before it did. */   \
 319         mov     KPTI_KCR3(%rsp), %r14;          \
 320         mov     %r14, %cr3;                     \
 321 5:                                              \
 322         /* Use the %rsp from the trap frame */  \
 323         mov     KPTI_RSP(%rsp), %r14;           \
 324         and     $(~0xf), %r14;                  \
 325 6:                                              \
 326         mov     %rsp, %r13;                     \
 327         /* %r14 contains our destination stk */ \
 328         mov     %r14, %rsp;                     \
 329         pushq   KPTI_SS(%r13);                  \
 330         pushq   KPTI_RSP(%r13);                 \
 331         pushq   KPTI_RFLAGS(%r13);              \
 332         pushq   KPTI_CS(%r13);                  \
 333         pushq   KPTI_RIP(%r13);                 \
 334         errpush;                                \
 335         mov     KPTI_R14(%r13), %r14;           \
 336         movq    $0, KPTI_FLAG(%r13);            \
 337         mov     KPTI_R13(%r13), %r13
 338 
 339 #define DBG_INTERRUPT_TRAMPOLINE_NOERR          \
 340         DBG_INTERRUPT_TRAMPOLINE_P(/**/)
 341 
 342 #define DBG_INTERRUPT_TRAMPOLINE                \
 343         DBG_INTERRUPT_TRAMPOLINE_P(pushq KPTI_ERR(%r13))
 344 
 345         /*
 346          * These labels (_start and _end) are used by trap.c to determine if
 347          * we took an interrupt like an NMI during the return process.
 348          */
 349 .global tr_sysc_ret_start
 350 tr_sysc_ret_start:
 351 
 352         /*
 353          * Syscall return trampolines.
 354          *
 355          * These are expected to be called on the kernel %gs. tr_sysret[ql] are
 356          * called after %rsp is changed back to the user value, so we have no
 357          * stack to work with. tr_sysexit has a kernel stack (but has to
 358          * preserve rflags, soooo).
 359          */
 360         ENTRY_NP(tr_sysretq)
 361         cmpq    $1, kpti_enable
 362         jne     1f
 363 
 364         mov     %r13, %gs:CPU_KPTI_R13
 365         SET_USER_CR3(%r13)
 366         mov     %gs:CPU_KPTI_R13, %r13
 367         /* Zero these to make sure they didn't leak from a kernel trap */
 368         movq    $0, %gs:CPU_KPTI_R13
 369         movq    $0, %gs:CPU_KPTI_R14
 370 1:
 371         swapgs
 372         sysretq
 373         SET_SIZE(tr_sysretq)
 374 
 375         ENTRY_NP(tr_sysretl)
 376         cmpq    $1, kpti_enable
 377         jne     1f
 378 
 379         mov     %r13, %gs:CPU_KPTI_R13
 380         SET_USER_CR3(%r13)
 381         mov     %gs:CPU_KPTI_R13, %r13
 382         /* Zero these to make sure they didn't leak from a kernel trap */
 383         movq    $0, %gs:CPU_KPTI_R13
 384         movq    $0, %gs:CPU_KPTI_R14
 385 1:
 386         SWAPGS
 387         SYSRETL
 388         SET_SIZE(tr_sysretl)
 389 
 390         ENTRY_NP(tr_sysexit)
 391         /*
 392          * Note: we want to preserve RFLAGS across this branch, since sysexit
 393          * (unlike sysret above) does not restore RFLAGS for us.
 394          *
 395          * We still have the real kernel stack (sysexit does restore that), so
 396          * we can use pushfq/popfq.
 397          */
 398         pushfq
 399 
 400         cmpq    $1, kpti_enable
 401         jne     1f
 402 
 403         /* Have to pop it back off now before we change %cr3! */
 404         popfq
 405         mov     %r13, %gs:CPU_KPTI_R13
 406         SET_USER_CR3(%r13)
 407         mov     %gs:CPU_KPTI_R13, %r13
 408         /* Zero these to make sure they didn't leak from a kernel trap */
 409         movq    $0, %gs:CPU_KPTI_R13
 410         movq    $0, %gs:CPU_KPTI_R14
 411         jmp     2f
 412 1:
 413         popfq
 414 2:
 415         swapgs
 416         sti
 417         sysexit
 418         SET_SIZE(tr_sysexit)
 419 
 420 .global tr_sysc_ret_end
 421 tr_sysc_ret_end:
 422 
 423         /*
 424          * Syscall entry trampolines.
 425          */
 426 
 427 #if DEBUG
 428 #define MK_SYSCALL_TRAMPOLINE(isr)              \
 429         ENTRY_NP(tr_/**/isr);                   \
 430         swapgs;                                 \
 431         mov     %r13, %gs:CPU_KPTI_R13;         \
 432         mov     %cr3, %r13;                     \
 433         mov     %r13, %gs:CPU_KPTI_TR_CR3;      \
 434         mov     %gs:CPU_KPTI_KCR3, %r13;        \
 435         mov     %r13, %cr3;                     \
 436         mov     %gs:CPU_KPTI_R13, %r13;         \
 437         swapgs;                                 \
 438         jmp     isr;                            \
 439         SET_SIZE(tr_/**/isr)
 440 #else
 441 #define MK_SYSCALL_TRAMPOLINE(isr)              \
 442         ENTRY_NP(tr_/**/isr);                   \
 443         swapgs;                                 \
 444         mov     %r13, %gs:CPU_KPTI_R13;         \
 445         mov     %gs:CPU_KPTI_KCR3, %r13;        \
 446         mov     %r13, %cr3;                     \
 447         mov     %gs:CPU_KPTI_R13, %r13;         \
 448         swapgs;                                 \
 449         jmp     isr;                            \
 450         SET_SIZE(tr_/**/isr)
 451 #endif
 452 
 453         MK_SYSCALL_TRAMPOLINE(sys_syscall)
 454         MK_SYSCALL_TRAMPOLINE(sys_syscall32)
 455         MK_SYSCALL_TRAMPOLINE(brand_sys_syscall)
 456         MK_SYSCALL_TRAMPOLINE(brand_sys_syscall32)
 457 
 458         /*
 459          * SYSENTER is special. The CPU is really not very helpful when it
 460          * comes to preserving and restoring state with it, and as a result
 461          * we have to do all of it by hand. So, since we want to preserve
 462          * RFLAGS, we have to be very careful in these trampolines to not
 463          * clobber any bits in it. That means no cmpqs or branches!
 464          */
 465         ENTRY_NP(tr_sys_sysenter)
 466         swapgs
 467         mov     %r13, %gs:CPU_KPTI_R13
 468 #if DEBUG
 469         mov     %cr3, %r13
 470         mov     %r13, %gs:CPU_KPTI_TR_CR3
 471 #endif
 472         mov     %gs:CPU_KPTI_KCR3, %r13
 473         mov     %r13, %cr3
 474         mov     %gs:CPU_KPTI_R13, %r13
 475         jmp     _sys_sysenter_post_swapgs
 476         SET_SIZE(tr_sys_sysenter)
 477 
 478         ENTRY_NP(tr_brand_sys_sysenter)
 479         swapgs
 480         mov     %r13, %gs:CPU_KPTI_R13
 481 #if DEBUG
 482         mov     %cr3, %r13
 483         mov     %r13, %gs:CPU_KPTI_TR_CR3
 484 #endif
 485         mov     %gs:CPU_KPTI_KCR3, %r13
 486         mov     %r13, %cr3
 487         mov     %gs:CPU_KPTI_R13, %r13
 488         jmp     _brand_sys_sysenter_post_swapgs
 489         SET_SIZE(tr_brand_sys_sysenter)
 490 
 491 #define MK_SYSCALL_INT_TRAMPOLINE(isr)          \
 492         ENTRY_NP(tr_/**/isr);                   \
 493         swapgs;                                 \
 494         mov     %r13, %gs:CPU_KPTI_R13;         \
 495         SET_KERNEL_CR3(%r13);                   \
 496         mov     %gs:CPU_THREAD, %r13;           \
 497         mov     T_STACK(%r13), %r13;            \
 498         addq    $REGSIZE+MINFRAME, %r13;        \
 499         mov     %r13, %rsp;                     \
 500         pushq   %gs:CPU_KPTI_SS;                \
 501         pushq   %gs:CPU_KPTI_RSP;               \
 502         pushq   %gs:CPU_KPTI_RFLAGS;            \
 503         pushq   %gs:CPU_KPTI_CS;                \
 504         pushq   %gs:CPU_KPTI_RIP;               \
 505         mov     %gs:CPU_KPTI_R13, %r13;         \
 506         swapgs;                                 \
 507         jmp     isr;                            \
 508         SET_SIZE(tr_/**/isr)
 509 
 510         MK_SYSCALL_INT_TRAMPOLINE(brand_sys_syscall_int)
 511         MK_SYSCALL_INT_TRAMPOLINE(sys_syscall_int)
 512 
 513         /*
 514          * Interrupt/trap return trampolines
 515          */
 516 
 517 .global tr_intr_ret_start
 518 tr_intr_ret_start:
 519 
 520         ENTRY_NP(tr_iret_auto)
 521         cmpq    $1, kpti_enable
 522         jne     tr_iret_kernel
 523         cmpw    $KCS_SEL, T_FRAMERET_CS(%rsp)
 524         je      tr_iret_kernel
 525         jmp     tr_iret_user
 526         SET_SIZE(tr_iret_auto)
 527 
 528         ENTRY_NP(tr_iret_kernel)
 529         /*
 530          * Yes, this does nothing extra. But this way we know if we see iret
 531          * elsewhere, then we've failed to properly consider trampolines there.
 532          */
 533         iretq
 534         SET_SIZE(tr_iret_kernel)
 535 
 536         ENTRY_NP(tr_iret_user)
 537 #if DEBUG
 538         /*
 539          * Panic if we find CR0.TS set. We're still on the kernel stack and
 540          * %cr3, but we do need to swap back to the kernel gs. (We don't worry
 541          * about swapgs speculation here.)
 542          */
 543         pushq   %rax
 544         mov     %cr0, %rax
 545         testq   $CR0_TS, %rax
 546         jz      1f
 547         swapgs
 548         popq    %rax
 549         leaq    _bad_ts_panic_msg(%rip), %rdi
 550         xorl    %eax, %eax
 551         pushq   %rbp
 552         movq    %rsp, %rbp
 553         call    panic
 554 1:
 555         popq    %rax
 556 #endif
 557 
 558         cmpq    $1, kpti_enable
 559         jne     1f
 560 
 561         /*
 562          * KPTI enabled: we're on the user gsbase at this point, so we
 563          * need to swap back so we can pivot stacks.
 564          *
 565          * The swapgs lfence mitigation is probably not needed here
 566          * since a mis-speculation of the above branch would imply KPTI
 567          * is disabled, but we'll do so anyway.
 568          */
 569         swapgs
 570         lfence
 571         mov     %r13, %gs:CPU_KPTI_R13
 572         PIVOT_KPTI_STK(%r13)
 573         SET_USER_CR3(%r13)
 574         mov     %gs:CPU_KPTI_R13, %r13
 575         /* Zero these to make sure they didn't leak from a kernel trap. */
 576         movq    $0, %gs:CPU_KPTI_R13
 577         movq    $0, %gs:CPU_KPTI_R14
 578         /* And back to user gsbase again. */
 579         swapgs
 580 1:
 581         iretq
 582         SET_SIZE(tr_iret_user)
 583 
 584         /*
 585          * This special return trampoline is for KDI's use only (with kmdb).
 586          *
 587          * KDI/kmdb do not use swapgs -- they directly write the GSBASE MSR
 588          * instead. This trampoline runs after GSBASE has already been changed
 589          * back to the userland value (so we can't use %gs).
 590          *
 591          * Instead, the caller gives us a pointer to the kpti_dbg frame in %r13.
 592          * The KPTI_R13 member in the kpti_dbg has already been set to what the
 593          * real %r13 should be before we IRET.
 594          *
 595          * Additionally, KDI keeps a copy of the incoming %cr3 value when it
 596          * took an interrupt, and has put that back in the kpti_dbg area for us
 597          * to use, so we don't do any sniffing of %cs here. This is important
 598          * so that debugging code that changes %cr3 is possible.
 599          */
 600         ENTRY_NP(tr_iret_kdi)
 601         movq    %r14, KPTI_R14(%r13)    /* %r14 has to be preserved by us */
 602 
 603         movq    %rsp, %r14      /* original %rsp is pointing at IRET frame */
 604         leaq    KPTI_TOP(%r13), %rsp
 605         pushq   T_FRAMERET_SS(%r14)
 606         pushq   T_FRAMERET_RSP(%r14)
 607         pushq   T_FRAMERET_RFLAGS(%r14)
 608         pushq   T_FRAMERET_CS(%r14)
 609         pushq   T_FRAMERET_RIP(%r14)
 610 
 611         movq    KPTI_TR_CR3(%r13), %r14
 612         movq    %r14, %cr3
 613 
 614         movq    KPTI_R14(%r13), %r14
 615         movq    KPTI_R13(%r13), %r13    /* preserved by our caller */
 616 
 617         iretq
 618         SET_SIZE(tr_iret_kdi)
 619 
 620 .global tr_intr_ret_end
 621 tr_intr_ret_end:
 622 
 623         /*
 624          * Interrupt/trap entry trampolines
 625          */
 626 
 627         /* CPU pushed an error code, and ISR wants one */
 628 #define MK_INTR_TRAMPOLINE(isr)                 \
 629         ENTRY_NP(tr_/**/isr);                   \
 630         INTERRUPT_TRAMPOLINE;                   \
 631         jmp     isr;                            \
 632         SET_SIZE(tr_/**/isr)
 633 
 634         /* CPU didn't push an error code, and ISR doesn't want one */
 635 #define MK_INTR_TRAMPOLINE_NOERR(isr)           \
 636         ENTRY_NP(tr_/**/isr);                   \
 637         push    $0;                             \
 638         INTERRUPT_TRAMPOLINE_NOERR;             \
 639         jmp     isr;                            \
 640         SET_SIZE(tr_/**/isr)
 641 
 642         /* CPU pushed an error code, and ISR wants one */
 643 #define MK_DBG_INTR_TRAMPOLINE(isr)     \
 644         ENTRY_NP(tr_/**/isr);                   \
 645         DBG_INTERRUPT_TRAMPOLINE;               \
 646         jmp     isr;                            \
 647         SET_SIZE(tr_/**/isr)
 648 
 649         /* CPU didn't push an error code, and ISR doesn't want one */
 650 #define MK_DBG_INTR_TRAMPOLINE_NOERR(isr)       \
 651         ENTRY_NP(tr_/**/isr);                   \
 652         push    $0;                             \
 653         DBG_INTERRUPT_TRAMPOLINE_NOERR;         \
 654         jmp     isr;                            \
 655         SET_SIZE(tr_/**/isr)
 656 
 657 
 658         MK_INTR_TRAMPOLINE_NOERR(div0trap)
 659         MK_DBG_INTR_TRAMPOLINE_NOERR(dbgtrap)
 660         MK_DBG_INTR_TRAMPOLINE_NOERR(brktrap)
 661         MK_INTR_TRAMPOLINE_NOERR(ovflotrap)
 662         MK_INTR_TRAMPOLINE_NOERR(boundstrap)
 663         MK_INTR_TRAMPOLINE_NOERR(invoptrap)
 664         MK_INTR_TRAMPOLINE_NOERR(ndptrap)
 665         MK_INTR_TRAMPOLINE(invtsstrap)
 666         MK_DBG_INTR_TRAMPOLINE(segnptrap)
 667         MK_DBG_INTR_TRAMPOLINE(stktrap)
 668         MK_DBG_INTR_TRAMPOLINE(gptrap)
 669         MK_DBG_INTR_TRAMPOLINE(pftrap)
 670         MK_INTR_TRAMPOLINE_NOERR(resvtrap)
 671         MK_INTR_TRAMPOLINE_NOERR(ndperr)
 672         MK_INTR_TRAMPOLINE(achktrap)
 673         MK_INTR_TRAMPOLINE_NOERR(xmtrap)
 674         MK_INTR_TRAMPOLINE_NOERR(invaltrap)
 675         MK_INTR_TRAMPOLINE_NOERR(fasttrap)
 676         MK_INTR_TRAMPOLINE_NOERR(dtrace_ret)
 677 
 678         /*
 679          * These are special because they can interrupt other traps, and
 680          * each other. We don't need to pivot their stacks, because they have
 681          * dedicated IST stack space, but we need to change %cr3.
 682          */
 683         ENTRY_NP(tr_nmiint)
 684         pushq   %r13
 685         mov     kpti_safe_cr3, %r13
 686         mov     %r13, %cr3
 687         popq    %r13
 688         jmp     nmiint
 689         SET_SIZE(tr_nmiint)
 690 
 691 #if !defined(__xpv)
 692         ENTRY_NP(tr_syserrtrap)
 693         /*
 694          * If we got here we should always have a zero error code pushed.
 695          * The INT $0x8 instr doesn't seem to push one, though, which we use
 696          * as an emergency panic in the other trampolines. So adjust things
 697          * here.
 698          */
 699         cmpq    $0, (%rsp)
 700         je      1f
 701         pushq   $0
 702 1:
 703         pushq   %r13
 704         mov     kpti_safe_cr3, %r13
 705         mov     %r13, %cr3
 706         popq    %r13
 707         jmp     syserrtrap
 708         SET_SIZE(tr_syserrtrap)
 709 #endif
 710 
 711         ENTRY_NP(tr_mcetrap)
 712         pushq   %r13
 713         mov     kpti_safe_cr3, %r13
 714         mov     %r13, %cr3
 715         popq    %r13
 716         jmp     mcetrap
 717         SET_SIZE(tr_mcetrap)
 718 
 719         /*
 720          * Interrupts start at 32
 721          */
 722 #define MKIVCT(n)                       \
 723         ENTRY_NP(tr_ivct/**/n)          \
 724         push    $0;                     \
 725         INTERRUPT_TRAMPOLINE;           \
 726         push    $n - 0x20;              \
 727         jmp     cmnint;                 \
 728         SET_SIZE(tr_ivct/**/n)
 729 
 730         MKIVCT(32);     MKIVCT(33);     MKIVCT(34);     MKIVCT(35);
 731         MKIVCT(36);     MKIVCT(37);     MKIVCT(38);     MKIVCT(39);
 732         MKIVCT(40);     MKIVCT(41);     MKIVCT(42);     MKIVCT(43);
 733         MKIVCT(44);     MKIVCT(45);     MKIVCT(46);     MKIVCT(47);
 734         MKIVCT(48);     MKIVCT(49);     MKIVCT(50);     MKIVCT(51);
 735         MKIVCT(52);     MKIVCT(53);     MKIVCT(54);     MKIVCT(55);
 736         MKIVCT(56);     MKIVCT(57);     MKIVCT(58);     MKIVCT(59);
 737         MKIVCT(60);     MKIVCT(61);     MKIVCT(62);     MKIVCT(63);
 738         MKIVCT(64);     MKIVCT(65);     MKIVCT(66);     MKIVCT(67);
 739         MKIVCT(68);     MKIVCT(69);     MKIVCT(70);     MKIVCT(71);
 740         MKIVCT(72);     MKIVCT(73);     MKIVCT(74);     MKIVCT(75);
 741         MKIVCT(76);     MKIVCT(77);     MKIVCT(78);     MKIVCT(79);
 742         MKIVCT(80);     MKIVCT(81);     MKIVCT(82);     MKIVCT(83);
 743         MKIVCT(84);     MKIVCT(85);     MKIVCT(86);     MKIVCT(87);
 744         MKIVCT(88);     MKIVCT(89);     MKIVCT(90);     MKIVCT(91);
 745         MKIVCT(92);     MKIVCT(93);     MKIVCT(94);     MKIVCT(95);
 746         MKIVCT(96);     MKIVCT(97);     MKIVCT(98);     MKIVCT(99);
 747         MKIVCT(100);    MKIVCT(101);    MKIVCT(102);    MKIVCT(103);
 748         MKIVCT(104);    MKIVCT(105);    MKIVCT(106);    MKIVCT(107);
 749         MKIVCT(108);    MKIVCT(109);    MKIVCT(110);    MKIVCT(111);
 750         MKIVCT(112);    MKIVCT(113);    MKIVCT(114);    MKIVCT(115);
 751         MKIVCT(116);    MKIVCT(117);    MKIVCT(118);    MKIVCT(119);
 752         MKIVCT(120);    MKIVCT(121);    MKIVCT(122);    MKIVCT(123);
 753         MKIVCT(124);    MKIVCT(125);    MKIVCT(126);    MKIVCT(127);
 754         MKIVCT(128);    MKIVCT(129);    MKIVCT(130);    MKIVCT(131);
 755         MKIVCT(132);    MKIVCT(133);    MKIVCT(134);    MKIVCT(135);
 756         MKIVCT(136);    MKIVCT(137);    MKIVCT(138);    MKIVCT(139);
 757         MKIVCT(140);    MKIVCT(141);    MKIVCT(142);    MKIVCT(143);
 758         MKIVCT(144);    MKIVCT(145);    MKIVCT(146);    MKIVCT(147);
 759         MKIVCT(148);    MKIVCT(149);    MKIVCT(150);    MKIVCT(151);
 760         MKIVCT(152);    MKIVCT(153);    MKIVCT(154);    MKIVCT(155);
 761         MKIVCT(156);    MKIVCT(157);    MKIVCT(158);    MKIVCT(159);
 762         MKIVCT(160);    MKIVCT(161);    MKIVCT(162);    MKIVCT(163);
 763         MKIVCT(164);    MKIVCT(165);    MKIVCT(166);    MKIVCT(167);
 764         MKIVCT(168);    MKIVCT(169);    MKIVCT(170);    MKIVCT(171);
 765         MKIVCT(172);    MKIVCT(173);    MKIVCT(174);    MKIVCT(175);
 766         MKIVCT(176);    MKIVCT(177);    MKIVCT(178);    MKIVCT(179);
 767         MKIVCT(180);    MKIVCT(181);    MKIVCT(182);    MKIVCT(183);
 768         MKIVCT(184);    MKIVCT(185);    MKIVCT(186);    MKIVCT(187);
 769         MKIVCT(188);    MKIVCT(189);    MKIVCT(190);    MKIVCT(191);
 770         MKIVCT(192);    MKIVCT(193);    MKIVCT(194);    MKIVCT(195);
 771         MKIVCT(196);    MKIVCT(197);    MKIVCT(198);    MKIVCT(199);
 772         MKIVCT(200);    MKIVCT(201);    MKIVCT(202);    MKIVCT(203);
 773         MKIVCT(204);    MKIVCT(205);    MKIVCT(206);    MKIVCT(207);
 774         MKIVCT(208);    MKIVCT(209);    MKIVCT(210);    MKIVCT(211);
 775         MKIVCT(212);    MKIVCT(213);    MKIVCT(214);    MKIVCT(215);
 776         MKIVCT(216);    MKIVCT(217);    MKIVCT(218);    MKIVCT(219);
 777         MKIVCT(220);    MKIVCT(221);    MKIVCT(222);    MKIVCT(223);
 778         MKIVCT(224);    MKIVCT(225);    MKIVCT(226);    MKIVCT(227);
 779         MKIVCT(228);    MKIVCT(229);    MKIVCT(230);    MKIVCT(231);
 780         MKIVCT(232);    MKIVCT(233);    MKIVCT(234);    MKIVCT(235);
 781         MKIVCT(236);    MKIVCT(237);    MKIVCT(238);    MKIVCT(239);
 782         MKIVCT(240);    MKIVCT(241);    MKIVCT(242);    MKIVCT(243);
 783         MKIVCT(244);    MKIVCT(245);    MKIVCT(246);    MKIVCT(247);
 784         MKIVCT(248);    MKIVCT(249);    MKIVCT(250);    MKIVCT(251);
 785         MKIVCT(252);    MKIVCT(253);    MKIVCT(254);    MKIVCT(255);
 786 
 787         /*
 788          * We're PCIDE, but we don't have INVPCID.  The only way to invalidate a
 789          * PCID other than the current one, then, is to load its cr3 then
 790          * invlpg.  But loading kf_user_cr3 means we can longer access our
 791          * caller's text mapping (or indeed, its stack).  So this little helper
 792          * has to live within our trampoline text region.
 793          *
 794          * Called as tr_mmu_flush_user_range(addr, len, pgsz, cr3)
 795          */
 796         ENTRY_NP(tr_mmu_flush_user_range)
 797         push    %rbx
 798         /* When we read cr3, it never has the NOINVL bit set. */
 799         mov     %cr3, %rax
 800         movq    $CR3_NOINVL_BIT, %rbx
 801         orq     %rbx, %rax
 802 
 803         mov     %rcx, %cr3
 804         add     %rdi, %rsi
 805 .align  ASM_ENTRY_ALIGN
 806 1:
 807         invlpg  (%rdi)
 808         add     %rdx, %rdi
 809         cmp     %rsi, %rdi
 810         jb      1b
 811         mov     %rax, %cr3
 812         pop     %rbx
 813         retq
 814         SET_SIZE(tr_mmu_flush_user_range)
 815 
 816 .align MMU_PAGESIZE
 817 .global kpti_tramp_end
 818 kpti_tramp_end:
 819         nop
 820 
 821 #endif  /* __lint */
--- EOF ---