On Thu, 3 Aug 2006, Andi Kleen wrote: > > As far as I can tell from this conversation there are special "Xen" > > drivers that need this not the rest of the system. > > Yes, but in general when a driver that runs on multiple architectures > (including IA64 btw) needs something architecture specific we usually > add it to asm, not add ifdefs. I still wonder why you are so focused on ifdefs. Why would we need those? > > What possible use could there be to someone else? > > e.g. for other hypervisors or possibly for special hardware access > (e.g. I could imagine it being used for some kind of cluster interconnect) > I remember Alan was using a similar hack in his EDAC drivers because > it was the only way to clear ECC errors. Maybe the best thing would be to have proper atomic ops in UP mode on i386? The current way of just dropping the lock bit is the source of the troubles. > > The "atomic" ops lock/unlock crap exists only for i386 as far as I can > > tell. As you said most architectures either always use atomic ops or > > never. The lock/unlock atomic ops are i386 specific material that > > better stay contained. Its arch specific and not generic. > > Well we have our share of weird hacks for IA64 too in generic code. But we all try to contain them. Here we have i386 hacks multiplying all over the system. > Just adding a single line #include for a wrapper asm-generic surely isn't > a undue burden for the other architectures, and it will save some > mess in the Xen drivers. Just adding a single line #include <asm/xen-bitops.h> to drivers that need this functionality is not an undue burden for the drivers that support Xen. They have to use special _xxx bitops anyways.