From owner-freebsd-mips@freebsd.org Tue Sep 22 19:57:11 2015 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 DD8A0A06EE5 for ; Tue, 22 Sep 2015 19:57:10 +0000 (UTC) (envelope-from sbruno@freebsd.org) Received: from mail.ignoranthack.me (ignoranthack.me [199.102.79.106]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id C48EA10BF for ; Tue, 22 Sep 2015 19:57:10 +0000 (UTC) (envelope-from sbruno@freebsd.org) Received: from [192.168.200.208] (unknown [50.136.155.142]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: sbruno@ignoranthack.me) by mail.ignoranthack.me (Postfix) with ESMTPSA id 418A719291B for ; Tue, 22 Sep 2015 19:57:08 +0000 (UTC) To: freebsd-mips@freebsd.org From: Sean Bruno Subject: MIPS Clang Update X-Enigmail-Draft-Status: N1210 Message-ID: <5601B293.7090804@freebsd.org> Date: Tue, 22 Sep 2015 12:57:07 -0700 User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:38.0) Gecko/20100101 Thunderbird/38.2.0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-BeenThere: freebsd-mips@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Porting FreeBSD to MIPS List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 22 Sep 2015 19:57:11 -0000 -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA512 With the help of Daniel Sanders at Imagination Tech, we got most of the required bits committed to llvm/clang that are required to compile libc. The only require diff is here: https://people.freebsd.org/~sbruno/clang_mips.diff MIPS32 in clang/llvm is a bit of a trainwreck. clang/llvm assumes that MIPS-III is 64bit only, so I'm skipping further testing until some resolution of this matter is found. MIPS64 on the other hand is workable. Using the following make.conf and src.conf, I can get to the final linking stage of libc. Clang/llvm appears to be generating objects that our base system binutils doesn't understand. I've attempted to remove ELF entries one at a time to resolve this linking issue to no avail. Basically, I'm stuck and don't see a way out. /var/tmp/mips.mips64/usr/home/sbruno/fbsd_head/tmp/usr/bin/ld: /var/tmp/mips.mips64/usr/home/sbruno/fbsd_head/tmp/usr/lib/crtbeginS.o: CALL16 reloc at 0x8 not against global symbol /var/tmp/mips.mips64/usr/home/sbruno/fbsd_head/tmp/usr/lib/crtbeginS.o: could not read symbols: Bad value clang-3.8: error: linker command failed with exit code 1 (use -v to see invocation) Upstream binutils is even worse in this matter and I've come to the conclusion that its unworkable. Our intree gcc generates an object that has the following ELF informatio n: https://people.freebsd.org/~sbruno/gcc_crtbeginS.o.txt Whereas clang/trunk generates: https://people.freebsd.org/~sbruno/clang_crtbeginS.o.txt Any advice and suggestions would be gladly accepted here. More or less, I'm stuck and can't progress with my limited understanding of the linker. - -- MALLOC_PRODUCTION=y NO_WERROR=y TARGET=mips TARGET_ARCH=mips64 XCFLAGS+=-Wno-typedef-redefinition XCC=/home/sbruno/clang/build/bin/clang XCPP=/home/sbruno/clang/build/bin/clang-cpp XCXX=/home/sbruno/clang/build/bin/clang++ LDFLAGS+=-v - -- WITHOUT_KERBEROS="YES" WITHOUT_KERBEROS_SUPPORT="YES" WITHOUT_NIS="YES" WITHOUT_NDIS="YES" WITHOUT_IPX="YES" WITHOUT_ATM="YES" WITHOUT_ICONV="YES" #WITHOUT_CLANG_IS_CC="YES" WITHOUT_CASPER="YES" WITHOUT_CAPSICUM="YES" WITHOUT_TESTS="YES" WITHOUT_GAMES="YES" WITHOUT_DOCS="YES" WITHOUT_MAN="YES" WITHOUT_INFO="YES" WITHOUT_LOCALES="YES" WITHOUT_NLS="YES" WITHOUT_EXAMPLES="YES" WITHOUT_ZFS="YES" WITHOUT_RCS="YES" WITHOUT_CLANG="YES" WITHOUT_CLANG_EXTRAS="YES" WITHOUT_CLANG_FULL="YES" WITHOUT_CLANG_BOOTSTRAP="YES" WITHOUT_GCC="YES" WITHOUT_GDB="YES" - -- -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQF8BAEBCgBmBQJWAbKPXxSAAAAAAC4AKGlzc3Vlci1mcHJAbm90YXRpb25zLm9w ZW5wZ3AuZmlmdGhob3JzZW1hbi5uZXRCQUFENDYzMkU3MTIxREU4RDIwOTk3REQx MjAxRUZDQTFFNzI3RTY0AAoJEBIB78oecn5kbmYH/1bfUwIumQSO9aY87QwuYDuY bDax/Ujwt0WhEUlZdtuA5KJ8XWGRq1Qm2r5foX0/k4JZA0XembJ9KTAIkdxOsXpn FcciN2R8pb4TvI3gfgNpT+dw8S+JJCTd3B5UsvmWA7gHGMS9iAFBNmhkzbh1HGHg 52U5MjSaAwIuar2pdMFBteGPpUmTPwH+DyM+rI3yixB2kUddTf8ay906rkT5PpBg 6n2CcE69LHqwal0b/g5OXAm9dL49btEaQQgV8zvmoygE+2xIcYQ4HbsbI/PKdniW ZCG7EkRtVL7CLl73NYSZvFB7Q9OEhAayr024ao5FIbHcVZDDsabuyryY4onYZ0s= =kJqd -----END PGP SIGNATURE-----