Received: by 2002:a05:7412:cfc7:b0:fc:a2b0:25d7 with SMTP id by7csp1829932rdb; Tue, 20 Feb 2024 08:10:58 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCWhrRjUoY9UQ7SafbFRVkErVv72u+ADNhbG5RjmN0tx25HEzW6aPCFKjDqk+XzvTQJoP+OY48mmEI0Yg6mp12ds6MfyvkIlUTe0FS0s9A== X-Google-Smtp-Source: AGHT+IFQEeya4ItOduEXwTqtMXDdVwyYfgHBt1KlV1BY8uZH+lfTIxovNfmfvpMWC9IrJORN05kQ X-Received: by 2002:a17:902:c1d5:b0:1db:c1f7:35ac with SMTP id c21-20020a170902c1d500b001dbc1f735acmr8880194plc.45.1708445458440; Tue, 20 Feb 2024 08:10:58 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708445458; cv=pass; d=google.com; s=arc-20160816; b=m/8WxFabpehZeQr7TgAB4coe6i3yn9ZDyfGMlPeyb9gX8t4/X1R7KC4PzeMDviJq0b Dd2rAATuQJNQS4L1y0TPBJPryd2NLSwDPs313sMI74me2Ha8j61TFtPuWEJvqzoLGf03 B7b4QArg9XjXxeyAR8jpbt2ITvllfmdnHGIlKgSYtjcsXgv5DuilZL+K7fXjSZr3e587 QIXifOckV1QqmlMkgRV/jpt7aElDjrN27cA8Qq16MupTF151nn8UKh988au9s119up06 w92dwxKOfQnm2Y+iM8ds9n2XlhJG9jii+pUQNk8iB6iTXbqJnIEM8bvCFuhHqmm0XyHd Ilnw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date; bh=x0aGAmYxxRfRThGc7f2rGLmlxEY3DA7SVM1HuwdZ8mI=; fh=wDMvF1eFl7NpEObARKvBUKTmbBPuekn8l/agkXpdb/Q=; b=ACZjL5iwVJxYY43NtLJ17/dBPLewPGgx15NRbZnnkrGsTdzAL0jw+Zpar3Va3jhFLv +a9rl9v3yQfRHs3lQ9Hw8Ouzw7q58eAbLy0tCr1yLLtEuwNkaStxsiThez6SncjmlNg4 5nNXVhAPZU3Z+YGDFreWBoKz1HE3ACHGddPy+3y+HAQeU4kI9w2j235NaLFMhe01IurA RumwtwmV67Ytxk7VpX0q1PIrXsU9Hy+QqFbFfn8gieo74BhxYp0bSWpa52Z5wIR6AY4B T/xtSw0fSEReq8sdM2Ax09XghB/CudeF7ebwyCb88jeJ7TtyTps4geMlYBqtgRlWSu/S JYfA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-73301-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-73301-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.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 n19-20020a637213000000b005dc7272dfd2si6563386pgc.228.2024.02.20.08.10.57 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Feb 2024 08:10:58 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-73301-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; arc=pass (i=1 spf=pass spfdomain=arm.com dmarc=pass fromdomain=arm.com); spf=pass (google.com: domain of linux-kernel+bounces-73301-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-73301-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.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 BBC67B215F3 for ; Tue, 20 Feb 2024 16:04:42 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 6B2D97641F; Tue, 20 Feb 2024 16:03:16 +0000 (UTC) Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8E564762E6; Tue, 20 Feb 2024 16:03:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=217.140.110.172 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708444995; cv=none; b=UHnqUVy6m3ujfSYRjLQf4X21aA/UQdXQ9wyFOjFgzzJsUkniHWujpym//d5hjY0uI8aE7ly4QDO3EOAiUHChkUEuqVThH6AJciYoenfwmYVqGNMtc7NZSAqgqwGEvVTJjzSLZbdG+2Jb8Q3H+e2VvyPiNH6IWWZymeTKn/fTgvA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708444995; c=relaxed/simple; bh=p3HCnuUUs6C/TGyrIeEpBxQfcIdcr5XT+JJjYMmCPNs=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=Yw6Z8bYKaJWG0ptjJRhpbRUb9PIZ4VNlHByzA1uMjnqPbXf3R1C2gbIbX6+xY50uYtWJtj0nqpO0rVUupM/3P+ejYU9bOTvCVolANbPV0HehSJdeUYWPAH+Uj5xCmZOsrMyQlyJ0BsmIAYg+2mWT4nAvoJEjR18a3TWUlHVf8cc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; arc=none smtp.client-ip=217.140.110.172 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id E8333FEC; Tue, 20 Feb 2024 08:03:51 -0800 (PST) Received: from raptor (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C114D3F762; Tue, 20 Feb 2024 08:03:08 -0800 (PST) Date: Tue, 20 Feb 2024 16:03:06 +0000 From: Alexandru Elisei To: David Hildenbrand Cc: catalin.marinas@arm.com, will@kernel.org, oliver.upton@linux.dev, maz@kernel.org, james.morse@arm.com, suzuki.poulose@arm.com, yuzenghui@huawei.com, pcc@google.com, steven.price@arm.com, anshuman.khandual@arm.com, eugenis@google.com, kcc@google.com, hyesoo.yu@samsung.com, rppt@kernel.org, akpm@linux-foundation.org, peterz@infradead.org, konrad.wilk@oracle.com, willy@infradead.org, jgross@suse.com, hch@lst.de, geert@linux-m68k.org, vitaly.wool@konsulko.com, ddstreet@ieee.org, sjenning@redhat.com, hughd@google.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org, linux-mm@kvack.org, alexandru.elisei@arm.com Subject: Re: arm64 MTE tag storage reuse - alternatives to MIGRATE_CMA Message-ID: References: <70d77490-9036-48ac-afc9-4b976433070d@redhat.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Hi, On Tue, Feb 20, 2024 at 03:07:22PM +0100, David Hildenbrand wrote: > > > > > > With large folios in place, we'd likely want to investigate not working on > > > individual pages, but on (possibly large) folios instead. > > > > Yes, that would be interesting. Since the backend has no way of controlling > > what tag storage page will be needed for tags, and subsequently dropped > > from the cache, we would have to figure out what to do if one of the pages > > that is part of a large folio is dropped. The easiest solution that I can > > see is to remove the entire folio from the cleancache, but that would mean > > also dropping the rest of the pages from the folio unnecessarily. > > Right, but likely that won't be an issue. Things get interesting when > thinking about an efficient allocation approach. Indeed. > > > > > > > > > > > > > > I believe this is a very good fit for tag storage reuse, because it allows > > > > tag storage to be allocated even in atomic contexts, which enables MTE in > > > > the kernel. As a bonus, all of the changes to MM from the current approach > > > > wouldn't be needed, as tag storage allocation can be handled entirely in > > > > set_ptes_at(), copy_*highpage() or arch_swap_restore(). > > > > > > > > Is this a viable approach that would be upstreamable? Are there other > > > > solutions that I haven't considered? I'm very much open to any alternatives > > > > that would make tag storage reuse viable. > > > > > > As raised recently, I had similar ideas with something like virtio-mem in > > > the past (wanted to call it virtio-tmem back then), but didn't have time to > > > look into it yet. > > > > > > I considered both, using special device memory as "cleancache" backend, and > > > using it as backend storage for something similar to zswap. We would not > > > need a memmap/"struct page" for that special device memory, which reduces > > > memory overhead and makes "adding more memory" a more reliable operation. > > > > Hm... this might not work with tag storage memory, the kernel needs to > > perform cache maintenance on the memory when it transitions to and from > > storing tags and storing data, so the memory must be mapped by the kernel. > > The direct map will definitely be required I think (copy in/out data). But > memmap for tag memory will likely not be required. Of course, it depends how > to manage tag storage. Likely we have to store some metadata, hopefully we > can avoid the full memmap and just use something else. So I guess instead of ZONE_DEVICE I should try to use arch_add_memory() directly? That has the limitation that it cannot be used by a driver (symbol not exported to modules). Thanks, Alex