Re: Fw: potential /dev/urandom scalability improvement

From: Dave Jones
Date: Fri Mar 26 2004 - 06:14:38 EST


On Thu, Mar 25, 2004 at 06:00:14PM -0800, Andrew Morton wrote:

> +static inline void prefetch_range(void *addr, size_t len)
> +{
> +#ifdef ARCH_HAS_PREFETCH
> + char *cp;
> + char *end = addr + len;
> +
> + for (cp = addr; cp < end; cp += PREFETCH_STRIDE)
> + prefetch(cp);
> +#endif
> +}
> +
> #endif

I think this may be dangerous on some CPUs, if may prefetch past
the end of the buffer. Ie, if PREFETCH_STRIDE was 32, and len
was 65, we'd end up prefetching 65->97. As well as being
wasteful to cachelines, this can crash if theres for eg
nothing mapped after the next page boundary.

Dave

-
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/