From patchwork Fri Nov 6 11:35:13 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "\(Exiting\) Baolin Wang" X-Patchwork-Id: 56111 Delivered-To: patch@linaro.org Received: by 10.112.61.134 with SMTP id p6csp953192lbr; Fri, 6 Nov 2015 03:36:42 -0800 (PST) X-Received: by 10.68.69.35 with SMTP id b3mr17469991pbu.22.1446809801892; Fri, 06 Nov 2015 03:36:41 -0800 (PST) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id dz5si17169390pab.108.2015.11.06.03.36.41; Fri, 06 Nov 2015 03:36:41 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dkim=neutral (body hash did not verify) header.i=@linaro_org.20150623.gappssmtp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1161396AbbKFLgb (ORCPT + 28 others); Fri, 6 Nov 2015 06:36:31 -0500 Received: from mail-pa0-f54.google.com ([209.85.220.54]:32821 "EHLO mail-pa0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1161376AbbKFLg1 (ORCPT ); Fri, 6 Nov 2015 06:36:27 -0500 Received: by pabfh17 with SMTP id fh17so120840195pab.0 for ; Fri, 06 Nov 2015 03:36:27 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro_org.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=1UT702mA8qOGiRAAY+PJEHbj3IxhWCpmBVM6SvQa0AQ=; b=o7JSHz7zQeXgORJV4EJQXhQaop7fJYez8fbbt6E9nAd/Fn8hDDx085lwHp3hQ7t8pp 06Bbf8VDuTB0OmZYxF06w32M/NrvdaXJ4lcjbKn5JAadvl96Z8IUwjkRV6rEnO1N9oLd MWgcSAu7ooNlxBW7Ngj7gtjLlfDu0Z9zQlel4iE2TjmjY+eqA9yityPTPayMYTWEzCfu KqfqJqIyp+wcqrn3BqQas9S014mWCwU+WT6hbpaE5JQsWGCE43RaiaOdBfGKBcWvQ9n+ W9yWSIELpZmOWiwNfv+hL1LNpB2ddLz1ymfdJQwECE3wswHf16W+IoYsiXauRp1xzLvZ RqTw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:in-reply-to:references; bh=1UT702mA8qOGiRAAY+PJEHbj3IxhWCpmBVM6SvQa0AQ=; b=UFYc+a6fmJ1ydTbWpDenjrNngSAqfVZjG4gw5w3QVIkqPgPJGi0oqa3hc+Wpj2jA8W ndRaRR3bNcAb9vdEJUINabAI4KEnei6Y0dPEemeUup1ehBqOFCgep8jLGrgFnooOrrYf HtthNedsH6S6YMY0x2erdQe1Gl0F24ER91Kj6EVuukTkEknJeGrYb2w4K11s9BcIZSzf 1f3EpIMImqVLySMSGosCVW4aEohsqBaL5O/wMKgzuRb14G8s3q4tqYyhH0qMJ8v6EoLd fMji9WDvsrJsjLtMrDUHS/PlUA6VxmgPMuXaIRq9TXSIuA0sDDlatdbTkOWlk/ADexFH mc9A== X-Gm-Message-State: ALoCoQk80R4eaKKKO7YzuNgDmIlrQszrxBDDXRGX3tkk5rjSjFnfxVjErFGRocAO9O1BNjyJDaXw X-Received: by 10.66.160.194 with SMTP id xm2mr17234512pab.68.1446809787516; Fri, 06 Nov 2015 03:36:27 -0800 (PST) Received: from baolinwangubtpc.spreadtrum.com ([175.111.195.49]) by smtp.gmail.com with ESMTPSA id xm4sm13644680pab.27.2015.11.06.03.36.22 (version=TLSv1 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 06 Nov 2015 03:36:26 -0800 (PST) From: Baolin Wang To: balbi@ti.com, sre@kernel.org, dbaryshkov@gmail.com, dwmw2@infradead.org Cc: broonie@kernel.org, linux-kernel@vger.kernel.org, baolin.wang@linaro.org, gregkh@linuxfoundation.org, peter.chen@freescale.com, stern@rowland.harvard.edu, r.baldyga@samsung.com, yoshihiro.shimoda.uh@renesas.com, linux-usb@vger.kernel.org, device-mainlining@lists.linuxfoundation.org, sameo@linux.intel.com, lee.jones@linaro.org, ckeepax@opensource.wolfsonmicro.com, patches@opensource.wolfsonmicro.com, linux-pm@vger.kernel.org Subject: [PATCH v5 4/5] gadget: Integrate with the usb gadget supporting for usb charger Date: Fri, 6 Nov 2015 19:35:13 +0800 Message-Id: <8637ed7d0a5214505f26768f8d52e7dc554a8160.1446807916.git.baolin.wang@linaro.org> X-Mailer: git-send-email 1.7.9.5 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When the usb gadget supporting for usb charger is ready, the usb charger should get the type by the 'get_charger_type' callback which is implemented by the usb gadget operations, and get the usb charger pointer from struct 'usb_gadget'. Signed-off-by: Baolin Wang --- drivers/usb/gadget/charger.c | 45 ++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 43 insertions(+), 2 deletions(-) -- 1.7.9.5 -- 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/ diff --git a/drivers/usb/gadget/charger.c b/drivers/usb/gadget/charger.c index 8387820..c260317 100644 --- a/drivers/usb/gadget/charger.c +++ b/drivers/usb/gadget/charger.c @@ -183,7 +183,11 @@ int usb_charger_unregister_notify(struct usb_charger *uchger, enum usb_charger_type usb_charger_detect_type(struct usb_charger *uchger) { - if (uchger->psy) { + if (uchger->gadget && uchger->gadget->ops + && uchger->gadget->ops->get_charger_type) { + uchger->type = + uchger->gadget->ops->get_charger_type(uchger->gadget); + } else if (uchger->psy) { union power_supply_propval val; power_supply_get_property(uchger->psy, @@ -387,6 +391,30 @@ static int usb_charger_plug_by_gadget(struct notifier_block *nb, unsigned long state, void *data) { + struct usb_gadget *gadget = (struct usb_gadget *)data; + struct usb_charger *uchger = gadget->charger; + enum usb_charger_state uchger_state; + + if (!uchger) + return NOTIFY_BAD; + + /* Report event to power to setting the current limitation + * for this usb charger when one usb charger state is changed + * with detecting by usb gadget state. + */ + if (uchger->old_gadget_state != state) { + uchger->old_gadget_state = state; + + if (state >= USB_STATE_ATTACHED) + uchger_state = USB_CHARGER_PRESENT; + else if (state == USB_STATE_NOTATTACHED) + uchger_state = USB_CHARGER_REMOVE; + else + uchger_state = USB_CHARGER_DEFAULT; + + usb_charger_notify_others(uchger, uchger_state); + } + return NOTIFY_OK; } @@ -542,6 +570,7 @@ int usb_charger_init(struct usb_gadget *ugadget) /* register a notifier on a usb gadget device */ uchger->gadget = ugadget; + ugadget->charger = uchger; uchger->old_gadget_state = ugadget->state; uchger->gadget_nb.notifier_call = usb_charger_plug_by_gadget; usb_gadget_register_notify(ugadget, &uchger->gadget_nb); @@ -565,7 +594,19 @@ fail: int usb_charger_exit(struct usb_gadget *ugadget) { - return 0; + struct usb_charger *uchger = ugadget->charger; + + if (!uchger) + return -EINVAL; + + if (uchger->extcon_dev) + extcon_unregister_notifier(uchger->extcon_dev, + EXTCON_USB, &uchger->extcon_nb.nb); + + usb_gadget_unregister_notify(uchger->gadget, &uchger->gadget_nb); + ida_simple_remove(&usb_charger_ida, uchger->id); + + return usb_charger_unregister(uchger); } static int __init usb_charger_sysfs_init(void)