mtrr.h 6.1 KB
Newer Older
T
Thomas Gleixner 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/*  Generic MTRR (Memory Type Range Register) ioctls.

    Copyright (C) 1997-1999  Richard Gooch

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Library General Public
    License as published by the Free Software Foundation; either
    version 2 of the License, or (at your option) any later version.

    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Library General Public License for more details.

    You should have received a copy of the GNU Library General Public
    License along with this library; if not, write to the Free
    Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

    Richard Gooch may be reached by email at  rgooch@atnf.csiro.au
    The postal address is:
      Richard Gooch, c/o ATNF, P. O. Box 76, Epping, N.S.W., 2121, Australia.
*/
H
H. Peter Anvin 已提交
23 24
#ifndef _ASM_X86_MTRR_H
#define _ASM_X86_MTRR_H
T
Thomas Gleixner 已提交
25 26 27 28 29 30

#include <linux/ioctl.h>
#include <linux/errno.h>

#define	MTRR_IOCTL_BASE	'M'

31
struct mtrr_sentry {
T
Thomas Gleixner 已提交
32 33 34 35 36 37 38 39 40 41 42
    unsigned long base;    /*  Base address     */
    unsigned int size;    /*  Size of region   */
    unsigned int type;     /*  Type of region   */
};

/* Warning: this structure has a different order from i386
   on x86-64. The 32bit emulation code takes care of that.
   But you need to use this for 64bit, otherwise your X server
   will break. */

#ifdef __i386__
43
struct mtrr_gentry {
T
Thomas Gleixner 已提交
44 45 46 47 48 49 50 51
    unsigned int regnum;   /*  Register number  */
    unsigned long base;    /*  Base address     */
    unsigned int size;    /*  Size of region   */
    unsigned int type;     /*  Type of region   */
};

#else /* __i386__ */

52
struct mtrr_gentry {
T
Thomas Gleixner 已提交
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
    unsigned long base;    /*  Base address     */
    unsigned int size;    /*  Size of region   */
    unsigned int regnum;   /*  Register number  */
    unsigned int type;     /*  Type of region   */
};
#endif /* !__i386__ */

/*  These are the various ioctls  */
#define MTRRIOC_ADD_ENTRY        _IOW(MTRR_IOCTL_BASE,  0, struct mtrr_sentry)
#define MTRRIOC_SET_ENTRY        _IOW(MTRR_IOCTL_BASE,  1, struct mtrr_sentry)
#define MTRRIOC_DEL_ENTRY        _IOW(MTRR_IOCTL_BASE,  2, struct mtrr_sentry)
#define MTRRIOC_GET_ENTRY        _IOWR(MTRR_IOCTL_BASE, 3, struct mtrr_gentry)
#define MTRRIOC_KILL_ENTRY       _IOW(MTRR_IOCTL_BASE,  4, struct mtrr_sentry)
#define MTRRIOC_ADD_PAGE_ENTRY   _IOW(MTRR_IOCTL_BASE,  5, struct mtrr_sentry)
#define MTRRIOC_SET_PAGE_ENTRY   _IOW(MTRR_IOCTL_BASE,  6, struct mtrr_sentry)
#define MTRRIOC_DEL_PAGE_ENTRY   _IOW(MTRR_IOCTL_BASE,  7, struct mtrr_sentry)
#define MTRRIOC_GET_PAGE_ENTRY   _IOWR(MTRR_IOCTL_BASE, 8, struct mtrr_gentry)
#define MTRRIOC_KILL_PAGE_ENTRY  _IOW(MTRR_IOCTL_BASE,  9, struct mtrr_sentry)

/*  These are the region types  */
#define MTRR_TYPE_UNCACHABLE 0
#define MTRR_TYPE_WRCOMB     1
/*#define MTRR_TYPE_         2*/
/*#define MTRR_TYPE_         3*/
#define MTRR_TYPE_WRTHROUGH  4
#define MTRR_TYPE_WRPROT     5
#define MTRR_TYPE_WRBACK     6
#define MTRR_NUM_TYPES       7

82
#ifdef __KERNEL__
T
Thomas Gleixner 已提交
83 84 85

/*  The following functions are for use by other drivers  */
# ifdef CONFIG_MTRR
I
Ingo Molnar 已提交
86
extern u8 mtrr_type_lookup(u64 addr, u64 end);
T
Thomas Gleixner 已提交
87 88
extern void mtrr_save_fixed_ranges(void *);
extern void mtrr_save_state(void);
89 90 91 92 93 94
extern int mtrr_add(unsigned long base, unsigned long size,
		    unsigned int type, bool increment);
