KVM_DEBUGREG_RELOAD = 4,
 };
 
+struct kvm_mtrr {
+       struct mtrr_var_range var_ranges[MTRR_MAX_VAR_RANGES];
+       mtrr_type fixed_ranges[KVM_NR_FIXED_MTRR_REGION];
+       unsigned char enabled;
+       mtrr_type def_type;
+};
+
 struct kvm_vcpu_arch {
        /*
         * rip and regs accesses must go through
        bool nmi_injected;    /* Trying to inject an NMI this entry */
        bool smi_pending;    /* SMI queued after currently running handler */
 
-       struct mtrr_state_type mtrr_state;
+       struct kvm_mtrr mtrr_state;
        u64 pat;
 
        unsigned switch_db_regs;
 
 
 static void update_mtrr(struct kvm_vcpu *vcpu, u32 msr)
 {
-       struct mtrr_state_type *mtrr_state = &vcpu->arch.mtrr_state;
+       struct kvm_mtrr *mtrr_state = &vcpu->arch.mtrr_state;
        unsigned char mtrr_enabled = mtrr_state->enabled;
        gfn_t start, end, mask;
        int index;
  * The function is based on mtrr_type_lookup() in
  * arch/x86/kernel/cpu/mtrr/generic.c
  */
-static int get_mtrr_type(struct mtrr_state_type *mtrr_state,
+static int get_mtrr_type(struct kvm_mtrr *mtrr_state,
                         u64 start, u64 end)
 {
        u64 base, mask;
        end--;
 
        /* Look in fixed ranges. Just return the type as per start */
-       if (mtrr_state->have_fixed && (mtrr_state->enabled & 0x1) &&
-             (start < 0x100000)) {
+       if ((mtrr_state->enabled & 0x1) && (start < 0x100000)) {
                int idx;
 
                if (start < 0x80000) {