[LLVMdev] path profile result with LLVM
raymondc
raymond_llvm at 163.com
Fri Jul 10 02:24:13 PDT 2015
Hello gssict, I've met just the same problem you met 2 years ago. The only
difference is that I'm new to LLVM while you were familiar with it and shall
be an expert at
it now. Since there is no answer to this question and series of questions
about path profiling, I have to solve it by myself.
I think the result you get is meaningful, though it needs further
regeneration to get the corresponding paths. I just read the paper96 by B&L,
and view the tech-
report2010 by Adam(seems that he implements the pp) I find:
1.The algorithm just focuses on intraprocedural, so each function has its
own path count(supported by the result);
2.Despite self loops, every backedge(at the end of while, for ...) leads to
an increment=1 of path count;
3.For self loops(there is one in the
common_fft,"for(stage=1;&&(j=j/2)!=1;stage++) ;"),increment should be made
inside basic block;
4.Combining 2 and 3, I manually instrument common_fft:
#--------------------------------------------------------------------------------------------------#
for(i=0;i<nfft-1;i++)
{ ++blcount;
if(i<j)
{
t=x[j];
x[j]=x[i];
x[i]=t;
}
k=nfft/2;
while(k<=j)
{ ++blcount;
j-=k;
k/=2;
}
j+=k;
}
int stage,le,lei,ip;
COMPLEX u,w;
j= nfft;
for(stage=1;(++blcount)&&(j=j/2)!=1;stage++) ; //caculate stage,which
represents butterfly stages
for(k=1;k<=stage;k++)
{ ++blcount;
le=2<<(k-1);
lei=le/2;
u.real=1.0;// u,butterfly factor initial value
u.img=0.0;
w.real=cos(PI/lei*isign);
w.img=sin(PI/lei*isign);
for(j=0;j<=lei-1;j++)
{ ++blcount;
for(i=j;i<=nfft-1;i+=le)
{ ++blcount;
ip=i+lei;
t=EE(x[ip],u);
x[ip].real=x[i].real-t.real;
x[ip].img=x[i].img-t.img;
x[i].real=x[i].real+t.real;
x[i].img=x[i].img+t.img;
}
u=EE(u,w);
}
}
#--------------------------------------------------------------------------------------------------#
Initially, blcount=0. And at the end of main, I print it out and get 162,
which equals to the sum of path counts of common_fft in your result.
5.What's more, combining 2, 3 and the rule of increment at the EXIT, we can
infer that during every execution of common_fft, every 1st backedge/selfloop
should be
recorded and it is different from other backedge/selfloop. Since there are 6
such backedge/selfloop, and common_fft executed 2 times, under the condition
that every
backedge/selfloop is executed, there should be exactly 6 counts of 2, which
is supported by your result!
Now at the end of my answer, I think the remaining question is how to
regenerate the paths.
I am new to LLVM, so I hope you can help me with how to output path
profiling result.
Desire for your help!!
Raymond Chen.
--
View this message in context: http://llvm.1065342.n5.nabble.com/path-profile-result-with-LLVM-tp56354p83568.html
Sent from the LLVM - Dev mailing list archive at Nabble.com.
More information about the llvm-dev
mailing list