|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v7 08/15] x86_64/mm: switch to new APIs in setup_m2p_table
On 29.05.2020 13:11, Hongyan Xia wrote:
> From: Wei Liu <wei.liu2@xxxxxxxxxx>
>
> Avoid repetitive mapping of l2_ro_mpt by keeping it across loops, and
> only unmap and map it when crossing 1G boundaries.
>
> Signed-off-by: Wei Liu <wei.liu2@xxxxxxxxxx>
> Signed-off-by: Hongyan Xia <hongyxia@xxxxxxxxxx>
Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx>
I do think, however, that ...
> @@ -438,32 +443,29 @@ static int setup_m2p_table(struct mem_hotadd_info *info)
>
> ASSERT(!(l3e_get_flags(l3_ro_mpt[l3_table_offset(va)]) &
> _PAGE_PSE));
> - if ( l3e_get_flags(l3_ro_mpt[l3_table_offset(va)]) &
> - _PAGE_PRESENT )
> - l2_ro_mpt = l3e_to_l2e(l3_ro_mpt[l3_table_offset(va)]) +
> - l2_table_offset(va);
> - else
> + if ( (l3e_get_flags(l3_ro_mpt[l3_table_offset(va)]) &
> + _PAGE_PRESENT) && !l2_ro_mpt)
> + l2_ro_mpt = map_l2t_from_l3e(l3_ro_mpt[l3_table_offset(va)]);
> + else if ( !l2_ro_mpt )
> {
... this would be slightly neater as
if ( l2_ro_mpt )
/* nothing */;
else if ( l3e_get_flags(l3_ro_mpt[l3_table_offset(va)]) &
_PAGE_PRESENT )
l2_ro_mpt = map_l2t_from_l3e(l3_ro_mpt[l3_table_offset(va)]);
else
{
...
My R-b holds if you would change it like this.
Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |