Received: by 2002:ab2:3350:0:b0:1f4:6588:b3a7 with SMTP id o16csp1938159lqe; Tue, 9 Apr 2024 05:21:32 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXFV5CPR5m/0utlSAxIwyViFGYveYuAlmn4Q8Swm3KzY0aMJk/C6SQZWhvFCCtXF7EPSiHvwBdyZmSh4hjihjTnpYPul4gK25mnwcWruw== X-Google-Smtp-Source: AGHT+IHUnI7BRvIq9gBv8Ndp88j0LWCT5xuDdRBy7zGMUkRA2SK0OXC2+J/hROBEOFDA/FPSugs3 X-Received: by 2002:a17:902:eccf:b0:1e2:a91c:9836 with SMTP id a15-20020a170902eccf00b001e2a91c9836mr13614094plh.33.1712665292286; Tue, 09 Apr 2024 05:21:32 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712665292; cv=pass; d=google.com; s=arc-20160816; b=s9eHlmpkZhBAz2fGdH754BzeBQFjWROVJqZXNzMlIVO27HmxBLfIp23qas1OkITmYW 9W7UrcOC8Qh9qykdcm8hcFjV0frwg7EgbnFh13TeX3apiTVsNreXd4DnHAD3SppyQeqf FQQhFGQHkJBRLoWtyY1U1yph+MAUievANJ1yCoVdkWa1uC0VJjw805Xjd9qwrkr4Q9ka QIVM7ylEADZQU96MRpI4UW7epCggZz5HuZJqGOaPpx1SJ6a9TDLkhpz6w2GmfD6IhfgN Gj+vDzmjBSzMqIfmYGyAzB30KxH9hY21A4hcs1kKnBQaFZaG/3m3sRAR2rSs3BWsm6wk MKAg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:from:subject:user-agent :mime-version:list-unsubscribe:list-subscribe:list-id:precedence :date:message-id:dkim-signature; bh=yHluCbH+Y4mvtj/fpytANH7A8mHkCJCLpNilx8K/sOI=; fh=1zCjqSKJmIxA3PWeOczi5au1ZWlULGJEYcu37YC/xUA=; b=dvT60gC5QGuQcI2GdaN+NxUyC0NbSFo/A8jpJJHR/K7bYVwZO3kD/EhK2mQx77Pd57 x22WEqbLu44QNAKJa91XWKjExmUVmSFqPRvWVJwTY00ByOm1wbiWGyD2LCcZBGehUs4/ yEHK/c+P5QOcA+gXuPjax+3iPjOY1moxVhTPvt8qcBipOVU7J7CsXYn9vKc/Lc37n9Rn D8xAaQu0GoUlzeo+uxJRGwZdyVXvU93wAYIVVv3D7uB3H+l0py+szF0tvuY8cw25ui/g +l0QvuUvqCEz9uuwqEfujGuYDpd2vmcTreIrHL99IZQaUactoZgYmGIm0eeMMBj8c3YJ Ei/A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=dZo8aTjl; arc=pass (i=1 spf=pass spfdomain=redhat.com dkim=pass dkdomain=redhat.com dmarc=pass fromdomain=redhat.com); spf=pass (google.com: domain of linux-kernel+bounces-136811-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-136811-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id d18-20020a170903209200b001e29dd9fd8esi7945367plc.265.2024.04.09.05.21.31 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 09 Apr 2024 05:21:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-136811-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=dZo8aTjl; arc=pass (i=1 spf=pass spfdomain=redhat.com dkim=pass dkdomain=redhat.com dmarc=pass fromdomain=redhat.com); spf=pass (google.com: domain of linux-kernel+bounces-136811-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-136811-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 4890BB22F7B for ; Tue, 9 Apr 2024 11:51:53 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 2CCD6129E6B; Tue, 9 Apr 2024 11:51:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="dZo8aTjl" Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DF3111EB46 for ; Tue, 9 Apr 2024 11:51:44 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=170.10.133.124 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712663506; cv=none; b=DMRwepQq0xdZ4yk8JrVnxexLLPFpvJPe6fMoEndS3bevpHh4H2XaNF1vTQb+otFZ3skWXXtbZLQbVRHbBWJrsG+mPMoTQDWqDoBKoRFrn0eK9ZPk5E/Xaj6MX9kDyJYlD26Ekf0+IViZaOoObwOCpzpL7w7rkTCR4nBCCn0QAEU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712663506; c=relaxed/simple; bh=IzzZL6bnEiczxvB63ldbyzTFH0H1zPjxpP/c3wQnHSA=; h=Message-ID:Date:MIME-Version:Subject:From:To:Cc:References: In-Reply-To:Content-Type; b=JFq+OtmFBWbQFnTsJIY6ZmdJH7HX+dwWHGfMcKOfSQolG7eXd1jHjk51kiF1tmzxuU/UrmZQwOl7MVvtmeBOo9QLjVbwijCBz1C0U6iHFYepUcSKMGh1EMSVeoG2ZcuU9A4BAYnJlbAjUj+R9gj2syvr/BpsA47eMqidB4zb4Sc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com; spf=pass smtp.mailfrom=redhat.com; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b=dZo8aTjl; arc=none smtp.client-ip=170.10.133.124 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1712663503; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:autocrypt:autocrypt; bh=yHluCbH+Y4mvtj/fpytANH7A8mHkCJCLpNilx8K/sOI=; b=dZo8aTjlJRb9OhGnJuZ9zu3LDHf+vbP/tKVyK1jpldy7eMuta4zyY1V/tIPW6a/JEjiYev eOMNcr7xhwF3nCsMiwXPSJbne2A7z2axwzZtS0bXxXV1VHHv/cq6yHqjeg58XUf7mNoYLs Mx+/MuyD8gcbSQVY0dDV20E+7x3uzMA= Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-480-Wv6iifWmN0GBhpHT2MT96g-1; Tue, 09 Apr 2024 07:51:42 -0400 X-MC-Unique: Wv6iifWmN0GBhpHT2MT96g-1 Received: by mail-wm1-f72.google.com with SMTP id 5b1f17b1804b1-4154f2b314cso24824465e9.3 for ; Tue, 09 Apr 2024 04:51:42 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1712663501; x=1713268301; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:from:subject:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=yHluCbH+Y4mvtj/fpytANH7A8mHkCJCLpNilx8K/sOI=; b=cKFt8nK1wWS69sLiOGqfzyYzB4yOILMA1BOfR5YL7G8IVxJd208PmQHe4zoOAzwiUK x7uFDTIEXwzcyRG5LrIVcaImjJLODXfjBhoqaYQ5eq6nqiY2q3qfmCdJhpRB/rotGqiC j1eUX/FubWgswxqygMoMenUo4g5iUEd9MzyqY4XrOFtQO+znhmCLTSif+eMJyXPM9gnl XYDvmyMTRhyK6Dd0hjLL8xfDoQ6XXEJdeOYLWz234HqGPL47goWY1oxuKVSgf9c66TTD Jk97cjOJuoK+8wa4boIvJm8JADejRnPPF72iKQhdHpfDPtXEFOJtGf7EQAtNEA5J84ZP pXag== X-Forwarded-Encrypted: i=1; AJvYcCXKyQ0frMknKF/fLJXI5LPKJ1r/RjjrAtVlvF4o6Za1/s79YS6jwb1vFdyotcknhAiumy2RLGE04CrOO8mTmWJSuHdOg0kqxyG9ml90 X-Gm-Message-State: AOJu0YyN3ElyVuSyoOPBqLWHDSMB/78IwawmItihcApKDI1JeqF1NvGV NK63XQF+XszvX4jLRIS+e3NZQvWSUVxbmr5REHtQoqvP3zE06BfOaV1y0tKQdquEfoUDkbgVNNk GeO3GCbTc6SgXi64E/1JhUk6d5mKonSDiyrdf8IQTbO5cCDbjoszN6y3pBVku4A== X-Received: by 2002:a05:600c:46c7:b0:416:8d61:7c91 with SMTP id q7-20020a05600c46c700b004168d617c91mr2639775wmo.10.1712663501026; Tue, 09 Apr 2024 04:51:41 -0700 (PDT) X-Received: by 2002:a05:600c:46c7:b0:416:8d61:7c91 with SMTP id q7-20020a05600c46c700b004168d617c91mr2639750wmo.10.1712663500517; Tue, 09 Apr 2024 04:51:40 -0700 (PDT) Received: from ?IPV6:2003:cb:c70a:be00:a285:bc76:307d:4eaa? (p200300cbc70abe00a285bc76307d4eaa.dip0.t-ipconnect.de. [2003:cb:c70a:be00:a285:bc76:307d:4eaa]) by smtp.gmail.com with ESMTPSA id w15-20020a05600c474f00b0041668770f37sm8066896wmo.17.2024.04.09.04.51.39 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 09 Apr 2024 04:51:39 -0700 (PDT) Message-ID: Date: Tue, 9 Apr 2024 13:51:38 +0200 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v2 0/4] Speed up boot with faster linear map creation From: David Hildenbrand To: Itaru Kitayama , Ryan Roberts Cc: Catalin Marinas , Will Deacon , Mark Rutland , Ard Biesheuvel , Donald Dutile , Eric Chanudet , Linux ARM , "linux-kernel@vger.kernel.org" References: <20240404143308.2224141-1-ryan.roberts@arm.com> <533adb77-8c2b-40db-84cb-88de77ab92bb@arm.com> <1d5abb48-08a8-4d83-a681-6915bc7b6907@arm.com> <268FBD1C-B102-4726-A7F4-1125123BDA7A@linux.dev> <5e4dc2fe-2945-4fc5-a533-c8b2d04668a0@redhat.com> Content-Language: en-US Autocrypt: addr=david@redhat.com; keydata= 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 WNyWQQ== Organization: Red Hat In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 09.04.24 13:29, David Hildenbrand wrote: > On 09.04.24 13:22, David Hildenbrand wrote: >> On 09.04.24 12:13, Itaru Kitayama wrote: >>> >>> >>>> On Apr 9, 2024, at 19:04, Ryan Roberts wrote: >>>> >>>> On 09/04/2024 01:10, Itaru Kitayama wrote: >>>>> Hi Ryan, >>>>> >>>>>> On Apr 8, 2024, at 16:30, Ryan Roberts wrote: >>>>>> >>>>>> On 06/04/2024 11:31, Itaru Kitayama wrote: >>>>>>> Hi Ryan, >>>>>>> >>>>>>> On Sat, Apr 06, 2024 at 09:32:34AM +0100, Ryan Roberts wrote: >>>>>>>> Hi Itaru, >>>>>>>> >>>>>>>> On 05/04/2024 08:39, Itaru Kitayama wrote: >>>>>>>>> On Thu, Apr 04, 2024 at 03:33:04PM +0100, Ryan Roberts wrote: >>>>>>>>>> Hi All, >>>>>>>>>> >>>>>>>>>> It turns out that creating the linear map can take a significant proportion of >>>>>>>>>> the total boot time, especially when rodata=full. And most of the time is spent >>>>>>>>>> waiting on superfluous tlb invalidation and memory barriers. This series reworks >>>>>>>>>> the kernel pgtable generation code to significantly reduce the number of those >>>>>>>>>> TLBIs, ISBs and DSBs. See each patch for details. >>>>>>>>>> >>>>>>>>>> The below shows the execution time of map_mem() across a couple of different >>>>>>>>>> systems with different RAM configurations. We measure after applying each patch >>>>>>>>>> and show the improvement relative to base (v6.9-rc2): >>>>>>>>>> >>>>>>>>>> | Apple M2 VM | Ampere Altra| Ampere Altra| Ampere Altra >>>>>>>>>> | VM, 16G | VM, 64G | VM, 256G | Metal, 512G >>>>>>>>>> ---------------|-------------|-------------|-------------|------------- >>>>>>>>>> | ms (%) | ms (%) | ms (%) | ms (%) >>>>>>>>>> ---------------|-------------|-------------|-------------|------------- >>>>>>>>>> base | 153 (0%) | 2227 (0%) | 8798 (0%) | 17442 (0%) >>>>>>>>>> no-cont-remap | 77 (-49%) | 431 (-81%) | 1727 (-80%) | 3796 (-78%) >>>>>>>>>> batch-barriers | 13 (-92%) | 162 (-93%) | 655 (-93%) | 1656 (-91%) >>>>>>>>>> no-alloc-remap | 11 (-93%) | 109 (-95%) | 449 (-95%) | 1257 (-93%) >>>>>>>>>> lazy-unmap | 6 (-96%) | 61 (-97%) | 257 (-97%) | 838 (-95%) >>>>>>>>>> >>>>>>>>>> This series applies on top of v6.9-rc2. All mm selftests pass. I've compile and >>>>>>>>>> boot tested various PAGE_SIZE and VA size configs. >>>>>>>>>> >>>>>>>>>> --- >>>>>>>>>> >>>>>>>>>> Changes since v1 [1] >>>>>>>>>> ==================== >>>>>>>>>> >>>>>>>>>> - Added Tested-by tags (thanks to Eric and Itaru) >>>>>>>>>> - Renamed ___set_pte() -> __set_pte_nosync() (per Ard) >>>>>>>>>> - Reordered patches (biggest impact & least controversial first) >>>>>>>>>> - Reordered alloc/map/unmap functions in mmu.c to aid reader >>>>>>>>>> - pte_clear() -> __pte_clear() in clear_fixmap_nosync() >>>>>>>>>> - Reverted generic p4d_index() which caused x86 build error. Replaced with >>>>>>>>>> unconditional p4d_index() define under arm64. >>>>>>>>>> >>>>>>>>>> >>>>>>>>>> [1] https://lore.kernel.org/linux-arm-kernel/20240326101448.3453626-1-ryan.roberts@arm.com/ >>>>>>>>>> >>>>>>>>>> Thanks, >>>>>>>>>> Ryan >>>>>>>>>> >>>>>>>>>> >>>>>>>>>> Ryan Roberts (4): >>>>>>>>>> arm64: mm: Don't remap pgtables per-cont(pte|pmd) block >>>>>>>>>> arm64: mm: Batch dsb and isb when populating pgtables >>>>>>>>>> arm64: mm: Don't remap pgtables for allocate vs populate >>>>>>>>>> arm64: mm: Lazily clear pte table mappings from fixmap >>>>>>>>>> >>>>>>>>>> arch/arm64/include/asm/fixmap.h | 5 +- >>>>>>>>>> arch/arm64/include/asm/mmu.h | 8 + >>>>>>>>>> arch/arm64/include/asm/pgtable.h | 13 +- >>>>>>>>>> arch/arm64/kernel/cpufeature.c | 10 +- >>>>>>>>>> arch/arm64/mm/fixmap.c | 11 + >>>>>>>>>> arch/arm64/mm/mmu.c | 377 +++++++++++++++++++++++-------- >>>>>>>>>> 6 files changed, 319 insertions(+), 105 deletions(-) >>>>>>>>>> >>>>>>>>>> -- >>>>>>>>>> 2.25.1 >>>>>>>>>> >>>>>>>>> >>>>>>>>> I've build and boot tested the v2 on FVP, base is taken from your >>>>>>>>> linux-rr repo. Running run_vmtests.sh on v2 left some gup longterm not oks, would you take a look at it? The mm ksefltests used is from your linux-rr repo too. >>>>>>>> >>>>>>>> Thanks for taking a look at this. >>>>>>>> >>>>>>>> I can't reproduce your issue unfortunately; steps as follows on Apple M2 VM: >>>>>>>> >>>>>>>> Config: arm64 defconfig + the following: >>>>>>>> >>>>>>>> # Squashfs for snaps, xfs for large file folios. >>>>>>>> ./scripts/config --enable CONFIG_SQUASHFS_LZ4 >>>>>>>> ./scripts/config --enable CONFIG_SQUASHFS_LZO >>>>>>>> ./scripts/config --enable CONFIG_SQUASHFS_XZ >>>>>>>> ./scripts/config --enable CONFIG_SQUASHFS_ZSTD >>>>>>>> ./scripts/config --enable CONFIG_XFS_FS >>>>>>>> >>>>>>>> # For general mm debug. >>>>>>>> ./scripts/config --enable CONFIG_DEBUG_VM >>>>>>>> ./scripts/config --enable CONFIG_DEBUG_VM_MAPLE_TREE >>>>>>>> ./scripts/config --enable CONFIG_DEBUG_VM_RB >>>>>>>> ./scripts/config --enable CONFIG_DEBUG_VM_PGFLAGS >>>>>>>> ./scripts/config --enable CONFIG_DEBUG_VM_PGTABLE >>>>>>>> ./scripts/config --enable CONFIG_PAGE_TABLE_CHECK >>>>>>>> >>>>>>>> # For mm selftests. >>>>>>>> ./scripts/config --enable CONFIG_USERFAULTFD >>>>>>>> ./scripts/config --enable CONFIG_TEST_VMALLOC >>>>>>>> ./scripts/config --enable CONFIG_GUP_TEST >>>>>>>> >>>>>>>> Running on VM with 12G memory, split across 2 (emulated) NUMA nodes (needed by >>>>>>>> some mm selftests), with kernel command line to reserve hugetlbs and other >>>>>>>> features required by some mm selftests: >>>>>>>> >>>>>>>> " >>>>>>>> transparent_hugepage=madvise earlycon root=/dev/vda2 secretmem.enable >>>>>>>> hugepagesz=1G hugepages=0:2,1:2 hugepagesz=32M hugepages=0:2,1:2 >>>>>>>> default_hugepagesz=2M hugepages=0:64,1:64 hugepagesz=64K hugepages=0:2,1:2 >>>>>>>> " >>>>>>>> >>>>>>>> Ubuntu userspace running off XFS rootfs. Build and run mm selftests from same >>>>>>>> git tree. >>>>>>>> >>>>>>>> >>>>>>>> Although I don't think any of this config should make a difference to gup_longterm. >>>>>>>> >>>>>>>> Looks like your errors are all "ftruncate() failed". I've seen this problem on >>>>>>>> our CI system. There it is due to running the tests from NFS file system. What >>>>>>>> filesystem are you using? Perhaps you are sharing into the FVP using 9p? That >>>>>>>> might also be problematic. >>>>>>> >>>>>>> That was it. This time I booted up the kernel including your series on >>>>>>> QEMU on my M1 and executed the gup_longterm program without the ftruncate >>>>>>> failures. When testing your kernel on FVP, I was executing the script from the FVP's host filesystem using 9p. >>>>>> >>>>>> I'm not sure exactly what the root cause is. Perhaps there isn't enough space on >>>>>> the disk? It might be worth enhancing the error log to provide the errno in >>>>>> tools/testing/selftests/mm/gup_longterm.c. >>>>>> >>>>> >>>>> Attached is the straceā€™d gup_longterm executiong log on your >>>>> pgtable-boot-speedup-v2 kernel. >>>> >>>> Sorry are you saying that it only fails with the pgtable-boot-speedup-v2 patch >>>> set applied? I thought we previously concluded that it was independent of that? >>>> I was under the impression that it was filesystem related and not something that >>>> I was planning to investigate. >>> >>> No, irrespective of the kernel, if using 9p on FVP the test program fails. >>> It is indeed 9p filesystem related, as I switched to using NFS all the issues are gone. >> >> Did it never work on 9p? If so, we might have to SKIP that test. >> >> openat(AT_FDCWD, "gup_longterm.c_tmpfile_BLboOt", O_RDWR|O_CREAT|O_EXCL, 0600) = 3 >> unlinkat(AT_FDCWD, "gup_longterm.c_tmpfile_BLboOt", 0) = 0 >> fstatfs(3, 0xffffe505a840) = -1 EOPNOTSUPP (Operation not supported) >> ftruncate(3, 4096) = -1 ENOENT (No such file or directory) > > Note: I'm wondering if the unlinkat here is the problem that makes > ftruncate() with 9p result in weird errors (e.g., the hypervisor > unlinked the file and cannot reopen it for the fstatfs/ftruncate. ... > which gives us weird errors here). > > Then, we should lookup the fs type in run_with_local_tmpfile() before > the unlink() and simply skip the test if it is 9p. The unlink with 9p most certainly was a known issue in the past: https://gitlab.com/qemu-project/qemu/-/issues/103 Maybe it's still an issue with older hypervisors (QEMU?)? Or it was never completely resolved? According to https://bugs.launchpad.net/qemu/+bug/1336794, QEMU v5.2.0 should contain a fix that is supposed to work with never kernels. -- Cheers, David / dhildenb