1 \
   2 \ Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
   3 \ Use is subject to license terms.
   4 \
   5 \ Copyright 2018 Joyent, Inc.
   6 \
   7 \ CDDL HEADER START
   8 \
   9 \ The contents of this file are subject to the terms of the
  10 \ Common Development and Distribution License (the "License").
  11 \ You may not use this file except in compliance with the License.
  12 \
  13 \ You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
  14 \ or http://www.opensolaris.org/os/licensing.
  15 \ See the License for the specific language governing permissions
  16 \ and limitations under the License.
  17 \
  18 \ When distributing Covered Code, include this CDDL HEADER in each
  19 \ file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  20 \ If applicable, add the following below this CDDL HEADER, with the
  21 \ fields enclosed by brackets "[]" replaced with your own identifying
  22 \ information: Portions Copyright [yyyy] [name of copyright owner]
  23 \
  24 \ CDDL HEADER END
  25 \
  26 \ CPU-save structure offsets for use in assembly code.
  27 \
  28 \ Keep in sync with kdi_state.h
  29 \
  30 
  31 #include <sys/cpuvar.h>
  32 #include <sys/kdi_impl.h>
  33 
  34 kdi_memrange_t  MR_SIZE
  35                 mr_base
  36                 mr_lim
  37 
  38 kdi_crumb_t     KRM_SIZE
  39                 krm_cpu_state
  40                 krm_pc
  41                 krm_sp
  42                 krm_trapno
  43                 krm_flag
  44 
  45 kdi_drreg_t
  46                 dr_ctl
  47                 dr_stat
  48                 dr_addr
  49 
  50 kdi_cpusave_t   KRS_SIZE
  51                 krs_gregs
  52                 krs_dr
  53                 krs_dr.dr_ctl                   KRS_DRCTL
  54                 krs_dr.dr_stat                  KRS_DRSTAT
  55                 krs_gdt
  56                 krs_idt
  57                 krs_cr0
  58                 krs_cpu_state
  59                 krs_curcrumbidx
  60                 krs_curcrumb
  61                 krs_crumbs
  62 
  63 cpu
  64                 cpu_id
  65 
  66 greg_t          KREG_SIZE
  67 
  68 #if defined(__amd64)
  69 \#define        REG_SHIFT               3
  70 #else
  71 \#define        REG_SHIFT               2
  72 #endif
  73 
  74 \#define        DRADDR_IDX(num)         _CONST(_MUL(num, DR_ADDR_INCR))
  75 \#define        DRADDR_OFF(num)         _CONST(DRADDR_IDX(num) + DR_ADDR)
  76 \#define        KRS_DROFF(num)          _CONST(DRADDR_OFF(num) + KRS_DR)
  77 \#define        REG_OFF(reg)            _CONST(_CONST(reg) << REG_SHIFT)
  78 \#define        KDIREG_OFF(reg)         _CONST(_MUL(KREG_SIZE, reg) + KRS_GREGS)