Date: Wed, 2 Jun 1999 00:14:20 +0000 (GMT) From: Terry Lambert <tlambert@primenet.com> To: steve@FreeBSD.ORG Cc: freebsd-advocacy@FreeBSD.ORG, freebsd-bugs@FreeBSD.ORG Subject: Re: advocacy/11947: kldload doesn't produce a linked file for the module Message-ID: <199906020014.RAA04848@usr09.primenet.com> In-Reply-To: <199905302232.PAA93554@freefall.freebsd.org> from "steve@FreeBSD.ORG" at May 30, 99 03:32:03 pm
next in thread | previous in thread | raw e-mail | index | archive | help
> Synopsis: kldload doesn't produce a linked file for the module > > Responsible-Changed-From-To: freebsd-advocacy->freebsd-bugs > Responsible-Changed-By: steve > Responsible-Changed-When: Sun May 30 15:31:28 PDT 1999 > Responsible-Changed-Why: > MIsfiled PR. He knows that. Read the whole thing. He needs symbol offsets for other reasons not having to do with linking. The answer is that there is a symbol table for modules that is maintained in the kernel, which should be used instead. For data symbols, the offsets relative to the module load address are not valid, BTW, using his workaround technique, because of ELF code vs. data segment non-offset in the file for page alignment. ELF images have the overlapping code/text page mapped twice, to reduce the stored image size at the expense of an average of 2k per image at load (the same average for an aligned image). So he must be using the symbol addresses for the text segment only, or mistakenly accessing the residual data mapped in the code page (mistakenly because it would not reflect modifications). The whole point of a two pass in the old LKM code (which I wrote, and for which Jeffrey Hsu provided the original PIC modifications to the x86 GNU compiler and linker) was to know where the relative data offsets would be for uninitialized BSS data. Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-bugs" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199906020014.RAA04848>