Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754216AbbEUHV5 (ORCPT ); Thu, 21 May 2015 03:21:57 -0400 Received: from mga09.intel.com ([134.134.136.24]:22309 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753471AbbEUHVy (ORCPT ); Thu, 21 May 2015 03:21:54 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.13,467,1427785200"; d="scan'208";a="713514490" Date: Thu, 21 May 2015 10:21:33 +0300 From: Heikki Krogerus To: "Lu, Baolu" Cc: David Cohen , Sasha Levin , gregkh@linuxfoundation.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, balbi@ti.com Subject: Re: [PATCH] usb: ulpi: don't register drivers if bus doesn't exist Message-ID: <20150521072133.GA16847@kuha.fi.intel.com> References: <1432150406-20550-1-git-send-email-sasha.levin@oracle.com> <20150520212235.GA20943@psi-dev26.jf.intel.com> <555D7DB4.6030606@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <555D7DB4.6030606@linux.intel.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2086 Lines: 59 > >>ULPI registers it's bus at module_init so if the bus fails to register, the > >A minor comment: s/it's/its/ > > > >>module will fail to load and all will be well in the world. > >> > >>However, if the ULPI code is built-in rather than a module, the bus > >>initialization may fail but we'd still try to register drivers later onto > >>a non-existant bus, which will panic the kernel. > >> > >>Fix that by checking that the bus was indeed initialized before trying to > >>register drivers on top of it. > >> > >>Signed-off-by: Sasha Levin > >>--- > >> drivers/usb/common/ulpi.c | 4 ++++ > >> 1 file changed, 4 insertions(+) > >> > >>diff --git a/drivers/usb/common/ulpi.c b/drivers/usb/common/ulpi.c > >>index 0e6f968..0b0a5e7 100644 > >>--- a/drivers/usb/common/ulpi.c > >>+++ b/drivers/usb/common/ulpi.c > >>@@ -132,6 +132,10 @@ int ulpi_register_driver(struct ulpi_driver *drv) > >> if (!drv->probe) > >> return -EINVAL; > >>+ /* Was the bus registered successfully? */ > >>+ if (!ulpi_bus.p) > >>+ return -ENODEV; I think we need to warn in this case. How about: if (unlikely(WARN_ON(!ulpi_bus.p))) return -ENODEV; > >Good catch. Otherwise it may trigger BUG() on driver_register(). > >I wonder if it would be nice to have a macro for that checking :) > > > >Anyway, > > > >Reviewed-by: David Cohen > > Well, I was also encountering panic issue when running it on > Intel Bay Trail tablets. In my case, it's due to the execution > sequence. When ulpi bus is built-in, driver or device registered > before ulpi bus registration. This patch will fix the panic you saw as well, but of course we still want the ulpi phy drivers to load successfully even if they and the bus are build-in, so we need your patch as well. Thanks, -- heikki -- 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/