On Mon, Mar 24, 2014 at 04:57:18PM -0400, Don Zickus wrote: > In order for the c2c tool to work correctly, it needs to properly > sort all the records on uniquely identifiable data addresses. These > unique addresses are converted from virtual addresses provided by the > hardware into a kernel address using an mmap2 record as the decoder. > > Once a unique address is converted, we can sort on them based on > various rules. Then it becomes clear which address are overlapping > with each other across mmap regions or pid spaces. > > This patch just creates the rules and inserts the records into a > sort entry for safe keeping until later patches process them. > > The general sorting rule is:
SNIP > + > +static int64_t > +sort__physid_major_cmp(struct hist_entry *left, struct hist_entry *right) > +{ > + struct map *l = left->mem_info->daddr.map; > + struct map *r = right->mem_info->daddr.map; > + > + return r->maj - l->maj; I got segfault here, and consequently in all other sorting functions, because it failed to resolve map earlier in ip__resolve_data we need to check it here, or before adding to the tree thanks, jirka -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/