On Fri, Apr 8, 2016 at 6:50 AM, Dmitry Safonov <dsafonov@xxxxxxxxxxxxx> wrote:And if it's not there - return error?
Hello again,For this thing:
what do you think about attached patch?
I think it should fix landing problem for i386 vdso mremap.
It does not touch fast syscall path, so there should be no
speed regression.
+ /* Fixing userspace landing - look at do_fast_syscall_32 */
+ if (current_thread_info()->status & TS_COMPAT)
+ regs->ip = (unsigned long)current->mm->context.vdso +
+ vdso_image_32.sym_int80_landing_pad;
Either check that ip was where you expected it
or simply remove thisYes, I'm working on it. This patch will only allow moving vdso
code -- user programs that are mremapping the vdso are already playing
with fire and can just use int $0x80 to do it.
Other than that, it looks generally sane. The .mremap hook didn't
exist last time I looked at this :)
The main downside of your approach is that it doesn't allow switching
between the 32-bit, 64-bit, and x32 images. Also, it requires
awareness of how vvar and vdso line up, whereas a dedicated API could
do the whole thing.