#include <errno.h>
 #include <math.h>
 
+#include "asm/bug.h"
+
 #include "hist.h"
 #include "util.h"
 #include "sort.h"
        /* lookup in childrens */
        while (*p) {
                s64 ret;
-               struct callchain_list *cnode;
 
                parent = *p;
                rnode = rb_entry(parent, struct callchain_node, rb_node_in);
-               cnode = list_first_entry(&rnode->val, struct callchain_list,
-                                        list);
 
-               /* just check first entry */
-               ret = match_chain(node, cnode);
-               if (ret == 0) {
-                       append_chain(rnode, cursor, period);
+               /* If at least first entry matches, rely to children */
+               ret = append_chain(rnode, cursor, period);
+               if (ret == 0)
                        goto inc_children_hit;
-               }
 
                if (ret < 0)
                        p = &parent->rb_left;
        u64 start = cursor->pos;
        bool found = false;
        u64 matches;
+       int cmp = 0;
 
        /*
         * Lookup in the current node
                if (!node)
                        break;
 
-               if (match_chain(node, cnode) != 0)
+               cmp = match_chain(node, cnode);
+               if (cmp)
                        break;
 
                found = true;
 
        /* matches not, relay no the parent */
        if (!found) {
+               WARN_ONCE(!cmp, "Chain comparison error\n");
                cursor->curr = curr_snap;
                cursor->pos = start;
-               return -1;
+               return cmp;
        }
 
        matches = cursor->pos - start;