Author: jhibbits
Date: Fri Mar 14 04:35:18 2014
New Revision: 263151
URL: http://svnweb.freebsd.org/changeset/base/263151

Log:
  MFC r262547
  
  Fix callchain capture for hwpmc(4).  While here, some style(9) fixes, too.

Modified:
  stable/10/sys/dev/hwpmc/hwpmc_powerpc.c
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/sys/dev/hwpmc/hwpmc_powerpc.c
==============================================================================
--- stable/10/sys/dev/hwpmc/hwpmc_powerpc.c     Fri Mar 14 03:42:05 2014        
(r263150)
+++ stable/10/sys/dev/hwpmc/hwpmc_powerpc.c     Fri Mar 14 04:35:18 2014        
(r263151)
@@ -32,6 +32,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/param.h>
 #include <sys/pmc.h>
 #include <sys/pmckern.h>
+#include <sys/sysent.h>
 #include <sys/systm.h>
 
 #include <machine/pmc_mdep.h>
@@ -60,10 +61,14 @@ pmc_save_kernel_callchain(uintptr_t *cc,
        cc[frames++] = PMC_TRAPFRAME_TO_PC(tf);
        sp = (uintptr_t *)PMC_TRAPFRAME_TO_FP(tf);
 
-       for (frames = 1; frames < maxsamples; frames++) {
+       for (; frames < maxsamples; frames++) {
                if (!INKERNEL(sp))
                        break;
+#ifdef __powerpc64__
+               cc[frames++] = sp[2];
+#else
                cc[frames++] = sp[1];
+#endif
                sp = (uintptr_t *)*sp;
        }
        return (frames);
@@ -72,12 +77,14 @@ pmc_save_kernel_callchain(uintptr_t *cc,
 static int
 powerpc_switch_in(struct pmc_cpu *pc, struct pmc_process *pp)
 {
+
        return (0);
 }
 
 static int
 powerpc_switch_out(struct pmc_cpu *pc, struct pmc_process *pp)
 {
+
        return (0);
 }
 
@@ -111,6 +118,7 @@ powerpc_describe(int cpu, int ri, struct
 int
 powerpc_get_config(int cpu, int ri, struct pmc **ppm)
 {
+
        *ppm = powerpc_pcpu[cpu]->pc_ppcpmcs[ri].phw_pmc;
 
        return (0);
@@ -182,11 +190,23 @@ pmc_save_user_callchain(uintptr_t *cc, i
        cc[frames++] = PMC_TRAPFRAME_TO_PC(tf);
        sp = (uintptr_t *)PMC_TRAPFRAME_TO_FP(tf);
 
-       for (frames = 1; frames < maxsamples; frames++) {
+       for (; frames < maxsamples; frames++) {
                if (!INUSER(sp))
                        break;
-               cc[frames++] = fuword(sp + 1);
-               sp = (uintptr_t *)fuword(sp);
+#ifdef __powerpc64__
+               /* Check if 32-bit mode. */
+               if (!(tf->srr1 & PSL_SF)) {
+                       cc[frames++] = fuword32((uint32_t *)sp + 1);
+                       sp = (uintptr_t *)(uintptr_t)fuword32(sp);
+               } else {
+                       cc[frames++] = fuword(sp + 2);
+                       sp = (uintptr_t *)fuword(sp);
+               }
+#else
+               cc[frames++] = fuword32((uint32_t *)sp + 1);
+               sp = (uintptr_t *)fuword32(sp);
+#endif
        }
+
        return (frames);
 }
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to