[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1391110761.945.15.camel@wall-e.seibold.net>
Date: Thu, 30 Jan 2014 20:39:21 +0100
From: Stefani Seibold <stefani@...bold.net>
To: Andy Lutomirski <luto@...capital.net>
Cc: Greg KH <gregkh@...uxfoundation.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
X86 ML <x86@...nel.org>, Thomas Gleixner <tglx@...utronix.de>,
Ingo Molnar <mingo@...hat.com>,
"H. Peter Anvin" <hpa@...or.com>, Andi Kleen <ak@...ux.intel.com>,
Andrea Arcangeli <aarcange@...hat.com>,
John Stultz <john.stultz@...aro.org>,
Pavel Emelyanov <xemul@...allels.com>,
Cyrill Gorcunov <gorcunov@...nvz.org>,
andriy.shevchenko@...ux.intel.com, Martin.Runge@...de-schwarz.com,
Andreas.Brief@...de-schwarz.com
Subject: Re: [PATCH 3/4] Add 32 bit VDSO support for 32 kernel
Am Donnerstag, den 30.01.2014, 10:17 -0800 schrieb Andy Lutomirski:
> > +struct vsyscall_gtod_data vvar_vsyscall_gtod_data
> > + __attribute__((visibility("hidden")));
> > +
> > +u32 hpet_counter
> > + __attribute__((visibility("hidden")));
> > +
> > +#define gtod (&vvar_vsyscall_gtod_data)
>
> Is it possible to keep the VVAR macro working for this? It'll keep
> this code more unified and make it easier for anyone who tries to add
> vgetcpu support.
>
Nope, since the access to the VVAR area differs in a 32 bit VDSO differ.
64 Bit VDSO always use FIXMAP Address, 32 bit VDSO depends on the sysctl
parameter vsyscall32 and the vdso32= kernel parameter.
In the origin code there is still gtod macro in the vclock_gettime.c,
but there is a mixed used of the gtod macro and
VVAR(vsyscall_gtod_data), so i cleaned it up only use the gtod Macro.
This has also nothing to do with vgetcpu, this is locate in a own file
called vgetcpu.c
> > if (compat_uses_vma || !compat) {
> > - /*
> > - * MAYWRITE to allow gdb to COW and set breakpoints
> > - */
> > - ret = install_special_mapping(mm, addr, PAGE_SIZE,
> > - VM_READ|VM_EXEC|
> > - VM_MAYREAD|VM_MAYWRITE|VM_MAYEXEC,
> > - vdso32_pages);
> > +
> > + vma = _install_special_mapping(mm,
> > + addr,
> > + VDSO_OFFSET(VDSO_PAGES),
> > + VM_READ|VM_EXEC,
> > + vdso32_pages);
> > +
> > + if (IS_ERR(vma)) {
> > + ret = PTR_ERR(vma);
> > + goto up_fail;
> > + }
> > +
> > + ret = remap_pfn_range(vma,
> > + vma->vm_start + VDSO_OFFSET(VDSO_VVAR_PAGE),
> > + __pa_symbol(&__vvar_page) >> PAGE_SHIFT,
> > + PAGE_SIZE,
> > + PAGE_READONLY);
> >
> > if (ret)
> > goto up_fail;
> > +
> > +#ifdef CONFIG_HPET_TIMER
> > + if (hpet_address) {
> > + ret = io_remap_pfn_range(vma,
> > + vma->vm_start + VDSO_OFFSET(VDSO_HPET_PAGE),
> > + hpet_address >> PAGE_SHIFT,
> > + PAGE_SIZE,
> > + pgprot_noncached(PAGE_READONLY));
> > +
> > + if (ret)
> > + goto up_fail;
> > + }
> > +#endif
> > }
>
> Now I'm confused. What's the fixmap stuff for? Isn't this sufficient?
>
> Also, presumably remap_pfn_range is already smart enough to prevent
> mprotect and ptrace from doing evil things.
>
The fixmap code is for the original behaviour. It saves address space
and does not change the layout. Never break user space.
> >
> > @@ -19,11 +22,17 @@ ENTRY(__kernel_vsyscall);
> > */
> > VERSION
> > {
> > - LINUX_2.5 {
> > + LINUX_2.6 {
> > global:
> > __kernel_vsyscall;
> > __kernel_sigreturn;
> > __kernel_rt_sigreturn;
> > + clock_gettime;
> > + __vdso_clock_gettime;
> > + gettimeofday;
> > + __vdso_gettimeofday;
> > + time;
> > + __vdso_time;
> > local: *;
>
> Please remove the functions that don't start with __vdso -- I don't
> think they serve any purpose. They can be confusing, since they're
> not interchangeable with the glibc functions of the same name. (The
> 64-bit vdso needs them for historical reasons.)
I can do this...
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists