Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp1746455rwd; Sun, 21 May 2023 05:36:06 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ47SZeRARv4LhaZzXueRq9QfxlfY5jPJbNgv6dsSMP3iMDpMK0RyaK3EYYO750mec88UAgO X-Received: by 2002:a05:6a20:438d:b0:105:5caa:b49c with SMTP id i13-20020a056a20438d00b001055caab49cmr8515799pzl.23.1684672566234; Sun, 21 May 2023 05:36:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684672566; cv=none; d=google.com; s=arc-20160816; b=VM8I3u8QieGA8/G2+v99nitiirXDfTIGOUFK7nPEt5bwdTDDXsrc0V5IY4UG6ITVuu KsTCZDK6PQDen4R72ofa9EtRKmnlTBvurJ+DRBpG0MObVJXx+Z3iNK3HdItjlDyjNuTR P7FRYLG6NrU6ymBZy+LzY6Vw+/P8cAG7fYy/3kXH2wvkBIi8YcIlscrXapYYQAlBL4vM L2OR1o8+qFcWGqUry/bGp0ktjTTYqHxNdvLJvJtiOyuvw/ll0QQXNRsKlkbqnbPSn7ls yVEwi7MKGdstewiJLLayzlATFAoOkUs6Gb7qMWs/6kqAoKoxdKK/d98tPjVHsR/4q0HO efBQ== 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:subject:cc:to:from:date :dkim-signature; bh=Z461S2Zo6WY8xCWdfve4K9FZBcQd/Ch4UbRgG82Oc/c=; b=PVpx7IRX2eOOjVLM7AprJ0A2DXBOPlrEn9kRVfE1brSHpi6qiYRjc2wZi/qHjsvxVI NNKavdcQCtXy0gZ4e80046i93HcaVXYQOqYSaiSTUf4hnxf/nEml1WCbv9WZ9/vBO7Em WZ4KE8gyN4ByH+IhAEenW1/ecY+tfSczyxcaRf/V3O1pN19oFQiRYz/lX2Liwe3/I+3j C/wAcEvQ9cZYEJZNzs+A0Yikdj0ZM61dTPO0VrdHiwUvx7wM43XnUXk4RWWlEvABYCqA D+0mZ9VbfWyAeX9R5CluM0oQ2WwJJ27oc5dtrOUWcQr2VeRLVba/jnZY6+msDLnYNdb+ AMig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="ZklILM9/"; 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=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i2-20020a633c42000000b00535a71508f3si3079169pgn.77.2023.05.21.05.35.53; Sun, 21 May 2023 05:36:06 -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=@kernel.org header.s=k20201202 header.b="ZklILM9/"; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231283AbjEULry (ORCPT + 99 others); Sun, 21 May 2023 07:47:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36930 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231650AbjEUKkV (ORCPT ); Sun, 21 May 2023 06:40:21 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A85F219B; Sun, 21 May 2023 03:31:15 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 384E7616F5; Sun, 21 May 2023 10:28:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 243EBC433EF; Sun, 21 May 2023 10:28:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1684664913; bh=fuwAavm/XaNEAXoWfH+8YMFck1QbFLwrPXjkugnEjGc=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=ZklILM9/gXHkmMK8esniIM/BsLqN2K4sb1ZQSwMJLVSn4FIJLDuSf6SqgodPF887D 52utCGg8uIy3Mp8jHuXlxJwsrRcc/O+t8xls6IAPFPQgH05ORKDyi0aOJ1gtr7x++x W0ebfTTsJ7Yp//nU0gL0Qr+7jKFJ7vLuHvpol1/rEdpqamal1a7Wf5e5dPbIy8QLsD TzuNvtoDSvI15/io6hy7ldIoZcnXa/xOn6R2rc8sKxhS1XJvmaG0/2O6jTgizm27bg +sk1gfglqE5tcQsoP45sgfn2m0fyM6242S6JCtRsBYs4mjav+vqqm6wamTHlNtZQkS g/nJd4Gt4kRZA== Date: Sun, 21 May 2023 19:28:26 +0900 From: Masami Hiramatsu (Google) To: David Howells Cc: Jens Axboe , Al Viro , Christoph Hellwig , Matthew Wilcox , Jan Kara , Jeff Layton , David Hildenbrand , Jason Gunthorpe , Logan Gunthorpe , Hillf Danton , Christian Brauner , Linus Torvalds , linux-fsdevel@vger.kernel.org, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, Christoph Hellwig , Steven Rostedt , Masami Hiramatsu , linux-trace-kernel@vger.kernel.org Subject: Re: [PATCH v21 26/30] splice: Convert trace/seq to use copy_splice_read() Message-Id: <20230521192826.825bfafa17645aacba9b1076@kernel.org> In-Reply-To: <20230520000049.2226926-27-dhowells@redhat.com> References: <20230520000049.2226926-1-dhowells@redhat.com> <20230520000049.2226926-27-dhowells@redhat.com> X-Mailer: Sylpheed 3.8.0beta1 (GTK+ 2.24.33; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.5 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_MED,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 Hi David, On Sat, 20 May 2023 01:00:45 +0100 David Howells wrote: > For the splice from the trace seq buffer, just use copy_splice_read(). So this is because you will remove generic_file_splice_read() (since it's buggy), right? > > In the future, something better can probably be done by gifting pages from > seq->buf into the pipe, but that would require changing seq->buf into a > vmap over an array of pages. So what we need is to introduce a vmap? We introduced splice support for avoiding copy ringbuffer pages, but this drops it. Thus this will drop performance of splice on ring buffer (trace file). If it is correct, can you also add a note about that? Thank you, > > Signed-off-by: David Howells > cc: Christoph Hellwig > cc: Al Viro > cc: Jens Axboe > cc: Steven Rostedt > cc: Masami Hiramatsu > cc: linux-kernel@vger.kernel.org > cc: linux-trace-kernel@vger.kernel.org > cc: linux-fsdevel@vger.kernel.org > cc: linux-block@vger.kernel.org > cc: linux-mm@kvack.org > --- > kernel/trace/trace.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c > index ebc59781456a..c210d02fac97 100644 > --- a/kernel/trace/trace.c > +++ b/kernel/trace/trace.c > @@ -5171,7 +5171,7 @@ static const struct file_operations tracing_fops = { > .open = tracing_open, > .read = seq_read, > .read_iter = seq_read_iter, > - .splice_read = generic_file_splice_read, > + .splice_read = copy_splice_read, > .write = tracing_write_stub, > .llseek = tracing_lseek, > .release = tracing_release, > -- Masami Hiramatsu (Google)