Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp706403ybz; Wed, 15 Apr 2020 17:09:02 -0700 (PDT) X-Google-Smtp-Source: APiQypK23BoI5FE7DJU4TqGzuS1Q53A6JhGUCe5nS8EyryTjO0p13Dsu2cyqwEXkdCI5qRXZtaiO X-Received: by 2002:aa7:dd0f:: with SMTP id i15mr12198588edv.245.1586995742578; Wed, 15 Apr 2020 17:09:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586995742; cv=none; d=google.com; s=arc-20160816; b=cekyNd9BDHXU/9RTOfUBsw6Yp4TFPn2UKpBD2HCuExxDnHs112AM1It6h1MlkdONOC vGWpqcp7fQQnFZPF2JOlkuIwtzl/qrwo3MNAqDiQQfNT8+GoYUXePSDVx03vVugvGhi+ leeiESlR/UH0PC8cnEecOUmn7k7dCDSCHQoAjtmnoTcQycpCHBWN7nlyiu56EXRx0QoS ofEa9WLuwFASSnzi2H9FQN9XmNkVFYswzqrYWWWCclgf1CY+CnfmBWTgakK23tTnnCwG eqI4940qIIZO7K+fiSp0BjdOBVeSm93gFUGv5CyTH+WuOz9qxyMs4H0lVxFzMEIwu31b F0rA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=bgvakJj1uHkjMjGHkZ+ouUycEukPBlVqKnEMBwQK0lg=; b=fLzvM1/9WAsb2/eUgdsUijTjB1aTlk5vwKEQ0BJ4Z4q/Q2e2knYOUFmDGpU7uqGUmJ pwGC3TeYdxi6/bI1zQ5tsuXxM3tMdmIFHY/D/bwbf6MGpwae7LAi3hMxTJ6CoBpeKKja CiaDIxtfa2hSiZkWNytNMtCiqcH4Whcv4eP6y+SUzi55QzGhkOCBotjj2cgyn4uiRnjK oUAG0GLLcCqV+sDH1Qfh0CQKH5rht9OMvmWkLLbDf4MVUfK1gk8+ni+FWSBBtFg9VbZx EtXSwQHBGbx3ffdg/erqIQsXu8lKfLRaOm2THomSTOcKW2DaOvI892LHOJx7CD1Z+Qbh 8T/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UFfFcxcU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org ([23.128.96.18]) by mx.google.com with ESMTP id cw6si6333186edb.552.2020.04.15.17.08.39; Wed, 15 Apr 2020 17:09:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UFfFcxcU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2394117AbgDOOdv (ORCPT + 99 others); Wed, 15 Apr 2020 10:33:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:44650 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2394034AbgDOOcw (ORCPT ); Wed, 15 Apr 2020 10:32:52 -0400 Received: from mail.kernel.org (ip5f5ad4d8.dynamic.kabel-deutschland.de [95.90.212.216]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C759E2137B; Wed, 15 Apr 2020 14:32:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1586961171; bh=tnnJpVmnbVuJ6k+jQRIZ9yUNqaXuvO9AT5XcHy6DOVg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UFfFcxcUtSqL8VLIaHeiLYto6vE/cKHVPRQgcqCO7Ah8QHCu+XcJMXpRJN85Fe57g WsfN5oGdA0lLFpROxGyNGJ44Ux+MCFMhOajE2Zu8QOj9s5hcaCv8HXEkJSdhtNAm0g +66PK3O6L8NBuyKiQbxRSe+CIezMcUuFX79mdsl0= Received: from mchehab by mail.kernel.org with local (Exim 4.92.3) (envelope-from ) id 1jOj5t-006kO4-2g; Wed, 15 Apr 2020 16:32:49 +0200 From: Mauro Carvalho Chehab To: Linux Doc Mailing List Cc: Mauro Carvalho Chehab , linux-kernel@vger.kernel.org, Jonathan Corbet , David Howells , linux-cachefs@redhat.com Subject: [PATCH 05/34] docs: filesystems: caching/operations.txt: convert it to ReST Date: Wed, 15 Apr 2020 16:32:18 +0200 Message-Id: X-Mailer: git-send-email 2.25.2 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org - Add a SPDX header; - Adjust document and section titles; - Comment out text ToC for html/pdf output; - Mark literal blocks as such; - Add it to filesystems/caching/index.rst. Signed-off-by: Mauro Carvalho Chehab --- Documentation/filesystems/caching/index.rst | 1 + .../{operations.txt => operations.rst} | 45 +++++++++---------- fs/fscache/operation.c | 2 +- 3 files changed, 23 insertions(+), 25 deletions(-) rename Documentation/filesystems/caching/{operations.txt => operations.rst} (90%) diff --git a/Documentation/filesystems/caching/index.rst b/Documentation/filesystems/caching/index.rst index d0651db450fb..75492b7c8ea0 100644 --- a/Documentation/filesystems/caching/index.rst +++ b/Documentation/filesystems/caching/index.rst @@ -9,3 +9,4 @@ Filesystem Caching fscache object netfs-api + operations diff --git a/Documentation/filesystems/caching/operations.txt b/Documentation/filesystems/caching/operations.rst similarity index 90% rename from Documentation/filesystems/caching/operations.txt rename to Documentation/filesystems/caching/operations.rst index d8976c434718..f7ddcc028939 100644 --- a/Documentation/filesystems/caching/operations.txt +++ b/Documentation/filesystems/caching/operations.rst @@ -1,10 +1,12 @@ - ================================ - ASYNCHRONOUS OPERATIONS HANDLING - ================================ +.. SPDX-License-Identifier: GPL-2.0 + +================================ +Asynchronous Operations Handling +================================ By: David Howells -Contents: +.. Contents: (*) Overview. @@ -17,8 +19,7 @@ Contents: (*) Asynchronous callback. -======== -OVERVIEW +Overview ======== FS-Cache has an asynchronous operations handling facility that it uses for its @@ -33,11 +34,10 @@ backend for completion. To make use of this facility, should be #included. -=============================== -OPERATION RECORD INITIALISATION +Operation Record Initialisation =============================== -An operation is recorded in an fscache_operation struct: +An operation is recorded in an fscache_operation struct:: struct fscache_operation { union { @@ -50,7 +50,7 @@ An operation is recorded in an fscache_operation struct: }; Someone wanting to issue an operation should allocate something with this -struct embedded in it. They should initialise it by calling: +struct embedded in it. They should initialise it by calling:: void fscache_operation_init(struct fscache_operation *op, fscache_operation_release_t release); @@ -67,8 +67,7 @@ FSCACHE_OP_WAITING may be set in op->flags prior to each submission of the operation and waited for afterwards. -========== -PARAMETERS +Parameters ========== There are a number of parameters that can be set in the operation record's flag @@ -87,7 +86,7 @@ operations: If this option is to be used, FSCACHE_OP_WAITING must be set in op->flags before submitting the operation, and the operating thread must wait for it - to be cleared before proceeding: + to be cleared before proceeding:: wait_on_bit(&op->flags, FSCACHE_OP_WAITING, TASK_UNINTERRUPTIBLE); @@ -101,7 +100,7 @@ operations: page to a netfs page after the backing fs has read the page in. If this option is used, op->fast_work and op->processor must be - initialised before submitting the operation: + initialised before submitting the operation:: INIT_WORK(&op->fast_work, do_some_work); @@ -114,7 +113,7 @@ operations: pages that have just been fetched from a remote server. If this option is used, op->slow_work and op->processor must be - initialised before submitting the operation: + initialised before submitting the operation:: fscache_operation_init_slow(op, processor) @@ -132,8 +131,7 @@ Furthermore, operations may be one of two types: operations running at the same time. -========= -PROCEDURE +Procedure ========= Operations are used through the following procedure: @@ -143,7 +141,7 @@ Operations are used through the following procedure: generic op embedded within. (2) The submitting thread must then submit the operation for processing using - one of the following two functions: + one of the following two functions:: int fscache_submit_op(struct fscache_object *object, struct fscache_operation *op); @@ -164,7 +162,7 @@ Operations are used through the following procedure: operation of conflicting exclusivity is in progress on the object. If the operation is asynchronous, the manager will retain a reference to - it, so the caller should put their reference to it by passing it to: + it, so the caller should put their reference to it by passing it to:: void fscache_put_operation(struct fscache_operation *op); @@ -179,12 +177,12 @@ Operations are used through the following procedure: (4) The operation holds an effective lock upon the object, preventing other exclusive ops conflicting until it is released. The operation can be enqueued for further immediate asynchronous processing by adjusting the - CPU time provisioning option if necessary, eg: + CPU time provisioning option if necessary, eg:: op->flags &= ~FSCACHE_OP_TYPE; op->flags |= ~FSCACHE_OP_FAST; - and calling: + and calling:: void fscache_enqueue_operation(struct fscache_operation *op) @@ -192,13 +190,12 @@ Operations are used through the following procedure: pools. -===================== -ASYNCHRONOUS CALLBACK +Asynchronous Callback ===================== When used in asynchronous mode, the worker thread pool will invoke the processor method with a pointer to the operation. This should then get at the -container struct by using container_of(): +container struct by using container_of():: static void fscache_write_op(struct fscache_operation *_op) { diff --git a/fs/fscache/operation.c b/fs/fscache/operation.c index 1a22a55f75a0..4a5651d4904e 100644 --- a/fs/fscache/operation.c +++ b/fs/fscache/operation.c @@ -4,7 +4,7 @@ * Copyright (C) 2008 Red Hat, Inc. All Rights Reserved. * Written by David Howells (dhowells@redhat.com) * - * See Documentation/filesystems/caching/operations.txt + * See Documentation/filesystems/caching/operations.rst */ #define FSCACHE_DEBUG_LEVEL OPERATION -- 2.25.2