Received: by 10.192.165.148 with SMTP id m20csp4559803imm; Tue, 24 Apr 2018 04:58:16 -0700 (PDT) X-Google-Smtp-Source: AB8JxZph+Soft28WA/o29cGNL7rxKmthcjXVaTE08BHFkBCdTtSUPDmMfinsCTfLKEDM01iCYw0b X-Received: by 10.98.9.27 with SMTP id e27mr3558001pfd.93.1524571096392; Tue, 24 Apr 2018 04:58:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524571096; cv=none; d=google.com; s=arc-20160816; b=mTi1MA5fcqwGmVTb1Rm7C5iQO8JWnGq1EU8Az3eIa8IivEqU4PJfxOunEAyzWiKm1H Y4ahMNYHAJWNYwdzQbtlTXMe5OTTR0N7mjbZqs3SwkcToMKsxHlO21wHmbDBis7+T+RY gmhEx96WfYfzlxCQ/PrMkS38kIfVMGSxisPnzJlfvUq0mAYaijgcUM/+fB7MFkZITkFX AR3Eo3DVJa6HeBSCfcsVrL6SeNdoemO5uJUGUCLFwNu2XTswVvkIP7JFP3tuhGTdeG1C b1TWXmkBd2EWFg9XjwixtxrRZ3BwhDIlzHSfJrizrFKxrINxu8Cv+pszrhzYDyJalr3U 1ObA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from:arc-authentication-results; bh=2yZmE18C6gXJmwjqXfESr+eot0/624sOdWZtWAKcabA=; b=um72JieN9FrmX8wlB1LVVLG6c0zfbn2Uz/U4NgXubjbUDc5LfclKfdGO/lFOetOJs3 4aA9J6cI0DHCwDY2HKzUR3FwSICE2daSZUf8dt+hn3d3gjtwYGOgkhk9PYLi2kBe084l +R7h9kRJ43MJgmUR3lb4hSn0IYee2q66fgF97mE2m+YR9wH1EFQGUhBicZNYndmn2bWg AExPwjgZwc+CtGWBlUJroyFNjKp/8/onOlSNdijNNpJrTpYUH5P8IGyAvH774/qjsJia YzM6gASh7oWNfL4uIYu2/TlTgzlPXBXme085qIz+tUaKBvQuGRd3iS0lyTv/lCANTtxH K0Nw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s14si3303733pfh.11.2018.04.24.04.58.02; Tue, 24 Apr 2018 04:58:16 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932456AbeDXLy3 (ORCPT + 99 others); Tue, 24 Apr 2018 07:54:29 -0400 Received: from smtprelay0092.hostedemail.com ([216.40.44.92]:55736 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751436AbeDXLyV (ORCPT ); Tue, 24 Apr 2018 07:54:21 -0400 Received: from filter.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay08.hostedemail.com (Postfix) with ESMTP id E1500182CF671; Tue, 24 Apr 2018 11:54:20 +0000 (UTC) X-Session-Marker: 7368656140736865616C6576792E636F6D X-Spam-Summary: 2,0,0,,d41d8cd98f00b204,shea@shealevy.com,:::::::,RULES_HIT:41:355:379:599:800:871:960:973:988:989:1000:1260:1313:1314:1345:1359:1431:1437:1516:1518:1534:1542:1575:1711:1730:1747:1777:1792:1981:2194:2199:2393:2553:2559:2562:3138:3139:3140:3141:3142:3354:3622:3865:3866:3867:3868:3870:3871:3872:3874:4250:4321:4362:4605:5007:6119:6261:6506:6747:7281:7875:7903:7909:8603:9036:10004:10848:11026:11232:11473:11657:11658:11914:12043:12296:12438:12555:12740:12895:12986:14096:14180:14181:14721:21060:21080:21433:21451:21627:21740:30025:30054:30090:30091,0,RBL:71.235.10.46:@shealevy.com:.lbl8.mailshell.net-62.4.0.191 64.201.201.201,CacheIP:none,Bayesian:0.5,0.5,0.5,Netcheck:none,DomainCache:0,MSF:not bulk,SPF:ff,MSBL:0,DNSBL:neutral,Custom_rules:0:0:0,LFtime:20,LUA_SUMMARY:none X-HE-Tag: nerve42_7d26f100e4f2d X-Filterd-Recvd-Size: 4874 Received: from localhost (c-71-235-10-46.hsd1.nh.comcast.net [71.235.10.46]) (Authenticated sender: shea@shealevy.com) by omf10.hostedemail.com (Postfix) with ESMTPA; Tue, 24 Apr 2018 11:54:19 +0000 (UTC) From: Shea Levy To: Palmer Dabbelt Cc: linux-riscv@lists.infradead.org, albert@sifive.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH] RISC-V: Load modules within relative jump range of the kernel text. In-Reply-To: References: Date: Tue, 24 Apr 2018 07:54:18 -0400 Message-ID: <87d0yoizv9.fsf@xps13.shealevy.com> MIME-Version: 1.0 Content-Type: multipart/signed; boundary="=-=-="; micalg=pgp-sha256; protocol="application/pgp-signature" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=-=-= Content-Type: text/plain Content-Transfer-Encoding: quoted-printable Hi Palmer, Palmer Dabbelt writes: > On Sun, 22 Apr 2018 05:53:56 PDT (-0700), shea@shealevy.com wrote: >> Hi Palmer, >> >> Shea Levy writes: >> >>> Signed-off-by: Shea Levy >>> --- >>> >>> Note that this patch worked in my old modules patchset and seems to be >>> working now, but my kernel boot locks up on top of >>> riscv-for-linus-4.17-mw0 and I don't know if it's due to this patch or >>> something else that's changed in the mean time. >>> >>> --- >>> arch/riscv/include/asm/pgtable.h | 9 +++++++++ >>> arch/riscv/kernel/module.c | 11 +++++++++++ >>> 2 files changed, 20 insertions(+) >>> >>> diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/= pgtable.h >>> index 16301966d65b..b08ded13364a 100644 >>> --- a/arch/riscv/include/asm/pgtable.h >>> +++ b/arch/riscv/include/asm/pgtable.h >>> @@ -25,6 +25,7 @@ >>> #include >>> #include >>> #include >>> +#include >>>=20=20 >>> #ifdef CONFIG_64BIT >>> #include >>> @@ -425,6 +426,14 @@ static inline void pgtable_cache_init(void) >>> #define TASK_SIZE VMALLOC_START >>> #endif >>>=20=20 >>> +/* >>> + * The module space lives between the addresses given by TASK_SIZE >>> + * and PAGE_OFFSET - it must be within 2G of the kernel text. >>> + */ >>> +#define MODULES_SIZE (SZ_128M) >>> +#define MODULES_VADDR (PAGE_OFFSET - MODULES_SIZE) >>> +#define MODULES_END (VMALLOC_END) >>> + >>> #include >>>=20=20 >>> #endif /* !__ASSEMBLY__ */ >>> diff --git a/arch/riscv/kernel/module.c b/arch/riscv/kernel/module.c >>> index 5dddba301d0a..1b382c7de095 100644 >>> --- a/arch/riscv/kernel/module.c >>> +++ b/arch/riscv/kernel/module.c >>> @@ -16,6 +16,8 @@ >>> #include >>> #include >>> #include >>> +#include >>> +#include >>>=20=20 >>> static int apply_r_riscv_64_rela(struct module *me, u32 *location, Elf= _Addr v) >>> { >>> @@ -382,3 +384,12 @@ int apply_relocate_add(Elf_Shdr *sechdrs, const ch= ar *strtab, >>>=20=20 >>> return 0; >>> } >>> + >>> +void *module_alloc(unsigned long size) >>> +{ >>> + return __vmalloc_node_range(size, 1, MODULES_VADDR, >>> + MODULES_END, GFP_KERNEL, >>> + PAGE_KERNEL_EXEC, 0, >>> + NUMA_NO_NODE, >>> + __builtin_return_address(0)); >>> +} >>> --=20 >>> 2.16.2 >> >> Any thoughts on this? > > The concept looks good, but does this actually keep the modules within 2G= iB of=20 > the text if PAGE_OFFSET is large? It's been some time since I wrote this, but I thought PAGE_OFFSET was where the kernel text *started*? So unless the text itself is bigger than 2G - 128 M, in which case we're SOL anyway, it seems like this should work. Is there something better we can do, without a large memory model? Thanks, Shea --=-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAEBCAAdFiEE6ESKvwKkwnxgMLnaXAvWlX2G/icFAlrfGuoACgkQXAvWlX2G /idBZxAA0NWUguvJC61Y4lCB7jT7jOnPkcZD/AC0w8nFCBdRN0r6gmIyxUO1tZ23 ufrdQESHOBdR+wKtrLRWqCX7cQ3djWspT6SkMapMGYhHKwzDYV4XmscfWdLqV7iV M2paC8L2+4U6GLApFodG9sC71C1CvPjVDyApC2NqUGlDkwu/q+1CxsHhMbSE85L4 fuSWTXPGV0k85Ne5pwE8a8V0lguXiDcUbxEsF/b0MLypAQSgvT+NEHabHjh+QVzO GVWBa8CvGe1o2cJSQRmOfCnIgU0P7DCOqLut7XUQDYYSsT2IbjSDt8+vMIpsp1+A VivzBoO8Hwd9YqLw06fwSR1Rnx2naOE4s5vl0LTIm5n/TaBXqKsoU5FOhrD1KUCK vNYF2hBHnwMUnEjjymAs8zwu6OQ1/j6AcKDqc33tiL7+SvLMYl7TSzrud7f+znkJ vKOKLRri+Qd3Dsb2uNYPdXkA2YmBfr24svM0U6nGJtZhJNLJP0PhmwekR29Eho0n QndPqHEbFVw+2SUCpAsAXOgppe5Gy//pEV0DN+AA9bAoqKVUNC56T3A4siDiC3Xe CWvHr25rl1JzoUosZIMKf0HP0wmAUWqJJn+sxIJgFSO6DLSCEu94eOw5nR6cRlGy UhEa+6hXnmOWmdP+W0ewSeRW0u3C4JqviyDSXAds86D8pMbblb0= =VMpJ -----END PGP SIGNATURE----- --=-=-=--