Message ID | 20230414142341.354556-15-shiyn.lin@gmail.com (mailing list archive) |
---|---|
State | New |
Headers | show
Return-Path: <owner-linux-mm@kvack.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 3D168C77B76 for <linux-mm@archiver.kernel.org>; Fri, 14 Apr 2023 14:26:34 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id D2D87900003; Fri, 14 Apr 2023 10:26:33 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id CDDDA6B007B; Fri, 14 Apr 2023 10:26:33 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id BA529900003; Fri, 14 Apr 2023 10:26:33 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id ADBCD6B0078 for <linux-mm@kvack.org>; Fri, 14 Apr 2023 10:26:33 -0400 (EDT) Received: from smtpin30.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id 78DC21A02C7 for <linux-mm@kvack.org>; Fri, 14 Apr 2023 14:26:33 +0000 (UTC) X-FDA: 80680222266.30.FFFEFBC Received: from mail-pj1-f41.google.com (mail-pj1-f41.google.com [209.85.216.41]) by imf12.hostedemail.com (Postfix) with ESMTP id 9B4964000C for <linux-mm@kvack.org>; Fri, 14 Apr 2023 14:26:31 +0000 (UTC) Authentication-Results: imf12.hostedemail.com; dkim=pass header.d=gmail.com header.s=20221208 header.b=HmAKDMks; spf=pass (imf12.hostedemail.com: domain of shiyn.lin@gmail.com designates 209.85.216.41 as permitted sender) smtp.mailfrom=shiyn.lin@gmail.com; dmarc=pass (policy=none) header.from=gmail.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1681482391; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=rbLbXdRuHfxtXDKPQRm3+FT68gnEt5TFpjsogoRT0lI=; b=1NH1reXkLMuBESi7pTJVQrtIXgizHNqOo2dcTy31PWSyACT86Pk1KtskuHaGo47GdGJTMQ OVuJvOyCMVO5btD+VxS/aztKAHuYYHZk1UATgIxj4pbsKgFSMjIQgyoRz0Sm/sk+K8d1zy Fprc8cOoe/HzITNCErMZsLMySDl+bn4= ARC-Authentication-Results: i=1; imf12.hostedemail.com; dkim=pass header.d=gmail.com header.s=20221208 header.b=HmAKDMks; spf=pass (imf12.hostedemail.com: domain of shiyn.lin@gmail.com designates 209.85.216.41 as permitted sender) smtp.mailfrom=shiyn.lin@gmail.com; dmarc=pass (policy=none) header.from=gmail.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1681482391; a=rsa-sha256; cv=none; b=vEJLyPmfc5J+UxWs6hz0ZwNu1LjJcl4uHMxYBcl5VNkyBErSrmvI/TGmqrM2hO4JTRFd1c JXIRHDnjQGZTp3S0EUaIVIRPJW6qdeexWBqh2FwiRid8Ar+E/w8N1PMUgQnldI2rGtUrjP 6kpU3YrnvJE5c4rRo8hgBNL2KbSeRvw= Received: by mail-pj1-f41.google.com with SMTP id fw22-20020a17090b129600b00247255b2f40so4639127pjb.1 for <linux-mm@kvack.org>; Fri, 14 Apr 2023 07:26:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1681482390; x=1684074390; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=rbLbXdRuHfxtXDKPQRm3+FT68gnEt5TFpjsogoRT0lI=; b=HmAKDMksf6xnRVcfcxIezwmEPoznukRB4mgVdijUHQ21YemDDShfTmL8ccYJJy/uIv m8wcVocb0Vu9eVxKqU1s7MpYGhcuKa+oShTZ+fEaDuq206zVo4U+a6BLfds/qNiJyf9P aBJBBXz5pGWdJwCV/ISvkd5f2lPY9+MmyenS3R3CLgKuxE1lM3D7qGDF37xFAjH6b+F4 3VsNve3Y7ot1RL+o7x7nuJ4ZPPVWRZ9yCgTv0NDTjoGu5zBmi13H0UBJOVTjJJqfyBjX eBme7l2CRwYd3A7kXwU5eY0/p3lxE6ieNay2Hkcq0BUNNIpDcn+prGiU5zYTEFJds9wk 5U3g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1681482390; x=1684074390; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=rbLbXdRuHfxtXDKPQRm3+FT68gnEt5TFpjsogoRT0lI=; b=BMBOj7ZWEguA9fG50qDVCs5p572Njs6ATBaWJpxqMojhEurqfKCBlenu6ePFw+hsOy mqgYrTz6JB0n/1Rly2dmlEbSNfmT0vBFcMszCVyMKdXTcBf9wZoZVhQ4zlx7s1u0eLgS 9iGj+OcZPol/M7EEvgd+8CXNpTpNRDWGLlsY7lpt01A2FxkqfpiYlM/JHEviwAOIOjV8 QBd9u/JecutrSWl2hwvNFXCyscLOvaFsiOg+XX7MrqXgYHMZBrWn0ZqrOnQvAYcJqt7u PYGLFmRzCGmYgK+3F4Gtu/PnN4yXNxrWnXxhJCfu9WSNhh++l2V4S+Smfgzy0A/2rnxS rQQw== X-Gm-Message-State: AAQBX9dgOWD2XRwlyDZ5cr91mBlQfiZzhDgfiKAI2JpYWEMPTKWM4B4k wFJQJxRJ9soeO3MkjYY1oEY= X-Google-Smtp-Source: AKy350aqLfuqbdu67mJ4nM0k7rzcjp896bC+PGdAfO2G4R7flBKcTTuNhdwRHh+IhJRQkBKzvLByHQ== X-Received: by 2002:a17:90a:2c05:b0:247:1e1e:57c0 with SMTP id m5-20020a17090a2c0500b002471e1e57c0mr5918775pjd.14.1681482390502; Fri, 14 Apr 2023 07:26:30 -0700 (PDT) Received: from strix-laptop.. (2001-b011-20e0-1499-8303-7502-d3d7-e13b.dynamic-ip6.hinet.net. [2001:b011:20e0:1499:8303:7502:d3d7:e13b]) by smtp.googlemail.com with ESMTPSA id h7-20020a17090ac38700b0022335f1dae2sm2952386pjt.22.2023.04.14.07.26.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Apr 2023 07:26:30 -0700 (PDT) From: Chih-En Lin <shiyn.lin@gmail.com> To: Andrew Morton <akpm@linux-foundation.org>, Qi Zheng <zhengqi.arch@bytedance.com>, David Hildenbrand <david@redhat.com>, "Matthew Wilcox (Oracle)" <willy@infradead.org>, Christophe Leroy <christophe.leroy@csgroup.eu>, John Hubbard <jhubbard@nvidia.com>, Nadav Amit <namit@vmware.com>, Barry Song <baohua@kernel.org>, Pasha Tatashin <pasha.tatashin@soleen.com> Cc: Thomas Gleixner <tglx@linutronix.de>, Ingo Molnar <mingo@redhat.com>, Borislav Petkov <bp@alien8.de>, Dave Hansen <dave.hansen@linux.intel.com>, "H. Peter Anvin" <hpa@zytor.com>, Steven Rostedt <rostedt@goodmis.org>, Masami Hiramatsu <mhiramat@kernel.org>, Peter Zijlstra <peterz@infradead.org>, Arnaldo Carvalho de Melo <acme@kernel.org>, Mark Rutland <mark.rutland@arm.com>, Alexander Shishkin <alexander.shishkin@linux.intel.com>, Jiri Olsa <jolsa@kernel.org>, Namhyung Kim <namhyung@kernel.org>, Ian Rogers <irogers@google.com>, Adrian Hunter <adrian.hunter@intel.com>, Yu Zhao <yuzhao@google.com>, Steven Barrett <steven@liquorix.net>, Juergen Gross <jgross@suse.com>, Peter Xu <peterx@redhat.com>, Kefeng Wang <wangkefeng.wang@huawei.com>, Tong Tiangen <tongtiangen@huawei.com>, Christoph Hellwig <hch@infradead.org>, "Liam R. Howlett" <Liam.Howlett@Oracle.com>, Yang Shi <shy828301@gmail.com>, Vlastimil Babka <vbabka@suse.cz>, Alex Sierra <alex.sierra@amd.com>, Vincent Whitchurch <vincent.whitchurch@axis.com>, Anshuman Khandual <anshuman.khandual@arm.com>, Li kunyu <kunyu@nfschina.com>, Liu Shixin <liushixin2@huawei.com>, Hugh Dickins <hughd@google.com>, Minchan Kim <minchan@kernel.org>, Joey Gouly <joey.gouly@arm.com>, Chih-En Lin <shiyn.lin@gmail.com>, Michal Hocko <mhocko@suse.com>, Suren Baghdasaryan <surenb@google.com>, "Zach O'Keefe" <zokeefe@google.com>, Gautam Menghani <gautammenghani201@gmail.com>, Catalin Marinas <catalin.marinas@arm.com>, Mark Brown <broonie@kernel.org>, "Eric W. Biederman" <ebiederm@xmission.com>, Andrei Vagin <avagin@gmail.com>, Shakeel Butt <shakeelb@google.com>, Daniel Bristot de Oliveira <bristot@kernel.org>, "Jason A. Donenfeld" <Jason@zx2c4.com>, Greg Kroah-Hartman <gregkh@linuxfoundation.org>, Alexey Gladkov <legion@kernel.org>, x86@kernel.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-trace-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, Dinglan Peng <peng301@purdue.edu>, Pedro Fonseca <pfonseca@purdue.edu>, Jim Huang <jserv@ccns.ncku.edu.tw>, Huichun Feng <foxhoundsk.tw@gmail.com> Subject: [PATCH v5 14/17] fs/proc: Support COW PTE with clear_refs_write Date: Fri, 14 Apr 2023 22:23:38 +0800 Message-Id: <20230414142341.354556-15-shiyn.lin@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230414142341.354556-1-shiyn.lin@gmail.com> References: <20230414142341.354556-1-shiyn.lin@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 9B4964000C X-Rspam-User: X-Stat-Signature: 13y3up9jmo1y56s94dc611m56qwet7xz X-HE-Tag: 1681482391-367902 X-HE-Meta: U2FsdGVkX1+3pAaEg8i2GjI5+kzkk7gb7/MFeoDBbELBumhM2A9Vo/u4uDAVUOK3vGr/qBIZg4nd5E+mBqYSl1JV41gGpexua03NmzPgc1FapH+H89q6w62lw4U99arv7r/rMd4MhTqPjmiSl1Yt8VAQJ7sav0tCmZEpS1DJFcymacaz857PMCwNpe05hyuBSAq2vywAj5+HsPKp3GXfZDrw3F4fy1b8pCtDAq6+duNgLiOlxwloyFUPfSAlKMzOaI4GJAtRrGFuW8OZukihz/jZM4dndsLcgm8cNuqWMM9XGNu6ehkl1/2bCtA1pvBgoJx85HaxiuBKyKCi87FASPsUrtxCDsz88nohs6lxr8+GaSl/WUQ8uWPVep6UYEk0SqTv4pdqMABMOE274yCuOwd/qWND5okzeA0GOPHr8cPn2DGRXbYIia5jM/4igmii+sbPbBfiVsfg5tRxAXK9AqTuaF23BLBEHtJc6hDlWniW32aDazjSAAIwQPB0hOfzTzeR/fWVzyZZFePlHi6tEu1KkgDcDm/P6u9X6q6w34YzUnmpcsaOfZSOQ+/QNpE4RqNvlpw+RwOa0S25lQVy4M/Gy6bcv/MQKIhJ31EVVgWvp5r4eoLBacEdtFFnOtEHCWVvWoRx5Cs5I4z9KmCaKVcdegMUwUpLbjBH4qpGpBzXUpO90p4mwPe1qZvV2s/hJY6NlcEEQtUsUZ/24Og16h2RcnmHHLkvZBPXmwBIZwXkdAO1cliTBW1dPnZ4crL9FtRVmRkT+F5pRIUkEV5nhI8VqKWi5Hag8a1iTvno8GBMOE3N0ReoCv0NN+NqSa5yd6eCL18pWxwcaCnYaNDzHCcLjmrwJCxrUNbdpJvWN8XnNdyT89F8/UoOoOoKVRzpWqU996rE93KAQXNdFdoPMXCVIyHewLu9iSiFBjXk278jlHRr46BF1/zqyOTGG1iZQ/oro+Thl1WlT+uc3nS SRi946Tl bVsP/hIfd1bs73AfarFP3YIiXNoeRE2nW3chpEw5NTUHBvapolr0AXsVBAQLo/iSju8Q1EdOeCZREBP4a5M96egXgWgBwQ1FAO8IRMgsXViMqxToBjjl0aNq+9Hn/eD5MrbbSUZWVu9D1MHRnFDhKoLyvcvyTKZqGtbHLi8y0OyrvQLv7UN3KPHcuxBuWgrQEKP0wFo/SwEJKQlY7thAIJQH/ozUiXoNO65GL3JqDOzNJa2csg3EgNpWyr9mRtDA6Q+2urZYaB2A4Tj5y0EY4UBPYWuP+dgRcuDGOwKzKxld+F+acDmCAQKFq4FyqPSQ5rwi7c3JubiKk3fNxoYAi5TpJMA5rC65WA2CYtNjN/pZ3GmrsPoIR9HvuEhveCvsHYwVpZ3ObPMaRCv0kEjtYt7JBo+0C9nju+4baxdBI9svlGJoLU+c0pYT/gd5Gvz9eNMKJmMyX5ByNck3RR0SF18lQpdAUsjDK7tRmwtfiilN7yu7FeLq7GcD5nF+J+j9jWEQN/cJvab9wY/Z3goZiylHQ7AJsbVf9vbWTIzAXge7l87TM/JO0A9kmNB6a+/y8zLp1VVwKHPAGGnWjvZyM6ueD0Q== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> |
Series |
Introduce Copy-On-Write to Page Table
|
expand
|
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index 6a96e1713fd5..c76b74029dfd 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c @@ -1195,6 +1195,11 @@ static int clear_refs_pte_range(pmd_t *pmd, unsigned long addr, if (pmd_trans_unstable(pmd)) return 0; + /* Only break COW when we modify the soft-dirty bit. */ + if (cp->type == CLEAR_REFS_SOFT_DIRTY && + break_cow_pte(vma, pmd, addr)) + return 0; + pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); for (; addr != end; pte++, addr += PAGE_SIZE) { ptent = *pte;
Before clearing the entry in COW-ed PTE, break COW PTE first. Signed-off-by: Chih-En Lin <shiyn.lin@gmail.com> --- fs/proc/task_mmu.c | 5 +++++ 1 file changed, 5 insertions(+)