Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1067610pxa; Thu, 20 Aug 2020 01:19:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzXGRW0E2rE/8SXRlGJWPnB+1uqmjpDIZQr5q6RbcckkA1jaD/ljwAe9IQkHiTLBbgq5/Hf X-Received: by 2002:a17:906:d159:: with SMTP id br25mr2097437ejb.16.1597911559689; Thu, 20 Aug 2020 01:19:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597911559; cv=none; d=google.com; s=arc-20160816; b=wp8NcwGBh9GYS01zL1AlS/QJijicd1VvSKp2gz/r4ITC35+tOPG8R4rZrHV6gzL1d4 0eQYrAW7cpTEQZ6PNUtXdi3Y9zyZmcTA8XtPAx9LIvXDzfsYm1h7JCUVE/fjqlbJwHrQ 1/NgB7qv6R9JFdrhY3lpCmUt8iMLznh5t0RG2CWeU8RUST14Ae62g3cV+W84//Zv3qoP 8b89ri/ridoEb58RnSmkV1GHM2rzvkRYu+/5LyhhAAxjEx/Hafw6ADlfVs4t2/N6ydnz TBWhaw1kIdvEDJ8QXeiq7ySFmVpD5Z1/3z5Ani/GwIVoacND3FNp0Tr+syn3xu7Jxi7b xgsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=poXc1DIYBqlmGfSgSPbKriSOzCgoq1M+inTxg9m6tUw=; b=J4rmY5OCq6oRne9k96IOtxRj5s1tP+ljZKhlg++zDGiLyGe+3bzlTU+r3xrfCjI9P0 7lhHM1ns4yaNy2QRMAji9wbXF6mvZDnEXQlJKUsU6DhfWSEtA/SbzG5nR9FGqiiFuBBg 2y6qeg+yjtNm6zwMo1NK5zkfGo/EqvKjUZfEo74plRh6x+gyFVyYULdRbJuTFIdwh5e+ Qqa1s784Oj6qNcu6GGAHd72rye2aFH7ZJC2dra6UZa+EWNxN4t0Bp8T4BbmFzcXXVoji GMwZM32S4WGtK827jE7Bt7017jRoSUG78EuW00pCkSce8J/YCONsiNaWZBB6C74xmwcH 7hlw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BiXjKHU+; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m4si757379eja.391.2020.08.20.01.18.55; Thu, 20 Aug 2020 01:19:19 -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=BiXjKHU+; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726716AbgHTISC (ORCPT + 99 others); Thu, 20 Aug 2020 04:18:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:57154 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725910AbgHTIRl (ORCPT ); Thu, 20 Aug 2020 04:17:41 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 78703207DE; Thu, 20 Aug 2020 08:17:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1597911461; bh=tnxzVI3REHYfxhlG+Le20oXiyBnTOIRi9Ha7ujsgOms=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=BiXjKHU+t3kt0dGqtIgfFJBr5zxmUNLlkx0oMPDZlYR433dwzz8qZjqWFWE3jnijg hUcICMiUQJZpweqeqgyYMB6nK/DJ3WparXIXodkZhJYJlkyR5wx2V1jBlmsyLgxTua zY6PV1YY+GAKsyE5tnpbxCA9YF0deNyUCa648srA= Date: Thu, 20 Aug 2020 10:18:01 +0200 From: Greg KH To: Mike Snitzer Cc: John Donnelly , Linux Kernel Mailing List , stable@vger.kernel.org, dm-devel@redhat.com Subject: Re: fixing 4.14-stable's broken DM cache writethrough support [was: Re: [(resend) PATCH v3: {linux-4.14.y} ] dm cache: submit writethrough writes in parallel to origin and cache] Message-ID: <20200820081801.GH4049659@kroah.com> References: <8CFF8DA9-C105-461C-8F5A-DA2BF448A135@oracle.com> <20200804124735.GA219143@kroah.com> <20200804182037.GA15453@redhat.com> <20200805143242.GC2154236@kroah.com> <20200805193409.GA21824@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200805193409.GA21824@redhat.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Aug 05, 2020 at 03:34:09PM -0400, Mike Snitzer wrote: > On Wed, Aug 05 2020 at 10:32am -0400, > Greg KH wrote: > > > On Tue, Aug 04, 2020 at 02:20:38PM -0400, Mike Snitzer wrote: > > > On Tue, Aug 04 2020 at 8:47am -0400, > > > Greg KH wrote: > > > > > > > On Tue, Aug 04, 2020 at 07:33:05AM -0500, John Donnelly wrote: > > > > > From: Mike Snitzer > > > > > > > > > > Discontinue issuing writethrough write IO in series to the origin and > > > > > then cache. > > > > > > > > > > Use bio_clone_fast() to create a new origin clone bio that will be > > > > > mapped to the origin device and then bio_chain() it to the bio that gets > > > > > remapped to the cache device. The origin clone bio does _not_ have a > > > > > copy of the per_bio_data -- as such check_if_tick_bio_needed() will not > > > > > be called. > > > > > > > > > > The cache bio (parent bio) will not complete until the origin bio has > > > > > completed -- this fulfills bio_clone_fast()'s requirements as well as > > > > > the requirement to not complete the original IO until the write IO has > > > > > completed to both the origin and cache device. > > > > > > > > > > Signed-off-by: Mike Snitzer > > > > > > > > > > (cherry picked from commit 2df3bae9a6543e90042291707b8db0cbfbae9ee9) > > > > > > > > > > Fixes: 4ec34f2196d125ff781170ddc6c3058c08ec5e73 (dm bio record: > > > > > save/restore bi_end_io and bi_integrity ) > > > > > > > > > > 4ec34f21 introduced a mkfs.ext4 hang on a LVM device that has been > > > > > modified with lvconvert --cachemode=writethrough. > > > > > > > > > > CC:stable@vger.kernel.org for 4.14.y > > > > > > > > > > Signed-off-by: John Donnelly > > > > > Reviewed-by: Somasundaram Krishnasamy > > > > > > > > > > conflicts: > > > > > drivers/md/dm-cache-target.c. - Corrected usage of > > > > > writethrough_mode(&cache->feature) that was caught by > > > > > compiler, and removed unused static functions : writethrough_endio(), > > > > > defer_writethrough_bio(), wake_deferred_writethrough_worker() > > > > > that generated warnings. > > > > > > > > What is this "conflicts nonsense"? You don't see that in any other > > > > kernel patch changelog, do you? > > > > > > > > > --- > > > > > drivers/md/dm-cache-target.c | 92 ++++++++++++++++++-------------------------- > > > > > 1 file changed, 37 insertions(+), 55 deletions(-) > > > > > > > > Please fix your email client up, it's totally broken and this does not > > > > work at all and is getting frustrating from my side here. > > > > > > > > Try sending emails to yourself and see if you can apply the patches, as > > > > the one you sent here does not work, again: > > > > > > John's inability to submit a patch that can apply aside: I do not like > > > how this patch header is constructed (yet attributed "From" me). It is > > > devoid of detail as it relates to stable@. > > > > > > Greg, please don't apply the v4 of this patch either. I'll craft a > > > proper stable@ patch that explains the reason for change and why we're > > > left having to resolve conflicts in stable@. > > > > > > But first I need to focus on sending DM changes to Linus for v5.9 merge. > > > > Ok, no worries, I'll drop all of these from my review queue and wait for > > something from you sometime in the future. > > Hey Greg, > > SO I've looked this required 4.14 stable@ backport over. Because 4.14 > already has these commits (to fix a dm integrity issue): > 1b17159e52b dm bio record: save/restore bi_end_io and bi_integrity > 248aa2645aa dm integrity: use dm_bio_record and dm_bio_restore > > DM-cache's 4.14 writethrough mode got broken because its implementation > (ab)used dm_hook_bio+dm_bio_record and predates 4.15's switch to using > bio_chain() via commit 2df3bae9a654. Without commit 2df3bae9a654 the > dm_hook_bio+dm_bio_record changes from commit 1b17159e52b break > dm-cache's writethrough support. > > So 4.14-stable now needs these 3 upstream 4.15 commits: > 8e3c3827776f dm cache: pass cache structure to mode functions > 2df3bae9a654 dm cache: submit writethrough writes in parallel to origin and cache > 9958f1d9a04e dm cache: remove all obsolete writethrough-specific code > > Applying those commits to v4.14.190 with: > git cherry-pick -x 8e3c3827776f^..9958f1d9a04e > > results in a kernel that successfully builds and should fix > 4.14-stable's broken dm-cache writethrough support. > > Are you ok with queueing up applying these 3 upstream commits to > 4.14-stable or do you need me to send a patchset? This is good enough, now all queued up, thanks! greg k-h