On Tue, Sep 29, 2015 at 11:06:13PM -0500, Nathan Lynch wrote: > On 09/29/2015 05:14 PM, Yury Norov wrote: > > From: Philipp Tomsich <philipp.toms...@theobroma-systems.com> > > > > Adjusted to move the move data page before code pages in sync with > > commit 601255ae3c98fdeeee3a8bb4696425e4f868b4f1 > > This commit message needs more information about how the ilp32 VDSO uses > the existing arm64 code. I had to really hunt through the Makefile to > figure out what's going on. > > The commit message should also identify the APIs that are supported. > The subject line mentions signal return, but gettimeofday, clock_gettime > and clock_getres are being added here too, and it is not obvious. > > > > Signed-off-by: Philipp Tomsich <philipp.toms...@theobroma-systems.com> > > Signed-off-by: Christoph Muellner <christoph.muell...@theobroma-systems.com> > > Signed-off-by: Yury Norov <yno...@caviumnetworks.com> > > > > create mode 100644 arch/arm64/kernel/vdso-ilp32/.gitignore > > create mode 100644 arch/arm64/kernel/vdso-ilp32/Makefile > > copy arch/arm64/{include/asm/vdso.h => kernel/vdso-ilp32/vdso-ilp32.S} > > (56%) > > create mode 100644 arch/arm64/kernel/vdso-ilp32/vdso-ilp32.lds.S > > How are you invoking git-format-patch? The copy detection in this case > is not conducive to review. > > It looks like the existing arm64 vdso Makefile has been copied to > vdso-ilp32/ and adjusted for paths and naming. While the gettimeofday > assembly implementation is reused, the build logic is duplicated. x86 > produces VDSOs for multiple ABIs with a single Makefile; is a similar > approach not appropriate for arm64? > > > > diff --git a/arch/arm64/kernel/vdso-ilp32/vdso-ilp32.lds.S > > b/arch/arm64/kernel/vdso-ilp32/vdso-ilp32.lds.S > > new file mode 100644 > > index 0000000..ac8029b > > --- /dev/null > > +++ b/arch/arm64/kernel/vdso-ilp32/vdso-ilp32.lds.S > > @@ -0,0 +1,98 @@ > > [...] > > > +#include <linux/const.h> > > +#include <asm/page.h> > > +#include <asm/vdso.h> > > + > > +/*OUTPUT_FORMAT("elf32-littleaarch64", "elf32-bigaarch64", > > "elf32-littleaarch64") > > +OUTPUT_ARCH(aarch64) > > +*/ > > If these lines aren't needed then omit them. > > [...] > > > > +/* > > + * This controls what symbols we export from the DSO. > > + */ > > +VERSION > > +{ > > + LINUX_2.6.39 { > > + global: > > + __kernel_rt_sigreturn; > > + __kernel_gettimeofday; > > + __kernel_clock_gettime; > > + __kernel_clock_getres; > > + local: *; > > + }; > > +} > > Something that came up during review of arch/arm's VDSO code: consider > using version and names that match x86, i.e. LINUX_2.6, __vdso_gettimeofday. > > http://lists.infradead.org/pipermail/linux-arm-kernel/2014-June/267940.html > > Using LINUX_2.6.39 for this code is nonsensical. > > > > diff --git a/arch/arm64/kernel/vdso.c b/arch/arm64/kernel/vdso.c > > index b239b9b..bed6cf1 100644 > > --- a/arch/arm64/kernel/vdso.c > > +++ b/arch/arm64/kernel/vdso.c > > @@ -40,6 +40,12 @@ extern char vdso_start, vdso_end; > > static unsigned long vdso_pages; > > static struct page **vdso_pagelist; > > > > +#ifdef CONFIG_ARM64_ILP32 > > +extern char vdso_ilp32_start, vdso_ilp32_end; > > +static unsigned long vdso_ilp32_pages; > > +static struct page **vdso_ilp32_pagelist; > > +#endif > > + > > /* > > * The vDSO data page. > > */ > > @@ -117,24 +123,29 @@ int aarch32_setup_vectors_page(struct linux_binprm > > *bprm, int uses_interp) > > } > > #endif /* CONFIG_AARCH32_EL0 */ > > > > -static struct vm_special_mapping vdso_spec[2]; > > - > > -static int __init vdso_init(void) > > +static inline int __init vdso_init_common(char *vdso_start, char *vdso_end, > > No inline please. > > > > + unsigned long *vdso_pagesp, > > + struct page ***vdso_pagelistp, > > + struct vm_special_mapping* vdso_spec) > > { > > [...] > > > int arch_setup_additional_pages(struct linux_binprm *bprm, > > int uses_interp) > > { > > struct mm_struct *mm = current->mm; > > unsigned long vdso_base, vdso_text_len, vdso_mapping_len; > > - void *ret; > > + void* ret; > > Gratuitous (and incorrect) style change. > > > > + unsigned long pages = vdso_pages; > > + struct vm_special_mapping* spec = vdso_spec; > > Incorrect style: *spec
Hi Nathan, If Philipp Philipp Tomsich will not answer soon, I'll fix all this. BR, Yury. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/