OpenVZ Forum


Home » Mailing lists » Devel » Re: Extending syscalls
Re: Extending syscalls [message #26224] Thu, 17 January 2008 19:26
hpa is currently offline  hpa
Messages: 38
Registered: January 2007
Member
Jonathan Corbet wrote:
> 
> Heh, indeed.  But we do seem to have a recurring problem of people
> wanting to extend sys_foo() beyond the confines of its original API.
> I've observed a few ways of doing that:
> 
>  - create sys_foo2() (or sys_foo64(), or sys_fooat(), or sys_pfoo(),
>    or...) and add the new stuff there.
> 
> The first approach has traditionally been the most popular.  If we have
> a consensus that this is the way to extend system calls in the future,
> it would be nice to set that down somewhere.  We could avoid a lot of
> API blind alleys that way.
> 

I would argue it is the right approach.  It lets the kernel system call 
entry dispatch directly to the system call for the "new" case, and to a 
compatibility thunk for the "old" case.  It has the following desirable 
properties:

- No overhead for the "new" case.
- Minimal overhead for the "old" case.
- Easily dealt with by tools like strace that examine system calls.

	-hpa
_______________________________________________
Containers mailing list
Containers@lists.linux-foundation.org
https://lists.linux-foundation.org/mailman/listinfo/containers
Previous Topic: Extending syscalls (was: [PATCH 1/2] Extend sys_clone and sys_unshare system calls API)
Next Topic: Broken "Make ip6_frags per namespace" patch
Goto Forum:
  


Current Time: Sun Oct 26 10:26:31 GMT 2025

Total time taken to generate the page: 0.08775 seconds