Commit ac51b934 authored by Kirill A. Shutemov's avatar Kirill A. Shutemov Committed by Linus Torvalds

mm: replace vma->sharead.linear with vma->shared

After removing vma->shared.nonlinear we have only one member of
vma->shared union, which doesn't make much sense.

This patch drops the union and move struct vma->shared.linear to
vma->shared.
Signed-off-by: default avatarKirill A. Shutemov <kirill.shutemov@linux.intel.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 27ba0644
...@@ -275,11 +275,9 @@ struct vm_area_struct { ...@@ -275,11 +275,9 @@ struct vm_area_struct {
* For areas with an address space and backing store, * For areas with an address space and backing store,
* linkage into the address_space->i_mmap interval tree. * linkage into the address_space->i_mmap interval tree.
*/ */
union {
struct { struct {
struct rb_node rb; struct rb_node rb;
unsigned long rb_subtree_last; unsigned long rb_subtree_last;
} linear;
} shared; } shared;
/* /*
......
...@@ -21,8 +21,8 @@ static inline unsigned long vma_last_pgoff(struct vm_area_struct *v) ...@@ -21,8 +21,8 @@ static inline unsigned long vma_last_pgoff(struct vm_area_struct *v)
return v->vm_pgoff + ((v->vm_end - v->vm_start) >> PAGE_SHIFT) - 1; return v->vm_pgoff + ((v->vm_end - v->vm_start) >> PAGE_SHIFT) - 1;
} }
INTERVAL_TREE_DEFINE(struct vm_area_struct, shared.linear.rb, INTERVAL_TREE_DEFINE(struct vm_area_struct, shared.rb,
unsigned long, shared.linear.rb_subtree_last, unsigned long, shared.rb_subtree_last,
vma_start_pgoff, vma_last_pgoff,, vma_interval_tree) vma_start_pgoff, vma_last_pgoff,, vma_interval_tree)
/* Insert node immediately after prev in the interval tree */ /* Insert node immediately after prev in the interval tree */
...@@ -36,26 +36,26 @@ void vma_interval_tree_insert_after(struct vm_area_struct *node, ...@@ -36,26 +36,26 @@ void vma_interval_tree_insert_after(struct vm_area_struct *node,
VM_BUG_ON_VMA(vma_start_pgoff(node) != vma_start_pgoff(prev), node); VM_BUG_ON_VMA(vma_start_pgoff(node) != vma_start_pgoff(prev), node);
if (!prev->shared.linear.rb.rb_right) { if (!prev->shared.rb.rb_right) {
parent = prev; parent = prev;
link = &prev->shared.linear.rb.rb_right; link = &prev->shared.rb.rb_right;
} else { } else {
parent = rb_entry(prev->shared.linear.rb.rb_right, parent = rb_entry(prev->shared.rb.rb_right,
struct vm_area_struct, shared.linear.rb); struct vm_area_struct, shared.rb);
if (parent->shared.linear.rb_subtree_last < last) if (parent->shared.rb_subtree_last < last)
parent->shared.linear.rb_subtree_last = last; parent->shared.rb_subtree_last = last;
while (parent->shared.linear.rb.rb_left) { while (parent->shared.rb.rb_left) {
parent = rb_entry(parent->shared.linear.rb.rb_left, parent = rb_entry(parent->shared.rb.rb_left,
struct vm_area_struct, shared.linear.rb); struct vm_area_struct, shared.rb);
if (parent->shared.linear.rb_subtree_last < last) if (parent->shared.rb_subtree_last < last)
parent->shared.linear.rb_subtree_last = last; parent->shared.rb_subtree_last = last;
} }
link = &parent->shared.linear.rb.rb_left; link = &parent->shared.rb.rb_left;
} }
node->shared.linear.rb_subtree_last = last; node->shared.rb_subtree_last = last;
rb_link_node(&node->shared.linear.rb, &parent->shared.linear.rb, link); rb_link_node(&node->shared.rb, &parent->shared.rb, link);
rb_insert_augmented(&node->shared.linear.rb, root, rb_insert_augmented(&node->shared.rb, root,
&vma_interval_tree_augment); &vma_interval_tree_augment);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment