Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp4151682pxv; Mon, 19 Jul 2021 18:33:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxfF4/ywAUD4OV0knOO1ucwGfGztBTRArIWOUyKqKL+ujRPwXMYqBxIHF2OWn9a8AOzrfDU X-Received: by 2002:a17:906:1701:: with SMTP id c1mr29813882eje.425.1626744836919; Mon, 19 Jul 2021 18:33:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626744836; cv=none; d=google.com; s=arc-20160816; b=gjaldOTgtzy8IvzM4iNaQVuOg3WvkggBPCseTnWjPeL5xntzOWfOECxsUvlid8nphD 5yTxfpMUo122hctnaHHHb9dgkTyEIamZfVuYUqEkG5cEjgxGDn1I2mJKmg8AN2SoijqF Ql5krL6ONHaNrnKMOXPsE7OS7TfoEcaLApSzdrGhPCzH3Jmsxx52lzPVnn6oU7Vp17Ia PIVWC5NRWoDFw8UfkcHLQ6pLF2z52KVoldoLty7RrEkqf4EwDm78uzEmtXY4ExQdvC8Q KSy8VvpZIn0qP0y4dS6c2cqklwSOupRiVq51EcdQP29qtk8mPQGNcYhkT17ufgSAd3uD QvlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=AxdN1HJ/Ut8PcyWH9WIa+wNF/gRzhUaekJim0SI7DFE=; b=EUZyLeIyot1wKNIfcNMix8FUy7O5TzmWhh+IVOvNw89xCHfUixjupdsQUtRJ9IAQnJ BgogiXFxeHnvdnqzhysosFuA7QS/OO3kEdWTlaWpCYQrIwPJCRjCSYvoAr1O5QN6p9Sj VUEfTrv5XCvUnHS0Dc/NxUthUHaJ2PCUZ2E6QNFf/g26ne1nVPmat5T/FMuxtoxmTr1Q OGZ6fNx382HiOWEsSDVZ5rDxC/4/1/wrMu35YfUsBgPiN/67Xky/nrTpgGkxfVnytM8l o9l7HuX+BYbYqQCZVB5HFLaza5dX02Ixf8vubRDalmh5TdLsJbsl0Q8zLXOK64xpN0va tJuQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MyePAsyA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qa18si22629609ejc.491.2021.07.19.18.33.21; Mon, 19 Jul 2021 18:33:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MyePAsyA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242957AbhGSOvm (ORCPT + 99 others); Mon, 19 Jul 2021 10:51:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:46568 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S245368AbhGSOed (ORCPT ); Mon, 19 Jul 2021 10:34:33 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0245E6128A; Mon, 19 Jul 2021 15:13:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626707639; bh=COMMYMrIZyJA7Y/8b9KO9zfJUI/g6UHTY3iQqUVpiVw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MyePAsyAfruDiZjmJUo1LtM/EPKj6Pkz+lUglUEFvWNcyzP9xnMdxXtOL2Nr8gPAG OSf2EmHKhoIB/3RXGg0CHHMH4XVOMbmTBS9wIjXmYEkeWL1LWO3n+6831RbVL+Bt/K PIPYmimV9Fpw9vV0Cg2pvptWfA3rFHoKTJanFBOw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Arnd Bergmann , Thomas Bogendoerfer , Sasha Levin Subject: [PATCH 4.9 243/245] mips: always link byteswap helpers into decompressor Date: Mon, 19 Jul 2021 16:53:05 +0200 Message-Id: <20210719144948.218519419@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144940.288257948@linuxfoundation.org> References: <20210719144940.288257948@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Arnd Bergmann [ Upstream commit cddc40f5617e53f97ef019d5b29c1bd6cbb031ec ] My series to clean up the unaligned access implementation across architectures caused some mips randconfig builds to fail with: mips64-linux-ld: arch/mips/boot/compressed/decompress.o: in function `decompress_kernel': decompress.c:(.text.decompress_kernel+0x54): undefined reference to `__bswapsi2' It turns out that this problem has already been fixed for the XZ decompressor but now it also shows up in (at least) LZO and LZ4. From my analysis I concluded that the compiler could always have emitted those calls, but the different implementation allowed it to make otherwise better decisions about not inlining the byteswap, which results in the link error when the out-of-line code is missing. While it could be addressed by adding it to the two decompressor implementations that are known to be affected, but as this only adds 112 bytes to the kernel, the safer choice is to always add them. Fixes: c50ec6787536 ("MIPS: zboot: Fix the build with XZ compression on older GCC versions") Fixes: 0652035a5794 ("asm-generic: unaligned: remove byteshift helpers") Link: https://lore.kernel.org/linux-mm/202106301304.gz2wVY9w-lkp@intel.com/ Link: https://lore.kernel.org/linux-mm/202106260659.TyMe8mjr-lkp@intel.com/ Link: https://lore.kernel.org/linux-mm/202106172016.onWT6Tza-lkp@intel.com/ Link: https://lore.kernel.org/linux-mm/202105231743.JJcALnhS-lkp@intel.com/ Signed-off-by: Arnd Bergmann Signed-off-by: Thomas Bogendoerfer Signed-off-by: Sasha Levin --- arch/mips/boot/compressed/Makefile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/arch/mips/boot/compressed/Makefile b/arch/mips/boot/compressed/Makefile index 0fa91c981658..3e93eea5a5f5 100644 --- a/arch/mips/boot/compressed/Makefile +++ b/arch/mips/boot/compressed/Makefile @@ -33,7 +33,7 @@ KBUILD_AFLAGS := $(LINUXINCLUDE) $(KBUILD_AFLAGS) -D__ASSEMBLY__ \ KCOV_INSTRUMENT := n # decompressor objects (linked with vmlinuz) -vmlinuzobjs-y := $(obj)/head.o $(obj)/decompress.o $(obj)/string.o +vmlinuzobjs-y := $(obj)/head.o $(obj)/decompress.o $(obj)/string.o $(obj)/bswapsi.o ifdef CONFIG_DEBUG_ZBOOT vmlinuzobjs-$(CONFIG_DEBUG_ZBOOT) += $(obj)/dbg.o @@ -47,7 +47,7 @@ extra-y += uart-ath79.c $(obj)/uart-ath79.c: $(srctree)/arch/mips/ath79/early_printk.c $(call cmd,shipped) -vmlinuzobjs-$(CONFIG_KERNEL_XZ) += $(obj)/ashldi3.o $(obj)/bswapsi.o +vmlinuzobjs-$(CONFIG_KERNEL_XZ) += $(obj)/ashldi3.o extra-y += ashldi3.c bswapsi.c $(obj)/ashldi3.o $(obj)/bswapsi.o: KBUILD_CFLAGS += -I$(srctree)/arch/mips/lib -- 2.30.2