On Wed, 16 Oct 2002, Maxim Sobolev wrote:
> > And it's not like the approach you've described makes it any easier to > > implement: you still have to break out the old and new structures since > > changing ipc_perm breaks the ABI for all of the System V interfaces, > > rewrite the kernel code, etc. You might as well have added the > > compatibility system calls since you still have to do all the mapping. > > I don't quite understand what you are trying to say. Linux does the > following on the beginning and the end of each {shm,sem,msg}ctl call: > > {shm,sem,msg}ctl(...) > { > if (IPC_64 flag is not set) { > convert user-supplied structure to a new 64-bit format > } > proceed as usual using 64-bit structure > if (IPC_64 flag is not set) { > convert result to be transferred back to user into old format > } > return > } > > This is apparently much more compact, ABI-safe and easier to implement > and maintain since we don't have two versions of mostly the same code. What you are missing here is that the same structures used in kernel are used in userspace, so an important step to "fixing" the SysVIPC problem is to divorce those structures, which means you need two sets of internalize and externalize functions. Your proposed solution involves exactly as much code as the other solution, it just happens to do the compatibility above the system call layer rather than at the system call layer. Robert N M Watson FreeBSD Core Team, TrustedBSD Projects [EMAIL PROTECTED] Network Associates Laboratories To Unsubscribe: send mail to [EMAIL PROTECTED] with "unsubscribe freebsd-current" in the body of the message