From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.2 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 6AE23C11F69 for ; Wed, 30 Jun 2021 08:31:12 +0000 (UTC) Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [216.205.24.124]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 140CD61D06 for ; Wed, 30 Jun 2021 08:31:11 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 140CD61D06 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.com Authentication-Results: mail.kernel.org; spf=tempfail smtp.mailfrom=dm-devel-bounces@redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1625041871; h=from:from:sender:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:list-id:list-help: list-unsubscribe:list-subscribe:list-post; bh=gawJ1ue7Gnphoq76WXs1GLqJOVRGBJBtHrTl9VLbKfI=; b=Ql2erHGpbPCssj2gs25YyljUwI8Hf0AoWY4jLKmu8d8nv8KXR6Z3/GtJl9LTpoH1OJp9qu QexpJYT4WzQqkK6kI01AeBFa+R/m11E/YRmTVBmbYydXjPy4Vi3qJEdWPbCxEMvKXhd8wc +LWsiGv7l4xo8aaNs+ELr5PYNibKSC0= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-109-iHKqSeW2NvCdrdSUCUkgmA-1; Wed, 30 Jun 2021 04:31:09 -0400 X-MC-Unique: iHKqSeW2NvCdrdSUCUkgmA-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 42D801936B60; Wed, 30 Jun 2021 08:31:04 +0000 (UTC) Received: from colo-mx.corp.redhat.com (colo-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.21]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 8D30960C13; Wed, 30 Jun 2021 08:31:03 +0000 (UTC) Received: from lists01.pubmisc.prod.ext.phx2.redhat.com (lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33]) by colo-mx.corp.redhat.com (Postfix) with ESMTP id C22B14EA2A; Wed, 30 Jun 2021 08:31:01 +0000 (UTC) Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP id 15U8Uxmc014352 for ; Wed, 30 Jun 2021 04:30:59 -0400 Received: by smtp.corp.redhat.com (Postfix) id D9A0260C13; Wed, 30 Jun 2021 08:30:59 +0000 (UTC) Received: from T590 (ovpn-13-153.pek2.redhat.com [10.72.13.153]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 98A1160C81; Wed, 30 Jun 2021 08:30:46 +0000 (UTC) Date: Wed, 30 Jun 2021 16:30:41 +0800 From: Ming Lei To: JeffleXu Message-ID: References: <20210617103549.930311-1-ming.lei@redhat.com> <20210617103549.930311-4-ming.lei@redhat.com> <5ba43dac-b960-7c85-3a89-fdae2d1e2f51@linux.alibaba.com> <9b42601a-ca54-4748-e592-3720b7994d7b@linux.alibaba.com> MIME-Version: 1.0 In-Reply-To: <9b42601a-ca54-4748-e592-3720b7994d7b@linux.alibaba.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-loop: dm-devel@redhat.com Cc: Jens Axboe , linux-block@vger.kernel.org, dm-devel@redhat.com, Christoph Hellwig , Mike Snitzer Subject: Re: [dm-devel] [RFC PATCH V2 3/3] dm: support bio polling X-BeenThere: dm-devel@redhat.com X-Mailman-Version: 2.1.12 Precedence: junk List-Id: device-mapper development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: dm-devel-bounces@redhat.com Errors-To: dm-devel-bounces@redhat.com X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=dm-devel-bounces@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Disposition: inline Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 T24gTW9uLCBKdW4gMjEsIDIwMjEgYXQgMDc6MzM6MzRQTSArMDgwMCwgSmVmZmxlWHUgd3JvdGU6 Cj4gCj4gCj4gT24gNi8xOC8yMSAxMDozOSBQTSwgTWluZyBMZWkgd3JvdGU6Cj4gPiBGcm9tIDQ3 ZTUyM2I5ZWU5ODgzMTczNjllYWFkYjk2ODI2MzIzY2Q4NjgxOWUgTW9uIFNlcCAxNyAwMDowMDow MCAyMDAxCj4gPiBGcm9tOiBNaW5nIExlaSA8bWluZy5sZWlAcmVkaGF0LmNvbT4KPiA+IERhdGU6 IFdlZCwgMTYgSnVuIDIwMjEgMTY6MTM6NDYgKzA4MDAKPiA+IFN1YmplY3Q6IFtSRkMgUEFUQ0gg VjMgMy8zXSBkbTogc3VwcG9ydCBiaW8gcG9sbGluZwo+ID4gCj4gPiBTdXBwb3J0IGJpbyhSRVFf UE9MTEVEKSBwb2xsaW5nIGluIHRoZSBmb2xsb3dpbmcgYXBwcm9hY2g6Cj4gPiAKPiA+IDEpIG9u bHkgc3VwcG9ydCBpbyBwb2xsaW5nIG9uIG5vcm1hbCBSRUFEL1dSSVRFLCBhbmQgb3RoZXIgYWJu b3JtYWwgSU9zCj4gPiBzdGlsbCBmYWxsYmFjayBvbiBJUlEgbW9kZSwgc28gdGhlIHRhcmdldCBp byBpcyBleGFjdGx5IGluc2lkZSB0aGUgZG0KPiA+IGlvLgo+ID4gCj4gPiAyKSBob2xkIG9uZSBy ZWZjbnQgb24gaW8tPmlvX2NvdW50IGFmdGVyIHN1Ym1pdHRpbmcgdGhpcyBkbSBiaW8gd2l0aAo+ ID4gUkVRX1BPTExFRAo+ID4gCj4gPiAzKSBzdXBwb3J0IGRtIG5hdGl2ZSBiaW8gc3BsaXR0aW5n LCBhbnkgZG0gaW8gaW5zdGFuY2UgYXNzb2NpYXRlZCB3aXRoCj4gPiBjdXJyZW50IGJpbyB3aWxs IGJlIGFkZGVkIGludG8gb25lIGxpc3Qgd2hpY2ggaGVhZCBpcyBiaW8tPmJpX2VuZF9pbwo+ID4g d2hpY2ggd2lsbCBiZSByZWNvdmVyZWQgYmVmb3JlIGVuZGluZyB0aGlzIGJpbwo+ID4gCj4gPiA0 KSBpbXBsZW1lbnQgLnBvbGxfYmlvKCkgY2FsbGJhY2ssIGNhbGwgYmlvX3BvbGwoKSBvbiB0aGUg c2luZ2xlIHRhcmdldAo+ID4gYmlvIGluc2lkZSB0aGUgZG0gaW8gd2hpY2ggaXMgcmV0cmlldmVk IHZpYSBiaW8tPmJpX2Jpb19kcnZfZGF0YTsgY2FsbAo+ID4gZGVjX3BlbmRpbmcoKSBhZnRlciB0 aGUgdGFyZ2V0IGlvIGlzIGRvbmUgaW4gLnBvbGxfYmlvKCkKPiA+IAo+ID4gNCkgZW5hYmxlIFFV RVVFX0ZMQUdfUE9MTCBpZiBhbGwgdW5kZXJseWluZyBxdWV1ZXMgZW5hYmxlIFFVRVVFX0ZMQUdf UE9MTCwKPiA+IHdoaWNoIGlzIGJhc2VkIG9uIEplZmZsZSdzIHByZXZpb3VzIHBhdGNoLgo+ID4g Cj4gPiBTaWduZWQtb2ZmLWJ5OiBNaW5nIExlaSA8bWluZy5sZWlAcmVkaGF0LmNvbT4KPiA+IC0t LQo+ID4gVjM6Cj4gPiAJLSBjb3ZlcnMgYWxsIGNvbW1lbnRzIGZyb20gSmVmZmxlCj4gPiAJLSBm aXggY29ybmVyIGNhc2VzIHdoZW4gcG9sbGluZyBvbiBhYm5vcm1hbCBpb3MKPiA+IAo+IC4uLgo+ IAo+IE9uZSBidWcgYW5kIG9uZSBwZXJmb3JtYW5jZSBpc3N1ZSwgdGhvdWdoIEkgaGF2ZW4ndCBp bnZlc3RpZ2F0ZWQgZGVlcAo+IGZvciBib3RoLgo+IAo+IAo+IGtlcm5lbCBiYXNlOiBiYXNlZCBv biBKZW5zJyBmb3ItbmV4dCwgYXBwbHlpbmcgQ2hyaXN0b3BoIGFuZCBMZWltaW5nJ3MKPiBwYXRj aHNldC4KPiAKPiAKPiAxLiBPbmUgYnVnIHdoZW4gdGhlcmUncyBETSBkZXZpY2Ugc3RhY2ssIGUu Zy4sIGRtLWxpbmVhciB1cG9uIGFub3RoZXIKPiBkbS1saW5lYXIuIENhbiBiZSByZXByb2R1Y2Vk IGJ5IGZvbGxvd2luZyBzdGVwczoKPiAKPiBgYGAKPiAkIHN1ZG8gZG1zZXR1cCBjcmVhdGUgdG1w ZGV2IC0tdGFibGUgJzAgMjA5NzE1MiBsaW5lYXIgL2Rldi9udm1lMG4xIDAnCj4gCj4gJCBjYXQg dG1wLnRhYmxlCj4gMCAyMDk3MTUyIGxpbmVhciAvZGV2L21hcHBlci90bXBkZXYgMAo+IDIwOTcx NTIgMjA5NzE1MiBsaW5lYXIgL2Rldi9udm1lMG4xIDAKPiAKPiAkIGNhdCB0bXAudGFibGUgfCBk bXNldHVwIGNyZWF0ZSB0ZXN0ZGV2Cj4gCj4gJCBmaW8gLW5hbWU9dGVzdCAtaW9lbmdpbmU9aW9f dXJpbmcgLWlvZGVwdGg9MTI4IC1udW1qb2JzPTEgLXRocmVhZAo+IC1ydz1yYW5kcmVhZCAtZGly ZWN0PTEgLWJzPTRrIC10aW1lX2Jhc2VkIC1ydW50aW1lPTEwIC1jcHVzX2FsbG93ZWQ9Ngo+IC1m aWxlbmFtZT0vZGV2L21hcHBlci90ZXN0ZGV2IC1oaXByaT0xCj4gYGBgCj4gCj4gCj4gQlVHOiB1 bmFibGUgdG8gaGFuZGxlIHBhZ2UgZmF1bHQgZm9yIGFkZHJlc3M6IGZmZmZmZmZmYzAxYTYyMDgK PiAjUEY6IHN1cGVydmlzb3Igd3JpdGUgYWNjZXNzIGluIGtlcm5lbCBtb2RlCj4gI1BGOiBlcnJv cl9jb2RlKDB4MDAwMykgLSBwZXJtaXNzaW9ucyB2aW9sYXRpb24KPiBQR0QgMzk3NDBjMDY3IFA0 RCAzOTc0MGMwNjcgUFVEIDM5NzQwZTA2NyBQTUQgMTAzNWRiMDY3IFBURSAxZGRmNmYwNjEKPiBP b3BzOiAwMDAzIFsjMV0gU01QIFBUSQo+IENQVTogNiBQSUQ6IDU4OTkgQ29tbTogZmlvIFRhaW50 ZWQ6IEcgUwo+IDUuMTMuMC0wLjEuZ2l0LjgxYmNkYzMuYWw3Lng4Nl82NCAjMQo+IEhhcmR3YXJl IG5hbWU6IEludmVudGVjICAgICBLOTAwRzMtMTBHL0I5MDBHMywgQklPUyBBMi4yMCAwNi8yMy8y MDE3Cj4gUklQOiAwMDEwOmRtX3N1Ym1pdF9iaW8rMHgxNzEvMHgzZTAgW2RtX21vZF0KPiBDb2Rl OiAwOCA4NSBjMCAwZiA4NCA3OCAwMSAwMCAwMCA4MCA3YyAyNCAyYyAwMCAwZiA4NCBiOCAwMCAw MCAwMCA0OCA4Ygo+IDUzIDM4IDQ4IDhiIDQ0IDI0IDE4IDQ4IDg1IGQyIDQ4IDhkIDQ4IDI4IDQ4 IDg5IDUwIDI4IDc0IDA0IDw0OD4gODkgNGEKPiAwOCA0OCA4OSA0YiAzOCA0OCA4MyBjMyAzOCA0 OCA4OSA1OCAzMCA0MSBmNyBjNSBmZSBmZiBmZgo+IFJTUDogMDAxODpmZmZmOWU1YzQ1ZTFiOWEw IEVGTEFHUzogMDAwMTAyODYKPiBSQVg6IGZmZmY4YWI1OWZkNTAxNDAgUkJYOiBmZmZmOGFiNTlm ZDUwMDg4IFJDWDogZmZmZjhhYjU5ZmQ1MDE2OAo+IFJEWDogZmZmZmZmZmZjMDFhNjIwMCBSU0k6 IDAwMDAwMDAwMDAwNTJmMDggUkRJOiAwMDAwMDAwMDAwMDAwMDAwCj4gUkJQOiBmZmZmOGFiNTlm ZDUwMWM4IFIwODogMDAwMDAwMDAwMDAwMDAwMCBSMDk6IDAwMDAwMDAwMDAwMDAwMDAKPiBSMTA6 IGZmZmY5ZTVjNDVlMWI5NTAgUjExOiAwMDAwMDAwMDAwMDAwMDA3IFIxMjogZmZmZjhhYjRjMmJj MjAwMAo+IFIxMzogMDAwMDAwMDAwMDAwMDAwMCBSMTQ6IGZmZmY4YWI0YzJiYzI1NDggUjE1OiBm ZmZmOGFiNTlmZDUwMTQwCj4gRlM6ICAwMDAwN2Y1NTVkZTQyNzAwKDAwMDApIEdTOmZmZmY4YWYz M2YxODAwMDAoMDAwMCkga25sR1M6MDAwMDAwMDAwMDAwMDAwMAo+IENTOiAgMDAxMCBEUzogMDAw MCBFUzogMDAwMCBDUjA6IDAwMDAwMDAwODAwNTAwMzMKPiBDUjI6IGZmZmZmZmZmYzAxYTYyMDgg Q1IzOiAwMDAwMDAwMTI0OTkwMDA1IENSNDogMDAwMDAwMDAwMDM3MDZlMAo+IERSMDogMDAwMDAw MDAwMDAwMDAwMCBEUjE6IDAwMDAwMDAwMDAwMDAwMDAgRFIyOiAwMDAwMDAwMDAwMDAwMDAwCj4g RFIzOiAwMDAwMDAwMDAwMDAwMDAwIERSNjogMDAwMDAwMDBmZmZlMGZmMCBEUjc6IDAwMDAwMDAw MDAwMDA0MDAKPiBDYWxsIFRyYWNlOgo+ICBzdWJtaXRfYmlvX25vYWNjdCsweDE0NC8weDNmMAo+ ICA/IHN1Ym1pdF9iaW8rMHg0Mi8weDEyMAo+ICBzdWJtaXRfYmlvKzB4NDIvMHgxMjAKPiAgYmxr ZGV2X2RpcmVjdF9JTysweDQ1NC8weDRiMAo+ICA/IGlvX3Jlc3VibWl0X3ByZXArMHg0MC8weDQw Cj4gID8gX19mc25vdGlmeV9wYXJlbnQrMHhmZi8weDM1MAo+ICA/IF9fZnNub3RpZnlfcGFyZW50 KzB4MTBmLzB4MzUwCj4gID8gZ2VuZXJpY19maWxlX3JlYWRfaXRlcisweDgzLzB4MTUwCj4gIGdl bmVyaWNfZmlsZV9yZWFkX2l0ZXIrMHg4My8weDE1MAo+ICBibGtkZXZfcmVhZF9pdGVyKzB4NDEv MHg1MAo+ICBpb19yZWFkKzB4ZTkvMHg0MjAKPiAgPyBfX2NvbmRfcmVzY2hlZCsweDE2LzB4NDAK PiAgPyBfX2ttYWxsb2Nfbm9kZSsweDE2ZS8weDRlMAo+ICA/IG1lbWNnX2FsbG9jX3BhZ2Vfb2Jq X2Nncm91cHMrMHgzMi8weDkwCj4gID8gaW9faXNzdWVfc3FlKzB4N2U4LzB4MTI2MAo+ICBpb19p c3N1ZV9zcWUrMHg3ZTgvMHgxMjYwCj4gID8gaW9fc3VibWl0X3NxZXMrMHg0N2IvMHgxNDIwCj4g IF9faW9fcXVldWVfc3FlKzB4NTYvMHgzODAKPiAgPyBpb19zdWJtaXRfc3FlcysweDEyMGEvMHgx NDIwCj4gIGlvX3N1Ym1pdF9zcWVzKzB4MTIwYS8weDE0MjAKPiAgPyBfX3g2NF9zeXNfaW9fdXJp bmdfZW50ZXIrMHgxZDIvMHgzZTAKPiAgX194NjRfc3lzX2lvX3VyaW5nX2VudGVyKzB4MWQyLzB4 M2UwCj4gID8gZXhpdF90b191c2VyX21vZGVfcHJlcGFyZSsweDRjLzB4MjEwCj4gIGRvX3N5c2Nh bGxfNjQrMHgzNi8weDcwCj4gIGVudHJ5X1NZU0NBTExfNjRfYWZ0ZXJfaHdmcmFtZSsweDQ0LzB4 YWUKPiBSSVA6IDAwMzM6MHg3ZjU1ZDNjYjFiNTkKPiBDb2RlOiAwMCBmMyBjMyA2NiAyZSAwZiAx ZiA4NCAwMCAwMCAwMCAwMCAwMCAwZiAxZiA0MCAwMCA0OCA4OSBmOCA0OCA4OQo+IGY3IDQ4IDg5 IGQ2IDQ4IDg5IGNhIDRkIDg5IGMyIDRkIDg5IGM4IDRjIDhiIDRjIDI0IDA4IDBmIDA1IDw0OD4g M2QgMDEKPiBmMCBmZiBmZiA3MyAwMSBjMyA0OCA4YiAwZCBmZiBlMiAyYiAwMCBmNyBkOCA2NCA4 OSAwMSA0OAo+IFJTUDogMDAyYjowMDAwN2Y1NTVkZTQxYjE4IEVGTEFHUzogMDAwMDAyNDYgT1JJ R19SQVg6IDAwMDAwMDAwMDAwMDAxYWEKPiBSQVg6IGZmZmZmZmZmZmZmZmZmZGEgUkJYOiAwMDAw MDAwMDAwMDAwMDAxIFJDWDogMDAwMDdmNTVkM2NiMWI1OQo+IFJEWDogMDAwMDAwMDAwMDAwMDAw MCBSU0k6IDAwMDAwMDAwMDAwMDAwMDEgUkRJOiAwMDAwMDAwMDAwMDAwMDA1Cj4gUkJQOiAwMDAw N2Y1NTdjZTgxMDAwIFIwODogMDAwMDAwMDAwMDAwMDAwMCBSMDk6IDAwMDAwMDAwMDAwMDAwMDAK PiBSMTA6IDAwMDAwMDAwMDAwMDAwMDEgUjExOiAwMDAwMDAwMDAwMDAwMjQ2IFIxMjogMDAwMDAw MDAwMTI3NjAwMAo+IFIxMzogMDAwMDAwMDAwMDAwMDAwMSBSMTQ6IDAwMDAwMDAwMDAwMDAwMDAg UjE1OiAwMDAwMDAwMDAxMmM4MzI4Cj4gCj4gCj4gCj4gCj4gMi4gUGVyZm9ybWFuY2UgSXNzdWUK PiAKPiBJIHRlc3QgYm90aCBvbiB4ODYgKHdpdGggb25seSBvbmUgTlZNZSkgYW5kIGFhcmNoNjQg KHdpdGggbXVsdGlwbGUgTlZNZXMpLgo+IAo+IFRoZSByZXN1bHQgKElPUFMpIG9uIHg4NiBpcyBh cyBleHBlY3RlZDoKPiAKPiBUeXBlIAkgIHxJUlEgICB8IFBvbGxpbmcKPiAtLS0tLS0tLS0gfCAt LS0tIHwgLS0tLQo+IGRtLWxpbmVhciB8IDIzOWsgfCAzNTdrCj4gCj4gLSBkbS1saW5lYXIgYnVp bHQgdXBvbiBvbmUgTlZNZe+8jGJzPTRrLCBpb3BvbGw9MSwgaW9kZXB0aD0xMjgsCj4gbnVtam9i cz0xLCBkaXJlY3QsIHJhbmRyZWFkLCBpb2VuZ2luZT1pb191cmluZwo+IAo+IAo+IAo+IFdoaWxl IHRoZSByZXN1bHQgb24gYWFyY2g2NCBpcyBhIGxpdHRsZSBjb25mdXNpbmcuCj4gCj4gVHlwZSAJ ICAgICAgfElSUSAgIHwgUG9sbGluZwo+IC0tLS0tLS0tLS0tLS0gfCAtLS0tIHwgLS0tLQo+IGRt LWxpbmVhciBbMV0gfCAyMDhrIHwgMjMwawo+IGRtLWxpbmVhciBbMl0gfCA2MzdrIHwgNjkxawo+ IGRtLXN0cmlwZSAgICAgfCAzMTBrIHwgMzU0awo+IAo+IC0gZG0tbGluZWFyIFsxXSBidWlsdCB1 cG9uICpvbmUqIE5WTWXvvIxicz00aywgaW9wb2xsPTEsIGlvZGVwdGg9MTI4LAo+ICpudW1qb2Jz PTEqLCBkaXJlY3QsIHJhbmRyZWFkLCBpb2VuZ2luZT1pb191cmluZwo+IC0gZG0tbGluZWFyIFsy XSBidWlsdCB1cG9uICp0aHJlZSogTlZNZXPvvIxicz00aywgaW9wb2xsPTEsIGlvZGVwdGg9MTI4 LAo+ICpudW1qb2JzPTMqLCBkaXJlY3QsIHJhbmRyZWFkLCBpb2VuZ2luZT1pb191cmluZwo+IC0g ZG0tc3RyaXBlIGJ1aWx0IHVwb24gKnRocmVlKiBOVk1lc++8jGNodW5rX3NpemU9NGssIGJzPTEy aywgaW9wb2xsPTEsCj4gaW9kZXB0aD0xMjgsIG51bWpvYnM9MywgZGlyZWN0LCByYW5kcmVhZCwg aW9lbmdpbmU9aW9fdXJpbmcKClRvZGF5IEkgZm91bmQgdGhlIGZvbGxvd2luZyBwYXRjaCBtYWtl cyBhIGJpZyBkaWZmZXJlbmNlIG9uIGFhcmNoNjQKbnZtZSBpbyBwb2xsaW5nLCBhbmQgeW91IGNh biB0cnkgdGhhdCBpbiB5b3VyIHRlc3Q6CgpodHRwczovL2xvcmUua2VybmVsLm9yZy9saW51eC1i bG9jay9ZTndmWTZrRXhxSk02NStMQFQ1OTAvVC8jbTkzNGZhYmY1ODhkNzA5MTA5ZmQ5OTA0MGEz ZTI2ZDdhOTgzOGRiMWYKaHR0cHM6Ly9sb3JlLmtlcm5lbC5vcmcvbGludXgtYmxvY2svWU53Zlk2 a0V4cUpNNjUrTEBUNTkwL1QvI200NTA0YjAxZDA2NTY2YjIwODAyMTY2NDA2MjVmYWM1ZmRkMzky OWU1CgpCVFcsIG15IHRlc3QgbWFjaGluZSBpcyBhbXBlcmUoMTYwY29yZXMsIGR1YWwgbnVtYSBu b2RlcykuCgoKVGhhbmtzLApNaW5nCgotLQpkbS1kZXZlbCBtYWlsaW5nIGxpc3QKZG0tZGV2ZWxA cmVkaGF0LmNvbQpodHRwczovL2xpc3RtYW4ucmVkaGF0LmNvbS9tYWlsbWFuL2xpc3RpbmZvL2Rt LWRldmVs From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.2 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 05452C11F65 for ; Wed, 30 Jun 2021 08:31:21 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id DFCA861CC6 for ; Wed, 30 Jun 2021 08:31:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233223AbhF3Ids (ORCPT ); Wed, 30 Jun 2021 04:33:48 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:36764 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233005AbhF3Ids (ORCPT ); Wed, 30 Jun 2021 04:33:48 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1625041879; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=jsfA3/eVFJ7YgyybwGUP7V3ugew9xbOFFkzq2gfdhHM=; b=W+AXJrgNF8zMLyt4KG2A4U7lQZX+U58qWymC/PXS8VXvaRrsazK/Zo0wR/WGXT9VHSpr8W EgOJaz8Ggd7MVQW6cZ2qN7rlrl6/OoEwExdrv5fzOnE90XDsLcyV4Ltt05d//hsIIQWvTY xOgyvZq6t1VKRIMswvX/X9O1fr723Pc= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-487-j8Z8E95XOJ2IJMoWgYb7cQ-1; Wed, 30 Jun 2021 04:31:01 -0400 X-MC-Unique: j8Z8E95XOJ2IJMoWgYb7cQ-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id DB1EC9F92D; Wed, 30 Jun 2021 08:30:59 +0000 (UTC) Received: from T590 (ovpn-13-153.pek2.redhat.com [10.72.13.153]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 98A1160C81; Wed, 30 Jun 2021 08:30:46 +0000 (UTC) Date: Wed, 30 Jun 2021 16:30:41 +0800 From: Ming Lei To: JeffleXu Cc: Jens Axboe , Mike Snitzer , linux-block@vger.kernel.org, dm-devel@redhat.com, Christoph Hellwig Subject: Re: [dm-devel] [RFC PATCH V2 3/3] dm: support bio polling Message-ID: References: <20210617103549.930311-1-ming.lei@redhat.com> <20210617103549.930311-4-ming.lei@redhat.com> <5ba43dac-b960-7c85-3a89-fdae2d1e2f51@linux.alibaba.com> <9b42601a-ca54-4748-e592-3720b7994d7b@linux.alibaba.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <9b42601a-ca54-4748-e592-3720b7994d7b@linux.alibaba.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 Precedence: bulk List-ID: X-Mailing-List: linux-block@vger.kernel.org On Mon, Jun 21, 2021 at 07:33:34PM +0800, JeffleXu wrote: > > > On 6/18/21 10:39 PM, Ming Lei wrote: > > From 47e523b9ee988317369eaadb96826323cd86819e Mon Sep 17 00:00:00 2001 > > From: Ming Lei > > Date: Wed, 16 Jun 2021 16:13:46 +0800 > > Subject: [RFC PATCH V3 3/3] dm: support bio polling > > > > Support bio(REQ_POLLED) polling in the following approach: > > > > 1) only support io polling on normal READ/WRITE, and other abnormal IOs > > still fallback on IRQ mode, so the target io is exactly inside the dm > > io. > > > > 2) hold one refcnt on io->io_count after submitting this dm bio with > > REQ_POLLED > > > > 3) support dm native bio splitting, any dm io instance associated with > > current bio will be added into one list which head is bio->bi_end_io > > which will be recovered before ending this bio > > > > 4) implement .poll_bio() callback, call bio_poll() on the single target > > bio inside the dm io which is retrieved via bio->bi_bio_drv_data; call > > dec_pending() after the target io is done in .poll_bio() > > > > 4) enable QUEUE_FLAG_POLL if all underlying queues enable QUEUE_FLAG_POLL, > > which is based on Jeffle's previous patch. > > > > Signed-off-by: Ming Lei > > --- > > V3: > > - covers all comments from Jeffle > > - fix corner cases when polling on abnormal ios > > > ... > > One bug and one performance issue, though I haven't investigated deep > for both. > > > kernel base: based on Jens' for-next, applying Christoph and Leiming's > patchset. > > > 1. One bug when there's DM device stack, e.g., dm-linear upon another > dm-linear. Can be reproduced by following steps: > > ``` > $ sudo dmsetup create tmpdev --table '0 2097152 linear /dev/nvme0n1 0' > > $ cat tmp.table > 0 2097152 linear /dev/mapper/tmpdev 0 > 2097152 2097152 linear /dev/nvme0n1 0 > > $ cat tmp.table | dmsetup create testdev > > $ fio -name=test -ioengine=io_uring -iodepth=128 -numjobs=1 -thread > -rw=randread -direct=1 -bs=4k -time_based -runtime=10 -cpus_allowed=6 > -filename=/dev/mapper/testdev -hipri=1 > ``` > > > BUG: unable to handle page fault for address: ffffffffc01a6208 > #PF: supervisor write access in kernel mode > #PF: error_code(0x0003) - permissions violation > PGD 39740c067 P4D 39740c067 PUD 39740e067 PMD 1035db067 PTE 1ddf6f061 > Oops: 0003 [#1] SMP PTI > CPU: 6 PID: 5899 Comm: fio Tainted: G S > 5.13.0-0.1.git.81bcdc3.al7.x86_64 #1 > Hardware name: Inventec K900G3-10G/B900G3, BIOS A2.20 06/23/2017 > RIP: 0010:dm_submit_bio+0x171/0x3e0 [dm_mod] > Code: 08 85 c0 0f 84 78 01 00 00 80 7c 24 2c 00 0f 84 b8 00 00 00 48 8b > 53 38 48 8b 44 24 18 48 85 d2 48 8d 48 28 48 89 50 28 74 04 <48> 89 4a > 08 48 89 4b 38 48 83 c3 38 48 89 58 30 41 f7 c5 fe ff ff > RSP: 0018:ffff9e5c45e1b9a0 EFLAGS: 00010286 > RAX: ffff8ab59fd50140 RBX: ffff8ab59fd50088 RCX: ffff8ab59fd50168 > RDX: ffffffffc01a6200 RSI: 0000000000052f08 RDI: 0000000000000000 > RBP: ffff8ab59fd501c8 R08: 0000000000000000 R09: 0000000000000000 > R10: ffff9e5c45e1b950 R11: 0000000000000007 R12: ffff8ab4c2bc2000 > R13: 0000000000000000 R14: ffff8ab4c2bc2548 R15: ffff8ab59fd50140 > FS: 00007f555de42700(0000) GS:ffff8af33f180000(0000) knlGS:0000000000000000 > CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 > CR2: ffffffffc01a6208 CR3: 0000000124990005 CR4: 00000000003706e0 > DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000 > DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400 > Call Trace: > submit_bio_noacct+0x144/0x3f0 > ? submit_bio+0x42/0x120 > submit_bio+0x42/0x120 > blkdev_direct_IO+0x454/0x4b0 > ? io_resubmit_prep+0x40/0x40 > ? __fsnotify_parent+0xff/0x350 > ? __fsnotify_parent+0x10f/0x350 > ? generic_file_read_iter+0x83/0x150 > generic_file_read_iter+0x83/0x150 > blkdev_read_iter+0x41/0x50 > io_read+0xe9/0x420 > ? __cond_resched+0x16/0x40 > ? __kmalloc_node+0x16e/0x4e0 > ? memcg_alloc_page_obj_cgroups+0x32/0x90 > ? io_issue_sqe+0x7e8/0x1260 > io_issue_sqe+0x7e8/0x1260 > ? io_submit_sqes+0x47b/0x1420 > __io_queue_sqe+0x56/0x380 > ? io_submit_sqes+0x120a/0x1420 > io_submit_sqes+0x120a/0x1420 > ? __x64_sys_io_uring_enter+0x1d2/0x3e0 > __x64_sys_io_uring_enter+0x1d2/0x3e0 > ? exit_to_user_mode_prepare+0x4c/0x210 > do_syscall_64+0x36/0x70 > entry_SYSCALL_64_after_hwframe+0x44/0xae > RIP: 0033:0x7f55d3cb1b59 > Code: 00 f3 c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 48 89 f8 48 89 > f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 > f0 ff ff 73 01 c3 48 8b 0d ff e2 2b 00 f7 d8 64 89 01 48 > RSP: 002b:00007f555de41b18 EFLAGS: 00000246 ORIG_RAX: 00000000000001aa > RAX: ffffffffffffffda RBX: 0000000000000001 RCX: 00007f55d3cb1b59 > RDX: 0000000000000000 RSI: 0000000000000001 RDI: 0000000000000005 > RBP: 00007f557ce81000 R08: 0000000000000000 R09: 0000000000000000 > R10: 0000000000000001 R11: 0000000000000246 R12: 0000000001276000 > R13: 0000000000000001 R14: 0000000000000000 R15: 00000000012c8328 > > > > > 2. Performance Issue > > I test both on x86 (with only one NVMe) and aarch64 (with multiple NVMes). > > The result (IOPS) on x86 is as expected: > > Type |IRQ | Polling > --------- | ---- | ---- > dm-linear | 239k | 357k > > - dm-linear built upon one NVMe,bs=4k, iopoll=1, iodepth=128, > numjobs=1, direct, randread, ioengine=io_uring > > > > While the result on aarch64 is a little confusing. > > Type |IRQ | Polling > ------------- | ---- | ---- > dm-linear [1] | 208k | 230k > dm-linear [2] | 637k | 691k > dm-stripe | 310k | 354k > > - dm-linear [1] built upon *one* NVMe,bs=4k, iopoll=1, iodepth=128, > *numjobs=1*, direct, randread, ioengine=io_uring > - dm-linear [2] built upon *three* NVMes,bs=4k, iopoll=1, iodepth=128, > *numjobs=3*, direct, randread, ioengine=io_uring > - dm-stripe built upon *three* NVMes,chunk_size=4k, bs=12k, iopoll=1, > iodepth=128, numjobs=3, direct, randread, ioengine=io_uring Today I found the following patch makes a big difference on aarch64 nvme io polling, and you can try that in your test: https://lore.kernel.org/linux-block/YNwfY6kExqJM65+L@T590/T/#m934fabf588d709109fd99040a3e26d7a9838db1f https://lore.kernel.org/linux-block/YNwfY6kExqJM65+L@T590/T/#m4504b01d06566b2080216640625fac5fdd3929e5 BTW, my test machine is ampere(160cores, dual numa nodes). Thanks, Ming