[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH for 4.20? v3 1/3] xen/riscv: implement software page table walking
On 07.02.2025 14:13, Oleksii Kurochko wrote: > --- a/xen/arch/riscv/pt.c > +++ b/xen/arch/riscv/pt.c > @@ -185,6 +185,57 @@ static int pt_next_level(bool alloc_tbl, pte_t **table, > unsigned int offset) > return XEN_TABLE_NORMAL; > } > > +/* > + * _pt_walk() performs software page table walking and returns the pte_t of > + * a leaf node or the leaf-most not-present pte_t if no leaf node is found > + * for further analysis. > + * Additionally, _pt_walk() returns the level of the found pte. That's optional, which I think wants expressing here. > + */ > +static pte_t *_pt_walk(vaddr_t va, unsigned int *pte_level) > +{ > + const mfn_t root = get_root_page(); > + unsigned int level; > + pte_t *table; > + > + DECLARE_OFFSETS(offsets, va); > + > + table = map_table(root); This mapping operation doesn't look to have a counterpart. Aiui ... > + /* > + * Find `table` of an entry which corresponds to `va` by iterating for > each > + * page level and checking if the entry points to a next page table or > + * to a page. > + * > + * Two cases are possible: > + * - ret == XEN_TABLE_SUPER_PAGE means that the entry was found; > + * (Despite the name) XEN_TABLE_SUPER_PAGE also covers 4K mappings. If > + * pt_next_level() is called for page table level 0, it results in the > + * entry being a pointer to a leaf node, thereby returning > + * XEN_TABLE_SUPER_PAGE, despite of the fact this leaf covers 4k > mapping. > + * - ret == XEN_TABLE_MAP_NONE means that requested `va` wasn't actually > + * mapped. > + */ > + for ( level = HYP_PT_ROOT_LEVEL; ; --level ) > + { > + int ret = pt_next_level(false, &table, offsets[level]); ... the mapping may be replaced here, but a new mapping will then still be held by this function and ... > + if ( ret == XEN_TABLE_MAP_NONE || ret == XEN_TABLE_SUPER_PAGE ) > + break; > + > + ASSERT(level); > + } > + > + if ( pte_level ) > + *pte_level = level; > + > + return table + offsets[level]; > +} ... the final one then be transferred to the caller. > +pte_t pt_walk(vaddr_t va, unsigned int *pte_level) > +{ > + return *_pt_walk(va, pte_level); > +} Hence aiui there needs to be an unmap operation here. Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |