> Hello all,
>
> kernel/src/plat/pc99/machine/intel-vtd.c::vtd_get_n_paging() confused me a
> lot. Wish to get any help.
>
> This func intends to calculate paging pages needed for all RMRRs. The
> following code 'filter the identical regions by pci bus id', and use them to
> figure out the final result.
> ```
>     for (word_t i = 1; i < rmrr_list->num; i++) {
>         if (vtd_get_root_index(rmrr_list->entries[i].device) !=
>             vtd_get_root_index(filtered.entries[filtered.num - 1].device) &&
>             rmrr_list->entries[i].base != filtered.entries[filtered.num - 
> 1].base &&
>             rmrr_list->entries[i].limit != filtered.entries[filtered.num - 
> 1].limit) {
>             filtered.entries[filtered.num] = rmrr_list->entries[i];
>             filtered.num++;
>         }
>     }
> ```
> But vtd_map_reserved_page() says, every different devices(with diff bus-dev-
> func ID) have their own paging structures. Then why do filter here like this
> , yet the logic looks so confusing.
>
> And on line 313, it counts pages according to the specified level address
> bits.
> ```
>                 size += get_n_paging(region, 32 - (VTD_PT_INDEX_BITS * i + 
> seL4_PageBits));
> ```
> So what does 32 mean? Maybe a typo?
>
> Thanks,
> laokz

Hi laokz,

`vtd_get_n_paging()` tries to pre-calculate how many page tables will be needed 
to set up the initial VTD mappings.  The value that it returns gets used to 
preallocate the memory required and then later on in the boot process the page 
tables are allocated using `it_alloc_paging`. Part of the logic in 
vtd_get_n_paging appears to try and calculate how many page tables are required 
for creating the reserved memory mapping regions. As you identify, the logic 
doesn't seem to be correct in several places. Currently, the final result is 
that it overcalculates the amount of page tables required by quite a lot, so 
the consequence for the overall system is some memory gets leaked during boot 
due to the overallocation.  I'm working on a patch and I'll notify you when 
it's up on GitHub.  Thanks for tracking this down!

Kent
_______________________________________________
Devel mailing list
[email protected]
https://sel4.systems/lists/listinfo/devel

Reply via email to