Re: [patch] Assigning syscall numbers for testing

Doug Ledford (dledford@redhat.com)
Mon, 24 Dec 2001 12:06:19 -0500


Alan Cox wrote:

>>Well, I'm not going to mess with code, but here's the example. Say you
>>start at syscall 240 for dynamic registration. Someone then submits a patch
>>
>
> The number you start at depends on the kernel you run.
>
>
>>modify the base of your patch, but if it has been accepted into any real
>>kernels anywhere, then someone could inadvertently end up running a user
>>space app compiled against Linus' new kernel and that uses the newly
>>allocated syscalls 240 and 241. If that's run on an older kernel with your
>>
>
> The code on execution will read the syscall numbers from procfs. It will
> find new numbers and call those. Its a very simple implementation of lazy
> binding. It only breaks if you actually run out of syscalls, and then it
> fails safe.
>
> Alan
>
>

No it doesn't. You are *assuming* that *all* code will check the lazy
syscall bindings. My example was about code using the predefined syscall
number for new functions on an older kernel where those functions don't
exist, but where they overlap with the older dynamic syscall numbers. In
short, the patch is safe for code that uses the lazy binding, but it can
still overlap with future syscall numbers and code that doesn't use the lazy
binding but instead uses predefined numbers.

-- 

Doug Ledford <dledford@redhat.com> http://people.redhat.com/dledford Please check my web site for aic7xxx updates/answers before e-mailing me about problems

- 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/