From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753979Ab2LNIdl (ORCPT ); Fri, 14 Dec 2012 03:33:41 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:42569 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751312Ab2LNIdk (ORCPT ); Fri, 14 Dec 2012 03:33:40 -0500 Date: Fri, 14 Dec 2012 00:33:28 -0800 From: Andrew Morton To: Andy Shevchenko Cc: Andy Shevchenko , linux-kernel@vger.kernel.org, Viresh Kumar , Vinod Koul Subject: Re: [PATCH 2/2] dmatest: check for dma mapping error Message-Id: <20121214003328.46cba41c.akpm@linux-foundation.org> In-Reply-To: References: <1355139464-6855-1-git-send-email-andriy.shevchenko@linux.intel.com> <1355139464-6855-2-git-send-email-andriy.shevchenko@linux.intel.com> <20121213153437.b8b0198d.akpm@linux-foundation.org> X-Mailer: Sylpheed 2.7.1 (GTK+ 2.18.9; x86_64-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 14 Dec 2012 09:06:03 +0200 Andy Shevchenko wrote: > On Fri, Dec 14, 2012 at 1:34 AM, Andrew Morton > wrote: > > On Mon, 10 Dec 2012 13:37:44 +0200 > > Andy Shevchenko wrote: > > > >> We get a warning if CONFIG_DMA_API_DEBUG=y > >> > >> [ 28.150631] WARNING: at lib/dma-debug.c:933 check_unmap+0x5d6/0x6ac() > >> [ 28.157058] dw_dmac dw_dmac.0: DMA-API: device driver failed to check map error[device address=0x0000000035698305] [size=14365 bytes] [mapped as single] > > >> --- a/drivers/dma/dmatest.c > >> +++ b/drivers/dma/dmatest.c > >> @@ -378,15 +378,35 @@ static int dmatest_func(void *data) > >> > >> dma_srcs[i] = dma_map_single(dev->dev, buf, len, > >> DMA_TO_DEVICE); > >> + ret = dma_mapping_error(dev->dev, dma_srcs[i]); > >> + if (ret) { > >> + unmap_src(dev->dev, dma_srcs, len, i); > >> + pr_warn("%s: #%u: mapping error %d with " > >> + "src_off=0x%x len=0x%x\n", > >> + thread_name, total_tests - 1, ret, > >> + src_off, len); > >> + failed_tests++; > >> + continue; > >> + } > > > > The changelog and the code don't match. Which one is out of date? > > I'm afraid I didn't get what is wrong. > The above code will not emit the string "dw_dmac dw_dmac.0: DMA-API: device driver failed to check map error[device address=0x0000000035698305] [size=14365 bytes] [mapped as single]". Oh I see what you did. That string is emitted by the kernel at present, and the patch prevents this. And it also emits a new warning if the mapping attempt failed, and that new warning wasn't described. I updated the changelog: : The kernel emits a warning if CONFIG_DMA_API_DEBUG=y: : : [ 28.150631] WARNING: at lib/dma-debug.c:933 check_unmap+0x5d6/0x6ac() : [ 28.157058] dw_dmac dw_dmac.0: DMA-API: device driver failed to check map error[device address=0x0000000035698305] [size=14365 bytes] [mapped as single] : : Fix this by adding the required checking of the dma_map_single() return : value.