From: Kyle McMartin <kyle@redhat.com>
To: linux-arm-kernel@lists.infradead.org
Cc: linux-kernel@vger.kernel.org, catalin.marinas@arm.com,
will.deacon@arm.com
Subject: [PATCH] aarch64: always map VDSO at worst case alignment
Date: Wed, 15 Jan 2014 16:41:44 -0500 [thread overview]
Message-ID: <20140115214144.GF18705@redacted.bos.redhat.com> (raw)
Currently on ARM64 with 4K pages set, GDB fails to load the VDSO with
the error "Failed to read a valid object file image from memory" as it
is applying the phdr alignment to the vma, and attempting to read below
where the VDSO is mapped. This is because our segment alignment is 64K
in the ELF headers, but the VDSO only has PAGE_SIZE alignment from
get_unmapped_area.
Work around this by calling vm_unmapped_area directly, and specifying
the worst case alignment (64K) directly.
With this patch applied, I no longer have issues loading the VDSO in
gdb (and no more error message every time I run a program inside it.)
Signed-off-by: Kyle McMartin <kyle@redhat.com>
--- a/arch/arm64/kernel/vdso.c
+++ b/arch/arm64/kernel/vdso.c
@@ -163,7 +163,18 @@ int arch_setup_additional_pages(struct linux_binprm *bprm,
vdso_mapping_len = (vdso_pages + 1) << PAGE_SHIFT;
down_write(&mm->mmap_sem);
- vdso_base = get_unmapped_area(NULL, 0, vdso_mapping_len, 0, 0);
+ {
+ /* the VDSO must be worst-case aligned to 64K */
+ struct vm_unmapped_area_info info =
+ {
+ .flags = 0,
+ .length = vdso_mapping_len,
+ .low_limit = mm->mmap_base,
+ .high_limit = TASK_SIZE,
+ .align_mask = (1 << 16) - 1,
+ };
+ vdso_base = vm_unmapped_area(&info);
+ }
if (IS_ERR_VALUE(vdso_base)) {
ret = vdso_base;
goto up_fail;
next reply other threads:[~2014-01-15 21:42 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-15 21:41 Kyle McMartin [this message]
2014-01-16 17:43 ` [PATCH] aarch64: always map VDSO at worst case alignment Will Deacon
2014-01-16 17:53 ` Kyle McMartin
2014-01-16 19:28 ` Kyle McMartin
2014-01-16 19:32 ` Will Deacon
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140115214144.GF18705@redacted.bos.redhat.com \
--to=kyle@redhat.com \
--cc=catalin.marinas@arm.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=will.deacon@arm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox