[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH for 4.20? v3 3/3] xen/riscv: update mfn calculation in pt_mapping_level()
On 07.02.2025 14:13, Oleksii Kurochko wrote: > --- a/xen/arch/riscv/pt.c > +++ b/xen/arch/riscv/pt.c > @@ -238,11 +238,10 @@ pte_t pt_walk(vaddr_t va, unsigned int *pte_level) > > /* Update an entry at the level @target. */ > static int pt_update_entry(mfn_t root, vaddr_t virt, > - mfn_t mfn, unsigned int target, > + mfn_t mfn, unsigned int *target, > unsigned int flags) > { > int rc; > - unsigned int level = HYP_PT_ROOT_LEVEL; > pte_t *table; Considering the lack of an initializer here, ... > @@ -256,39 +255,45 @@ static int pt_update_entry(mfn_t root, vaddr_t virt, > bool alloc_tbl = !mfn_eq(mfn, INVALID_MFN) || (flags & PTE_POPULATE); > pte_t pte, *entry; > > - /* convenience aliases */ > - DECLARE_OFFSETS(offsets, virt); > - > - table = map_table(root); > - for ( ; level > target; level-- ) > + if ( *target == CONFIG_PAGING_LEVELS ) > + entry = _pt_walk(virt, target); > + else > { > - rc = pt_next_level(alloc_tbl, &table, offsets[level]); > - if ( rc == XEN_TABLE_MAP_NOMEM ) > + unsigned int level = HYP_PT_ROOT_LEVEL; > + /* convenience aliases */ > + DECLARE_OFFSETS(offsets, virt); > + > + table = map_table(root); > + for ( ; level > *target; level-- ) > { > - rc = -ENOMEM; > - goto out; > + rc = pt_next_level(alloc_tbl, &table, offsets[level]); > + if ( rc == XEN_TABLE_MAP_NOMEM ) > + { > + rc = -ENOMEM; > + goto out; > + } > + > + if ( rc == XEN_TABLE_MAP_NONE ) > + { > + rc = 0; > + goto out; > + } > + > + if ( rc != XEN_TABLE_NORMAL ) > + break; > } > > - if ( rc == XEN_TABLE_MAP_NONE ) > + if ( level != *target ) > { > - rc = 0; > + dprintk(XENLOG_ERR, > + "%s: Shattering superpage is not supported\n", __func__); > + rc = -EOPNOTSUPP; > goto out; > } > > - if ( rc != XEN_TABLE_NORMAL ) > - break; > - } > - > - if ( level != target ) > - { > - dprintk(XENLOG_ERR, > - "%s: Shattering superpage is not supported\n", __func__); > - rc = -EOPNOTSUPP; > - goto out; > + entry = table + offsets[level]; > } > > - entry = table + offsets[level]; > - > rc = -EINVAL; > if ( !pt_check_entry(*entry, mfn, flags) ) > goto out; ... I'm surprised the compiler doesn't complain about use of a possibly uninitialized variable at out: unmap_table(table); For the new path you're adding the variable is uninitialized afaict. Which implies that you're again failing to unmap what _pt_walk() has handed you. Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |