]> git.karo-electronics.de Git - karo-tx-linux.git/commit
mm, vmalloc: only call setup_vmalloc_vm() only in __get_vm_area_node()
authorZhang Yanfei <zhangyanfei@cn.fujitsu.com>
Fri, 7 Jun 2013 00:08:22 +0000 (10:08 +1000)
committerStephen Rothwell <sfr@canb.auug.org.au>
Fri, 7 Jun 2013 05:42:31 +0000 (15:42 +1000)
commit4a2e89253e9d88a06c53c3cbaaa83babbc69b9d9
tree5d701cb694824f97a8262dca9a127a323b77695a
parent836f29bbb0f7a08dbdf1ed3ee704ef8aea81e56f
mm, vmalloc: only call setup_vmalloc_vm() only in __get_vm_area_node()

Now for insert_vmalloc_vm, it only calls the two functions:
- setup_vmalloc_vm: fill vm_struct and vmap_area instances
- clear_vm_unlist: clear VM_UNLIST bit in vm_struct->flags

So in __get_vm_area_node(), if VM_UNLIST bit unset in flags, that is the
else branch here, we don't need to clear VM_UNLIST bit for vm->flags since
this bit is obviously not set.  That is to say, we could only call
setup_vmalloc_vm instead of insert_vmalloc_vm here.  And then we could
even remove the if test here.

Signed-off-by: Zhang Yanfei <zhangyanfei@cn.fujitsu.com>
Acked-by: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
mm/vmalloc.c