From patchwork Thu Jan 9 13:49:11 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mikulas Patocka X-Patchwork-Id: 13932607 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C78181FFC4E for ; Thu, 9 Jan 2025 13:49:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=170.10.133.124 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736430564; cv=none; b=kgt4WBA0W5ZbUhoY8TM5K1p8bnJTALouE6x3D+2cz+HTfQ9ls3Vh/JFu5V98OvzT7JigBqV8t9Cyk6sRHipzYCz6LM2FQwEN3ishmSjq0YyosBd9btMXZhiqE8ndcP5kIQc3E8cXfCoyL+mcr55eCtyIa2QCvinZsUHvGJOueas= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736430564; c=relaxed/simple; bh=TzJOsxj0dkWiwAK+ED7JYMUThliDNRG/ikqiR7rZxSU=; h=Date:From:To:cc:Subject:Message-ID:MIME-Version:Content-Type; b=cmdxyLVCzaLu87je+jETXBQD0TJLfk9OAtrimTRW008xvXHs7mZJ/0TYKTlmw11ys+W0pIesO8gTv0N0M3fg/VB9stLqzpS0/ONIfM/KLPAf5//6MxiW7QOhlivg/A1VdxSprWpVMEvfcy8ODf/bbZT7Qvp8SC8E/UrpQPHVEzI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com; spf=pass smtp.mailfrom=redhat.com; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b=KMe2+WH5; arc=none smtp.client-ip=170.10.133.124 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=redhat.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="KMe2+WH5" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1736430560; 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; bh=7M6JmV1Z4Feo1qwBbf8wulQga1EBG//Hepfi2cQMJUA=; b=KMe2+WH51lM0VhFZcrl/e7ItOH8I41ENFASMEoACp/38K8KO37pZIy2UJCDd6t42pl8tfT ww7i/XIrnUVegRAua1brTPdW1dJ2/qJF55CSth+AuCTvzUlK4UbIS0cKMs/sqpUCaWo5or gXfPR5jZCiFFgYVwOn4PM8cEqoSjDkE= Received: from mx-prod-mc-01.mail-002.prod.us-west-2.aws.redhat.com (ec2-54-186-198-63.us-west-2.compute.amazonaws.com [54.186.198.63]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-258-gtXbp26SP-uj9ipmOh2KlQ-1; Thu, 09 Jan 2025 08:49:17 -0500 X-MC-Unique: gtXbp26SP-uj9ipmOh2KlQ-1 X-Mimecast-MFC-AGG-ID: gtXbp26SP-uj9ipmOh2KlQ Received: from mx-prod-int-04.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-04.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.40]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mx-prod-mc-01.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id 669A01955F43; Thu, 9 Jan 2025 13:49:16 +0000 (UTC) Received: from [10.45.224.27] (unknown [10.45.224.27]) by mx-prod-int-04.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id AD2BF19560AD; Thu, 9 Jan 2025 13:49:14 +0000 (UTC) Date: Thu, 9 Jan 2025 14:49:11 +0100 (CET) From: Mikulas Patocka To: Alasdair Kergon , Mike Snitzer , Jens Axboe cc: dm-devel@lists.linux.dev, linux-block@vger.kernel.org Subject: [PATCH] dm: disable REQ_NOWAIT for flushes Message-ID: <79cd51da-2546-de7e-86e1-be6a835721e2@redhat.com> Precedence: bulk X-Mailing-List: dm-devel@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-Scanned-By: MIMEDefang 3.0 on 10.30.177.40 REQ_NOWAIT for flushes cannot be easily supported by device mapper because it may allocate multiple bios and its impossible to undo if one of those allocations wants to wait. So, this patch disables REQ_NOWAIT flushes in device mapper and we always return EAGAIN. Previously, the code accepted REQ_NOWAIT flushes, but the non-blocking execution was not guaranteed. Signed-off-by: Mikulas Patocka --- drivers/md/dm.c | 9 +++++++++ 1 file changed, 9 insertions(+) Index: linux-2.6/drivers/md/dm.c =================================================================== --- linux-2.6.orig/drivers/md/dm.c 2025-01-08 17:26:52.000000000 +0100 +++ linux-2.6/drivers/md/dm.c 2025-01-08 17:44:59.000000000 +0100 @@ -1968,6 +1968,15 @@ static void dm_split_and_process_bio(str /* Only support nowait for normal IO */ if (unlikely(bio->bi_opf & REQ_NOWAIT) && !is_abnormal) { + /* + * Don't support NOWAIT for FLUSH because it may allocate + * multiple bios and there's no easy way how to undo the + * allocations. + */ + if (bio->bi_opf & REQ_PREFLUSH) { + bio_wouldblock_error(bio); + return; + } io = alloc_io(md, bio, GFP_NOWAIT); if (unlikely(!io)) { /* Unable to do anything without dm_io. */