Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4826761rwd; Sat, 17 Jun 2023 23:30:39 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6QoTqVPuER7kW8zCQMinSRz/nt0T1XjJh5f77wLuSCc5PVn1uZ6Xp58ga/jfW3JIwWjsZz X-Received: by 2002:a17:90a:12:b0:25e:7fdd:f39c with SMTP id 18-20020a17090a001200b0025e7fddf39cmr4774284pja.16.1687069839288; Sat, 17 Jun 2023 23:30:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687069839; cv=none; d=google.com; s=arc-20160816; b=SVjPKaVLN0POLsydK9Rq4xzB/9pv18B3B6KvsgH6VYZT6DqPUbZoNWfnXoEpFTfmhG 5stdJJJIlakcwczoIs135Rzxd3g5WRaSH1e5aSLeqPRi06eLdxNwrqDEZ7Z64qBOYQIX EvB4xIuJcyu6cM1djHYgD+gsRVRrvf1OQ1U+i0pC0uSG6OxFKdRBubf3nHQAblIfJQVt l46yJkTw5Q8d6flNoDuugqaQf+6+K2dnbrX1dGR6SrQ9Y+nlQhfiA0Vf4qLsMT+0NvV/ Xp97DgmrFSuHDqcvIesEXyNx34pX4IZnb9G9KLmaYg/khe6xqlKE4MlVXJaZi1CqBPTU bnGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=2lEqHyxGtCRDjYgsfTX1nfcI5nfmX6OULc3IM+psge4=; b=FugLJgLbZP30ys7SB+J25J2xEXDq3C9GkPQzBmEukMTx44rQaL8EnrM3RZIqIGVZCb Qo4vA+1u9+lU+d+g6IhdzR1Av3P/pscfDro9I/mYvuYgBJhj9eT5029Bo0cCgOMwgQTS LrG+7hruGVXhPRKAy/s0+Jtf4WLpxMjRI7x7LMjzwtMi8FcjcNU+er6GxF2U1Spenm0w /a3UaFycz/i5ledH/LeApdgIu6Hz18T/4foBKAY1Itw7qHygxz6peZYYzMgEKD4GoeK7 QfWx1JPQUNgNoD2kjfN07Hw6+MM6OfzVlbXTqKmq5NGuU6yqH3H+T7pFMn3XKs6oFbVG XOHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=LCRM+gXk; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v20-20020a17090ac91400b002534f4ce2b6si5017037pjt.125.2023.06.17.23.30.24; Sat, 17 Jun 2023 23:30:39 -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=@chromium.org header.s=google header.b=LCRM+gXk; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229503AbjFRFZe (ORCPT + 99 others); Sun, 18 Jun 2023 01:25:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38754 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229487AbjFRFZd (ORCPT ); Sun, 18 Jun 2023 01:25:33 -0400 Received: from mail-pf1-x435.google.com (mail-pf1-x435.google.com [IPv6:2607:f8b0:4864:20::435]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 137B7DA for ; Sat, 17 Jun 2023 22:25:32 -0700 (PDT) Received: by mail-pf1-x435.google.com with SMTP id d2e1a72fcca58-66869feb7d1so355590b3a.3 for ; Sat, 17 Jun 2023 22:25:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; t=1687065931; x=1689657931; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=2lEqHyxGtCRDjYgsfTX1nfcI5nfmX6OULc3IM+psge4=; b=LCRM+gXkewTc7CVIoPzQl0RbPysH9hV3npvzPDDnu1asWxNE0iZNHZbckrm4KnsB+A QDy0VZaR8WOZgfYsYi8yueNybrOfR0ys8QEtBzclC4JOwyS346ECW/qIBqYqhe41/l0f ZrJuWg1lBFpq1Vd58dOAnP8TmL5SZtGw5cRsI= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1687065931; x=1689657931; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=2lEqHyxGtCRDjYgsfTX1nfcI5nfmX6OULc3IM+psge4=; b=TZ14q7KsOaNyVoUBpGFeD3UV4pjGofi0diVb4ramcqF6+JdHPWgZLtK5dU6bLp3cl7 gN3x8YUf2iUNwMrUP9WybxukqtRgiKparYKhSyZ+nc7ADm/aT/Ygt6ScQYQ4co0ltzph 9+vXommntsNSNJ4o59epOBI3v02XHqyurHSiadf8Ozw9GAZCJhO8dk/tyhPd3Ss4uE5K /KZXH8rqw/3wtSKJGc4BPUVLooTUnMXwegjX0kEwOsCX/OpO1/bF0vS9ZroX91zx1awQ rpvRdN5qftHKz+pU0teUtKLniZGQ/FoqKs3xPQFrf/ezCkZg7pzEpwNSfdXa81NcpE7h Uxug== X-Gm-Message-State: AC+VfDzPtPYbyDdiYlKbDl49bT3n6chvawY84vQsjGe/AZyga7CjSsHx KMblM7libZQbwjjOHlAgYeBMTQ== X-Received: by 2002:a17:902:d483:b0:1b4:fe23:1eaa with SMTP id c3-20020a170902d48300b001b4fe231eaamr5350017plg.28.1687065931541; Sat, 17 Jun 2023 22:25:31 -0700 (PDT) Received: from google.com (KD124209188001.ppp-bb.dion.ne.jp. [124.209.188.1]) by smtp.gmail.com with ESMTPSA id jk17-20020a170903331100b001b54a88e6adsm1739188plb.309.2023.06.17.22.25.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 17 Jun 2023 22:25:30 -0700 (PDT) Date: Sun, 18 Jun 2023 14:25:26 +0900 From: Sergey Senozhatsky To: Yosry Ahmed Cc: Sergey Senozhatsky , Domenico Cerasuolo , vitaly.wool@konsulko.com, minchan@kernel.org, linux-mm@kvack.org, ddstreet@ieee.org, sjenning@redhat.com, nphamcs@gmail.com, hannes@cmpxchg.org, akpm@linux-foundation.org, linux-kernel@vger.kernel.org, kernel-team@meta.com Subject: Re: [PATCH v3 1/7] mm: zswap: add pool shrinking mechanism Message-ID: <20230618052526.GB2417524@google.com> References: <20230612093815.133504-1-cerasuolodomenico@gmail.com> <20230612093815.133504-2-cerasuolodomenico@gmail.com> <20230618043857.GA2417524@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FSL_HELO_FAKE, 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 (23/06/17 21:48), Yosry Ahmed wrote: > > On (23/06/12 11:38), Domenico Cerasuolo wrote: > > > +static int zswap_reclaim_entry(struct zswap_pool *pool) > > > +{ > > > + struct zswap_header *zhdr; > > > + struct zswap_entry *entry; > > > + struct zswap_tree *tree; > > > + pgoff_t swpoffset; > > > + int ret; > > > + > > > + /* Get an entry off the LRU */ > > > + spin_lock(&pool->lru_lock); > > > + if (list_empty(&pool->lru)) { > > > + spin_unlock(&pool->lru_lock); > > > + return -EINVAL; > > > + } > > > + entry = list_last_entry(&pool->lru, struct zswap_entry, lru); > > > + list_del_init(&entry->lru); > > > > A quick question: should we zswap_entry_get() here? > > We need to hold the tree lock for that, and the lock ordering is tree > lock -> lru lock. If we try to grab the tree lock here we may > deadlock. We can deadlock doing this? lock tree_lock lock lru_lock list_del_init unlock lru_lock entry_get unlock tree_lock writeback