From owner-freebsd-mips@freebsd.org Tue Dec 27 20:22:43 2016 Return-Path: Delivered-To: freebsd-mips@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 8C32BC93DE7 for ; Tue, 27 Dec 2016 20:22:43 +0000 (UTC) (envelope-from jhb@freebsd.org) Received: from mail.baldwin.cx (bigwig.baldwin.cx [96.47.65.170]) (using TLSv1 with cipher DHE-RSA-CAMELLIA256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 4CF0E14B9 for ; Tue, 27 Dec 2016 20:22:42 +0000 (UTC) (envelope-from jhb@freebsd.org) Received: from ralph.baldwin.cx (c-73-231-226-104.hsd1.ca.comcast.net [73.231.226.104]) by mail.baldwin.cx (Postfix) with ESMTPSA id C26D310AA59; Tue, 27 Dec 2016 15:22:41 -0500 (EST) From: John Baldwin To: Juli Mallett Cc: "freebsd-mips@FreeBSD.org" Subject: Re: External toolchain friendliness and /usr/lib32 for mips64 Date: Tue, 27 Dec 2016 12:13:46 -0800 Message-ID: <17902308.cnRfHqtlNY@ralph.baldwin.cx> User-Agent: KMail/4.14.10 (FreeBSD/11.0-STABLE; KDE/4.14.10; amd64; ; ) In-Reply-To: References: <2978934.3KKo4yUUSV@ralph.baldwin.cx> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.4.3 (mail.baldwin.cx); Tue, 27 Dec 2016 15:22:41 -0500 (EST) X-Virus-Scanned: clamav-milter 0.99.2 at mail.baldwin.cx X-Virus-Status: Clean X-BeenThere: freebsd-mips@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Porting FreeBSD to MIPS List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 27 Dec 2016 20:22:43 -0000 On Friday, December 23, 2016 03:09:36 PM Juli Mallett wrote: > Hi John, > > On Fri, Dec 23, 2016 at 2:13 PM, John Baldwin wrote: > > I have a set of patches (currently tied together, but could be split > > into two chunks) for MIPS builds that do two things: > > > > 1) Be more external toolchain-friendly by explicitly specifying the > > desired endianness and ABI both to the compiler and the linker. > > This means we don't depend on the default target of a toolchain > > matching the desired target arch. Previously, I had to explicitly > > specify a TARGET_CPUTYPE for 32-bit mips when using > > mips-xtoolchain-gcc, but with the ABI set explicitly simply > > 'TARGET_ARCH=mips' is sufficient. This also means that you can > > now use 'mips-xtoolchain-gcc' to build mips64 (without > > requiring the separate mips64-xtoolchain-gcc), and you can > > build mipsn32 with gcc from ports (we don't have a binutils or > > gcc port for mips that defaults to mipsn32 currently). > > > > 2) Add build glue for /usr/lib32 on mips64. This builds and installs > > an o32 set of libraries and rtld (of matching endianness) in > > /usr/lib32. > > > > I have tested the latter with the MALTA64 kernel config (just adding > > COMPAT_FREEBSD32) under qemu and am able to run 32-bit binaries just > > fine. > > > > Note that for 1), there is still the case that if we build a compiler > > via the base/ ports, we want the default output to match the host, > > so we would need a mips64-specific base/gcc separate from the mips > > one (and we need a mipsn32 set of packages). > > > > One annoyance is in the sys/boot/beri ldscripts. In-tree binutils > > uses 'elf64-trad*mips' for its ABIs on FreeBSD while upstream > > biutils uses 'elf64-trad*mips-freebsd'. However, the ldscripts are > > already being linked with a linker that is using 64-bit MIPS (and > > are only built for "mips64"), so the OUTPUT_FORMAT() isn't really > > needed and can just be removed. I'd probably want to also remove > > OUTPUT_ARCH() as well as I think that would be most consistent. > > > > The patches are at: > > > > https://github.com/freebsd/freebsd/compare/master...bsdjhb:mips_lib32 > > I've looked these over and they look good to me. There were a few > things that caught me off-guard, and then looked right. > > I'd suggest Makefile.libcompat doing something like ld/Makefile.mips > does with ${_EMULATION_ENDIAN}, so that the almost identical o32 LD > settings can be combined. I think it would end up being larger to do that, but I'm open to whichever makes sense. > I recall making COMPAT_FREEBSD32 in the kernel work with n32 kernels > and o32 in userland, I don't suppose you've tried that to see if it > still works? If so, since the userland changes are so small, it seems > like they might be worth throwing in here? I can't get an n32 world to work at all in qemu currently much less testing freebsd32 compat. :-/ > As to us needing a n32 package sets, I think that might be a bit of a > stretch. If we go down the x32 route for amd64, would we be having > x32 packages, too? I guess if we have the resources to build the > extra package sets for MIPS, there's no reason not to, but I'm > skeptical of their value. I know that's not in this change, but as > part of the larger arc here. If we supported x32 on x86, yes, we would want x32 packages I think, but n32 is different because you can build an n32 world. I would only imagine x32 as an optional abi on amd64, so you wouldn't have an x32 kernel or a pure x32 world, but an amd64 kernel/world with a /usr/libx32 and the ability to build certain binaries as x32. With mips though you can have an n32 kernel/world where all the native binaries are n32. You would want a 'cc' in such a world to generate n32 binaries by default. In the model of external toolchains that would mean having a base/gcc package for n32 that builds a 'default-to-n32' cc. -- John Baldwin