[PATCH v3 21/23] mm/vma: convert as much as we can in mm/vma.c to vma_flags_t
Lorenzo Stoakes (Oracle)
ljs at kernel.org
Sat Mar 21 05:28:28 AEDT 2026
On Fri, Mar 20, 2026 at 11:15:52AM +0100, Vlastimil Babka (SUSE) wrote:
> On 3/18/26 16:50, Lorenzo Stoakes (Oracle) wrote:
> > Now we have established a good foundation for vm_flags_t to vma_flags_t
> > changes, update mm/vma.c to utilise vma_flags_t wherever possible.
> >
> > We are able to convert VM_STARTGAP_FLAGS entirely as this is only used in
> > mm/vma.c, and to account for the fact we can't use VM_NONE to make life
> > easier, place the definition of this within existing #ifdef's to be
> > cleaner.
> >
> > Generally the remaining changes are mechanical.
> >
> > Also update the VMA tests to reflect the changes.
> >
> > Signed-off-by: Lorenzo Stoakes (Oracle) <ljs at kernel.org>
>
> Acked-by: Vlastimil Babka (SUSE) <vbabka at kernel.org>
Thanks!
>
> Nits:
>
> > @@ -2338,8 +2339,11 @@ void mm_drop_all_locks(struct mm_struct *mm)
> > * We account for memory if it's a private writeable mapping,
> > * not hugepages and VM_NORESERVE wasn't set.
> > */
> > -static bool accountable_mapping(struct file *file, vm_flags_t vm_flags)
> > +static bool accountable_mapping(struct mmap_state *map)
> > {
> > + const struct file *file = map->file;
> > + vma_flags_t mask;
> > +
> > /*
> > * hugetlb has its own accounting separate from the core VM
> > * VM_HUGETLB may not be set yet so we cannot check for that flag.
> > @@ -2347,7 +2351,9 @@ static bool accountable_mapping(struct file *file, vm_flags_t vm_flags)
> > if (file && is_file_hugepages(file))
> > return false;
> >
> > - return (vm_flags & (VM_NORESERVE | VM_SHARED | VM_WRITE)) == VM_WRITE;
> > + mask = vma_flags_and(&map->vma_flags, VMA_NORESERVE_BIT, VMA_SHARED_BIT,
> > + VMA_WRITE_BIT);
> > + return vma_flags_same(&mask, VMA_WRITE_BIT);
>
> Another case of possible refactor, if you agree with those pointed out in
> earlier patch.
Ack
>
> > }
> >
> > /*
>
> > @@ -2993,7 +2998,8 @@ unsigned long unmapped_area(struct vm_unmapped_area_info *info)
> > gap = vma_iter_addr(&vmi) + info->start_gap;
> > gap += (info->align_offset - gap) & info->align_mask;
> > tmp = vma_next(&vmi);
> > - if (tmp && (tmp->vm_flags & VM_STARTGAP_FLAGS)) { /* Avoid prev check if possible */
> > + /* Avoid prev check if possible */
> > + if (tmp && (vma_test_any_mask(tmp, VMA_STARTGAP_FLAGS))) {
>
> The parentheses around function call not necessary?
True, can fix up.
>
> > if (vm_start_gap(tmp) < gap + length - 1) {
> > low_limit = tmp->vm_end;
> > vma_iter_reset(&vmi);
> > @@ -3045,7 +3051,8 @@ unsigned long unmapped_area_topdown(struct vm_unmapped_area_info *info)
> > gap -= (gap - info->align_offset) & info->align_mask;
> > gap_end = vma_iter_end(&vmi);
> > tmp = vma_next(&vmi);
> > - if (tmp && (tmp->vm_flags & VM_STARTGAP_FLAGS)) { /* Avoid prev check if possible */
> > + /* Avoid prev check if possible */
> > + if (tmp && (vma_test_any_mask(tmp, VMA_STARTGAP_FLAGS))) {
>
> Same.
True, will fix up.
>
> > if (vm_start_gap(tmp) < gap_end) {
> > high_limit = vm_start_gap(tmp);
> > vma_iter_reset(&vmi);
Cheers, Lorenzo
More information about the Linuxppc-dev
mailing list