Re: [PATCH 0/8] perf: add ability to sample physical data addresses

From: Ingo Molnar
Date: Wed Jun 26 2013 - 09:29:39 EST



* Peter Zijlstra <peterz@xxxxxxxxxxxxx> wrote:

> > > Such would completely shatter physical page relations.
> > >
> > > If the shared memory thing is really the issue, doesn't perf already
> > > have the process memory layout (/proc/$PID/maps and aux stream mmap
> > > updates) with which it can compute map relative offsets and compare
> > > thusly?
> >
> > Not sure I understand this.
> > suppose the same shared memory segment is mapped at two different
> > addresses by shmat(). First, I don't know if those show up in /proc/maps.
>
> They should; IIRC maps is a full vma list.. /me prods about in
> fs/proc/task_mmu.c.. yes it prints all vmas.

Btw., as a related matter, it would be nice to add an ioctl() that would
trigger a regular MMAP event for all current vmas.

PERF_EVENT_IOC_DUMP_MMAPS or so?

This would be easier to process than the somewhat fragile parsing
/proc/*/maps text files, and it would more consistently fit into the perf
tracing model.

I suspect it would/could also be less racy than /proc/*/maps, which is
restart based due to the 4K procfs limit, while the ioctl() could dump
everything into the trace buffer, as long as the buffer is large enough.

Thanks,

Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/