arm64: vdso: use consistent 'map' nomenclature
authorMark Rutland <mark.rutland@arm.com>
Tue, 28 Apr 2020 16:49:21 +0000 (17:49 +0100)
committerWill Deacon <will@kernel.org>
Wed, 29 Apr 2020 09:52:53 +0000 (10:52 +0100)
The current code doesn't use a consistent naming scheme for structures,
enums, or variables, making it harder than necessary to determine the
relationship between these.

Let's make this easier by consistently using 'map' nomenclature for
mappings created in userspace, minimizing redundant comments, and
using designated array initializers to tie indices to their respective
elements.

There should be no functional change as a result of this patch.

Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Vincenzo Frascino <vincenzo.frascino@arm.com>
Cc: Will Deacon <will@kernel.org>
Link: https://lore.kernel.org/r/20200428164921.41641-5-mark.rutland@arm.com
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm64/kernel/vdso.c

index 89ef61686362863e2f9340dab7037899bcd1a38b..f3eea5e20a41775d402187f83736f069a59f78a8 100644 (file)
@@ -182,45 +182,36 @@ static int aarch32_vdso_mremap(const struct vm_special_mapping *sm,
 }
 #endif /* CONFIG_COMPAT_VDSO */
 
-/*
- * aarch32_vdso_pages:
- * 0 - kuser helpers
- * 1 - sigreturn code
- * or (CONFIG_COMPAT_VDSO):
- * 0 - kuser helpers
- * 1 - vdso data
- * 2 - vdso code
- */
-#define C_VECTORS      0
+enum aarch32_map {
+       AA32_MAP_VECTORS, /* kuser helpers */
 #ifdef CONFIG_COMPAT_VDSO
-#define C_VVAR         1
-#define C_VDSO         2
-#define C_PAGES                (C_VDSO + 1)
+       AA32_MAP_VVAR,
+       AA32_MAP_VDSO,
 #else
-#define C_SIGPAGE      1
-#define C_PAGES                (C_SIGPAGE + 1)
-#endif /* CONFIG_COMPAT_VDSO */
+       AA32_MAP_SIGPAGE
+#endif
+};
 
 static struct page *aarch32_vectors_page __ro_after_init;
 #ifndef CONFIG_COMPAT_VDSO
 static struct page *aarch32_sig_page __ro_after_init;
 #endif
 
-static struct vm_special_mapping aarch32_vdso_spec[C_PAGES] = {
-       {
+static struct vm_special_mapping aarch32_vdso_maps[] = {
+       [AA32_MAP_VECTORS] = {
                .name   = "[vectors]", /* ABI */
                .pages  = &aarch32_vectors_page,
        },
 #ifdef CONFIG_COMPAT_VDSO
-       {
+       [AA32_MAP_VVAR] = {
                .name = "[vvar]",
        },
-       {
+       [AA32_MAP_VDSO] = {
                .name = "[vdso]",
                .mremap = aarch32_vdso_mremap,
        },
 #else
-       {
+       [AA32_MAP_SIGPAGE] = {
                .name   = "[sigpage]", /* ABI */
                .pages  = &aarch32_sig_page,
        },
@@ -252,8 +243,8 @@ static int __aarch32_alloc_vdso_pages(void)
 {
        int ret;
 
-       vdso_info[VDSO_ABI_AA32].dm = &aarch32_vdso_spec[C_VVAR];
-       vdso_info[VDSO_ABI_AA32].cm = &aarch32_vdso_spec[C_VDSO];
+       vdso_info[VDSO_ABI_AA32].dm = &aarch32_vdso_maps[AA32_MAP_VVAR];
+       vdso_info[VDSO_ABI_AA32].cm = &aarch32_vdso_maps[AA32_MAP_VDSO];
 
        ret = __vdso_init(VDSO_ABI_AA32);
        if (ret)
@@ -305,7 +296,7 @@ static int aarch32_kuser_helpers_setup(struct mm_struct *mm)
        ret = _install_special_mapping(mm, AARCH32_VECTORS_BASE, PAGE_SIZE,
                                       VM_READ | VM_EXEC |
                                       VM_MAYREAD | VM_MAYEXEC,
-                                      &aarch32_vdso_spec[C_VECTORS]);
+                                      &aarch32_vdso_maps[AA32_MAP_VECTORS]);
 
        return PTR_ERR_OR_ZERO(ret);
 }
@@ -329,7 +320,7 @@ static int aarch32_sigreturn_setup(struct mm_struct *mm)
        ret = _install_special_mapping(mm, addr, PAGE_SIZE,
                                       VM_READ | VM_EXEC | VM_MAYREAD |
                                       VM_MAYWRITE | VM_MAYEXEC,
-                                      &aarch32_vdso_spec[C_SIGPAGE]);
+                                      &aarch32_vdso_maps[AA32_MAP_SIGPAGE]);
        if (IS_ERR(ret))
                goto out;
 
@@ -373,19 +364,16 @@ static int vdso_mremap(const struct vm_special_mapping *sm,
        return __vdso_remap(VDSO_ABI_AA64, sm, new_vma);
 }
 
-/*
- * aarch64_vdso_pages:
- * 0 - vvar
- * 1 - vdso
- */
-#define A_VVAR         0
-#define A_VDSO         1
-#define A_PAGES                (A_VDSO + 1)
-static struct vm_special_mapping vdso_spec[A_PAGES] __ro_after_init = {
-       {
+enum aarch64_map {
+       AA64_MAP_VVAR,
+       AA64_MAP_VDSO,
+};
+
+static struct vm_special_mapping aarch64_vdso_maps[] __ro_after_init = {
+       [AA64_MAP_VVAR] = {
                .name   = "[vvar]",
        },
-       {
+       [AA64_MAP_VDSO] = {
                .name   = "[vdso]",
                .mremap = vdso_mremap,
        },
@@ -393,8 +381,8 @@ static struct vm_special_mapping vdso_spec[A_PAGES] __ro_after_init = {
 
 static int __init vdso_init(void)
 {
-       vdso_info[VDSO_ABI_AA64].dm = &vdso_spec[A_VVAR];
-       vdso_info[VDSO_ABI_AA64].cm = &vdso_spec[A_VDSO];
+       vdso_info[VDSO_ABI_AA64].dm = &aarch64_vdso_maps[AA64_MAP_VVAR];
+       vdso_info[VDSO_ABI_AA64].cm = &aarch64_vdso_maps[AA64_MAP_VDSO];
 
        return __vdso_init(VDSO_ABI_AA64);
 }