c++kcachegrind

Understanding Kcachegrind callgraph number output


Hi I am new to using this tool and I don't have much documentation on it other that what I was able to google a bit. I have a compiled c++ program that I am running callgrind on and I see the call graph but if I don't use relative %. What do the numbers mean? I will see 3 numbers in the calling function box and a meter that has some blue fill in it. Also, the arrow to the functions it calls has a number like 224 x and then 3 numbers under it along with a meter and blue fill also. Trying to get some exact information on what the 3 numbers mean and what the numbers on the arrow mean. Sometimes you will get 36 217 x on an arrow and then 3 numbers underneath it. Sometimes you will just get 359 x with no prefix number.


Solution

  • The kcachegrind display can be confusing.

    The "three numbers" you are seeing are actually one number separated into groups of three digits. Imagine comma's or dots depending on your locale between the groups of digits. The one number that results is the cost (a count of how many times your program was observed in the function.)

    The box with a blue fill is a "percent meter" so that in addition to the absolute cost for a function you have a rough estimate of how much of the total cost was assigned to this function.

    PS: I don't know what the trailing 'x' means. Maybe someone else can help with that one!