extern int mtrr_add_page(unsigned long base, unsigned long size,
			 unsigned int type, bool increment);
extern int mtrr_del(int reg, unsigned long base, unsigned long size);
extern int mtrr_del_page(int reg, unsigned long base, unsigned long size);
T
Thomas Gleixner 已提交
95 96 97
extern void mtrr_centaur_report_mcr(int mcr, u32 lo, u32 hi);
extern void mtrr_ap_init(void);
extern void mtrr_bp_init(void);
98
extern int mtrr_trim_uncached_memory(unsigned long end_pfn);
99
extern int amd_special_default_mtrr(void);
T
Thomas Gleixner 已提交
100
#  else
I
Ingo Molnar 已提交
101 102 103 104 105 106 107
static inline u8 mtrr_type_lookup(u64 addr, u64 end)
{
	/*
	 * Return no-MTRRs:
	 */
	return 0xff;
}
T
Thomas Gleixner 已提交
108 109
#define mtrr_save_fixed_ranges(arg) do {} while (0)
#define mtrr_save_state() do {} while (0)
110 111
static inline int mtrr_add(unsigned long base, unsigned long size,
			   unsigned int type, bool increment)
T
Thomas Gleixner 已提交
112 113 114
{
    return -ENODEV;
}
115
static inline int mtrr_add_page(unsigned long base, unsigned long size,
116
				unsigned int type, bool increment)
T
Thomas Gleixner 已提交
117 118 119
{
    return -ENODEV;
}
120
static inline int mtrr_del(int reg, unsigned long base, unsigned long size)
T
Thomas Gleixner 已提交
121 122 123
{
    return -ENODEV;
}
124
static inline int mtrr_del_page(int reg, unsigned long base, unsigned long size)
T
Thomas Gleixner 已提交
125 126 127
{
    return -ENODEV;
}
128 129 130 131
static inline int mtrr_trim_uncached_memory(unsigned long end_pfn)
{
	return 0;
}
132 133 134
static inline void mtrr_centaur_report_mcr(int mcr, u32 lo, u32 hi)
{
}
T
Thomas Gleixner 已提交
135 136 137 138 139 140 141 142

#define mtrr_ap_init() do {} while (0)
#define mtrr_bp_init() do {} while (0)
#  endif

#ifdef CONFIG_COMPAT
#include <linux/compat.h>

143
struct mtrr_sentry32 {
T
Thomas Gleixner 已提交
144 145 146 147 148
    compat_ulong_t base;    /*  Base address     */
    compat_uint_t size;    /*  Size of region   */
    compat_uint_t type;     /*  Type of region   */
};

149
struct mtrr_gentry32 {
T
Thomas Gleixner 已提交
150 151 152 153 154 155 156 157
    compat_ulong_t regnum;   /*  Register number  */
    compat_uint_t base;    /*  Base address     */
    compat_uint_t size;    /*  Size of region   */
    compat_uint_t type;     /*  Type of region   */
};

#define MTRR_IOCTL_BASE 'M'

158 159 160 161 162 163 164 165 166 167 168
#define MTRRIOC32_ADD_ENTRY      _IOW(MTRR_IOCTL_BASE,  0, struct mtrr_sentry32)
#define MTRRIOC32_SET_ENTRY      _IOW(MTRR_IOCTL_BASE,  1, struct mtrr_sentry32)
#define MTRRIOC32_DEL_ENTRY      _IOW(MTRR_IOCTL_BASE,  2, struct mtrr_sentry32)
#define MTRRIOC32_GET_ENTRY      _IOWR(MTRR_IOCTL_BASE, 3, struct mtrr_gentry32)
#define MTRRIOC32_KILL_ENTRY     _IOW(MTRR_IOCTL_BASE,  4, struct mtrr_sentry32)
#define MTRRIOC32_ADD_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE,  5, struct mtrr_sentry32)
#define MTRRIOC32_SET_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE,  6, struct mtrr_sentry32)
#define MTRRIOC32_DEL_PAGE_ENTRY _IOW(MTRR_IOCTL_BASE,  7, struct mtrr_sentry32)
#define MTRRIOC32_GET_PAGE_ENTRY _IOWR(MTRR_IOCTL_BASE, 8, struct mtrr_gentry32)
#define MTRRIOC32_KILL_PAGE_ENTRY		\
				 _IOW(MTRR_IOCTL_BASE,  9, struct mtrr_sentry32)
T
Thomas Gleixner 已提交
169 170 171 172
#endif /* CONFIG_COMPAT */

#endif /* __KERNEL__ */

H
H. Peter Anvin 已提交
173
#endif /* _ASM_X86_MTRR_H */