Received: by 2002:a05:6a10:7420:0:0:0:0 with SMTP id hk32csp428087pxb; Thu, 17 Feb 2022 07:07:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJxg5cYoVpKdG25qzHQ0x/WiYiUHJjQDjAJjh6Ezc8EhPnCx+Z748oi0Dv4LQc2vTfzWY4ee X-Received: by 2002:a17:902:8e88:b0:14d:66f3:8d71 with SMTP id bg8-20020a1709028e8800b0014d66f38d71mr3138358plb.105.1645110426414; Thu, 17 Feb 2022 07:07:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1645110426; cv=none; d=google.com; s=arc-20160816; b=vd4p6lknzMfLfHKI3XXRQ6yxXba6TGSAaPzpXPy+7X22WaHfFhF55s4QHBgQEYshKt hLlprOOS4CX7tX6qkkDZNpb0xrB6ZS1mIO9QmSCQ5GTYBLCCrlopsKXCZZmUXPi9eT6D 5+AhMmKkcTHZWLPs/eC7aSng26YoB1w7KGDIUSeVESqOWrE+/4iZ1poHwyOdGWnmRcz2 l4oLFxbQAYTJCNnCJWCPmrQuqJ6z4Frr/x9ERD161vl1xIvlPWTjzSKCbxVnBnX+Dbcm 0pctJ/Q1G6MOJfw1aEokSYOqgsS2EURbLNvxZfoA7hB0myns8aj5RWB2q1SwlhJkYj9E LNrQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=xsU7VRCX+BeL6ly3a/7nEBgiUyLHU8jIOwt/IYyaXVY=; b=THlbX3I/iPkPoupCuRV0cqnTceZKFEqos0lBEnhl8iycooZIM1TrnGgDeSU6Y6Lf3h wtwtFYFZXg3JmSK/aflh5KmV4UbS1Gfc8yRts26OHFui5MkPk8SeiiLYwPJzTDANRkmL SXSazwaVAnk1mlDETDqejS/7hxyUC8PapI+HlAdczn1zDvv565KemGPAySQRofQUrmKT Q5qzExMOc5QJAuVAv7T8jGwS1ShZ/Qh25/rVLQ7CF4EuuV2FGVEL++Pgux9wKKKRTCDR sw+A3u5IszXZG47bgGg7wN6bbTYTfGHsy5S2REYpBY6IXxv6UhdKyK454f0iwxK6SgQ/ i0ww== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id p21si1885425pgk.69.2022.02.17.07.05.56; Thu, 17 Feb 2022 07:07:06 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240217AbiBQMC0 (ORCPT + 99 others); Thu, 17 Feb 2022 07:02:26 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:51718 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240190AbiBQMCR (ORCPT ); Thu, 17 Feb 2022 07:02:17 -0500 Received: from out30-57.freemail.mail.aliyun.com (out30-57.freemail.mail.aliyun.com [115.124.30.57]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CDFAC60F4; Thu, 17 Feb 2022 04:02:02 -0800 (PST) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R191e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04400;MF=jefflexu@linux.alibaba.com;NM=1;PH=DS;RN=13;SR=0;TI=SMTPD_---0V4kVs6e_1645099318; Received: from localhost(mailfrom:jefflexu@linux.alibaba.com fp:SMTPD_---0V4kVs6e_1645099318) by smtp.aliyun-inc.com(127.0.0.1); Thu, 17 Feb 2022 20:01:59 +0800 From: Jeffle Xu To: dhowells@redhat.com, linux-cachefs@redhat.com Cc: xiang@kernel.org, torvalds@linux-foundation.org, gregkh@linuxfoundation.org, willy@infradead.org, linux-fsdevel@vger.kernel.org, joseph.qi@linux.alibaba.com, bo.liu@linux.alibaba.com, tao.peng@linux.alibaba.com, gerry@linux.alibaba.com, eguan@linux.alibaba.com, linux-kernel@vger.kernel.org Subject: [RESEND PATCH v3 3/4] cachefiles: extract generic function for daemon methods Date: Thu, 17 Feb 2022 20:01:53 +0800 Message-Id: <20220217120154.16658-4-jefflexu@linux.alibaba.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20220217120154.16658-1-jefflexu@linux.alibaba.com> References: <20220217120154.16658-1-jefflexu@linux.alibaba.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL 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 ... so that the following new devnode can reuse most of the code when implementing its own methods. Signed-off-by: Jeffle Xu Reviewed-by: Liu Bo --- fs/cachefiles/daemon.c | 70 +++++++++++++++++++++++++++--------------- 1 file changed, 45 insertions(+), 25 deletions(-) diff --git a/fs/cachefiles/daemon.c b/fs/cachefiles/daemon.c index 7ac04ee2c0a0..6b8d7c5bbe5d 100644 --- a/fs/cachefiles/daemon.c +++ b/fs/cachefiles/daemon.c @@ -78,6 +78,34 @@ static const struct cachefiles_daemon_cmd cachefiles_daemon_cmds[] = { { "", NULL } }; +static struct cachefiles_cache *cachefiles_daemon_open_cache(void) +{ + struct cachefiles_cache *cache; + + /* allocate a cache record */ + cache = kzalloc(sizeof(struct cachefiles_cache), GFP_KERNEL); + if (cache) { + mutex_init(&cache->daemon_mutex); + init_waitqueue_head(&cache->daemon_pollwq); + INIT_LIST_HEAD(&cache->volumes); + INIT_LIST_HEAD(&cache->object_list); + spin_lock_init(&cache->object_list_lock); + + /* set default caching limits + * - limit at 1% free space and/or free files + * - cull below 5% free space and/or free files + * - cease culling above 7% free space and/or free files + */ + cache->frun_percent = 7; + cache->fcull_percent = 5; + cache->fstop_percent = 1; + cache->brun_percent = 7; + cache->bcull_percent = 5; + cache->bstop_percent = 1; + } + + return cache; +} /* * Prepare a cache for caching. @@ -96,31 +124,13 @@ static int cachefiles_daemon_open(struct inode *inode, struct file *file) if (xchg(&cachefiles_open, 1) == 1) return -EBUSY; - /* allocate a cache record */ - cache = kzalloc(sizeof(struct cachefiles_cache), GFP_KERNEL); + + cache = cachefiles_daemon_open_cache(); if (!cache) { cachefiles_open = 0; return -ENOMEM; } - mutex_init(&cache->daemon_mutex); - init_waitqueue_head(&cache->daemon_pollwq); - INIT_LIST_HEAD(&cache->volumes); - INIT_LIST_HEAD(&cache->object_list); - spin_lock_init(&cache->object_list_lock); - - /* set default caching limits - * - limit at 1% free space and/or free files - * - cull below 5% free space and/or free files - * - cease culling above 7% free space and/or free files - */ - cache->frun_percent = 7; - cache->fcull_percent = 5; - cache->fstop_percent = 1; - cache->brun_percent = 7; - cache->bcull_percent = 5; - cache->bstop_percent = 1; - file->private_data = cache; cache->cachefilesd = file; return 0; @@ -209,10 +219,11 @@ static ssize_t cachefiles_daemon_read(struct file *file, char __user *_buffer, /* * Take a command from cachefilesd, parse it and act on it. */ -static ssize_t cachefiles_daemon_write(struct file *file, - const char __user *_data, - size_t datalen, - loff_t *pos) +static ssize_t cachefiles_daemon_do_write(struct file *file, + const char __user *_data, + size_t datalen, + loff_t *pos, + const struct cachefiles_daemon_cmd *cmds) { const struct cachefiles_daemon_cmd *cmd; struct cachefiles_cache *cache = file->private_data; @@ -261,7 +272,7 @@ static ssize_t cachefiles_daemon_write(struct file *file, } /* run the appropriate command handler */ - for (cmd = cachefiles_daemon_cmds; cmd->name[0]; cmd++) + for (cmd = cmds; cmd->name[0]; cmd++) if (strcmp(cmd->name, data) == 0) goto found_command; @@ -284,6 +295,15 @@ static ssize_t cachefiles_daemon_write(struct file *file, goto error; } +static ssize_t cachefiles_daemon_write(struct file *file, + const char __user *_data, + size_t datalen, + loff_t *pos) +{ + return cachefiles_daemon_do_write(file, _data, datalen, pos, + cachefiles_daemon_cmds); +} + /* * Poll for culling state * - use EPOLLOUT to indicate culling state -- 2.27.0