From owner-freebsd-mips@freebsd.org Fri Dec 23 22:13:45 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 5C070C8EF26 for ; Fri, 23 Dec 2016 22:13:45 +0000 (UTC) (envelope-from jhb@freebsd.org) Received: from mail.baldwin.cx (bigwig.baldwin.cx [IPv6:2001:470:1f11:75::1]) (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 35615A79; Fri, 23 Dec 2016 22:13:45 +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 E718B10AA47; Fri, 23 Dec 2016 17:13:43 -0500 (EST) From: John Baldwin To: freebsd-mips@freebsd.org Subject: External toolchain friendliness and /usr/lib32 for mips64 Date: Fri, 23 Dec 2016 14:13:38 -0800 Message-ID: <2978934.3KKo4yUUSV@ralph.baldwin.cx> User-Agent: KMail/4.14.10 (FreeBSD/11.0-PRERELEASE; KDE/4.14.10; amd64; ; ) 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); Fri, 23 Dec 2016 17:13:44 -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: Fri, 23 Dec 2016 22:13:45 -0000 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 -- John Baldwin From owner-freebsd-mips@freebsd.org Fri Dec 23 23:09:58 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 6A901C8EA64 for ; Fri, 23 Dec 2016 23:09:58 +0000 (UTC) (envelope-from juli@clockworksquid.com) Received: from mail-it0-x22d.google.com (mail-it0-x22d.google.com [IPv6:2607:f8b0:4001:c0b::22d]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 3B2B78B3 for ; Fri, 23 Dec 2016 23:09:58 +0000 (UTC) (envelope-from juli@clockworksquid.com) Received: by mail-it0-x22d.google.com with SMTP id 75so126733052ite.1 for ; Fri, 23 Dec 2016 15:09:58 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=clockworksquid.com; s=google; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=FliAOAmAxR3JHKRCCj2pcYzXmEbLIyZAU+2z1O4QnU4=; b=bMdJSXb/G7q7DjPF0uaD6S01zlLG9rC39IMsegJVixq88SPslihlflBBRMa86ghHag vQSqhOBr3uVAsn7Cv25rzeOAMbhgQay17GK3fn2YK8a3w8dtON9z6Yw+oPp3HaCYCDkz MlfUzx/KnqDbetlqf2lTnPoA6zLqv4sGNM1z4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=FliAOAmAxR3JHKRCCj2pcYzXmEbLIyZAU+2z1O4QnU4=; b=pzuqFRyT8o1bfbNA30YpGiTNXaymHHVZrjNa+gVMmQN5+l9YDX2Snm0IGDE9JLNX2/ bjr/CYbzpgxJ877cJkLhP1QhpkRANTOvGtDo69lr3Xi17Zl5D/qD3rJtmhVJ8nA8DdMd 3AqyLhKCifyrS6ThPVg2RhzBgll053u0IrQsiDAOpt0VQw3diSQgUVEkeI8ZyLsRnGez O4HGy7ypfeGcUYqsxKlsnMy1tATZHWt2SNH7E+IFqItPGfkx7HUWwbRhtYAdGnAuWpak 1E92FRiPHuSky6izs34dnACZgXUqTVUllWpe52e8E+HCccm4fIEaq5wOgmpQz0pN4ZGx dTrg== X-Gm-Message-State: AIkVDXIxjzRZVdlgvdoWnfnco4zNlT7zhA3aahCYsJyk6+OBnE+5QVnM9snOR3XXoLrzB7HS6702lDrwNBmghw== X-Received: by 10.36.29.21 with SMTP id 21mr17574575itj.80.1482534597501; Fri, 23 Dec 2016 15:09:57 -0800 (PST) MIME-Version: 1.0 Received: by 10.36.50.210 with HTTP; Fri, 23 Dec 2016 15:09:36 -0800 (PST) In-Reply-To: <2978934.3KKo4yUUSV@ralph.baldwin.cx> References: <2978934.3KKo4yUUSV@ralph.baldwin.cx> From: Juli Mallett Date: Fri, 23 Dec 2016 15:09:36 -0800 Message-ID: Subject: Re: External toolchain friendliness and /usr/lib32 for mips64 To: John Baldwin Cc: "freebsd-mips@FreeBSD.org" Content-Type: text/plain; charset=UTF-8 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: Fri, 23 Dec 2016 23:09:58 -0000 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 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? 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. Thanks very much for doing this work! Juli.