Jeffrey Yasskin
2010-Apr-26  21:09 UTC
[LLVMdev] Proposal for a new LLVM concurrency memory model
On Mon, Apr 26, 2010 at 1:09 PM, David Greene <dag at cray.com> wrote:> On Monday 26 April 2010 14:03:35 Chandler Carruth wrote: >> We can allow the IR to represent vectors, but unless hardware supports it, >> I think lowering these by decomposing them is more than LLVM should try to >> do. Because of that, I'm not sure we should support vectors as elsewhere >> they degrade gracefully. > > Vector atomics are extremely useful on architectures that support them.I'm curious about the architectures/instructions you're thinking of. Something like 'lock; movdqa'?> I'm not sure we need atomicity across vector elements, so decomposing > shouldn't be a problem, but I will have to think about it a bit.That's interesting. Naïvely, it seems to violate the whole point of atomics, since it means their side-effects don't appear atomic to other threads. We could relax that if it's useful, of course. How do you imagine specifying the program's constraints on vector/word tearing? Jeffrey
David Greene
2010-Apr-27  16:02 UTC
[LLVMdev] Proposal for a new LLVM concurrency memory model
On Monday 26 April 2010 16:09:48 Jeffrey Yasskin wrote:> > Vector atomics are extremely useful on architectures that support them. > > I'm curious about the architectures/instructions you're thinking of. > Something like 'lock; movdqa'?Don't think X86. Think traditional vector machines like the Cray X1/X2. Atomic vector adds and logicals are common operations.> > I'm not sure we need atomicity across vector elements, so decomposing > > shouldn't be a problem, but I will have to think about it a bit. > > That's interesting. Naïvely, it seems to violate the whole point of > atomics, since it means their side-effects don't appear atomic to > other threads. We could relax that if it's useful, of course. How do > you imagine specifying the program's constraints on vector/word > tearing?I wrote up a response to Renato's question. In the end I don't think the tearing idea is worth the effort. The compiler should just not generate vector atomics if the target doesn't support them. -Dave
David Greene
2010-Apr-27  16:48 UTC
[LLVMdev] Proposal for a new LLVM concurrency memory model
On Tuesday 27 April 2010 11:02:54 David Greene wrote:> On Monday 26 April 2010 16:09:48 Jeffrey Yasskin wrote: > > > Vector atomics are extremely useful on architectures that support them. > > > > I'm curious about the architectures/instructions you're thinking of. > > Something like 'lock; movdqa'? > > Don't think X86. Think traditional vector machines like the Cray X1/X2. > Atomic vector adds and logicals are common operations.In terms of x86, the equivalent would be if there was an instruction like ADDPD mem128, xmm and we could put a LOCK prefix on it. -Dave
Possibly Parallel Threads
- [LLVMdev] Proposal for a new LLVM concurrency memory model
- [LLVMdev] Proposal for a new LLVM concurrency memory model
- [LLVMdev] Proposal for a new LLVM concurrency memory model
- [LLVMdev] Proposal for a new LLVM concurrency memory model
- [LLVMdev] Proposal for a new LLVM concurrency memory model