Home | History | Annotate | Download | only in asm
      1 /****************************************************************************
      2  ****************************************************************************
      3  ***
      4  ***   This header was automatically generated from a Linux kernel header
      5  ***   of the same name, to make information necessary for userspace to
      6  ***   call into the kernel available to libc.  It contains only constants,
      7  ***   structures, and macros generated from the original header, and thus,
      8  ***   contains no copyrightable information.
      9  ***
     10  ***   To edit the content of this header, modify the corresponding
     11  ***   source file (e.g. under external/kernel-headers/original/) then
     12  ***   run bionic/libc/kernel/tools/update_all.py
     13  ***
     14  ***   Any manual change here will be lost the next time this script will
     15  ***   be run. You've been warned!
     16  ***
     17  ****************************************************************************
     18  ****************************************************************************/
     19 #ifndef _UAPI_ASM_X86_MTRR_H
     20 #define _UAPI_ASM_X86_MTRR_H
     21 #include <linux/types.h>
     22 #include <linux/ioctl.h>
     23 #include <linux/errno.h>
     24 #define MTRR_IOCTL_BASE 'M'
     25 #ifdef __i386__
     26 struct mtrr_sentry {
     27   unsigned long base;
     28   unsigned int size;
     29   unsigned int type;
     30 };
     31 struct mtrr_gentry {
     32   unsigned int regnum;
     33   unsigned long base;
     34   unsigned int size;
     35   unsigned int type;
     36 };
     37 #else
     38 struct mtrr_sentry {
     39   __u64 base;
     40   __u32 size;
     41   __u32 type;
     42 };
     43 struct mtrr_gentry {
     44   __u64 base;
     45   __u32 size;
     46   __u32 regnum;
     47   __u32 type;
     48   __u32 _pad;
     49 };
     50 #endif
     51 struct mtrr_var_range {
     52   __u32 base_lo;
     53   __u32 base_hi;
     54   __u32 mask_lo;
     55   __u32 mask_hi;
     56 };
     57 typedef __u8 mtrr_type;
     58 #define MTRR_NUM_FIXED_RANGES 88
     59 #define MTRR_MAX_VAR_RANGES 256
     60 struct mtrr_state_type {
     61   struct mtrr_var_range var_ranges[MTRR_MAX_VAR_RANGES];
     62   mtrr_type fixed_ranges[MTRR_NUM_FIXED_RANGES];
     63   unsigned char enabled;
     64   unsigned char have_fixed;
     65   mtrr_type def_type;
     66 };
     67 #define MTRRphysBase_MSR(reg) (0x200 + 2 * (reg))
     68 #define MTRRphysMask_MSR(reg) (0x200 + 2 * (reg) + 1)
     69 #define MTRRIOC_ADD_ENTRY _IOW(MTRR_IOCTL_BASE, 0, struct mtrr_sentry)
     70 #define MTRRIOC_SET_ENTRY _IOW(MTRR_IOCTL_BASE, 1, struct mtrr_sentry)
     71 #define MTRRIOC_DEL_ENTRY _IOW(MTRR_IOCTL_BASE, 2, struct mtrr_sentry)
     72 #define MTRRIOC_GET_ENTRY _IOWR(MTRR_IOCTL_BASE, 3, struct mtrr_gentry)
     73 #define MTRRIOC_KILL_ENTRY _IOW(MTRR_IOCTL_BASE, 4, struct mtrr_sentry)
     74 #define MTRRIOC_ADD_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE, 5, struct mtrr_sentry)
     75 #define MTRRIOC_SET_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE, 6, struct mtrr_sentry)
     76 #define MTRRIOC_DEL_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE, 7, struct mtrr_sentry)
     77 #define MTRRIOC_GET_PAGE_ENTRY _IOWR(MTRR_IOCTL_BASE, 8, struct mtrr_gentry)
     78 #define MTRRIOC_KILL_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE, 9, struct mtrr_sentry)
     79 #define MTRR_TYPE_UNCACHABLE 0
     80 #define MTRR_TYPE_WRCOMB 1
     81 #define MTRR_TYPE_WRTHROUGH 4
     82 #define MTRR_TYPE_WRPROT 5
     83 #define MTRR_TYPE_WRBACK 6
     84 #define MTRR_NUM_TYPES 7
     85 #define MTRR_TYPE_INVALID 0xff
     86 #endif
     87