Re: kextload failure on 10.5
Re: kextload failure on 10.5
- Subject: Re: kextload failure on 10.5
- From: mogambo <email@hidden>
- Date: Fri, 23 Apr 2010 17:59:30 -0700
You mean with -Xarch, right? I tried the following, but I get an error.
gcc -arch ppc -Xarch_ppc -isysroot $(SDKROOT) -arch i386 -Xarch_i386 -isysroot $(SDKROOT) -arch x86_64 -Xarch_x86_64 -isysroot $(SDKROOT10_6)
gcc-4.2: file /Developer/SDKs/MacOSX10.5.sdk specified more than once on the command line
I also figured out that one my include paths was including /System/Library/..., instead of $(SDKROOT)/System/Library/.... When I fixed that, I was able to build an i386 binary on 10.6.2 64-bit that I could load on a 10.5. Note that SDKROOT is 10.4u.sdk. However, I could not just add "-arch x86_64" to the command line. I got the following error:
/Developer/SDKs/MacOSX10.4u.sdk/System/Library/Frameworks/Kernel.framework/Headers/machine/limits.h:28:2: error: #error architecture not supported
If I include $(SDKROOT10_6)/System/Library/... instead of /System/Library, I can build the kext, but I am back to the undefined symbols at load time on 10.5.
-s.
On Fri, Apr 23, 2010 at 3:47 PM, Shantonu Sen
<email@hidden> wrote:
Kexts don't support forward compatibility (loading a kext that was built for a newer release). If you want to deploy on 10.5, you must use the 10.5 SDK (with -isysroot).
If you want to also deploy on 10.6 for x86_64, use a different SDK per arch
Shantonu Sen
email@hidden
Sent from my Mac Pro
On Apr 23, 2010, at 3:42 PM, mogambo wrote:
> Hi,
>
> We have a file system driver kext that we build with make. We build two separate versions for 32- and 64-bit OS X since last year when 10.6 was released. I did some tweaks to the Makefile and was able to build a UB on 10.6.2 x86_64 machine containing code for all 3 architectures we support - ppc, i386 and x86_64. I was able to load the same kext on 10.4/ppc, 10.6/i386 and 10.6/x86_64.
>
> When I tried to load the same kext on a 10.5.7/i386, it failed with the following errors:
> $ sudo kextload fsd.kext
> kld(): Undefined symbols:
> ___stack_chk_fail
> ___stack_chk_guard
> _lck_mtx_unlock_darwin10
> kextload: kld_load_from_memory() failed for module /Users/apple/fsd-47.107/fsd.kext/Contents/MacOS/fsd
> kextload: a link/load error occured for kernel extension fsd.kext
> link/load failed for extension fsd.kext
> (run kextload with -t for diagnostic output)
>
> I added -fno-stack-protector to gcc, which got rid of stack_chk{fail,guard} errors. However, _lck_mtx_unlock_darwin10 persists.
>
> Here's the gcc command line:
> gcc -arch ppc -arch i386 -arch x86_64 -isysroot /Developer/SDKs/MacOSX10.6.sdk -mmacosx-version-min=10.4 -g -static -nostdinc -Wall -Wno-switch -fno-stack-protector -msoft-float -mlong-branch -force_cpusubtype_ALL -fno-builtin -DKERNEL -DAPPLE -D__KERNEL__ -DKERNEL_PRIVATE -DOPENSSL_NO_STDIO -DOPENSSL_NO_ENGINE -DOPENSSL_NO_FP_API -DOPENSSL_NO_SHA256 -DOPENSSL_NO_SHA512 -DOPENSSL_NO_ASM -DNO_OLD_ASN1 -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_BIO -DPROFILE -DOPENSSL_NO_ERR -I. -I.. -I/System/Library/Frameworks/Kernel.framework/Headers -I/System/Library/Frameworks/Kernel.framework/Headers/bsd -I/Users/apple/workspace/include -I/Developer/SDKs/MacOSX10.6.sdk -I/usr/include/sys -c probe.c -o probe.o
>
> The linker command line:
> gcc -arch ppc -arch i386 -arch x86_64 -isysroot /Developer/SDKs/MacOSX10.6.sdk -mmacosx-version-min=10.4 -static -Wall -nostdlib -r -lkmod -lkmodc++ -lcc_kext -Xlinker -kext -o fsd <list of .o files>
>
> Any ideas?
>
> Thanks!
> -m.
> _______________________________________________
> Do not post admin requests to the list. They will be ignored.
> Darwin-kernel mailing list (email@hidden)
> Help/Unsubscribe/Update your Subscription:
>
> This email sent to email@hidden
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Darwin-kernel mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden