Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp3041588pxb; Tue, 12 Jan 2021 05:04:38 -0800 (PST) X-Google-Smtp-Source: ABdhPJwa1zNVcwJ4VOYHAJ98t/8wHk6BVCmHSsB4KFid7eKNceP5gpWKr0c2IoPU2VyHXh1iATLn X-Received: by 2002:a17:907:c01:: with SMTP id ga1mr3085023ejc.488.1610456677778; Tue, 12 Jan 2021 05:04:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610456677; cv=none; d=google.com; s=arc-20160816; b=D8diayjWprfm3YCkC5exeEslyh6LGOcFk9/nC5d9GN0XHUTynVqC1DkuHxbn+ADFFU En+wEhUHJNzum12ove+/UcYUd/jPvgquyNUJj6wFHlnGeOhdLj5AKIVK+MMwJcPinI+t azJipWxosLSxnhHMNAd4b8WGIcLfwOP4TgTkzgwa6ATa8eYwh/Bx23as8+PkWknNyJxl LXDGif07Id+qbQ30dSafW4wsNvkuNU+Wqh8tZp8hNwsOJD9igVre28FWqIWa+j0rFIB5 zeZ4WXtLwVFceZBJ0ctOLuC/OxuqIY1RCWzxC1/osFa6ZsJWje3FvIOYzUvqNgAaW6EX qCeg== 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 :user-agent:date:message-id:cc:subject:from:to; bh=z7UVC+KH2FvL7BTwrOt1fiA+OdxorV13LY4h7F2gjko=; b=Q0OBaIntnhuBhzcQrbA5eZrXztcFnUMEZj2Kfnmelb26FwIpn98sSCADoT0eK2fto+ D9N8rdbw+x8HIubVVc04ZYULyxGzjVWi1n4OfH5R2B7HaExmrrAZZLFNgOzCmmc8Shzl 8A1Z4qLBaOEPuJ+MNdPMy2KVXoe4Tj9g1m6udeI4Gk3VtKq/TnFRImRXPs3Oy8Kp18J5 /+27UqCQnw+Ave0S26rdijOmpXfydR8sy4FXyzpQEiLY5HBYMk29X0OsO2C/IffgVzdU 15J++fUcwLVGO2kSmJ38qIoJazrZQAmdjob+I5i7GzKaHcnPcXTzvkCFlEdKH9ic9J9m c0Pg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o8si315031ejn.500.2021.01.12.05.03.48; Tue, 12 Jan 2021 05:04:37 -0800 (PST) Received-SPF: pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-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 S1729208AbhALLrt (ORCPT + 99 others); Tue, 12 Jan 2021 06:47:49 -0500 Received: from out30-42.freemail.mail.aliyun.com ([115.124.30.42]:45828 "EHLO out30-42.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730958AbhALLrs (ORCPT ); Tue, 12 Jan 2021 06:47:48 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R111e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04423;MF=xiaoguang.wang@linux.alibaba.com;NM=1;PH=DS;RN=2;SR=0;TI=SMTPD_---0ULWk8Hc_1610452025; Received: from 30.225.32.185(mailfrom:xiaoguang.wang@linux.alibaba.com fp:SMTPD_---0ULWk8Hc_1610452025) by smtp.aliyun-inc.com(127.0.0.1); Tue, 12 Jan 2021 19:47:06 +0800 To: Ext4 Developers List From: Xiaoguang Wang Subject: code questions about ext4_inode_datasync_dirty() Cc: joseph qi Message-ID: Date: Tue, 12 Jan 2021 19:45:06 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 Content-Type: text/plain; charset=gbk; format=flowed Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org hi, I use io_uring to evaluate ext4 randread performance(direct io), observed obvious overhead in jbd2_transaction_committed(): Samples: 124K of event 'cycles:ppp', Event count (approx.): 80630088951 Overhead Command Shared Object Symbol 7.02% io_uring-sq-per [kernel.kallsyms] [k] jbd2_transaction_committed The codes: /* * Writes that span EOF might trigger an I/O size update on completion, * so consider them to be dirty for the purpose of O_DSYNC, even if * there is no other metadata changes being made or are pending. */ iomap->flags = 0; if (ext4_inode_datasync_dirty(inode) || offset + length > i_size_read(inode)) iomap->flags |= IOMAP_F_DIRTY; ext4_inode_datasync_dirty() calls jbd2_transaction_committed(). Sorry, I don't spend much time to learn iomap codes yet, just ask a quick question here. Do we need to call ext4_inode_datasync_dirty() for a read operation? If we must call ext4_inode_datasync_dirty() for a read operation, can we improve jbd2_transaction_committed() a bit, for example, have a quick check between inode->i_datasync_tid and j_commit_sequence, if inode->i_datasync_tid is less than or equal to j_commit_sequence, we also don't call jbd2_transaction_committed()? Regards, Xiaoguang Wang