Andi Kleen wrote:
>> +    /* convert from IF type flag */
>> +    flags = !(flags & X86_EFLAGS_IF);
>> +    vcpu = x86_read_percpu(xen_vcpu);
>> +    vcpu->evtchn_upcall_mask = flags;
>> +    if (flags == 0) {
>> +            barrier(); /* unmask then check (avoid races) */
>>     
>
> Don't you need a rmb() here then? The CPU could speculate reads
> (more occurrences) 
>   

Is rmb() sufficient?  It will stop a speculative read on the pending
flag, but will it make sure the write has happened by then?  Ie, is it a
write-vs-read barrier, or just a read-vs-read? 
Documentation/memory-barriers.txt suggests not.

    J
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to