Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759401Ab3FCRvN (ORCPT ); Mon, 3 Jun 2013 13:51:13 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:38439 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756029Ab3FCRvJ (ORCPT ); Mon, 3 Jun 2013 13:51:09 -0400 Date: Mon, 3 Jun 2013 10:51:08 -0700 From: Greg KH To: Roger Quadros Cc: Alan Stern , balbi@ti.com, linux-usb@vger.kernel.org, linux-omap@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree-discuss@lists.ozlabs.org Subject: Re: [PATCH 1/1] USB: ehci-omap: Reset dma_mask pointer on probe Message-ID: <20130603175108.GA11188@kroah.com> References: <519E2BD4.9020906@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <519E2BD4.9020906@ti.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1733 Lines: 43 On Thu, May 23, 2013 at 05:46:44PM +0300, Roger Quadros wrote: > On 05/23/2013 05:11 PM, Alan Stern wrote: > > On Thu, 23 May 2013, Roger Quadros wrote: > > > >> Device tree probed devices don't get dma_mask set. Previously > >> we were setting the dma_mask pointer only if it was NULL. > >> However, the address of 'omap_ehci_dma_mask' would change > >> each time the module is unloaded and loaded back thus causing > >> the devices dma_mask pointer to be invalid on the next load. > >> > >> This will cause page faults if any driver tries to access the > >> old dma_mask pointer. > >> > >> Unconditionally re-setting the dma_mask pointer fixes this problem. > > > >> diff --git a/drivers/usb/host/ehci-omap.c b/drivers/usb/host/ehci-omap.c > >> index 3d1491b..b33e306 100644 > >> --- a/drivers/usb/host/ehci-omap.c > >> +++ b/drivers/usb/host/ehci-omap.c > >> @@ -146,8 +146,7 @@ static int ehci_hcd_omap_probe(struct platform_device *pdev) > >> * Since shared usb code relies on it, set it here for now. > >> * Once we have dma capability bindings this can go away. > >> */ > >> - if (!pdev->dev.dma_mask) > >> - pdev->dev.dma_mask = &omap_ehci_dma_mask; > >> + pdev->dev.dma_mask = &omap_ehci_dma_mask; > > > > Is this the solution that people have agreed on? There has been a lot > > of discussion on this topic. In particular, there has been talk about > > fixing it in the DT core. > > Fixing it in DT core would be best. Then please do that. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/