From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx1.redhat.com (mx1.redhat.com [209.132.183.28]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mail.server123.net (Postfix) with ESMTPS for ; Wed, 1 Jun 2016 16:10:51 +0200 (CEST) Date: Wed, 1 Jun 2016 10:02:43 -0400 From: Mike Snitzer Message-ID: <20160601140243.GC30759@redhat.com> References: <07bf01d1bbbd$53991750$facb45f0$@codenest.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <07bf01d1bbbd$53991750$facb45f0$@codenest.com> Subject: Re: [dm-crypt] dm-log-writes: fix bug with too large bios List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: James Johnston Cc: 'Mikulas Patocka' , "'Alasdair G. Kergon'" , 'Josef Bacik' , 'Eric Wheeler' , dm-crypt@saout.de, dm-devel@redhat.com, 'Neil Brown' , linux-raid@vger.kernel.org, linux-bcache@vger.kernel.org, 'Kent Overstreet' , 'Tim Small' On Wed, Jun 01 2016 at 12:23am -0400, James Johnston wrote: > Hi Mikulas, > > > bio_alloc can allocate a bio with at most BIO_MAX_PAGES (256) vector > > entries. However, the incoming bio may have more vector entries if it was > > allocated by other means. For example, bcache submits bios with more than > > BIO_MAX_PAGES entries. This results in bio_alloc failure. > > > > To avoid the failure, change the code so that it allocates bio with at > > most BIO_MAX_PAGES entries. If the incoming bio has more entries, > > bio_add_page will fail and a new bio will be allocated - the code that > > handles bio_add_page failure already exists in the dm-log-writes target. > > > > Also, move atomic_inc(&lc->io_blocks) before bio_alloc to fix a bug that > > the target hangs if bio_alloc fails. The error path does put_io_block(lc), > > so we must do atomic_inc(&lc->io_blocks) before invoking the error path to > > avoid underflow of lc->io_blocks. > > > > Signed-off-by: Mikulas Patocka > > Cc: stable@vger.kernel.org # v4.1+ > > How does this relate to the previous patch you made to dm-crypt? How best > should I test this? It looks like the dm-crypt patch fixed the problem. > > Should I test by applying this patch ONLY and reverting the dm-crypt patch? > (i.e. does this patch also fix the problem.) Or should I just test with > both patches applied simultaneously? The dm-log-writes patch has nothing to do with the dm-crypt patch. It is just that both targets have comparable issues with bcache issuing really large bios.