Message ID | 20230208171607.391107-1-xry111@xry111.site |
---|---|
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:adf:eb09:0:0:0:0:0 with SMTP id s9csp3580242wrn; Wed, 8 Feb 2023 09:18:54 -0800 (PST) X-Google-Smtp-Source: AK7set/3nJMVdHmqp3rnQPagqQXRBKm4H32RVcKU0ezAuQ0zGYr3joOT1ZCpeFuyjuqdB+h+uye6 X-Received: by 2002:a05:6402:278a:b0:4aa:b394:7b28 with SMTP id b10-20020a056402278a00b004aab3947b28mr10155663ede.3.1675876734693; Wed, 08 Feb 2023 09:18:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1675876734; cv=none; d=google.com; s=arc-20160816; b=H8Z9XLTBJyW0cbPmDXcJO6gL6cyQ44i8RvXZDExntJn9UGwknsSrZXNx242jvGB5qU Eirkopcdo0FgrTq1kbmTJTebYuj59tFrf0Lb5Axh+d46lXZCozkk17aS7q+C84js7yFb +LLCIVc0So99uMY6ua86ymhfDi2bA87K3vFi4Fdld3SBDw5kVEQoHdNu1vG1w99G116r PHHDGJp5EPSXStaI9GaKcqENKK2OuXrnoFG56pjaF+G0SCfe+apnonX9PI9rX4bUiTOA EJY9Wppyu+Vc+WTP2AhfZ0rTxzcsuDBCqeVMuOp6C1fsGumuIg6YvMbG8ueYdENaKdXO f4LQ== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=uVg3vBcy1D6E/KGTJ5n9T/Lbg98d7aSK6xGE+OXMZkI=; b=q9iIbddXFPgY1hcqKwB2LbklQmTTckDSO62D1BtZzBJwIkccXc15bXdxpm/VFtSmkA GUyqPWAxSVFI2tJzYI+PT9UwOovkYTUgnvx6rk2t+625B38JIpe9o58NRiIFpOyLwt7l 8uFXBg9c7K1pVahkYicEIYwrPuCIhCOE/xZQD7gnKgm/U3khkEB+pYx4JlCtOwItXphw vkizNzbhJtrPkn9zXytXGEyB4Sg/RbzpT7KvDx2i1TUJJA8dzvfbBV2kZdvU63vTKSBy TsNDxQySg68OoH+7kNd+WHh2oLrTnxk9T6LD+rTnBlX6vVAzvLkLmLkVE8rZvk3ulRs3 kJRQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@xry111.site header.s=default header.b=je3ll1bB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=xry111.site Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id gh18-20020a1709073c1200b0087877581be7si18076974ejc.810.2023.02.08.09.18.13; Wed, 08 Feb 2023 09:18:54 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@xry111.site header.s=default header.b=je3ll1bB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=xry111.site Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231586AbjBHRQe (ORCPT <rfc822;ivan.orlov0322@gmail.com> + 99 others); Wed, 8 Feb 2023 12:16:34 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45510 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231346AbjBHRQb (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Wed, 8 Feb 2023 12:16:31 -0500 Received: from xry111.site (xry111.site [IPv6:2001:470:683e::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DEBD928D03 for <linux-kernel@vger.kernel.org>; Wed, 8 Feb 2023 09:16:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=xry111.site; s=default; t=1675876585; bh=EJ9NVe253KjmTra80L8ReGUQvb0ZTCo7dnOHVEPK+Pc=; h=From:To:Cc:Subject:Date:From; b=je3ll1bBqQBDkdYtOapkJMEg9JcFZoNvog+AyMHyFs9uArqxgb74J+7bQucywo7x8 kVC9rEj8NWAQPOyjksILpJUSa8f3DLgVN6wASTzQx2cHT9EVEl+xtWUXWFNYW6laqu 35MSdl8t/X4rHK2rwqu1ZPDOWV2wVPamEbTdvDYw= Received: from xry111-x57s1.. (unknown [IPv6:240e:358:1174:d100:dc73:854d:832e:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-384) server-digest SHA384) (Client did not present a certificate) (Authenticated sender: xry111@xry111.site) by xry111.site (Postfix) with ESMTPSA id 3FC6665C4F; Wed, 8 Feb 2023 12:16:21 -0500 (EST) From: Xi Ruoyao <xry111@xry111.site> To: Youling Tang <tangyouling@loongson.cn>, Huacai Chen <chenhuacai@kernel.org>, Jinyang He <hejinyang@loongson.cn> Cc: Xuerui Wang <kernel@xen0n.name>, loongarch@lists.linux.dev, linux-kernel@vger.kernel.org, Xi Ruoyao <xry111@xry111.site> Subject: [PATCH v3 0/5] LoongArch: Add kernel relocation and KASLR support Date: Thu, 9 Feb 2023 01:16:02 +0800 Message-Id: <20230208171607.391107-1-xry111@xry111.site> X-Mailer: git-send-email 2.39.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1757183036471982558?= X-GMAIL-MSGID: =?utf-8?q?1757284122889909532?= |
Series |
LoongArch: Add kernel relocation and KASLR support
|
|
Message
Xi Ruoyao
Feb. 8, 2023, 5:16 p.m. UTC
This patch series to support kernel relocation and KASLR (only 64bit). Tested the kernel images built with new toolchain (Binutils-2.40 + patched GCC-12.2) and old toolchain (kernel.org cross toolchain [1]) on a 3A5000-7A2000-EVB. With CONFIG_RANDOMIZE_BASE=y, the results are: 1. first boot, new toolchain: $ sudo cat /proc/iomem | grep Kernel 01080000-0189ffff : Kernel code 018a0000-01deb5ff : Kernel data 01deb600-01ef6e9f : Kernel bss 2. second boot, new toolchain: $ sudo cat /proc/iomem | grep Kernel 012f0000-01b0ffff : Kernel code 01b10000-0205b5ff : Kernel data 0205b600-02166e9f : Kernel bss 3. first boot, old toolchain: 010e0000-018fffff : Kernel code 01900000-01e591ff : Kernel data 01e59200-01f56dcf : Kernel bss 4. second boot, old toolchain: 010b0000-018cffff : Kernel code 018d0000-01e291ff : Kernel data 01e29200-01f26dcf : Kernel bss Changes from v2: - Correctly fixup pcaddi12i/ori/lu32i.d/lu52i.d sequence generated by GNU as <= 2.39 for la.pcrel. Changes from v1 to v2: - Relocate the handlers instead of using a trampoline, to avoid performance issue on NUMA systems. - Fix compiler warnings. Xi Ruoyao (2): LoongArch: Use la.pcrel instead of la.abs when it's trivially possible LoongArch: Use la.pcrel instead of la.abs for exception handlers Youling Tang (3): LoongArch: Add JUMP_LINK_ADDR macro implementation to avoid using la.abs LoongArch: Add support for kernel relocation LoongArch: Add support for kernel address space layout randomization (KASLR) arch/loongarch/Kconfig | 37 +++++ arch/loongarch/Makefile | 5 + arch/loongarch/include/asm/inst.h | 1 + arch/loongarch/include/asm/page.h | 6 + arch/loongarch/include/asm/setup.h | 6 +- arch/loongarch/include/asm/stackframe.h | 13 +- arch/loongarch/include/asm/uaccess.h | 1 - arch/loongarch/kernel/Makefile | 2 + arch/loongarch/kernel/entry.S | 2 +- arch/loongarch/kernel/genex.S | 40 ++++- arch/loongarch/kernel/head.S | 30 +++- arch/loongarch/kernel/relocate.c | 211 ++++++++++++++++++++++++ arch/loongarch/kernel/setup.c | 3 + arch/loongarch/kernel/traps.c | 158 +++++++++++++++--- arch/loongarch/kernel/vmlinux.lds.S | 11 +- arch/loongarch/mm/tlb.c | 23 +-- arch/loongarch/mm/tlbex.S | 72 +++++++- arch/loongarch/power/suspend_asm.S | 5 +- 18 files changed, 564 insertions(+), 62 deletions(-) create mode 100644 arch/loongarch/kernel/relocate.c