Gregory Haskins wrote:
> Out of curiosity, did you review my kick_process() version or the newer 
> smp_call_function_single() based version of the patch?  
>
>   

The former.

>>     
>>> @@ -1866,6 +1874,19 @@ static int kvm_vcpu_ioctl_run(struct kvm_vcpu *vcpu, 
>>>       
>> struct kvm_run *kvm_run)
>>     
>>>             kvm_arch_ops->decache_regs(vcpu);
>>>     }
>>>  
>>> +   /*
>>> +    * Make sure the current task is accurately recorded.  Most of the 
>>> +    * time, it will be so we first check if its necessary without taking
>>> +    * the lock.  If there is a mismatch, we must aquire the lock and 
>>> +    * check again to eliminate races
>>> +    */
>>> +   if (unlikely(vcpu->irq.task != current)) {
>>> +           spin_lock(&vcpu->irq.lock);
>>> +           if (vcpu->irq.task != current)
>>> +                   vcpu->irq.task = current;
>>> +           spin_unlock(&vcpu->irq.lock);
>>> +   }
>>> +
>>>   
>>>       
>> Isn't this equivalent to
>>
>>     vcpu->irq.task = current
>>     
>
> Yeah, good point.  I originally had a printk in there to report when it 
> changes, thus the conditional.  I didn't collapse it when I took the printk 
> out.  I suppose you could argue that updating the variable indiscriminately 
> will unnecessarily dirty a cache-line, but I doubt it would matter in the 
> grand scheme of things.
>
>   

The vcpu cachelines are already dirty.

Please repost the patchset (one patch per message) so I can see it
together.  Thanks.

-- 
Do not meddle in the internals of kernels, for they are subtle and quick to 
panic.


-------------------------------------------------------------------------
This SF.net email is sponsored by DB2 Express
Download DB2 Express C - the FREE version of DB2 express and take
control of your XML. No limits. Just data. Click to get it now.
http://sourceforge.net/powerbar/db2/
_______________________________________________
kvm-devel mailing list
kvm-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/kvm-devel

Reply via email to