Make MTRR min hole alignment 64MB
[coreboot.git] / src / include / cpu / x86 / mtrr.h
1 #ifndef CPU_X86_MTRR_H
2 #define CPU_X86_MTRR_H
3
4 /*  These are the region types  */
5 #define MTRR_TYPE_UNCACHEABLE 0
6 #define MTRR_TYPE_WRCOMB     1
7 /*#define MTRR_TYPE_         2*/
8 /*#define MTRR_TYPE_         3*/
9 #define MTRR_TYPE_WRTHROUGH  4
10 #define MTRR_TYPE_WRPROT     5
11 #define MTRR_TYPE_WRBACK     6
12 #define MTRR_NUM_TYPES       7
13
14 #define MTRRcap_MSR     0x0fe
15 #define MTRRdefType_MSR 0x2ff
16
17 #define MTRRdefTypeEn           (1 << 11)
18 #define MTRRdefTypeFixEn        (1 << 10)
19
20 #define SMRRphysBase_MSR 0x1f2
21 #define SMRRphysMask_MSR 0x1f3
22
23 #define MTRRphysBase_MSR(reg) (0x200 + 2 * (reg))
24 #define MTRRphysMask_MSR(reg) (0x200 + 2 * (reg) + 1)
25
26 #define MTRRphysMaskValid       (1 << 11)
27
28 #define NUM_FIXED_RANGES 88
29 #define MTRRfix64K_00000_MSR 0x250
30 #define MTRRfix16K_80000_MSR 0x258
31 #define MTRRfix16K_A0000_MSR 0x259
32 #define MTRRfix4K_C0000_MSR 0x268
33 #define MTRRfix4K_C8000_MSR 0x269
34 #define MTRRfix4K_D0000_MSR 0x26a
35 #define MTRRfix4K_D8000_MSR 0x26b
36 #define MTRRfix4K_E0000_MSR 0x26c
37 #define MTRRfix4K_E8000_MSR 0x26d
38 #define MTRRfix4K_F0000_MSR 0x26e
39 #define MTRRfix4K_F8000_MSR 0x26f
40
41 #if !defined (__ASSEMBLER__) && !defined(__PRE_RAM__)
42 #include <device/device.h>
43 void enable_fixed_mtrr(void);
44 void x86_setup_var_mtrrs(unsigned int address_bits, unsigned int above4gb);
45 void x86_setup_mtrrs(void);
46 int x86_mtrr_check(void);
47 void set_var_mtrr_resource(void *gp, struct device *dev, struct resource *res);
48 void x86_setup_fixed_mtrrs(void);
49 #endif
50
51 #if !defined(CONFIG_RAMTOP)
52 # error "CONFIG_RAMTOP not defined"
53 #endif
54
55 #if ((CONFIG_XIP_ROM_SIZE & (CONFIG_XIP_ROM_SIZE -1)) != 0)
56 # error "CONFIG_XIP_ROM_SIZE is not a power of 2"
57 #endif
58
59 #if (CONFIG_RAMTOP & (CONFIG_RAMTOP - 1)) != 0
60 # error "CONFIG_RAMTOP must be a power of 2"
61 #endif
62
63 #endif /* CPU_X86_MTRR_H */