On Sun, 27 Jan 2002 15:16:10 +0000,
"kumar M" <kumarm4@hotmail.com> wrote:
>I am interested in knowing how mangling the name of symbols
>exported by the kernel to include the checksum of the information related to
>that symbol is done, whenever MOD VERSIONS
>is used for building a module. Is there any documentation on the
>process of the checksum computation, and which portion of the linux
>sources I need to go through to understand this ?
genksyms.c in the modutils source package[1]. The make dep process
pre-processes the C sources from each directory feeding the cpp output
into genksyms. genksyms calculates a hash for each exported symbol
based on its type, return values, parameters etc., recursively
descending parameter types as required.
The resulting hashes are written out as #defines to change foo to
foo_Rxxxxxxxx. The defines are read back in when the real compile is
done, change references to foo into foo_Rxxxxxxxx. In the kernel the
original symbols are used but the export list includes the suffix. In
modules, external references include the suffix.
In theory if a module refers to a symbol and the hashes for that symbol
match then the symbol has not changed its ABI and it is safe to load
the module, even if the kernel and module are from different versions.
In practice, modversions relies far too much on human processes and is
prone to false positives. The hashes can match when the ABI is
different because of human error[2], especially when people compile
drivers outside the kernel tree. Kernel and modutils 2.5 will have a
completely different method for checking ABI compatibility, if kbuild
2.5 ever gets in.
[1] http://kernel.org/pub/linux/utils/kernel/modutils/v2.4
[2] http://prdownloads.sourceforge.net/kbuild/kbuild-2.5-history.tar.bz2
-
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/
This archive was generated by hypermail 2b29 : Thu Jan 31 2002 - 21:00:46 EST