On Tue, 12 Apr 2005, Franco "Sensei" wrote:
Date: Tue, 12 Apr 2005 12:22:30 -0500
From: Franco "Sensei" <[email protected]>
To: Krzysztof Halasa <[email protected]>
Cc: Adrian Bunk <[email protected]>, [email protected]
Subject: Re: [INFO] Kernel strict versioning
Krzysztof Halasa wrote:
It isn't enough. The same compiler and the same .config - yes. But that
means you'd have no progress within, say, 2.6. Only bug fixes.
There _is_ a tree like that - 2.6.11.Xs are only bugfixes.
Ok, this adds a new information. Let me explain what I understand now.
When a new component is added to the kernel, let's say support for a new file
system, a .config entry is created (CONFIG_MYFS=y|m). Why is this entry
breaking compatibility? I mean, symbols still remains the same. The addition
of symbols is not a breaking point.
some config changes are additions, some redefine things.
you are mistakeing the .config file for a symbol table.
for example if you compile a kernel with SMP=y you get different code then
if you compile with SMP=n
if you have the same kernel version on identical machines, but with the
SMP option different on the two different machines you cannot use the same
module binary on both of them.
But remember that changing a single config option may make your kernel
incompatible. You can't avoid that without making the kernel suboptimal
for most situations - basically you'd have to disable non-SMP builds,
disable (or permanently enable) 4KB pages etc.
What about making extensive use of modules? If everything (acceptable) is
built on modules, can you still have abi, can you still change modules and
api implementation without breaking anything? What are the requisites to abi?
you would have an ABI for that kernel image, compiled with those options,
and with that compiler. if you change any of those things then your
modules won't work (you have a different ABI
I'm really curious about it. How abi can be made actual, and how would it be
if we had a completely modular kernel (not micro, but something alike,
modular in kernel-space, not in user-space).
what you are missing is that nobody has any interest in supporting a
kernel ABI, even within a single kernel version. there are just too many
advantages to changeing fundamantal things in the kernel depending on the
config options.
If you make a proprietary closed-sourse system (with kernel modules), you
probably have to make the system suboptimal. But with open source there
is a better alternative.
No, I wouldn't. Closed source is out of discussion. Optimal kernel, even in
open source can be achieved.
Asking for one modules dir only is similar to asking for only one
/boot/vmlinuz-2.6 kernel file.
Quite the same, yes. You can still have different kernels of course! By the
way, another stupid curiosity is why /lib/modules instead of /boot? Because
boot can be a partition and not be mounted? The same thing for /lib (crazy,
but you can do it). I would expect a kernel and all its parts all in one
place, not different locations...
I don't know why the default location for the modules, but again you are
assuming that you CAN have a single vmlinuz-2.6 kernel file for all
machines of a given arch.
you can't.
there are just too many config options that change the internals of the
kernel (locking, function call formats, CPU type optmizations, etc) for
you to just have one.
First, each 2.6.X would have to be binary-compatible with itself.
That's the only point for me. I wouldn't make 2.6 and 2.8 kernels binary
compatibles.
but 2.6.11.7 is not nessasarily binary compatable with 2.6.11.7, let alone
something drasticly different (say 2.6.11.6)
David Lang
--
Sensei <mailto:[email protected]> <pgp:8998A2DB>
<icqnum:241572242>
<yahoo!:sensei_sen>
<msn-id:[email protected]>
--
There are two ways of constructing a software design. One way is to make it so simple that there are obviously no deficiencies. And the other way is to make it so complicated that there are no obvious deficiencies.
-- C.A.R. Hoare
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]