1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License, Version 1.0 only
   6  * (the "License").  You may not use this file except in compliance
   7  * with the License.
   8  *
   9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
  10  * or http://www.opensolaris.org/os/licensing.
  11  * See the License for the specific language governing permissions
  12  * and limitations under the License.
  13  *
  14  * When distributing Covered Code, include this CDDL HEADER in each
  15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  16  * If applicable, add the following below this CDDL HEADER, with the
  17  * fields enclosed by brackets "[]" replaced with your own identifying
  18  * information: Portions Copyright [yyyy] [name of copyright owner]
  19  *
  20  * CDDL HEADER END
  21  */
  22 /*
  23  * Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
  24  * Use is subject to license terms.
  25  */
  26 /*
  27  * Copyright 2019 Joyent, Inc.
  28  */
  29 
  30 #ifndef _SYS_CPUID_DRV_H
  31 #define _SYS_CPUID_DRV_H
  32 
  33 #include <sys/types.h>
  34 
  35 #ifdef __cplusplus
  36 extern "C" {
  37 #endif
  38 
  39 /*
  40  * /dev names:
  41  *      /dev/cpu/                       - containing directory
  42  *              self/                   - describes current cpu
  43  *                      cpuid           - cpu identification
  44  */
  45 
  46 #define CPUID_DRIVER_NAME       "cpuid"
  47 #define CPUID_DRIVER_SELF_NODE  "self"
  48 
  49 #define CPUID_DIR_NAME          "cpu"
  50 #define CPUID_SELF_DIR_NAME     "self"
  51 #define CPUID_NAME              "cpuid"
  52 #define CPUID_SELF_NAME         \
  53         CPUID_DIR_NAME "/" CPUID_SELF_DIR_NAME "/" CPUID_NAME
  54 
  55 /*
  56  * This minor number corresponds to the cpu we're running on at
  57  * the time we invoke its interfaces.
  58  */
  59 #define CPUID_SELF_CPUID_MINOR  ((minor_t)0x3fffful)
  60 
  61 /*
  62  * ioctl numbers: not an exported interface
  63  */
  64 #define CPUID_IOC               (('c'<<24)|('i'<<16)|('d'<<8))
  65 
  66 #define CPUID_GET_HWCAP         (CPUID_IOC|0)
  67 #define CPUID_RDMSR             (CPUID_IOC|1)
  68 
  69 struct cpuid_get_hwcap {
  70         char *cgh_archname;
  71         uint_t cgh_hwcap[2];
  72 };
  73 
  74 struct cpuid_rdmsr {
  75         uint64_t cr_msr_nr;
  76         uint64_t cr_msr_val;
  77 };
  78 
  79 #if defined(_SYSCALL32_IMPL)
  80 
  81 #include <sys/types32.h>
  82 
  83 struct cpuid_get_hwcap32 {
  84         caddr32_t cgh_archname;
  85         uint32_t cgh_hwcap[2];
  86 };
  87 
  88 #endif  /* _SYSCALL32_IMPL */
  89 
  90 #ifdef __cplusplus
  91 }
  92 #endif
  93 
  94 #endif  /* _SYS_CPUID_DRV_H */