Commit 2d3e63c0 authored by Jinbum Park's avatar Jinbum Park Committed by Khalid Elmously

ARM: 8748/1: mm: Define vdso_start, vdso_end as array

BugLink: https://bugs.launchpad.net/bugs/1775771

[ Upstream commit 73b9160d ]

Define vdso_start, vdso_end as array to avoid compile-time analysis error
for the case of built with CONFIG_FORTIFY_SOURCE.

and, since vdso_start, vdso_end are used in vdso.c only,
move extern-declaration from vdso.h to vdso.c.

If kernel is built with CONFIG_FORTIFY_SOURCE,
compile-time error happens at this code.
- if (memcmp(&vdso_start, "177ELF", 4))

The size of "&vdso_start" is recognized as 1 byte, but n is 4,
So that compile-time error is reported.
Acked-by: default avatarKees Cook <keescook@chromium.org>
Signed-off-by: default avatarJinbum Park <jinb.park7@gmail.com>
Signed-off-by: default avatarRussell King <rmk+kernel@armlinux.org.uk>
Signed-off-by: default avatarSasha Levin <alexander.levin@microsoft.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarJuerg Haefliger <juergh@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent 7449e0ef
...@@ -11,8 +11,6 @@ struct mm_struct; ...@@ -11,8 +11,6 @@ struct mm_struct;
void arm_install_vdso(struct mm_struct *mm, unsigned long addr); void arm_install_vdso(struct mm_struct *mm, unsigned long addr);
extern char vdso_start, vdso_end;
extern unsigned int vdso_total_pages; extern unsigned int vdso_total_pages;
#else /* CONFIG_VDSO */ #else /* CONFIG_VDSO */
......
...@@ -38,6 +38,8 @@ ...@@ -38,6 +38,8 @@
static struct page **vdso_text_pagelist; static struct page **vdso_text_pagelist;
extern char vdso_start[], vdso_end[];
/* Total number of pages needed for the data and text portions of the VDSO. */ /* Total number of pages needed for the data and text portions of the VDSO. */
unsigned int vdso_total_pages __read_mostly; unsigned int vdso_total_pages __read_mostly;
...@@ -178,13 +180,13 @@ static int __init vdso_init(void) ...@@ -178,13 +180,13 @@ static int __init vdso_init(void)
unsigned int text_pages; unsigned int text_pages;
int i; int i;
if (memcmp(&vdso_start, "\177ELF", 4)) { if (memcmp(vdso_start, "\177ELF", 4)) {
pr_err("VDSO is not a valid ELF object!\n"); pr_err("VDSO is not a valid ELF object!\n");
return -ENOEXEC; return -ENOEXEC;
} }
text_pages = (&vdso_end - &vdso_start) >> PAGE_SHIFT; text_pages = (vdso_end - vdso_start) >> PAGE_SHIFT;
pr_debug("vdso: %i text pages at base %p\n", text_pages, &vdso_start); pr_debug("vdso: %i text pages at base %p\n", text_pages, vdso_start);
/* Allocate the VDSO text pagelist */ /* Allocate the VDSO text pagelist */
vdso_text_pagelist = kcalloc(text_pages, sizeof(struct page *), vdso_text_pagelist = kcalloc(text_pages, sizeof(struct page *),
...@@ -199,7 +201,7 @@ static int __init vdso_init(void) ...@@ -199,7 +201,7 @@ static int __init vdso_init(void)
for (i = 0; i < text_pages; i++) { for (i = 0; i < text_pages; i++) {
struct page *page; struct page *page;
page = virt_to_page(&vdso_start + i * PAGE_SIZE); page = virt_to_page(vdso_start + i * PAGE_SIZE);
vdso_text_pagelist[i] = page; vdso_text_pagelist[i] = page;
} }
...@@ -210,7 +212,7 @@ static int __init vdso_init(void) ...@@ -210,7 +212,7 @@ static int __init vdso_init(void)
cntvct_ok = cntvct_functional(); cntvct_ok = cntvct_functional();
patch_vdso(&vdso_start); patch_vdso(vdso_start);
return 0; return 0;
} }
......
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