Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1944042ybt; Thu, 2 Jul 2020 18:52:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx/FjbJWN3eJWdp+EqL11DHoRH7CIA7uUiT2Y2Mv8jllUDFDGjnQvpA4sOAxrUQLZ6QKO8J X-Received: by 2002:a05:6402:354:: with SMTP id r20mr38199967edw.32.1593741148774; Thu, 02 Jul 2020 18:52:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593741148; cv=none; d=google.com; s=arc-20160816; b=cXgcrcWd7Zjn2N4Of4bboutOUi2u5jLW+frXMjOKzc9gY9nZEO44zim6pf7YsPpy6u SN0wg2w0EDGj0L+R3ZCUXUXWBdIVkc4ebyGTOK3DPHtV3g5UK+vEzTYpe0vCLXP8DcQ4 j5R3a7+9m1uxV9zHeNrm1vHR1n8yA76vJ9882XB8ShXzLzYpdaOL3qzA7ByEH+hQ5q9I P3FSRtBwHBP7lFfyoVwr1Ko52bS67ZOPt2NIIP5LJsL0KArfM4RdFNC48kR3yPDt4nJi EzfqagRrnRxTroOW2hrdUcYaDxNCAksulOD4Tuv6acMcZs9FrVIlMqjkmgGS1b16ucL+ Ojrw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dmarc-filter:dkim-signature; bh=y8/ctKm6tCpyD/g3YN6BJR2wxls6kXM15EgJhqps8Ik=; b=pLlBk58VpmtPulGfG+C9JQbEH7HTHZ4OYssvp+BpHThA0f1ybcyNsvrmS+3Fc3gueE 8xW82wzaPH/R5qkRzb1qQZKJohoAAgDJXIyuuVD3+YR/ilomHMGm4dvSHWGB5piepSZo EviBaQLkk9LL2FWpjM7gCUHiK95L5EfBEDVVQsuDrTDQQEvvtkgRK7slEMUKERgLgv8q VGGg28Sgy1Bs7RWGHgjzMVxZzI5kJBBMebMa4uq7CfFV1SWb5oxwuNdaFIEoKCCljuEp kFxSjthAZpjYs3xN5zpBD3AsAFp27xsN1O2JL61QjNJqkZ8BMUGLG8n4vpkv7Mv7DAzR 9YrQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=REib3M9N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r4si7491080edl.262.2020.07.02.18.52.06; Thu, 02 Jul 2020 18:52:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=REib3M9N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726874AbgGCBvZ (ORCPT + 99 others); Thu, 2 Jul 2020 21:51:25 -0400 Received: from m43-7.mailgun.net ([69.72.43.7]:59050 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726810AbgGCBvX (ORCPT ); Thu, 2 Jul 2020 21:51:23 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1593741083; h=Content-Transfer-Encoding: MIME-Version: Message-Id: Date: Subject: Cc: To: From: Sender; bh=y8/ctKm6tCpyD/g3YN6BJR2wxls6kXM15EgJhqps8Ik=; b=REib3M9NsHAUY7T+1rVVkLJECDM/hge6YGhEZokUlkpwMjn5bvkM+kUsDVCIpmjZ/n7NorY0 c/5SQqAtuuCP+0iKX+U44C6ud7DGWF5R+L5F47LoKkUM76S/E2DUwg6KESUH67/n+IkX+bG+ zNoqwc6jOVE6O9+Il1DJDQmjQKA= X-Mailgun-Sending-Ip: 69.72.43.7 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n13.prod.us-east-1.postgun.com with SMTP id 5efe8f0b567385e8e77b4c82 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Fri, 03 Jul 2020 01:51:07 GMT Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 3CA14C433AF; Fri, 3 Jul 2020 01:51:06 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED,SPF_NONE autolearn=unavailable autolearn_force=no version=3.4.0 Received: from wcheng-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: wcheng) by smtp.codeaurora.org (Postfix) with ESMTPSA id 9ABE5C433CA; Fri, 3 Jul 2020 01:51:04 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 9ABE5C433CA Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=wcheng@codeaurora.org From: Wesley Cheng To: lgirdwood@gmail.com, mark.rutland@arm.com, agross@kernel.org, broonie@kernel.org, heikki.krogerus@linux.intel.com, robh+dt@kernel.org, gregkh@linuxfoundation.org, bjorn.andersson@linaro.org Cc: linux-arm-msm@vger.kernel.org, devicetree@vger.kernel.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, jackp@codeaurora.org, rdunlap@infradead.org, bryan.odonoghue@linaro.org, Wesley Cheng Subject: [PATCH v5 0/6] Introduce PMIC based USB type C detection Date: Thu, 2 Jul 2020 18:50:56 -0700 Message-Id: <20200703015102.27295-1-wcheng@codeaurora.org> X-Mailer: git-send-email 2.27.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Changes in v5: - Fix dt_binding_check warning/error in qcom,pmic-typec.yaml Changes in v4: - Modified qcom,pmic-typec binding to include the SS mux and the DRD remote endpoint nodes underneath port@1, which is assigned to the SSUSB path according to usb-connector - Added usb-connector reference to the typec dt-binding - Added tags to the usb type c and vbus nodes - Removed "qcom" tags from type c and vbus nodes - Modified Kconfig module name, and removed module alias from the typec driver Changes in v3: - Fix driver reference to match driver name in Kconfig for qcom_usb_vbus-regulator.c - Utilize regulator bitmap helpers for enable, disable and is enabled calls in qcom_usb_vbus-regulator.c - Use of_get_regulator_init_data() to initialize regulator init data, and to set constraints in qcom_usb_vbus-regulator.c - Remove the need for a local device structure in the vbus regulator driver Changes in v2: - Use devm_kzalloc() in qcom_pmic_typec_probe() - Add checks to make sure return value of typec_find_port_power_role() is valid - Added a VBUS output regulator driver, which will be used by the PMIC USB type c driver to enable/disable the source - Added logic to control vbus source from the PMIC type c driver when UFP/DFP is detected - Added dt-binding for this new regulator driver - Fixed Kconfig typec notation to match others - Leave type C block disabled until enabled by a platform DTS Add the required drivers for implementing type C orientation and role detection using the Qualcomm PMIC. Currently, PMICs such as the PM8150B have an integrated type C block, which can be utilized for this. This series adds the dt-binding, PMIC type C driver, and DTS nodes. The PMIC type C driver will register itself as a type C port w/ a registered type C switch for orientation, and will fetch a USB role switch handle for the role notifications. It will also have the ability to enable the VBUS output to any connected devices based on if the device is behaving as a UFP or DFP. Wesley Cheng (6): usb: typec: Add QCOM PMIC typec detection driver dt-bindings: usb: Add Qualcomm PMIC type C controller dt-binding arm64: boot: dts: qcom: pm8150b: Add node for USB type C block regulator: Add support for QCOM PMIC VBUS booster dt-bindings: regulator: Add dt-binding for QCOM PMIC VBUS output regulator arm64: boot: dts: qcom: pm8150b: Add DTS node for PMIC VBUS booster .../regulator/qcom,usb-vbus-regulator.yaml | 41 +++ .../bindings/usb/qcom,pmic-typec.yaml | 130 +++++++++ arch/arm64/boot/dts/qcom/pm8150b.dtsi | 13 + arch/arm64/boot/dts/qcom/sm8150-mtp.dts | 4 + drivers/regulator/Kconfig | 10 + drivers/regulator/Makefile | 1 + drivers/regulator/qcom_usb_vbus-regulator.c | 97 ++++++ drivers/usb/typec/Kconfig | 12 + drivers/usb/typec/Makefile | 1 + drivers/usb/typec/qcom-pmic-typec.c | 275 ++++++++++++++++++ 10 files changed, 584 insertions(+) create mode 100644 Documentation/devicetree/bindings/regulator/qcom,usb-vbus-regulator.yaml create mode 100644 Documentation/devicetree/bindings/usb/qcom,pmic-typec.yaml create mode 100644 drivers/regulator/qcom_usb_vbus-regulator.c create mode 100644 drivers/usb/typec/qcom-pmic-typec.c -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project