Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp6606343pxb; Wed, 17 Feb 2021 08:39:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJysRnb16FcTg8j8ecfoYzV2tfAzbfoMeZrQ7GAGQ+W3FwkBcz/3rE9jN07nRHmvxjxv6wyW X-Received: by 2002:a17:907:20f2:: with SMTP id rh18mr26814701ejb.350.1613579958423; Wed, 17 Feb 2021 08:39:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613579958; cv=none; d=google.com; s=arc-20160816; b=XhDdQyGsKrfnnKE5mct8q4YQsJryhogbidUUCwhLCty/kwjyw62UKhuqKKBRWQuZsd pPJO8ZzdXNVLAV3V1kgdnR0ilKtKZ9Br2lsjm03Ik2WJUD6BooHxE37QQ/43LiU+15F5 SIXqeOqxBljWg0CcpgPwYpvx5x62tdW4PZBvMd3yTUdpTbdQVHzp4vtFrUANS1BA6LrT /XK6HZJH7zVNzW1As1nhT8zf+6c4LMtHkCtDVYLY7cEMlSCeMX1Eyr2HClasCh72zRUq UHXOCIwEORxT16rAOy6EOcVA/zAG6wOejUSs4sawG3CxLTaB0NQtAvT+kXDgGqrKxaPK UBIg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=+HDFo6+6pv6arGtABmy02j+YNyprBo8mkAgVf9fCcUo=; b=fzcWikZQIWXs6iMI0KSy2gWzDi3bzSTcR9hR8xZ0qa6ZdqHmgvIlj98D3hDdBAaFOd PIpWtib5mxYgBsOrZVz+Si0yH+6pdjEMhn5e01G7OaXq2xS2FxsfF8VPl0/ANZa+TKt1 wDN7f/+0t3UNmHfyno6Pru6XUFT13GGMfE0TU8WW0hvkTJ5yCoAxL96A2fCEaLRb4k8Z EWDMaZc0gstmi0xeU3iffbN9m5dHVDWMRf2E3p1mWHAz/5J6frNhWmpWaDM0XBzmJ0Cm Cf7e7QHgbh/PnZQ79OOkz0yzawHLLX4+Eb41NxfEfUU3PH4/j0UW/COsSeNHt+L++yZ4 tqWA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id kd11si1851391ejc.396.2021.02.17.08.38.53; Wed, 17 Feb 2021 08:39:18 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234209AbhBQQhg (ORCPT + 99 others); Wed, 17 Feb 2021 11:37:36 -0500 Received: from relay5-d.mail.gandi.net ([217.70.183.197]:48973 "EHLO relay5-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234227AbhBQQhf (ORCPT ); Wed, 17 Feb 2021 11:37:35 -0500 X-Originating-IP: 2.7.49.219 Received: from [192.168.1.12] (lfbn-lyo-1-457-219.w2-7.abo.wanadoo.fr [2.7.49.219]) (Authenticated sender: alex@ghiti.fr) by relay5-d.mail.gandi.net (Postfix) with ESMTPSA id 62D241C0004; Wed, 17 Feb 2021 16:36:40 +0000 (UTC) Subject: Re: riscv+KASAN does not boot To: Dmitry Vyukov Cc: Albert Ou , Bjorn Topel , Palmer Dabbelt , LKML , nylon7@andestech.com, syzkaller , Andreas Schwab , Paul Walmsley , Tobias Klauser , linux-riscv References: <20210118145310.crnqnh6kax5jqicj@distanz.ch> <6e9ee3a1-0e16-b1fc-a690-f1ca8e9823a5@ghiti.fr> <24857bfc-c557-f141-8ae7-2e3da24f67f5@ghiti.fr> From: Alex Ghiti Message-ID: <957f09fb-84f4-2e0a-13ab-f7e4831ee7d0@ghiti.fr> Date: Wed, 17 Feb 2021 11:36:40 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 2/16/21 à 11:42 PM, Dmitry Vyukov a écrit : > On Tue, Feb 16, 2021 at 9:42 PM Alex Ghiti wrote: >> >> Hi Dmitry, >> >> Le 2/16/21 à 6:25 AM, Dmitry Vyukov a écrit : >>> On Tue, Feb 16, 2021 at 12:17 PM Dmitry Vyukov wrote: >>>> >>>> On Fri, Jan 29, 2021 at 9:11 AM Dmitry Vyukov wrote: >>>>>> I was fixing KASAN support for my sv48 patchset so I took a look at your >>>>>> issue: I built a kernel on top of the branch riscv/fixes using >>>>>> https://github.com/google/syzkaller/blob/269d24e857a757d09a898086a2fa6fa5d827c3e1/dashboard/config/linux/upstream-riscv64-kasan.config >>>>>> and Buildroot 2020.11. I have the warnings regarding the use of >>>>>> __virt_to_phys on wrong addresses (but that's normal since this function >>>>>> is used in virt_addr_valid) but not the segfaults you describe. >>>>> >>>>> Hi Alex, >>>>> >>>>> Let me try to rebuild buildroot image. Maybe there was something wrong >>>>> with my build, though, I did 'make clean' before doing. But at the >>>>> same time it worked back in June... >>>>> >>>>> Re WARNINGs, they indicate kernel bugs. I am working on setting up a >>>>> syzbot instance on riscv. If there a WARNING during boot then the >>>>> kernel will be marked as broken. No further testing will happen. >>>>> Is it a mis-use of WARN_ON? If so, could anybody please remove it or >>>>> replace it with pr_err. >>>> >>>> >>>> Hi, >>>> >>>> I've localized one issue with riscv/KASAN: >>>> KASAN breaks VDSO and that's I think the root cause of weird faults I >>>> saw earlier. The following patch fixes it. >>>> Could somebody please upstream this fix? I don't know how to add/run >>>> tests for this. >>>> Thanks >>>> >>>> diff --git a/arch/riscv/kernel/vdso/Makefile b/arch/riscv/kernel/vdso/Makefile >>>> index 0cfd6da784f84..cf3a383c1799d 100644 >>>> --- a/arch/riscv/kernel/vdso/Makefile >>>> +++ b/arch/riscv/kernel/vdso/Makefile >>>> @@ -35,6 +35,7 @@ CFLAGS_REMOVE_vgettimeofday.o = $(CC_FLAGS_FTRACE) -Os >>>> # Disable gcov profiling for VDSO code >>>> GCOV_PROFILE := n >>>> KCOV_INSTRUMENT := n >>>> +KASAN_SANITIZE := n >>>> >>>> # Force dependency >>>> $(obj)/vdso.o: $(obj)/vdso.so >> >> What's weird is that I don't have any issue without this patch with the >> following config whereas it indeed seems required for KASAN. But when >> looking at the segfaults you got earlier, the segfault address is 0xbb0 >> and the cause is an instruction page fault: this address is the PLT base >> address in vdso.so and an instruction page fault would mean that someone >> tried to jump at this address, which is weird. At first sight, that does >> not seem related to your patch above, but clearly I may be wrong. >> >> Tobias, did you observe the same segfaults as Dmitry ? > > > I noticed that not all buildroot images use VDSO, it seems to be > dependent on libc settings (at least I think I changed it in the > past). Ok, I used uClibc but then when using glibc, I have the same segfaults, only when KASAN is enabled. And your patch fixes the problem. I will try to take a look later to better understand the problem. > I also booted an image completely successfully including dhcpd/sshd > start, but then my executable crashed in clock_gettime. The executable > was build on linux/amd64 host with "riscv64-linux-gnu-gcc -static" > (10.2.1). > > >>> Second issue I am seeing seems to be related to text segment size. >>> I check out v5.11 and use this config: >>> https://gist.github.com/dvyukov/6af25474d455437577a84213b0cc9178 >> >> This config gave my laptop a hard time ! Finally I was able to boot >> correctly to userspace, but I realized I used my sv48 branch...Either I >> fixed your issue along the way or I can't reproduce it, I'll give it a >> try tomorrow. > > Where is your branch? I could also test in my setup on your branch. > You can find my branch int/alex/riscv_kernel_end_of_address_space_v2 here: https://github.com/AlexGhiti/riscv-linux.git Thanks, > >>> Then trying to boot it using: >>> QEMU emulator version 5.2.0 (Debian 1:5.2+dfsg-3) >>> $ qemu-system-riscv64 -machine virt -smp 2 -m 4G ... >>> >>> It shows no output from the kernel whatsoever, even though I have >>> earlycon and output shows very early with other configs. >>> Kernel boots fine with defconfig and other smaller configs. >>> >>> If I enable KASAN_OUTLINE and CC_OPTIMIZE_FOR_SIZE, then this config >>> also boots fine. Both of these options significantly reduce kernel >>> size. However, I can also boot the kernel without these 2 configs, if >>> I disable a whole lot of subsystem configs. This makes me think that >>> there is an issue related to kernel size somewhere in >>> qemu/bootloader/kernel bootstrap code. >>> Does it make sense to you? Can somebody reproduce what I am seeing? > >> >> I did not bring any answer to your question, but at least you know I'm >> working on it, I'll keep you posted. >> >> Thanks for taking the time to setup syzkaller. >> >> Alex >> >>> Thanks >>> >>> _______________________________________________ >>> linux-riscv mailing list >>> linux-riscv@lists.infradead.org >>> http://lists.infradead.org/mailman/listinfo/linux-riscv >>> > > _______________________________________________ > linux-riscv mailing list > linux-riscv@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-riscv >