[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-ia64-devel] [patch] faults.c indentation


  • To: xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
  • From: Jes Sorensen <jes@xxxxxxx>
  • Date: 10 Nov 2006 07:59:09 -0500
  • Delivery-date: Fri, 10 Nov 2006 04:59:22 -0800
  • List-id: Discussion of the ia64 port of Xen <xen-ia64-devel.lists.xensource.com>

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 *) &regs->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, &regs->cr_ipsr, &regs->ar_fpsr,
-                        &isr, &regs->pr, &regs->cr_ifs, regs);
+                        &isr, &regs->pr, &regs->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


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.