Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp7442903rwd; Tue, 20 Jun 2023 01:02:09 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5N9G2IMWpdXwjWw2j1d4prorrfaRjfLAxShrgiiNLKlfDRfFqMkDD4zpOTvsuLdjns9/LR X-Received: by 2002:a05:6a20:1455:b0:11f:1b6f:6658 with SMTP id a21-20020a056a20145500b0011f1b6f6658mr13477363pzi.11.1687248128926; Tue, 20 Jun 2023 01:02:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687248128; cv=none; d=google.com; s=arc-20160816; b=lV1jhZhoi0Wt0C18ZAjUy2L4rDWn2YaQDsfia110iL7RR2mpPPFkMQe8bC66WvaWNa mBg9bB18XsrQpI4EartAo8HqWb0kZnPgum8AD0+ouvzcjWg6c+xeNFbALUErGWRO/Dh8 4Mf9dQYacyLSm1jRezuJ4gqMOe2TBcVpuGpnrQcvmt8NwpNwSwAECjNwzcsPR9U64q4d XDXel44ioc0n2R26ehZ7c60O28kSiSWYXhIP0DQkEnwQ4i9P71XKqRXm3E8Szmaee2bf wbom+vbzO7OeIO+O0lUnLoA9fEAuHr1BgW/1aobh1EW6nKGJ4fEygI0UL7pahoqF2Xqd VZkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=Q8XRqtrVQ4uDQI1aOZLeB4EEpxrYXM5eZCjUM6LThGI=; b=kOanGy7Yv0LFbd4UjFTvxv6ssWkb6pBskQNltQ4Ch1JV+atiUKBNsmChfWYscseVqA fY06PB7TC/5DasmWERJLStCxVcHg0krehcuAra1a8nta5HnbjYoV1po+WY76pqsXPcxC nasSx8yRUHO+DzhxKy5UPY2wrVU1vZhefy8CA7e80jKIOfDy4sBRX1egzCaXvgzRwTxk qh5uVcvkEujCnpyfpJCtEyr6v4b23l9ivcB820RktXU8fiqTASMlfw3kfUJAyS0XdMuK o58cGp7KOWX6lSuDGBjMDmgjlP/NPFQe3H0D2a0LcgTZC9bzvOBEw0x2EzipfFiE/qwt kJYA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t8-20020a17090340c800b001b55934ae61si1396068pld.288.2023.06.20.01.01.40; Tue, 20 Jun 2023 01:02:08 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231569AbjFTHxh (ORCPT + 99 others); Tue, 20 Jun 2023 03:53:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52476 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231547AbjFTHxY (ORCPT ); Tue, 20 Jun 2023 03:53:24 -0400 Received: from mail.loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8B4C2199E; Tue, 20 Jun 2023 00:53:00 -0700 (PDT) Received: from loongson.cn (unknown [113.200.148.30]) by gateway (Coremail) with SMTP id _____8DxDeurWpFkNhwHAA--.14649S3; Tue, 20 Jun 2023 15:52:11 +0800 (CST) Received: from bogon.localdomain (unknown [113.200.148.30]) by localhost.localdomain (Coremail) with SMTP id AQAAf8AxauWoWpFkdmghAA--.28374S4; Tue, 20 Jun 2023 15:52:10 +0800 (CST) From: Youling Tang To: Josh Poimboeuf , Peter Zijlstra , Huacai Chen , madvenka@linux.microsoft.com Cc: chenzhongjin@huawei.com, WANG Xuerui , Xi Ruoyao , live-patching@vger.kernel.org, linux-kernel@vger.kernel.org, loongarch@lists.linux.dev, tangyouling00@gmail.com, youling.tang@outlook.com Subject: [RFC PATCH v1 17/23] LoongArch: Support R_LARCH_32_PCREL relocation type in kernel module Date: Tue, 20 Jun 2023 15:52:04 +0800 Message-Id: <1687247526-32258-3-git-send-email-tangyouling@loongson.cn> X-Mailer: git-send-email 2.1.0 In-Reply-To: <1687247526-32258-1-git-send-email-tangyouling@loongson.cn> References: <1687247526-32258-1-git-send-email-tangyouling@loongson.cn> X-CM-TRANSID: AQAAf8AxauWoWpFkdmghAA--.28374S4 X-CM-SenderInfo: 5wdqw5prxox03j6o00pqjv00gofq/ X-Coremail-Antispam: 1Uk129KBj93XoW7uw48Kw4UGw1DWw4xJr43urX_yoW8CF4xpF y5Cr13GF4rGFnFqFWYqw1DW3WrW3WkCay2qayrC34IyrnxJryDA3WIqr1DJayjqrn5Gr1F qr1rt3WFqanrAagCm3ZEXasCq-sJn29KB7ZKAUJUUUU3529EdanIXcx71UUUUU7KY7ZEXa sCq-sGcSsGvfJ3Ic02F40EFcxC0VAKzVAqx4xG6I80ebIjqfuFe4nvWSU5nxnvy29KBjDU 0xBIdaVrnRJUUUmIb4IE77IF4wAFF20E14v26r1j6r4UM7CY07I20VC2zVCF04k26cxKx2 IYs7xG6rWj6s0DM7CIcVAFz4kK6r126r13M28lY4IEw2IIxxk0rwA2F7IY1VAKz4vEj48v e4kI8wA2z4x0Y4vE2Ix0cI8IcVAFwI0_tr0E3s1l84ACjcxK6xIIjxv20xvEc7CjxVAFwI 0_Gr1j6F4UJwA2z4x0Y4vEx4A2jsIE14v26r4UJVWxJr1l84ACjcxK6I8E87Iv6xkF7I0E 14v26r4UJVWxJr1ln4kS14v26r126r1DM2AIxVAIcxkEcVAq07x20xvEncxIr21l57IF6x kI12xvs2x26I8E6xACxx1l5I8CrVACY4xI64kE6c02F40Ex7xfMcIj6xIIjxv20xvE14v2 6r45tVCq3wAv7VC2z280aVAFwI0_Gr1j6F4UJwAm72CE4IkC6x0Yz7v_Jr0_Gr1lF7xvr2 IYc2Ij64vIr41lF7xvrVCFI7AF6II2Y40_Zr0_Gr1UMxkF7I0En4kS14v26r126r1DMxAI w28IcxkI7VAKI48JMxC20s026xCaFVCjc4AY6r1j6r4UMxCIbckI1I0E14v26r126r1DMI 8I3I0E5I8CrVAFwI0_Jr0_Jr4lx2IqxVCjr7xvwVAFwI0_JrI_JrWlx4CE17CEb7AF67AK xVWUtVW8ZwCIc40Y0x0EwIxGrwCI42IY6xIIjxv20xvE14v26w1j6s0DMIIF0xvE2Ix0cI 8IcVCY1x0267AKxVW8Jr0_Cr1UMIIF0xvE42xK8VAvwI8IcIk0rVWUJVWUCwCI42IY6I8E 87Iv67AKxVW8Jr0_Cr1UMIIF0xvEx4A2jsIEc7CjxVAFwI0_Gr1j6F4UJbIYCTnIWIevJa 73UjIFyTuYvjxUvNB_UUUUU X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE 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: X-Mailing-List: linux-kernel@vger.kernel.org Fix "unsupported relocation type" errors caused by adding ORC support, which generates unsupported relocation types. The reason is because the generated '.rela.orc_unwind_ip' section will contain the R_LARCH_32_PCCREL type. Relocation section '.rela.orc_unwind_ip' at offset 0x1fb58 contains 600 entries: Offset Info Type Sym. Value Sym. Name + Addend 000000000000 000300000063 R_LARCH_32_PCREL 0000000000000000 .text + 0 000000000004 000300000063 R_LARCH_32_PCREL 0000000000000000 .text + 64 Signed-off-by: Youling Tang --- arch/loongarch/kernel/module.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/arch/loongarch/kernel/module.c b/arch/loongarch/kernel/module.c index 44f31b1958b1..3cc31701c76a 100644 --- a/arch/loongarch/kernel/module.c +++ b/arch/loongarch/kernel/module.c @@ -368,6 +368,15 @@ static int apply_r_larch_got_pc(struct module *mod, return apply_r_larch_pcala(mod, location, got, rela_stack, rela_stack_top, type); } +static int apply_r_larch_32_pcrel(struct module *mod, u32 *location, Elf_Addr v, + s64 *rela_stack, size_t *rela_stack_top, unsigned int type) +{ + ptrdiff_t offset = (void *)v - (void *)location; + + *(u32 *)location = offset; + return 0; +} + /* * reloc_handlers_rela() - Apply a particular relocation to a module * @mod: the module to apply the reloc to @@ -397,6 +406,7 @@ static reloc_rela_handler reloc_rela_handlers[] = { [R_LARCH_SOP_POP_32_S_10_5 ... R_LARCH_SOP_POP_32_U] = apply_r_larch_sop_imm_field, [R_LARCH_ADD32 ... R_LARCH_SUB64] = apply_r_larch_add_sub, [R_LARCH_PCALA_HI20...R_LARCH_PCALA64_HI12] = apply_r_larch_pcala, + [R_LARCH_32_PCREL] = apply_r_larch_32_pcrel, }; int apply_relocate_add(Elf_Shdr *sechdrs, const char *strtab, -- 2.39.2