On 2017-11-02 11:23:16 [-0600], Logan Gunthorpe wrote: > > Well, you clearly didn't read the article I sent or even what I said. But I did, I just didn't manage to make the link. The futex example looks like compiler optimisation which should not have happen and would be ideal for READ_ONCE, yes. But this is not the case here and this is what I pointed out. And the ps2 example, well it did not check condition after the wait so it was not obvious if the condition (for which it was waiting) was true or not. So if you want this thing to be catched by tools, I don't know how this bug | int rc = -1; | ... | wait_event_timeout(ps2dev->wait, !(READ_ONCE(ps2dev->flags) & PS2_FLAG_CMD), timeout); | for (i = 0; i < receive; i++) | resp[i] = ps2dev->cmdbuf[(receive - 1) - i]; | if (READ_ONCE(ps2dev->cmdcnt)) | goto out; | rc = 0; |out: | return rc; could have spotted by anything but a human. > your reasoning is a bit flawed seeing try_wait_for_completion() is not > designed to be inlined and will never be inlined unless the kernel is > compiled with link-time optimization which I don't think many people use. See 7c34e3180a01 ("sched/completion: Add lock-free checking of the blocking case") > Logan Sebastian