Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp862201rwd; Thu, 18 May 2023 05:08:30 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ51LeQt4QgO+ER84CVdwKrK08jt+wVLjGhFvzWKDdZTgXZA6sbEbWzj+qvMS1v1zjJyy7qn X-Received: by 2002:a81:6109:0:b0:55a:1e:b4dd with SMTP id v9-20020a816109000000b0055a001eb4ddmr767387ywb.48.1684411710217; Thu, 18 May 2023 05:08:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684411710; cv=none; d=google.com; s=arc-20160816; b=JSq7v0UoFAOpE2X9Lib6vBRepCY/gViwCiQ7EIAtebi1ZvdDUmIwHOQnTzuIXFHFqz l+9rsYRtyDrfnPJOTfqBlwRxXzUIsHMKRwyvdHQCwoDXCRb8VxhKiyttx0NKBHvZd8cW nVcXSSioaZtPQNbqiicqpezDWzkl/gDgsiObrfupdkWNDfecsdxq6wFOcL7TcZnbyPrs SfMSWsERxYCGIdcu2uH12nUTr9b/M06wp8KGwq82l3JtfwzFrV41JY51Yky7+W2v38Nw RLPhRQuAbNDPODqc83hqJD4B8gIolsKNkJekMp1UiR6JEsmrEZXPQDqNTp+JdegGK4y3 O3IA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=a/ODccGbb1uH9T049hHCug/9Hyr+9/bpUSuqpLv3dLg=; b=g1d4dpMipessesbEVIOqHP+pwdAhvZ0z2RoXmVGCteQFBS4JLKSobMyqdy5OWNyDmj XGKJ/s5XkC82pkbRxN754ROfTQmiZUpcUCjp6VsxHdKyuaUKy8thHzfHT9mSSvwMFsRO nip7dUoOgimElR4cktPr5QviTslceCV6d3dGy9rQeC2fJmHzKSFS9QnPhaszUMQrhBa1 kDtVWfthn9Mt+D90eibwzgqcYn5sX4/YNk/PJkKm/stT8F0E+XrqZyq2v8fVwLEwGlNH MwknE/zpe3ps/HJ2mFhcc1f1UO1UJ+iG/Zzn9SlAJqhF8hBboLpyFItuGwOYnuB2L4w8 4jlA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=Sr7RmWJK; 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 z187-20020a8165c4000000b0055a077c0cfesi752719ywb.205.2023.05.18.05.08.14; Thu, 18 May 2023 05:08:30 -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; dkim=pass header.i=@rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=Sr7RmWJK; 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 S231575AbjERLzU (ORCPT + 99 others); Thu, 18 May 2023 07:55:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47128 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231661AbjERLzF (ORCPT ); Thu, 18 May 2023 07:55:05 -0400 Received: from mail-wr1-x434.google.com (mail-wr1-x434.google.com [IPv6:2a00:1450:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 85864B4 for ; Thu, 18 May 2023 04:55:02 -0700 (PDT) Received: by mail-wr1-x434.google.com with SMTP id ffacd0b85a97d-3075e802738so1847648f8f.1 for ; Thu, 18 May 2023 04:55:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rivosinc-com.20221208.gappssmtp.com; s=20221208; t=1684410901; x=1687002901; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=a/ODccGbb1uH9T049hHCug/9Hyr+9/bpUSuqpLv3dLg=; b=Sr7RmWJKegGRqhyEBx/AePX9VxqJPVyZFwuwn8eNk/V8rSczZ+4ZjMMGE7dR4mhAqQ Ef8vgN3lkdbEjOE9yejwdELvh/Ng9XT9ocfvC4hgUUVAF6nUipuMxDzUbJFk+ieDdoGN k+KOyWr5JcqMCis2Blk/kdZ2SBmJxtR0wtWvZaaxRP9pWct29t+Nxl35E23NjgZ6ighv DVcLmfFdQl1HLHyH2UORFzffM1XNs7WzQcrQlDDLkfdgh49PPBqrp/eTtWIqZPxsoOpv 9Ud2T3j4EQWUAqOJrVUCNXasN+FmtkWLWyHploStk4LIpsf9Wg4Qqa4jGdVzqH0L6fit hHhA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1684410901; x=1687002901; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=a/ODccGbb1uH9T049hHCug/9Hyr+9/bpUSuqpLv3dLg=; b=bt8975N1I4Z2Bh0OfVtXzMFaIh56zX5G2yWgkrGU6E5CMdNh7h7k0KARJ5PVQ6J4/D tzXTZHP3PHk6hhnJYVYd9jtrispwMS7dLhQFLVALEe1R4aJY7UU1bqXmbNTCj7ZqvvHC JjahMXKO+YHSnOfD4QTbTBLo8SNbGGFmD8ernNjDAfxB8q/jpbHVGPV9snlDjTjf0nyl FNpj6fkv5w/pM3fc2lIZWklY3YVlIJIqdOz44kTBWWd3YFJgPvHXW7C539HoN+QyOIfh mY8MOs+vx0kqEx/ghSlogaegcZ8EMqUI2/J16dxCg50X8/MUEEG9UE1OdxaEYmpBy1zM wvHA== X-Gm-Message-State: AC+VfDwRkY+aUSak12k9pRlHQPKYLSR+g1bdc7T80zHv/Likm4yrmdkm +cLTXjmfks0ucijD0r9K8H8hPpUSqiSdZ01zgvJUDQ== X-Received: by 2002:a5d:6b09:0:b0:306:343a:aede with SMTP id v9-20020a5d6b09000000b00306343aaedemr1231534wrw.65.1684410900949; Thu, 18 May 2023 04:55:00 -0700 (PDT) MIME-Version: 1.0 References: In-Reply-To: From: Alexandre Ghiti Date: Thu, 18 May 2023 13:54:50 +0200 Message-ID: Subject: Re: Bug report: kernel paniced when system hibernates To: Song Shuai Cc: Rob Herring , Andrew Jones , Anup Patel , Palmer Dabbelt , Sia Jee Heng , Leyfoon Tan , Mason Huo , Paul Walmsley , Guo Ren , linux-riscv , Linux Kernel Mailing List , Conor Dooley Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,RCVD_IN_DNSWL_NONE,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 On Thu, May 18, 2023 at 5:30=E2=80=AFAM Song Shuai = wrote: > > Alexandre Ghiti =E4=BA=8E2023=E5=B9=B45=E6=9C=88= 17=E6=97=A5=E5=91=A8=E4=B8=89 14:42=E5=86=99=E9=81=93=EF=BC=9A > > > > Sorry, pressed "reply" instead of "reply all"... > > > > ---------- Forwarded message --------- > > From: Alexandre Ghiti > > Date: Wed, May 17, 2023 at 4:40=E2=80=AFPM > > Subject: Re: Bug report: kernel paniced when system hibernates > > To: Song Shuai , Anup Patel > > , Atish Kumar Patra > > > > > > On Wed, May 17, 2023 at 1:05=E2=80=AFPM Song Shuai wrote: > > > > > > Alexandre Ghiti =E4=BA=8E2023=E5=B9=B45=E6= =9C=8817=E6=97=A5=E5=91=A8=E4=B8=89 08:58=E5=86=99=E9=81=93=EF=BC=9A > > > > > > > > On Tue, May 16, 2023 at 1:12=E2=80=AFPM Alexandre Ghiti wrote: > > > > > > > > > > Hi Song, > > > > > > > > > > On Tue, May 16, 2023 at 11:24=E2=80=AFAM Song Shuai wrote: > > > > > > > > > > > > Description of problem: > > > > > > > > > > > > The latest hibernation support[1] of RISC-V Linux produced a ke= rnel panic. > > > > > > The entire log has been posted at this link: https://termbin.co= m/sphl . > > > > > > > > > > > > How reproducible: > > > > > > > > > > > > You can reproduce it with the following step : > > > > > > > > > > > > 1. prepare the environment with > > > > > > - Qemu-virt v8.0.0 (with OpenSbi v1.2) > > > > > > - Linux v6.4-rc1 > > > > > > > > > > > > 2. start the Qemu virt > > > > > > ```sh > > > > > > $ cat ~/8_riscv/start_latest.sh > > > > > > #!/bin/bash > > > > > > /home/song/8_riscv/3_acpi/qemu/ooo/usr/local/bin/qemu-system-ri= scv64 \ > > > > > > -smp 2 -m 4G -nographic -machine virt \ > > > > > > -kernel /home/song/9_linux/linux/00_rv_test/arch/riscv/boot/Ima= ge \ > > > > > > -append "root=3D/dev/vda ro eaylycon=3Duart8250,mmio,0x10000000 > > > > > > early_ioremap_debug console=3DttyS0 loglevel=3D8 memblock=3Ddeb= ug > > > > > > no_console_suspend audit=3D0 3" \ > > > > > > -drive file=3D/home/song/8_riscv/fedora/stage4-disk.img,format= =3Draw,id=3Dhd0 \ > > > > > > -device virtio-blk-device,drive=3Dhd0 \ > > > > > > -drive file=3D/home/song/8_riscv/fedora/adisk.qcow2,format=3Dqc= ow2,id=3Dhd1 \ > > > > > > -device virtio-blk-device,drive=3Dhd1 \ > > > > > > -gdb tcp::1236 #-S > > > > > > ``` > > > > > > 3. execute hibernation > > > > > > > > > > > > ```sh > > > > > > swapon /dev/vdb2 # this is my swap disk > > > > > > > > > > > > echo disk > /sys/power/state > > > > > > ``` > > > > > > > > > > > > 4. Then you will encounter the kernel panic logged in the above= link > > > > > > > > > > > > > > > > > > Other Information: > > > > > > > > > > > > After my initial and incomplete dig-up, the commit (3335068f872= 1 > > > > > > "riscv: Use PUD/P4D/PGD pages for the linear mapping")[2] > > > > > > is closely related to this panic. This commit uses re-defined > > > > > > `MIN_MEMBLOCK_ADDR` to discover the entire system memory > > > > > > and extends the `va_pa_offset` from `kernel_map.phys_addr` to > > > > > > `phys_ram_base` for linear memory mapping. > > > > > > > > > > > > If the firmware delivered the firmware memory region (like: a P= MP > > > > > > protected region in OpenSbi) without "no-map" propriety, > > > > > > this commit will result in firmware memory being directly mappe= d by > > > > > > `create_linear_mapping_page_table()`. > > > > > > > > > > > > We can see the mapping via ptdump : > > > > > > ```c > > > > > > ---[ Linear mapping ]--- > > > > > > 0xff60000000000000-0xff60000000200000 0x0000000080000000 2M PMD= D A G > > > > > > . . W R V ------------- the firmware memory > > > > > > 0xff60000000200000-0xff60000000c00000 0x0000000080200000 10M PM= D D A G . . . R V > > > > > > 0xff60000000c00000-0xff60000001000000 0x0000000080c00000 4M PMD= D A G . . W R V > > > > > > 0xff60000001000000-0xff60000001600000 0x0000000081000000 6M PMD= D A G . . . R V > > > > > > 0xff60000001600000-0xff60000040000000 0x0000000081600000 1002M = PMD D A > > > > > > G . . W R V > > > > > > 0xff60000040000000-0xff60000100000000 0x00000000c0000000 3G PUD= D A G . . W R V > > > > > > ---[ Modules/BPF mapping ]--- > > > > > > ---[ Kernel mapping ]--- > > > > > > 0xffffffff80000000-0xffffffff80a00000 0x0000000080200000 10M PM= D D A G . X . R V > > > > > > 0xffffffff80a00000-0xffffffff80c00000 0x0000000080c00000 2M PMD= D A G . . . R V > > > > > > 0xffffffff80c00000-0xffffffff80e00000 0x0000000080e00000 2M PMD= D A G . . W R V > > > > > > 0xffffffff80e00000-0xffffffff81400000 0x0000000081000000 6M PMD= D A G . . . R V > > > > > > 0xffffffff81400000-0xffffffff81800000 0x0000000081600000 4M PMD > > > > > > ``` > > > > > > > > > > > > In the hibernation process, `swsusp_save()` calls > > > > > > `copy_data_pages(©_bm, &orig_bm)` to copy these two memory > > > > > > bitmaps, > > > > > > the Oops(load access fault) occurred while copying the page of > > > > > > PAGE_OFFSET (which maps the firmware memory). > > > > > > > > > > I'm not saying that the hibernation process is in fault here, but > > > > > that's weird that it is trying to access pages that are not avail= able > > > > > to the kernel: this region is mapped in the page table so that we= can > > > > > use a 1GB page, but it is reserved so that it is not added to the > > > > > kernel memory pool. > > > Yes, my fault, the Test2 is not a correct testcase. > > > > > > > > > > > > > > > > > I also did two other tests: > > > > > > Test1: > > > > > > > > > > > > The hibernation works well in the kernel with the commit 333506= 8f8721 > > > > > > reverted at least in the current environment. > > > > > > > > > > > > Test2: > > > > > > > > > > > > I built a simple kernel module to simulate the access of the va= lue of > > > > > > `PAGE_OFFSET` address, and the same panic occurred with the loa= d > > > > > > access fault. > > > > > > So hibernation seems not the only case to trigger this panic. > > > > > > > > > > > > Finally, should we always leave the firmware memory with > > > > > > `MEMBLOCK_NOMAP` flag by some efforts from Linux or OpenSbi (at= least > > > > > > in the current environment) or any other suggestions? > > > > > > > > > > > > > > > > I actually removed this flag a few years ago, and I have to admit= that > > > > > I need to check if that's necessary: the goal of commit 3335068f8= 721 > > > > > ("riscv: Use PUD/P4D/PGD pages for the linear mapping") is to exp= ose > > > > > the "right" start of DRAM so that we can align virtual and physic= al > > > > > addresses on a 1GB boundary. > > > > > > > > > > So I have to check if a nomap region is actually added as a > > > > > memblock.memory.regions[] or not: if yes, that's perfect, let's a= dd > > > > > the nomap attributes to the PMP regions, otherwise, I don't think= that > > > > > is a good solution. > > > > > > > > So here is the current linear mapping without nomap in openSBI: > > > > > > > > ---[ Linear mapping ]--- > > > > 0xff60000000000000-0xff60000000200000 0x0000000080000000 = 2M > > > > PMD D A G . . W R V > > > > 0xff60000000200000-0xff60000000e00000 0x0000000080200000 = 12M > > > > PMD D A G . . . R V > > > > > > > > And below the linear mapping with nomap in openSBI: > > > > > > > > ---[ Linear mapping ]--- > > > > 0xff60000000080000-0xff60000000200000 0x0000000080080000 15= 36K > > > > PTE D A G . . W R V > > > > 0xff60000000200000-0xff60000000e00000 0x0000000080200000 = 12M > > > > PMD D A G . . . R V > > > > > > > > So adding nomap does not misalign virtual and physical addresses, i= t > > > > prevents the usage of 1GB page for this area though, so that's a > > > > solution, we just lose this 1GB page here. > > > > > > > > But even though that may be the fix, I think we also need to fix th= at > > > > in the kernel as it would break compatibility with certain versions= of > > > > openSBI *if* we fix openSBI...So here are a few solutions: > > > > > > > > 1. we can mark all "mmode_resv" nodes in the device tree as nomap, > > > > before the linear mapping is established (IIUC, those nodes are add= ed > > > > by openSBI to advertise PMP regions) > > > > -> This amounts to the same fix as opensbi and we lose the 1GB = hugepage. > > > > 2. we can tweak pfn_is_nosave function to *not* save pfn correspond= ing > > > > to PMP regions > > > > -> We don't lose the 1GB hugepage \o/ > > > > 3. we can use register_nosave_region() to not save the "mmode_resv" > > > > regions (x86 does that > > > > https://elixir.bootlin.com/linux/v6.4-rc1/source/arch/x86/kernel/e8= 20.c#L753) > > > > -> We don't lose the 1GB hugepage \o/ > > > > 4. Given JeeHeng pointer to > > > > https://elixir.bootlin.com/linux/v6.4-rc1/source/kernel/power/snaps= hot.c#L1340, > > > > we can mark those pages as non-readable and make the hibernation > > > > process not save those pages > > > > -> Very late-in-the-day idea, not sure what it's worth, we also > > > > lose the 1GB hugepage... > > > > > > > > To me, the best solution is 3 as it would prepare for other similar > > > > issues later, it is similar to x86 and it allows us to keep 1GB > > > > hugepages. > > > > > > I agree, > > > register_nosave_region() is a good way in the early initialization to > > > set page frames (like the PMP regions) in forbidden_pages_map and mar= k > > > them as no-savable for hibernation. > > > > > > Look forward to your fixing. > > > > Please find below the patch in question, which worked for me, if you > > can give it a try. As mentioned by Conor, I'd like to make sure the > > mmode_resv "interface" is really what we need to use before > > upstreaming this fix @Anup Patel @Atish Kumar Patra > > > > diff --git a/arch/riscv/kernel/hibernate.c b/arch/riscv/kernel/hibernat= e.c > > index 264b2dcdd67e..9ad8bf5c956b 100644 > > --- a/arch/riscv/kernel/hibernate.c > > +++ b/arch/riscv/kernel/hibernate.c > > @@ -24,6 +24,8 @@ > > #include > > #include > > #include > > +#include > > +#include > > > > /* The logical cpu number we should resume on, initialised to a > > non-cpu number. */ > > static int sleep_cpu =3D -EINVAL; > > @@ -67,6 +69,45 @@ static void arch_hdr_invariants(struct > > arch_hibernate_hdr_invariants *i) > > memcpy(i->uts_version, init_utsname()->version, sizeof(i->uts_v= ersion)); > > } > > > > +void __init register_nosave_regions(void) > > +{ > > +#define MMODE_RESV "mmode_resv" > > + int node, child; > > + const void *fdt =3D initial_boot_params; > > + > > + node =3D fdt_path_offset(fdt, "/reserved-memory"); > > + if (node < 0) > > + return; > > + > > + fdt_for_each_subnode(child, fdt, node) { > > + phys_addr_t base, size; > > + const __be32 *prop; > > + const char *uname; > > + int len; > > + int t_len =3D (dt_root_addr_cells + dt_root_size_cells) > > * sizeof(__be32); > > + > > + uname =3D fdt_get_name(fdt, child, NULL); > > + > > + if (!uname || strncmp(uname, MMODE_RESV, > > sizeof(MMODE_RESV) - 1)) > > + continue; > > + > > + prop =3D of_get_flat_dt_prop(child, "reg", &len); > > + if (!prop) > > + continue; > > + > > + while (len >=3D t_len) { > > + base =3D dt_mem_next_cell(dt_root_addr_cells, &= prop); > > + size =3D dt_mem_next_cell(dt_root_size_cells, &= prop); > > + > > + if (size) > > + register_nosave_region(phys_to_pfn(base= ), > > + > > phys_to_pfn(base + size)); > > + > > + len -=3D t_len; > > + } > > + } > > +} > > + > > /* > > * Check if the given pfn is in the 'nosave' section. > > */ > > @@ -421,6 +462,8 @@ static int __init riscv_hibernate_init(void) > > if (WARN_ON(!hibernate_cpu_context)) > > return -ENOMEM; > > > > + register_nosave_regions(); > > + > > return 0; > > } > > > I encountered 2 (possible) problems in my test with the patch above. > The full log has been posted here : https://termbin.com/qp3x . > > First, a `WARN_ON_ONCE()` was triggered in `memblock_alloc_internal()` > when calling `register_nosave_regions()` although the `nosave_region` > was allocated successfully. > ``` > [ 0.112658] memblock_alloc_try_nid: 32 bytes align=3D0x40 nid=3D-1 > from=3D0x0000000000000000 max_addr=3D0x0000000000000000 > register_nosave_region+0x54/0xd4 > [ 0.113698] ------------[ cut here ]------------ > [ 0.114185] WARNING: CPU: 0 PID: 1 at mm/memblock.c:1517 > memblock_alloc_internal+0x34/0xb0\ > ... > ``` > The WARNING shows that slab is available at this time and > `memblock_alloc()` shouldn't be used here. > I think we should move the calling of `register_nosave_regions()` to > somewhere eariler at least before `memblock_free_all()` You're right, thanks! > > > Second, the resume process failed with a Memory map mismatch. > I didn't dig into it further and not sure it's this patch caused it > (we couldn't hibernate successfully before this patch, right?) > Just report it in this thread. > I'll dig into this one then. > ``` > [ 2.991958] PM: Loading image data pages (88091 pages)... > [ 2.995308] PM: Image loading progress: 0% > [ 3.005533] PM: hibernation: [Firmware Bug]: Memory map mismatch at > 0x0 after hibernation > [ 3.006343] PM: hibernation: Read 352364 kbytes in 0.01 seconds (35236.40= MB/s) > [ 3.007270] PM: hibernation: Failed to load image, recovering. > ``` Thanks for your thorough reports Song, it really helps a lot! > > > > > > > > I have been thinking, and to me nomap does not provide anything sin= ce > > > > the kernel should not address this memory range, so if it does, we > > > > must fix the kernel. > > > > > > > > Let me know what you all think, I'll be preparing a PoC of 3 in the= meantime! > > > > > > > > Alex > > > > > > > > > > > > > > > > > > > > > > And a last word: Mike Rapoport recently gave a speech [1] where h= e > > > > > states that mapping the linear mapping with hugepages does not gi= ve > > > > > rise to better performance so *maybe* reverting this commit may b= e a > > > > > solution too as it may not provide the expected benefits (even th= ough > > > > > I'd rather have it and another benefit of mapping the linear mapp= ing > > > > > with 1GB hugepages is that it is faster to boot, but that needs t= o be > > > > > measured). > > > > > > > > > > [1] https://lwn.net/Articles/931406/ > > > > > > > > > > > Please correct me if I'm wrong. > > > > > > > > > > > > [1]: https://lore.kernel.org/r/20230330064321.1008373-5-jeeheng= .sia@starfivetech.com > > > > > > [2]: https://lore.kernel.org/r/20230324155421.271544-4-alexghit= i@rivosinc.com > > > > > > > > > > > > -- > > > > > > Thanks, > > > > > > Song > > > > > > > > > > Thanks for the thorough report! > > > > > > > > > > Alex > > > > > > > > > > > > -- > > > Thanks, > > > Song > > > > -- > Thanks, > Song