From owner-freebsd-arch@FreeBSD.ORG Thu Nov 18 17:43:29 2010 Return-Path: Delivered-To: freebsd-arch@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 19938106564A; Thu, 18 Nov 2010 17:43:29 +0000 (UTC) (envelope-from tijl@coosemans.org) Received: from mailrelay012.isp.belgacom.be (mailrelay012.isp.belgacom.be [195.238.6.179]) by mx1.freebsd.org (Postfix) with ESMTP id 482248FC12; Thu, 18 Nov 2010 17:43:27 +0000 (UTC) X-Belgacom-Dynamic: yes X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: AvsEAM7y5ExbsUip/2dsb2JhbACiUnK/E4VLBA Received: from 169.72-177-91.adsl-dyn.isp.belgacom.be (HELO kalimero.tijl.coosemans.org) ([91.177.72.169]) by relay.skynet.be with ESMTP; 18 Nov 2010 18:43:25 +0100 Received: from kalimero.tijl.coosemans.org (kalimero.tijl.coosemans.org [127.0.0.1]) by kalimero.tijl.coosemans.org (8.14.4/8.14.4) with ESMTP id oAIHhPlW004350; Thu, 18 Nov 2010 18:43:25 +0100 (CET) (envelope-from tijl@coosemans.org) From: Tijl Coosemans To: freebsd-arch@freebsd.org Date: Thu, 18 Nov 2010 18:43:15 +0100 User-Agent: KMail/1.13.5 (FreeBSD/8.1-STABLE; KDE/4.5.2; i386; ; ) References: <201007291718.12687.tijl@coosemans.org> <201011172058.05683.tijl@coosemans.org> <4CE43B7A.8030202@bsdimp.com> In-Reply-To: <4CE43B7A.8030202@bsdimp.com> MIME-Version: 1.0 Content-Type: multipart/signed; boundary="nextPart5445173.RJdgcoN9Pt"; protocol="application/pgp-signature"; micalg=pgp-sha256 Content-Transfer-Encoding: 7bit Message-Id: <201011181843.23185.tijl@coosemans.org> Cc: Dimitry Andric , Garrett Cooper Subject: Re: Support for cc -m32 X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 18 Nov 2010 17:43:29 -0000 --nextPart5445173.RJdgcoN9Pt Content-Type: Text/Plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable On Wednesday 17 November 2010 21:30:50 Warner Losh wrote: > On 11/17/2010 12:57, Tijl Coosemans wrote: >>>>>>> :> http://people.freebsd.org/~tijl/cc-m32-2.diff >>>>>>> :> http://people.freebsd.org/~tijl/cc-m32-3.diff >> I've updated them to today's CURRENT. They're a bit smaller now because >> some amd64 headers have been moved to x86. This also solved the problem >> with the kdump build. >> >> Here are the commit logs: >> >> cc-m32-2.diff: >> >> Install i386 headers on amd64. >> >> Machine specific headers for an architecture $arch are now installed >> under /usr/include/$arch. This means machine headers are always in = the >> same location whether you are cross compiling or not. >> >> /usr/include/machine is a symlink to /usr/include/${MACHINE}. > > Yea, I don't like this (the sym link) at all because. Machine headers=20 > wind up being wrong for amd64, so you have to resort to the following=20 > kludge. > >> cc-m32-3.diff: >> Modify amd64 headers to include i386 headers when compiling 32 bit = code. >> >> All amd64 headers follow the following format: >> >> #ifndef _AMD64_HEADER_H_ >> #define _AMD64_HEADER_H_ >> >> #ifdef __i386__ >> #include >> #else >> >> /* Amd64 declarations go here. */ >> >> #endif /* __i386__ */ >> #endif /* !_AMD64_HEADER_H_ */ > > ... you wind up with stuff like this, which is also wrong. It precludes= =20 > implementing -mpc98 for building on amd64, for example. Maybe I was wrong to call it cross compilation because in this case the resulting binaries also run on the host system. The patches are meant to support only this particular feature of amd64 to make it possible to build emulators/wine on amd64 for instance. I don't think we should ever support general cross compilation like compiling for pc98 on amd64 or for amd64 on i386. Users have to install a real cross compiler with its own include (and lib) directories for that anyway. In this case however the system compiler already compiles and links 32 bit code. It just uses the wrong types at the moment. To fix that there are basically two approaches: change the compiler or change the headers. Personally I prefer the latter because the former would have to be repeated for every compiler. And so that's what the patches do. They add 32 bit types to the amd64 headers and reuse the i386 headers for that. I admit they currently take the blunt shotgun approach by modifying (almost) all amd64 headers in the same way. This could be refined somewhat header by header. Some headers can be moved to x86 and the existing header replaced by a stub that includes the x86 header such as has been done for apm_bios.h. The patch doesn't modify that one. Some other headers don't conflict and can be merged and moved to x86. Some can be merged with only a few changes. For instance, some i386 headers already define some types as 64 bit in case of PAE. You could add "|| defined(__x86_64__)" to that. If the differences between the headers are small, they can be grouped and put behind #ifdef __i386__ =2E.. #else ... #endif. This seems to be the approach taken by NetBSD. Most headers have been merged and moved to x86. Only some of the amd64 headers have #ifdef __x86_64__ ... #else #include #endif. If I understand their Makefiles correctly /usr/include/machine is also a symlink. On OpenBSD as well. The patches would bring us more in line here. > I'd rather we install {i386,amd64} into /usr/include/ and have machine=20 > be generated from those two directories (or three, if we supported=20 > -mpc98 ever). That way, we wouldn't "forget" to add this code to new=20 > headers, etc. The generated code would be trivial: >=20 > #ifdef __i386__ > #include > #else > #include > #endif I'm not entirely opposed to this, but what would this look like on other architectures? For instance, will i386 headers be available under /usr/include/i386 on a i386 system as well? It's not a requirement, but still a nice side effect of the current patches. Also, this would get in the way of headers that have been moved to x86. They wouldn't need this. I also don't think forgetting to add 32 bit support to new amd64 headers will be a significant problem. There haven't been any new headers in years. In the end it's just another machine specific feature that in my opinion belongs in machine specific headers. The difference with other machine specific features is of course that isn't isolated to one header, but rather spread over all of them. That makes it look impressive, but it isn't actually very complicated. So, I'm open to further comments (of course), but I still think the patches take the right approach. --nextPart5445173.RJdgcoN9Pt Content-Type: application/pgp-signature; name=signature.asc Content-Description: This is a digitally signed message part. -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.16 (FreeBSD) iF4EABEIAAYFAkzlZboACgkQfoCS2CCgtiufhAD+LgzR1thMgrt0QM9LbiKy1KJw KzBzppsWXSXj70DRyL8A/jDsbcPRitBdhPN4VkDfOhKeUG/QvGrw4z9wrBbGTc07 =iYfX -----END PGP SIGNATURE----- --nextPart5445173.RJdgcoN9Pt--