[RESEND PATCH v7 3/4] arm: dirty log write protect management support
Mario Smarduch
m.smarduch at samsung.com
Fri Jun 6 10:36:41 PDT 2014
On 06/05/2014 10:52 PM, Xiao Guangrong wrote:
> On 06/06/2014 03:09 AM, Mario Smarduch wrote:
>> On 06/04/2014 11:55 PM, Xiao Guangrong wrote:
>>> On 06/05/2014 05:11 AM, Mario Smarduch wrote:
>>>
>>>> + spin_lock(&kvm->mmu_lock);
>>>> +
>>>> + for (i = 0; i < n / sizeof(long); i++) {
>>>> + unsigned long mask;
>>>> + gfn_t offset;
>>>> +
>>>> + if (!dirty_bitmap[i])
>>>> + continue;
>>>> +
>>>> + is_dirty = true;
>>>> +
>>>> + mask = xchg(&dirty_bitmap[i], 0);
>>>> + dirty_bitmap_buffer[i] = mask;
>>>> +
>>>> + offset = i * BITS_PER_LONG;
>>>> + kvm_mmu_write_protect_pt_masked(kvm, memslot, offset, mask);
>>>> + }
>>>> + if (is_dirty)
>>>> + kvm_flush_remote_tlbs(kvm);
>>>
>>> You moved the flush into mmu-lock. Please do not :).
>>>
>>> See commit 198c74f43f0f5473f99967aead30ddc622804bc1
>>>
>>
>> Thanks for reviewing, I revised to pick up your version.
>>
>> Functionally there should be no impact on ARM, the
>> TLB flush function is different.
>
> Yeah, i agree your point on ARM, but your patch moved
> the function from x86 to the common code, that means
> this function is reused between ARM and x86. No?
>
Yes you pretty much summarized it. My point was more like
I'm glad the change had no impact on ARM :)
Thanks,
- Mario
More information about the linux-arm-kernel
mailing list