Re: [PATCH 01/18] asm-generic/barrier: add generic nospec helpers

From: Linus Torvalds
Date: Fri Jan 05 2018 - 21:55:39 EST


On Fri, Jan 5, 2018 at 5:09 PM, Dan Williams <dan.j.williams@xxxxxxxxx> wrote:
> +#ifndef nospec_ptr
> +#define nospec_ptr(ptr, lo, hi) \

Do we actually want this horrible interface?

It just causes the compiler - or inline asm - to generate worse code,
because it needs to compare against both high and low limits.

Basically all users are arrays that are zero-based, and where a
comparison against the high _index_ limit would be sufficient.

But the way this is all designed, it's literally designed for bad code
generation for the unusual case, and the usual array case is written
in the form of the unusual and wrong non-array case. That really seems
excessively stupid.

Linus