Re: [PATCH] compatibility syscall layer (lets try again)

David S. Miller (davem@redhat.com)
Mon, 09 Dec 2002 12:18:29 -0800 (PST)


From: "Martin Schwidefsky" <schwidefsky@de.ibm.com>
Date: Mon, 9 Dec 2002 18:16:43 +0100

>Architecture maintainers, can you comment on how easy/hard it is to do the
>same thing on your architectures? I _assume_ it's trivial (akin to the
>three-liner register state change in i386/kernel/signal.c).

For s390/s390x this is actually quite tricky. The system call number is
coded in the instruction, e.g. 0x0aa2 is svc 162 or sys_nanosleep. There
is no register involved that contains the system call number I could
simply change. I either have to change the instruction (no way) or I
have to avoid going back to userspace in this case. This would require
assembler magic in entry.S. Not nice.

Put the magic restart_block syscall at some fixed place in every
user process, change the PC to that. Or, alternatively, put the
restart_block syscall insn on the stack and point the PC at that.

This isn't rocket science :-)

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/