Received: by 2002:ab2:6991:0:b0:1f7:f6c3:9cb1 with SMTP id v17csp306877lqo; Tue, 7 May 2024 23:33:16 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVDv1CS9TlGEjClSQQKYI+LW6u68Jp1Gv42ZG0/6vSzQ8IfgtmHFFS8p9vv6Vt0WezhBq87eKlhaFSBUOZsNpFdAUoyCD3JKeZK2T97zw== X-Google-Smtp-Source: AGHT+IE0hm4LIndJNJnYFfDLUqY/YoEFzybuGdcL0NYTTnqlS7fRkSphitRgAX+EbAel87Z2YZeW X-Received: by 2002:a05:6a21:2d8a:b0:1af:86e4:bc99 with SMTP id adf61e73a8af0-1afc87346ffmr2908475637.10.1715149996043; Tue, 07 May 2024 23:33:16 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715149996; cv=pass; d=google.com; s=arc-20160816; b=jnCon4zXHJIpINW5LJTU3ea/0hABdWRcUGbCrg7aW8nYQw1IJp/hwOW4Fzk85Xy3cy MlnXxTktZ8qjixj32u7URWCrbrS6auloTdZuAVxPjFUv3zkYW0vY4cAxH0Oxd9TPdQp1 +BTRy5z6BXximfQb4tcb90UXg/oEsFv9mtBhQdQ21rx6RwOYRMNK/8KVDolebWVCMwIB A/1og1VnYuZyDgyF6saNz5EtV/57luct6TJLZ0IVpwt57zve23SpW/wZdBSLvQz6TUk8 lcSykfZ+4Yqv7Xes0fV/lBKIZTBnfKmANvctjoXAuKoEOXtpdP9OrlTGdAKEwwfXXzac BU7Q== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=mime-version:list-unsubscribe:list-subscribe:list-id:precedence :user-agent:message-id:date:references:in-reply-to:subject:cc:to :from:dkim-signature; bh=a/0KRJikDbNf3c1Kz0LM/oyki79vliBCuZIzFCCoLto=; fh=29olaKlqM7Am6Fr1p/EL2eyiA7t9otb3pxzlIYPMzt8=; b=IVEGcJd4nHjka+hwOj2dY1WWwZbkZnbLrae6QaMRZqWTYCJFpkX/5E0OihRXDVZzEx 6c4pxuX21CJ2Z69q3jaXBbSzwv9pVTTb0FN8irslT7N0XJ+pDaDSrorwg0Uxglo2OHD5 /d24EcWdClc4aGL//8SpanN6AoGqTq/C+bSblwsyXd6jhalX33fu82m0xEpnlExxGWDZ zvXi5OTlqLeMOyayovVWF5wUTy6MBIkoflRBxjco2CRF7aJ7F+UXDKUfSEXK6DbNALIV Ja/Vlm9UWNeOmXqQYCrZEM5mKU0buEjEE52FXQbmTmNeh5A/a+IK8IL0dK99MHskSB++ Rotw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=TQgn9kBN; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-172761-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-172761-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.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 cz5-20020aa79305000000b006f4081561b3si9424521pfb.86.2024.05.07.23.33.15 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 May 2024 23:33:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-172761-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=@intel.com header.s=Intel header.b=TQgn9kBN; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-172761-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-172761-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.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 A07DDB249CF for ; Wed, 8 May 2024 06:30:47 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7969D1EB45; Wed, 8 May 2024 06:30:37 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="TQgn9kBN" Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.19]) (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 2D90C384; Wed, 8 May 2024 06:30:35 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=192.198.163.19 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715149836; cv=none; b=lMvflIY09WGyG81WKOqpldgWHt7guTyh1CoOAuxkl79hvgv7aiyFqPtPHGmjjkQMDLGQ9d+H6dEXuvAqqqHmgpYcgXpFxcfKWCwbydTBPMvnCAIsNRNhCWc45YqJFAeF91xZyGB8X4Sf9ugGmFxhGmYdHUofOkQ8mVFqt2IkZEI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715149836; c=relaxed/simple; bh=5jxRy94UaFRt03ZEYe2d4KvQGZLYJ8qOnRbCZ8mahzk=; h=From:To:Cc:Subject:In-Reply-To:References:Date:Message-ID: MIME-Version:Content-Type; b=amnz5KLsk3hmGjZ3aabQyUxyOLY3xDxLo563Py2rquvi4cBABFaxHds7TaKc6pvg1vdiNnhkiFWNJPZRQ6EmpWAFAcHhX5OclJ7UB53OyCoin8BzVCQdTRq3CA41Dh2NR0xcvd3z6w5zf127qSxayXQBbi5gK31dS6lJx4IeKQo= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=TQgn9kBN; arc=none smtp.client-ip=192.198.163.19 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1715149835; x=1746685835; h=from:to:cc:subject:in-reply-to:references:date: message-id:mime-version; bh=5jxRy94UaFRt03ZEYe2d4KvQGZLYJ8qOnRbCZ8mahzk=; b=TQgn9kBNX2uiNerJtvLzEymcI8qFf6VKsADBDQIDoV+LOTtimW4NQFB5 A/AaUjbMHqURq68G0Znj172BM94zjEzNT2icP6cJTlkYOEXm90QCKdaZn mQAP/iZYyuMIP/TYgeaoW8XDk7PA4/pk1+2SM24Mf+s79tfsPxiMJf7Dr YHmluYgy8qDKy86MnKvlzFujdV1wJQ7/bRrWre49WOGAnB5xVGXGvD6Fg xQeqdsuKREqjczdOQtbUMeqsighoN8PwEiuEZx68GS+BHQ58CVsEcPoIk 3e8SK4CaibBkqXlMnWlcb2Br8hKQL4OeiapVAaRyL28CBWHU+pgARCgMh A==; X-CSE-ConnectionGUID: 8qyn6g5MRuSkoUTNh7uN7w== X-CSE-MsgGUID: t+FF2jRhSwO1XKRot+tMhw== X-IronPort-AV: E=McAfee;i="6600,9927,11066"; a="10856015" X-IronPort-AV: E=Sophos;i="6.08,144,1712646000"; d="scan'208";a="10856015" Received: from fmviesa004.fm.intel.com ([10.60.135.144]) by fmvoesa113.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 May 2024 23:30:34 -0700 X-CSE-ConnectionGUID: aQ/0s7eNRzG6JHjbKHdLBg== X-CSE-MsgGUID: dak9a4neSL+mA6jf6j99og== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.08,144,1712646000"; d="scan'208";a="33330313" Received: from unknown (HELO yhuang6-desk2.ccr.corp.intel.com) ([10.238.208.55]) by fmviesa004-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 May 2024 23:30:30 -0700 From: "Huang, Ying" To: Kairui Song Cc: linux-mm@kvack.org, Kairui Song , Andrew Morton , Matthew Wilcox , Chris Li , Barry Song , Ryan Roberts , Neil Brown , Minchan Kim , Hugh Dickins , David Hildenbrand , Yosry Ahmed , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 09/12] mm/swap: get the swap device offset directly In-Reply-To: <20240502084939.30250-2-ryncsn@gmail.com> (Kairui Song's message of "Thu, 2 May 2024 16:49:36 +0800") References: <20240502084609.28376-1-ryncsn@gmail.com> <20240502084939.30250-2-ryncsn@gmail.com> Date: Wed, 08 May 2024 14:28:38 +0800 Message-ID: <87edaclsvd.fsf@yhuang6-desk2.ccr.corp.intel.com> User-Agent: Gnus/5.13 (Gnus v5.13) 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=ascii Kairui Song writes: > From: Kairui Song > > folio_file_pos and page_file_offset are for mixed usage of swap cache > and page cache, it can't be page cache here, so introduce a new helper > to get the swap offset in swap device directly. > > Need to include swapops.h in mm/swap.h to ensure swp_offset is always > defined before use. > > Signed-off-by: Kairui Song LGTM! Thanks! Reviewed-by: "Huang, Ying" > --- > mm/page_io.c | 6 +++--- > mm/swap.h | 9 +++++++++ > 2 files changed, 12 insertions(+), 3 deletions(-) > > diff --git a/mm/page_io.c b/mm/page_io.c > index 46c603dddf04..a360857cf75d 100644 > --- a/mm/page_io.c > +++ b/mm/page_io.c > @@ -280,7 +280,7 @@ static void sio_write_complete(struct kiocb *iocb, long ret) > * be temporary. > */ > pr_err_ratelimited("Write error %ld on dio swapfile (%llu)\n", > - ret, page_file_offset(page)); > + ret, swap_dev_pos(page_swap_entry(page))); > for (p = 0; p < sio->pages; p++) { > page = sio->bvec[p].bv_page; > set_page_dirty(page); > @@ -299,7 +299,7 @@ static void swap_writepage_fs(struct folio *folio, struct writeback_control *wbc > struct swap_iocb *sio = NULL; > struct swap_info_struct *sis = swp_swap_info(folio->swap); > struct file *swap_file = sis->swap_file; > - loff_t pos = folio_file_pos(folio); > + loff_t pos = swap_dev_pos(folio->swap); > > count_swpout_vm_event(folio); > folio_start_writeback(folio); > @@ -430,7 +430,7 @@ static void swap_read_folio_fs(struct folio *folio, struct swap_iocb **plug) > { > struct swap_info_struct *sis = swp_swap_info(folio->swap); > struct swap_iocb *sio = NULL; > - loff_t pos = folio_file_pos(folio); > + loff_t pos = swap_dev_pos(folio->swap); > > if (plug) > sio = *plug; > diff --git a/mm/swap.h b/mm/swap.h > index fc2f6ade7f80..82023ab93205 100644 > --- a/mm/swap.h > +++ b/mm/swap.h > @@ -5,6 +5,7 @@ > struct mempolicy; > > #ifdef CONFIG_SWAP > +#include /* for swp_offset */ > #include /* for bio_end_io_t */ > > /* linux/mm/page_io.c */ > @@ -31,6 +32,14 @@ extern struct address_space *swapper_spaces[]; > (&swapper_spaces[swp_type(entry)][swp_offset(entry) \ > >> SWAP_ADDRESS_SPACE_SHIFT]) > > +/* > + * Return the swap device position of the swap entry. > + */ > +static inline loff_t swap_dev_pos(swp_entry_t entry) > +{ > + return ((loff_t)swp_offset(entry)) << PAGE_SHIFT; > +} > + > void show_swap_cache_info(void); > bool add_to_swap(struct folio *folio); > void *get_shadow_from_swap_cache(swp_entry_t entry);