Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp598528ybh; Wed, 22 Jul 2020 08:28:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzVLtcntQv4dD3A4GZnsnqVc1thWXO6v88SUOmgFgz8iB8Z9bjtDYp7LgKvwZmfZ0F5sBrc X-Received: by 2002:a17:906:3650:: with SMTP id r16mr25167ejb.465.1595431690131; Wed, 22 Jul 2020 08:28:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595431690; cv=none; d=google.com; s=arc-20160816; b=f31aPJrJTImZG7Isfxueb9rbTwOb3ZekIia2ZG70GKeAiMXYrwiLDlpaRw7q6Fh3+A vdRy83QiES4fDJDJ7Oiphi2e25n45MV9Zia9bisdzPDg4YrqTgyBO1BVoTMGEJG5onpw HOOxsFTIC861dP0PkeqS10E58I8BcMJ9ymft2e+TMHa19ySHmXiQphDYnbfLAxVidl2P RKjHk64iYW2/LWsRIM/2yyJmkMJ8siLLq+wh1buFvgEff2XxQGCCrMgbPW+zFFqZx15q YlZa4TYMFaBM+aTlAMyf5grh/n7Ho9OB4bQqBn6uFhLEgHFHkbpN7xjum/OYfay57tW/ cIfg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=oEUTvzTQxkutsYD2xNhisVLjdwlB+VfI1QN0lmcgXFw=; b=imX/geXooE1hhprjc79FUw0T8CIzOwlaSTTVZ7d+w4ZRirw6+efeH0D+zGVw8knwl5 3CC8EgwKMjV0grWVclrPz9PliNyKui9IPIS1Bh3yOCKiacS1L4x8anUi7Cy+8uJGOp+y 4Q8438imm6mrNgE4r9Yf5RI48Qu2iuxSM0j5am1VnFPghiKYHdjaclJtLYy4kF8zzyH/ oKSqAAviCaBT50f7bClrnBQ/MDIwYZK93FpNsbc/xbu3tOv+D5zSAJsNNHdffQqBJXJC 65RKAE5UXgw350+KKAsasvyAlnr148XTPilJKNEMGrvFTdRBXyEahV2esN6YPWhpRSFs y5Qg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j22si205638ejv.451.2020.07.22.08.27.47; Wed, 22 Jul 2020 08:28:10 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732690AbgGVP1i (ORCPT + 99 others); Wed, 22 Jul 2020 11:27:38 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:35002 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730600AbgGVP1h (ORCPT ); Wed, 22 Jul 2020 11:27:37 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 6F6F22982CB Subject: Re: [PATCH v2] platform/chrome: cros_ec_typec: USB4 support To: Prashant Malani , Linux Kernel Mailing List Cc: Rajmohan Mani , Heikki Krogerus , Benson Leung , Guenter Roeck References: <20200710194017.1126000-1-pmalani@chromium.org> From: Enric Balletbo i Serra Message-ID: Date: Wed, 22 Jul 2020 17:27:32 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Prashant, On 21/7/20 21:55, Prashant Malani wrote: > Hey Enric, Benson, > > Just wondering if you've had a chance to review this patch. > It's on my radar but I'm waiting for the dependencies to be merged. > Best regards, > > -Prashant > > On Fri, Jul 10, 2020 at 12:40 PM Prashant Malani wrote: >> >> From: Heikki Krogerus >> >> With USB4 mode the mux driver needs the Enter_USB Data >> Object (EUDO) that was used when the USB mode was entered. >> Though the object is not available in the driver, it is >> possible to construct it from the information we have. >> >> Signed-off-by: Heikki Krogerus >> Signed-off-by: Prashant Malani For my own reference: Acked-by: Enric Balletbo i Serra >> --- >> >> This patch depends on latest usb-next from Greg KH, this commit in >> particular: >> https://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb.git/commit/?h=usb-next&id=ad8db94d6813dc659bd4de0531a8a1150559eafb >> >> Changes in v2: >> - Removed EUDO bits for cable current and tunneling support. >> >> drivers/platform/chrome/cros_ec_typec.c | 33 ++++++++++++++++++++++++- >> 1 file changed, 32 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/platform/chrome/cros_ec_typec.c b/drivers/platform/chrome/cros_ec_typec.c >> index 0c041b79cbba..a9700275a851 100644 >> --- a/drivers/platform/chrome/cros_ec_typec.c >> +++ b/drivers/platform/chrome/cros_ec_typec.c >> @@ -13,6 +13,7 @@ >> #include >> #include >> #include >> +#include >> #include >> #include >> #include >> @@ -494,6 +495,34 @@ static int cros_typec_enable_dp(struct cros_typec_data *typec, >> return typec_mux_set(port->mux, &port->state); >> } >> >> +static int cros_typec_enable_usb4(struct cros_typec_data *typec, >> + int port_num, >> + struct ec_response_usb_pd_control_v2 *pd_ctrl) >> +{ >> + struct cros_typec_port *port = typec->ports[port_num]; >> + struct enter_usb_data data; >> + >> + data.eudo = EUDO_USB_MODE_USB4 << EUDO_USB_MODE_SHIFT; >> + >> + /* Cable Speed */ >> + data.eudo |= pd_ctrl->cable_speed << EUDO_CABLE_SPEED_SHIFT; >> + >> + /* Cable Type */ >> + if (pd_ctrl->control_flags & USB_PD_CTRL_OPTICAL_CABLE) >> + data.eudo |= EUDO_CABLE_TYPE_OPTICAL << EUDO_CABLE_TYPE_SHIFT; >> + else if (pd_ctrl->control_flags & USB_PD_CTRL_ACTIVE_CABLE) >> + data.eudo |= EUDO_CABLE_TYPE_RE_TIMER << EUDO_CABLE_TYPE_SHIFT; >> + >> + data.active_link_training = !!(pd_ctrl->control_flags & >> + USB_PD_CTRL_ACTIVE_LINK_UNIDIR); >> + >> + port->state.alt = NULL; >> + port->state.data = &data; >> + port->state.mode = TYPEC_MODE_USB4; >> + >> + return typec_mux_set(port->mux, &port->state); >> +} >> + >> static int cros_typec_configure_mux(struct cros_typec_data *typec, int port_num, >> uint8_t mux_flags, >> struct ec_response_usb_pd_control_v2 *pd_ctrl) >> @@ -514,7 +543,9 @@ static int cros_typec_configure_mux(struct cros_typec_data *typec, int port_num, >> if (ret) >> return ret; >> >> - if (mux_flags & USB_PD_MUX_TBT_COMPAT_ENABLED) { >> + if (mux_flags & USB_PD_MUX_USB4_ENABLED) { >> + ret = cros_typec_enable_usb4(typec, port_num, pd_ctrl); >> + } else if (mux_flags & USB_PD_MUX_TBT_COMPAT_ENABLED) { >> ret = cros_typec_enable_tbt(typec, port_num, pd_ctrl); >> } else if (mux_flags & USB_PD_MUX_DP_ENABLED) { >> ret = cros_typec_enable_dp(typec, port_num, pd_ctrl); >> -- >> 2.27.0.383.g050319c2ae-goog >>