[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-ia64-devel] [patch] faults.c indentation
Hi, Since I was in the process of tracking down faults problems on SN2, I did the same to faults.c as was done to vcpu.c and others. There is no functional change to this patch. Cheers, Jes Run arch/ia64/xen/faults.c through Lindent to make it manageble. Signed-off-by: Jes Sorensen <jes@xxxxxxx> diff -r 11b718eb22c9 xen/arch/ia64/xen/faults.c --- a/xen/arch/ia64/xen/faults.c Thu Nov 02 12:43:04 2006 -0700 +++ b/xen/arch/ia64/xen/faults.c Fri Nov 10 13:56:06 2006 +0100 @@ -44,54 +44,58 @@ extern IA64FAULT ia64_hypercall(struct p IA64_PSR_DT | IA64_PSR_RT | IA64_PSR_CPL1 | \ IA64_PSR_IT | IA64_PSR_BN) -#define DELIVER_PSR_CLR (IA64_PSR_AC | IA64_PSR_DFL | IA64_PSR_DFH | \ - IA64_PSR_SP | IA64_PSR_DI | IA64_PSR_SI | \ - IA64_PSR_DB | IA64_PSR_LP | IA64_PSR_TB | \ - IA64_PSR_CPL | IA64_PSR_MC | IA64_PSR_IS | \ - IA64_PSR_ID | IA64_PSR_DA | IA64_PSR_DD | \ - IA64_PSR_SS | IA64_PSR_RI | IA64_PSR_ED | IA64_PSR_IA) - +#define DELIVER_PSR_CLR (IA64_PSR_AC | IA64_PSR_DFL | IA64_PSR_DFH | \ + IA64_PSR_SP | IA64_PSR_DI | IA64_PSR_SI | \ + IA64_PSR_DB | IA64_PSR_LP | IA64_PSR_TB | \ + IA64_PSR_CPL| IA64_PSR_MC | IA64_PSR_IS | \ + IA64_PSR_ID | IA64_PSR_DA | IA64_PSR_DD | \ + IA64_PSR_SS | IA64_PSR_RI | IA64_PSR_ED | IA64_PSR_IA) extern void do_ssc(unsigned long ssc, struct pt_regs *regs); // should never panic domain... if it does, stack may have been overrun -void check_bad_nested_interruption(unsigned long isr, struct pt_regs *regs, unsigned long vector) -{ - struct vcpu *v = current; - - if (!(PSCB(v,ipsr) & IA64_PSR_DT)) { - panic_domain(regs,"psr.dt off, trying to deliver nested dtlb!\n"); +void check_bad_nested_interruption(unsigned long isr, struct pt_regs *regs, + unsigned long vector) +{ + struct vcpu *v = current; + + if (!(PSCB(v, ipsr) & IA64_PSR_DT)) { + panic_domain(regs, + "psr.dt off, trying to deliver nested dtlb!\n"); } vector &= ~0xf; if (vector != IA64_DATA_TLB_VECTOR && vector != IA64_ALT_DATA_TLB_VECTOR && vector != IA64_VHPT_TRANS_VECTOR) { - panic_domain(regs,"psr.ic off, delivering fault=%lx,ipsr=%lx,iip=%lx,ifa=%lx,isr=%lx,PSCB.iip=%lx\n", - vector,regs->cr_ipsr,regs->cr_iip,PSCB(v,ifa),isr,PSCB(v,iip)); - } -} - -void reflect_interruption(unsigned long isr, struct pt_regs *regs, unsigned long vector) -{ - struct vcpu *v = current; - - if (!PSCB(v,interrupt_collection_enabled)) - check_bad_nested_interruption(isr,regs,vector); - PSCB(v,unat) = regs->ar_unat; // not sure if this is really needed? - PSCB(v,precover_ifs) = regs->cr_ifs; + panic_domain(regs, "psr.ic off, delivering fault=%lx," + "ipsr=%lx,iip=%lx,ifa=%lx,isr=%lx,PSCB.iip=%lx\n", + vector, regs->cr_ipsr, regs->cr_iip, PSCB(v, ifa), + isr, PSCB(v, iip)); + } +} + +void reflect_interruption(unsigned long isr, struct pt_regs *regs, + unsigned long vector) +{ + struct vcpu *v = current; + + if (!PSCB(v, interrupt_collection_enabled)) + check_bad_nested_interruption(isr, regs, vector); + PSCB(v, unat) = regs->ar_unat; // not sure if this is really needed? + PSCB(v, precover_ifs) = regs->cr_ifs; vcpu_bsw0(v); - PSCB(v,ipsr) = vcpu_get_ipsr_int_state(v,regs->cr_ipsr); - PSCB(v,isr) = isr; - PSCB(v,iip) = regs->cr_iip; - PSCB(v,ifs) = 0; - PSCB(v,incomplete_regframe) = 0; - - regs->cr_iip = ((unsigned long) PSCBX(v,iva) + vector) & ~0xffUL; + PSCB(v, ipsr) = vcpu_get_ipsr_int_state(v, regs->cr_ipsr); + PSCB(v, isr) = isr; + PSCB(v, iip) = regs->cr_iip; + PSCB(v, ifs) = 0; + PSCB(v, incomplete_regframe) = 0; + + regs->cr_iip = ((unsigned long)PSCBX(v, iva) + vector) & ~0xffUL; regs->cr_ipsr = (regs->cr_ipsr & ~DELIVER_PSR_CLR) | DELIVER_PSR_SET; regs->r31 = current->domain->arch.shared_info_va + XSI_IPSR_OFS; v->vcpu_info->evtchn_upcall_mask = 1; - PSCB(v,interrupt_collection_enabled) = 0; + PSCB(v, interrupt_collection_enabled) = 0; perfc_incra(slow_reflect, vector >> 8); } @@ -105,13 +109,15 @@ void reflect_extint(struct pt_regs *regs static int first_extint = 1; if (first_extint) { - printk("Delivering first extint to domain: isr=0x%lx, iip=0x%lx\n", isr, regs->cr_iip); + printk("Delivering first extint to domain: isr=0x%lx, " + "iip=0x%lx\n", isr, regs->cr_iip); first_extint = 0; } if (vcpu_timer_pending_early(v)) -printk("*#*#*#* about to deliver early timer to domain %d!!!\n",v->domain->domain_id); - PSCB(current,itir) = 0; - reflect_interruption(isr,regs,IA64_EXTINT_VECTOR); + printk("*#*#*#* about to deliver early timer to domain %d!!\n", + v->domain->domain_id); + PSCB(current, itir) = 0; + reflect_interruption(isr, regs, IA64_EXTINT_VECTOR); } void reflect_event(struct pt_regs *regs) @@ -128,24 +134,25 @@ void reflect_event(struct pt_regs *regs) if (!event_pending(v)) return; - if (!PSCB(v,interrupt_collection_enabled)) - printk("psr.ic off, delivering event, ipsr=%lx,iip=%lx,isr=%lx,viip=0x%lx\n", + if (!PSCB(v, interrupt_collection_enabled)) + printk("psr.ic off, delivering event, ipsr=%lx,iip=%lx," + "isr=%lx,viip=0x%lx\n", regs->cr_ipsr, regs->cr_iip, isr, PSCB(v, iip)); - PSCB(v,unat) = regs->ar_unat; // not sure if this is really needed? - PSCB(v,precover_ifs) = regs->cr_ifs; + PSCB(v, unat) = regs->ar_unat; // not sure if this is really needed? + PSCB(v, precover_ifs) = regs->cr_ifs; vcpu_bsw0(v); - PSCB(v,ipsr) = vcpu_get_ipsr_int_state(v,regs->cr_ipsr); - PSCB(v,isr) = isr; - PSCB(v,iip) = regs->cr_iip; - PSCB(v,ifs) = 0; - PSCB(v,incomplete_regframe) = 0; + PSCB(v, ipsr) = vcpu_get_ipsr_int_state(v, regs->cr_ipsr); + PSCB(v, isr) = isr; + PSCB(v, iip) = regs->cr_iip; + PSCB(v, ifs) = 0; + PSCB(v, incomplete_regframe) = 0; regs->cr_iip = v->arch.event_callback_ip; regs->cr_ipsr = (regs->cr_ipsr & ~DELIVER_PSR_CLR) | DELIVER_PSR_SET; regs->r31 = current->domain->arch.shared_info_va + XSI_IPSR_OFS; v->vcpu_info->evtchn_upcall_mask = 1; - PSCB(v,interrupt_collection_enabled) = 0; + PSCB(v, interrupt_collection_enabled) = 0; } // ONLY gets called from ia64_leave_kernel @@ -159,25 +166,25 @@ void deliver_pending_interrupt(struct pt if (!is_idle_domain(d) && user_mode(regs)) { if (vcpu_deliverable_interrupts(v)) reflect_extint(regs); - else if (PSCB(v,pending_interruption)) + else if (PSCB(v, pending_interruption)) ++pending_false_positive; } } -static int -handle_lazy_cover(struct vcpu *v, struct pt_regs *regs) -{ - if (!PSCB(v,interrupt_collection_enabled)) { - PSCB(v,ifs) = regs->cr_ifs; - PSCB(v,incomplete_regframe) = 1; +static int handle_lazy_cover(struct vcpu *v, struct pt_regs *regs) +{ + if (!PSCB(v, interrupt_collection_enabled)) { + PSCB(v, ifs) = regs->cr_ifs; + PSCB(v, incomplete_regframe) = 1; regs->cr_ifs = 0; perfc_incrc(lazy_cover); - return(1); // retry same instruction with cr.ifs off - } - return(0); -} - -void ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *regs, unsigned long itir) + return 1; // retry same instruction with cr.ifs off + } + return 0; +} + +void ia64_do_page_fault(unsigned long address, unsigned long isr, + struct pt_regs *regs, unsigned long itir) { unsigned long iip = regs->cr_iip, iha; // FIXME should validate address here @@ -188,26 +195,28 @@ void ia64_do_page_fault (unsigned long a u64 logps; if ((isr & IA64_ISR_SP) - || ((isr & IA64_ISR_NA) && (isr & IA64_ISR_CODE_MASK) == IA64_ISR_CODE_LFETCH)) - { + || ((isr & IA64_ISR_NA) + && (isr & IA64_ISR_CODE_MASK) == IA64_ISR_CODE_LFETCH)) { /* - * This fault was due to a speculative load or lfetch.fault, set the "ed" - * bit in the psr to ensure forward progress. (Target register will get a - * NaT for ld.s, lfetch will be canceled.) + * This fault was due to a speculative load or lfetch.fault, + * set the "ed" bit in the psr to ensure forward progress. + * (Target register will get a NaT for ld.s, lfetch will be + * canceled.) */ ia64_psr(regs)->ed = 1; return; } again: - fault = vcpu_translate(current,address,is_data,&pteval,&itir,&iha); + fault = vcpu_translate(current, address, is_data, &pteval, + &itir, &iha); if (fault == IA64_NO_FAULT || fault == IA64_USE_TLB) { struct p2m_entry entry; unsigned long m_pteval; m_pteval = translate_domain_pte(pteval, address, itir, - &logps, &entry); - vcpu_itc_no_srlz(current, (is_data? 2: 1) | 4, - address, m_pteval, pteval, logps, &entry); + &logps, &entry); + vcpu_itc_no_srlz(current, (is_data ? 2 : 1) | 4, + address, m_pteval, pteval, logps, &entry); if ((fault == IA64_USE_TLB && !current->arch.dtlb.pte.p) || p2m_entry_retry(&entry)) { /* dtlb has been purged in-between. This dtlb was @@ -225,16 +234,17 @@ void ia64_do_page_fault (unsigned long a if (is_ptc_l_needed) vcpu_ptc_l(current, address, logps); - if (!user_mode (regs)) { + if (!user_mode(regs)) { /* The fault occurs inside Xen. */ if (!ia64_done_with_exception(regs)) { // should never happen. If it does, region 0 addr may // indicate a bad xen pointer printk("*** xen_handle_domain_access: exception table" - " lookup failed, iip=0x%lx, addr=0x%lx, spinning...\n", - iip, address); - panic_domain(regs,"*** xen_handle_domain_access: exception table" - " lookup failed, iip=0x%lx, addr=0x%lx, spinning...\n", + " lookup failed, iip=0x%lx, addr=0x%lx, " + "spinning...\n", iip, address); + panic_domain(regs, "*** xen_handle_domain_access: " + "exception table lookup failed, " + "iip=0x%lx, addr=0x%lx, spinning...\n", iip, address); } return; @@ -243,45 +253,47 @@ void ia64_do_page_fault (unsigned long a if ((isr & IA64_ISR_IR) && handle_lazy_cover(current, regs)) return; - if (!PSCB(current,interrupt_collection_enabled)) { - check_bad_nested_interruption(isr,regs,fault); + if (!PSCB(current, interrupt_collection_enabled)) { + check_bad_nested_interruption(isr, regs, fault); //printk("Delivering NESTED DATA TLB fault\n"); fault = IA64_DATA_NESTED_TLB_VECTOR; - regs->cr_iip = ((unsigned long) PSCBX(current,iva) + fault) & ~0xffUL; - regs->cr_ipsr = (regs->cr_ipsr & ~DELIVER_PSR_CLR) | DELIVER_PSR_SET; + regs->cr_iip = + ((unsigned long)PSCBX(current, iva) + fault) & ~0xffUL; + regs->cr_ipsr = + (regs->cr_ipsr & ~DELIVER_PSR_CLR) | DELIVER_PSR_SET; // NOTE: nested trap must NOT pass PSCB address //regs->r31 = (unsigned long) &PSCB(current); perfc_incra(slow_reflect, fault >> 8); return; } - PSCB(current,itir) = itir; - PSCB(current,iha) = iha; - PSCB(current,ifa) = address; + PSCB(current, itir) = itir; + PSCB(current, iha) = iha; + PSCB(current, ifa) = address; reflect_interruption(isr, regs, fault); } fpswa_interface_t *fpswa_interface = 0; -void trap_init (void) +void trap_init(void) { if (ia64_boot_param->fpswa) - /* FPSWA fixup: make the interface pointer a virtual address: */ + /* FPSWA fixup: make the interface pointer a virtual address */ fpswa_interface = __va(ia64_boot_param->fpswa); else printk("No FPSWA supported.\n"); } static fpswa_ret_t -fp_emulate (int fp_fault, void *bundle, unsigned long *ipsr, - unsigned long *fpsr, unsigned long *isr, unsigned long *pr, - unsigned long *ifs, struct pt_regs *regs) +fp_emulate(int fp_fault, void *bundle, unsigned long *ipsr, + unsigned long *fpsr, unsigned long *isr, unsigned long *pr, + unsigned long *ifs, struct pt_regs *regs) { fp_state_t fp_state; fpswa_ret_t ret; if (!fpswa_interface) - return ((fpswa_ret_t) {-1, 0, 0, 0}); + return (fpswa_ret_t) {-1, 0, 0, 0}; memset(&fp_state, 0, sizeof(fp_state_t)); @@ -290,7 +302,7 @@ fp_emulate (int fp_fault, void *bundle, * kernel, so set those bits in the mask and set the low volatile * pointer to point to these registers. */ - fp_state.bitmask_low64 = 0xfc0; /* bit6..bit11 */ + fp_state.bitmask_low64 = 0xfc0; /* bit6..bit11 */ fp_state.fp_state_low_volatile = (fp_state_low_volatile_t *) ®s->f6; /* @@ -304,8 +316,8 @@ fp_emulate (int fp_fault, void *bundle, * unsigned long *pifs, * void *fp_state); */ - ret = (*fpswa_interface->fpswa)(fp_fault, bundle, - ipsr, fpsr, isr, pr, ifs, &fp_state); + ret = (*fpswa_interface->fpswa) (fp_fault, bundle, + ipsr, fpsr, isr, pr, ifs, &fp_state); return ret; } @@ -314,7 +326,7 @@ fp_emulate (int fp_fault, void *bundle, * Handle floating-point assist faults and traps for domain. */ unsigned long -handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr) +handle_fpu_swa(int fp_fault, struct pt_regs *regs, unsigned long isr) { struct vcpu *v = current; IA64_BUNDLE bundle; @@ -324,7 +336,8 @@ handle_fpu_swa (int fp_fault, struct pt_ fault_ip = regs->cr_iip; /* * When the FP trap occurs, the trapping instruction is completed. - * If ipsr.ri == 0, there is the trapping instruction in previous bundle. + * If ipsr.ri == 0, there is the trapping instruction in previous + * bundle. */ if (!fp_fault && (ia64_psr(regs)->ri == 0)) fault_ip -= 16; @@ -332,8 +345,7 @@ handle_fpu_swa (int fp_fault, struct pt_ if (VMX_DOMAIN(current)) { if (IA64_RETRY == __vmx_get_domain_bundle(fault_ip, &bundle)) return IA64_RETRY; - } - else + } else bundle = __get_domain_bundle(fault_ip); if (!bundle.i64[0] && !bundle.i64[1]) { @@ -343,25 +355,25 @@ handle_fpu_swa (int fp_fault, struct pt_ } ret = fp_emulate(fp_fault, &bundle, ®s->cr_ipsr, ®s->ar_fpsr, - &isr, ®s->pr, ®s->cr_ifs, regs); + &isr, ®s->pr, ®s->cr_ifs, regs); if (ret.status) { PSCBX(v, fpswa_ret) = ret; printk("%s(%s): fp_emulate() returned %ld\n", - __FUNCTION__, fp_fault?"fault":"trap", ret.status); + __FUNCTION__, fp_fault ? "fault" : "trap", ret.status); } return ret.status; } void -ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, - unsigned long iim, unsigned long itir, unsigned long arg5, - unsigned long arg6, unsigned long arg7, unsigned long stack) -{ - struct pt_regs *regs = (struct pt_regs *) &stack; +ia64_fault(unsigned long vector, unsigned long isr, unsigned long ifa, + unsigned long iim, unsigned long itir, unsigned long arg5, + unsigned long arg6, unsigned long arg7, unsigned long stack) +{ + struct pt_regs *regs = (struct pt_regs *)&stack; unsigned long code; - static const char * const reason[] = { + static const char *const reason[] = { "IA-64 Illegal Operation fault", "IA-64 Privileged Operation fault", "IA-64 Privileged Register fault", @@ -374,14 +386,15 @@ ia64_fault (unsigned long vector, unsign "Unknown fault 13", "Unknown fault 14", "Unknown fault 15" }; - printk("ia64_fault, vector=0x%lx, ifa=0x%016lx, iip=0x%016lx, ipsr=0x%016lx, isr=0x%016lx\n", - vector, ifa, regs->cr_iip, regs->cr_ipsr, isr); - - - if ((isr & IA64_ISR_NA) && ((isr & IA64_ISR_CODE_MASK) == IA64_ISR_CODE_LFETCH)) { + printk("ia64_fault, vector=0x%lx, ifa=0x%016lx, iip=0x%016lx, " + "ipsr=0x%016lx, isr=0x%016lx\n", vector, ifa, + regs->cr_iip, regs->cr_ipsr, isr); + + if ((isr & IA64_ISR_NA) && + ((isr & IA64_ISR_CODE_MASK) == IA64_ISR_CODE_LFETCH)) { /* - * This fault was due to lfetch.fault, set "ed" bit in the psr to cancel - * the lfetch. + * This fault was due to lfetch.fault, set "ed" bit in the + * psr to cancel the lfetch. */ ia64_psr(regs)->ed = 1; printk("ia64_fault: handled lfetch.fault\n"); @@ -389,108 +402,107 @@ ia64_fault (unsigned long vector, unsign } switch (vector) { - case 0: + case 0: printk("VHPT Translation.\n"); break; - - case 4: + + case 4: printk("Alt DTLB.\n"); break; - - case 6: + + case 6: printk("Instruction Key Miss.\n"); break; - case 7: + case 7: printk("Data Key Miss.\n"); break; - case 8: + case 8: printk("Dirty-bit.\n"); break; - case 20: + case 20: printk("Page Not Found.\n"); break; - case 21: + case 21: printk("Key Permission.\n"); break; - case 22: + case 22: printk("Instruction Access Rights.\n"); break; - case 24: /* General Exception */ + case 24: /* General Exception */ code = (isr >> 4) & 0xf; printk("General Exception: %s%s.\n", reason[code], - (code == 3) ? ((isr & (1UL << 37)) ? " (RSE access)" : - " (data access)") : ""); + (code == 3) ? ((isr & (1UL << 37)) ? " (RSE access)" : + " (data access)") : ""); if (code == 8) { -# ifdef CONFIG_IA64_PRINT_HAZARDS - printk("%s[%d]: possible hazard @ ip=%016lx (pr = %016lx)\n", - current->comm, current->pid, - regs->cr_iip + ia64_psr(regs)->ri, - regs->pr); -# endif +#ifdef CONFIG_IA64_PRINT_HAZARDS + printk("%s[%d]: possible hazard @ ip=%016lx " + "(pr = %016lx)\n", current->comm, current->pid, + regs->cr_iip + ia64_psr(regs)->ri, regs->pr); +#endif printk("ia64_fault: returning on hazard\n"); return; } break; - case 25: + case 25: printk("Disabled FP-Register.\n"); break; - case 26: + case 26: printk("NaT consumption.\n"); break; - case 29: + case 29: printk("Debug.\n"); break; - case 30: + case 30: printk("Unaligned Reference.\n"); break; - case 31: + case 31: printk("Unsupported data reference.\n"); break; - case 32: + case 32: printk("Floating-Point Fault.\n"); break; - case 33: + case 33: printk("Floating-Point Trap.\n"); break; - case 34: + case 34: printk("Lower Privilege Transfer Trap.\n"); break; - case 35: + case 35: printk("Taken Branch Trap.\n"); break; - case 36: + case 36: printk("Single Step Trap.\n"); break; - - case 45: + + case 45: printk("IA-32 Exception.\n"); break; - case 46: + case 46: printk("IA-32 Intercept.\n"); break; - case 47: + case 47: printk("IA-32 Interrupt.\n"); break; - default: + default: printk("Fault %lu\n", vector); break; } @@ -501,65 +513,65 @@ ia64_fault (unsigned long vector, unsign unsigned long running_on_sim = 0; - /* Also read in hyperprivop.S */ int first_break = 0; void -ia64_handle_break (unsigned long ifa, struct pt_regs *regs, unsigned long isr, unsigned long iim) +ia64_handle_break(unsigned long ifa, struct pt_regs *regs, unsigned long isr, + unsigned long iim) { struct domain *d = current->domain; struct vcpu *v = current; IA64FAULT vector; - if (iim == 0x80001 || iim == 0x80002) { //FIXME: don't hardcode constant - do_ssc(vcpu_get_gr(current,36), regs); - } + if (iim == 0x80001 || iim == 0x80002) {//FIXME: don't hardcode constant + do_ssc(vcpu_get_gr(current, 36), regs); + } #ifdef CRASH_DEBUG else if ((iim == 0 || iim == CDB_BREAK_NUM) && !user_mode(regs)) { if (iim == 0) show_registers(regs); - debugger_trap_fatal(0 /* don't care */, regs); - } + debugger_trap_fatal(0 /* don't care */ , regs); + } #endif - else if (iim == d->arch.breakimm && - ia64_get_cpl(regs->cr_ipsr) == 2) { + else if (iim == d->arch.breakimm && ia64_get_cpl(regs->cr_ipsr) == 2) { /* by default, do not continue */ v->arch.hypercall_continuation = 0; if ((vector = ia64_hypercall(regs)) == IA64_NO_FAULT) { if (!PSCBX(v, hypercall_continuation)) vcpu_increment_iip(current); - } - else reflect_interruption(isr, regs, vector); - } - else if (!PSCB(v,interrupt_collection_enabled)) { - if (ia64_hyperprivop(iim,regs)) + } else + reflect_interruption(isr, regs, vector); + } else if (!PSCB(v, interrupt_collection_enabled)) { + if (ia64_hyperprivop(iim, regs)) vcpu_increment_iip(current); - } - else { - if (iim == 0) + } else { + if (iim == 0) die_if_kernel("bug check", regs, iim); - PSCB(v,iim) = iim; - reflect_interruption(isr,regs,IA64_BREAK_VECTOR); + PSCB(v, iim) = iim; + reflect_interruption(isr, regs, IA64_BREAK_VECTOR); } } void -ia64_handle_privop (unsigned long ifa, struct pt_regs *regs, unsigned long isr, unsigned long itir) +ia64_handle_privop(unsigned long ifa, struct pt_regs *regs, unsigned long isr, + unsigned long itir) { IA64FAULT vector; - vector = priv_emulate(current,regs,isr); + vector = priv_emulate(current, regs, isr); if (vector != IA64_NO_FAULT && vector != IA64_RFI_IN_PROGRESS) { // Note: if a path results in a vector to reflect that requires // iha/itir (e.g. vcpu_force_data_miss), they must be set there - reflect_interruption(isr,regs,vector); + reflect_interruption(isr, regs, vector); } } void -ia64_handle_reflection (unsigned long ifa, struct pt_regs *regs, unsigned long isr, unsigned long iim, unsigned long vector) +ia64_handle_reflection(unsigned long ifa, struct pt_regs *regs, + unsigned long isr, unsigned long iim, + unsigned long vector) { struct vcpu *v = current; unsigned long check_lazy_cover = 0; @@ -567,39 +579,48 @@ ia64_handle_reflection (unsigned long if unsigned long status; /* Following faults shouldn'g be seen from Xen itself */ - BUG_ON (!(psr & IA64_PSR_CPL)); - - switch(vector) { - case 8: - vector = IA64_DIRTY_BIT_VECTOR; break; - case 9: - vector = IA64_INST_ACCESS_BIT_VECTOR; break; - case 10: + BUG_ON(!(psr & IA64_PSR_CPL)); + + switch (vector) { + case 8: + vector = IA64_DIRTY_BIT_VECTOR; + break; + case 9: + vector = IA64_INST_ACCESS_BIT_VECTOR; + break; + case 10: check_lazy_cover = 1; - vector = IA64_DATA_ACCESS_BIT_VECTOR; break; - case 20: + vector = IA64_DATA_ACCESS_BIT_VECTOR; + break; + case 20: check_lazy_cover = 1; - vector = IA64_PAGE_NOT_PRESENT_VECTOR; break; - case 22: - vector = IA64_INST_ACCESS_RIGHTS_VECTOR; break; - case 23: + vector = IA64_PAGE_NOT_PRESENT_VECTOR; + break; + case 22: + vector = IA64_INST_ACCESS_RIGHTS_VECTOR; + break; + case 23: check_lazy_cover = 1; - vector = IA64_DATA_ACCESS_RIGHTS_VECTOR; break; - case 25: + vector = IA64_DATA_ACCESS_RIGHTS_VECTOR; + break; + case 25: vector = IA64_DISABLED_FPREG_VECTOR; break; - case 26: + case 26: if (((isr >> 4L) & 0xfL) == 1) { /* Fault is due to a register NaT consumption fault. */ //regs->eml_unat = 0; FIXME: DO WE NEED THIS?? - printk("ia64_handle_reflection: handling regNaT fault\n"); - vector = IA64_NAT_CONSUMPTION_VECTOR; break; + printk("ia64_handle_reflection: handling regNaT " + "fault\n"); + vector = IA64_NAT_CONSUMPTION_VECTOR; + break; } #if 1 // pass null pointer dereferences through with no error // but retain debug output for non-zero ifa if (!ifa) { - vector = IA64_NAT_CONSUMPTION_VECTOR; break; + vector = IA64_NAT_CONSUMPTION_VECTOR; + break; } #endif #ifdef CONFIG_PRIVIFY @@ -610,32 +631,38 @@ ia64_handle_reflection (unsigned long if isr, ifa, regs->cr_iip, psr); //regs->eml_unat = 0; FIXME: DO WE NEED THIS??? // certain NaT faults are higher priority than privop faults - vector = priv_emulate(v,regs,isr); + vector = priv_emulate(v, regs, isr); if (vector == IA64_NO_FAULT) { - printk("*** Handled privop masquerading as NaT fault\n"); + printk("*** Handled privop masquerading as NaT " + "fault\n"); return; } #endif - vector = IA64_NAT_CONSUMPTION_VECTOR; break; - case 27: - //printk("*** Handled speculation vector, itc=%lx!\n",ia64_get_itc()); - PSCB(current,iim) = iim; - vector = IA64_SPECULATION_VECTOR; break; - case 30: + vector = IA64_NAT_CONSUMPTION_VECTOR; + break; + case 27: + //printk("*** Handled speculation vector, itc=%lx!\n", + // ia64_get_itc()); + PSCB(current, iim) = iim; + vector = IA64_SPECULATION_VECTOR; + break; + case 30: // FIXME: Should we handle unaligned refs in Xen?? - vector = IA64_UNALIGNED_REF_VECTOR; break; - case 32: + vector = IA64_UNALIGNED_REF_VECTOR; + break; + case 32: status = handle_fpu_swa(1, regs, isr); if (!status) { - vcpu_increment_iip(v); - return; + vcpu_increment_iip(v); + return; } // fetch code fail if (IA64_RETRY == status) return; printk("ia64_handle_reflection: handling FP fault\n"); - vector = IA64_FP_FAULT_VECTOR; break; - case 33: + vector = IA64_FP_FAULT_VECTOR; + break; + case 33: status = handle_fpu_swa(0, regs, isr); if (!status) return; @@ -643,31 +670,39 @@ ia64_handle_reflection (unsigned long if if (IA64_RETRY == status) return; printk("ia64_handle_reflection: handling FP trap\n"); - vector = IA64_FP_TRAP_VECTOR; break; - case 34: + vector = IA64_FP_TRAP_VECTOR; + break; + case 34: printk("ia64_handle_reflection: handling lowerpriv trap\n"); - vector = IA64_LOWERPRIV_TRANSFER_TRAP_VECTOR; break; - case 35: + vector = IA64_LOWERPRIV_TRANSFER_TRAP_VECTOR; + break; + case 35: printk("ia64_handle_reflection: handling taken branch trap\n"); - vector = IA64_TAKEN_BRANCH_TRAP_VECTOR; break; - case 36: + vector = IA64_TAKEN_BRANCH_TRAP_VECTOR; + break; + case 36: printk("ia64_handle_reflection: handling single step trap\n"); - vector = IA64_SINGLE_STEP_TRAP_VECTOR; break; - - default: - printk("ia64_handle_reflection: unhandled vector=0x%lx\n",vector); - while(vector); - return; - } - if (check_lazy_cover && (isr & IA64_ISR_IR) && handle_lazy_cover(v, regs)) return; - PSCB(current,ifa) = ifa; - PSCB(current,itir) = vcpu_get_itir_on_fault(v,ifa); - reflect_interruption(isr,regs,vector); + vector = IA64_SINGLE_STEP_TRAP_VECTOR; + break; + + default: + printk("ia64_handle_reflection: unhandled vector=0x%lx\n", + vector); + while (vector) + ; + return; + } + if (check_lazy_cover && (isr & IA64_ISR_IR) && + handle_lazy_cover(v, regs)) + return; + PSCB(current, ifa) = ifa; + PSCB(current, itir) = vcpu_get_itir_on_fault(v, ifa); + reflect_interruption(isr, regs, vector); } void ia64_shadow_fault(unsigned long ifa, unsigned long itir, - unsigned long isr, struct pt_regs *regs) + unsigned long isr, struct pt_regs *regs) { struct vcpu *v = current; struct domain *d = current->domain; @@ -677,11 +712,11 @@ ia64_shadow_fault(unsigned long ifa, uns /* There are 2 jobs to do: - marking the page as dirty (the metaphysical address must be - extracted to do that). + extracted to do that). - reflecting or not the fault (the virtual Dirty bit must be - extracted to decide). + extracted to decide). Unfortunatly these informations are not immediatly available! - */ + */ /* Extract the metaphysical address. Try to get it from VHPT and M2P as we need the flags. */ @@ -691,8 +726,7 @@ ia64_shadow_fault(unsigned long ifa, uns /* The VHPT entry is valid. */ gpfn = get_gpfn_from_mfn((pte & _PAGE_PPN_MASK) >> PAGE_SHIFT); BUG_ON(gpfn == INVALID_M2P_ENTRY); - } - else { + } else { unsigned long itir, iha; IA64FAULT fault; @@ -715,14 +749,14 @@ ia64_shadow_fault(unsigned long ifa, uns } /* Set the dirty bit in the bitmap. */ - shadow_mark_page_dirty (d, gpfn); + shadow_mark_page_dirty(d, gpfn); /* Update the local TC/VHPT and decides wether or not the fault should be reflected. SMP note: we almost ignore the other processors. The shadow_bitmap has been atomically updated. If the dirty fault happen on another processor, it will do its job. - */ + */ if (pte != 0) { /* We will know how to handle the fault. */ @@ -733,21 +767,19 @@ ia64_shadow_fault(unsigned long ifa, uns cpu VHPT owner can write page_flags. */ if (vlfe) vlfe->page_flags = pte | _PAGE_D; - + /* Purge the TC locally. It will be reloaded from the VHPT iff the VHPT entry is still valid. */ ia64_ptcl(ifa, PAGE_SHIFT << 2); atomic64_inc(&d->arch.shadow_fault_count); - } - else { + } else { /* Reflect. In this case there is no need to purge. */ ia64_handle_reflection(ifa, regs, isr, 0, 8); } - } - else { + } else { /* We don't know wether or not the fault must be reflected. The VHPT entry is not valid. */ /* FIXME: in metaphysical mode, we could do an ITC now. */ _______________________________________________ Xen-ia64-devel mailing list Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-ia64-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |