[Cbe-oss-dev] [RFC, PATCH 4/4] Add support to OProfile for profiling Cell BE SPUs -- update
Arnd Bergmann
arnd at arndb.de
Thu Feb 1 02:42:41 EST 2007
On Wednesday 31 January 2007 10:24, Milton Miller wrote:
> > +/* The three functions below are for maintaining and accessing
> > + * the vma-to-file offset map.
> > + */
> > +vma_map_t * create_vma_map(const struct spu * spu, u64 objectid);
> > +unsigned int vma_map_lookup(vma_map_t *map, unsigned int vma,
> > + const struct spu * aSpu);
> > +void vma_map_free(struct vma_map *map);
> > +
>
> Why would the SPU to cookie translation need to be different
> than the standard vm one? Is it that spufs takes refs on the
> pages but doesn't have the standard vma? Maybe an approach
> of creating them would reuse the oprofile code.
It's a two stage process for SPUs:
* samples are relative to the local store, and for each sample
we need to know what context was running. The context is
identified over a pointer to user space effective addresses.
* The effective address identifies the SPU ELF binary mapped
at that address. It may however be in the middle of a VMA,
so you get another offset into the mapped file.
For each sample, you then get an offset into the ls, an offset
into the file to identify the ELF object, and the dcookie
for the file containing that object.
As a consequence, you only need dcookies for the case where
a context switch happens (the executable changes), but not
for each of the samples during the a time slice, they all
point to the same object.
Arnd <><
More information about the cbe-oss-dev
mailing list