Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756590AbdIHRHn (ORCPT ); Fri, 8 Sep 2017 13:07:43 -0400 Received: from mx1.redhat.com ([209.132.183.28]:54176 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752482AbdIHRHl (ORCPT ); Fri, 8 Sep 2017 13:07:41 -0400 DMARC-Filter: OpenDMARC Filter v1.3.2 mx1.redhat.com 6FA814E34A Authentication-Results: ext-mx09.extmail.prod.ext.phx2.redhat.com; dmarc=none (p=none dis=none) header.from=redhat.com Authentication-Results: ext-mx09.extmail.prod.ext.phx2.redhat.com; spf=fail smtp.mailfrom=hdegoede@redhat.com Subject: Re: [PATCH v2 03/11] mux: core: Add usb.h header with MUX_USB_* and and MUX_TYPEC_* state constants To: Peter Rosin , MyungJoo Ham , Chanwoo Choi , Guenter Roeck , Heikki Krogerus , Darren Hart , Andy Shevchenko , Mathias Nyman Cc: linux-kernel@vger.kernel.org, platform-driver-x86@vger.kernel.org, devel@driverdev.osuosl.org, Kuppuswamy Sathyanarayanan , Sathyanarayanan Kuppuswamy Natarajan , Greg Kroah-Hartman , linux-usb@vger.kernel.org References: <20170905164221.11266-1-hdegoede@redhat.com> <20170905164221.11266-4-hdegoede@redhat.com> From: Hans de Goede Message-ID: Date: Fri, 8 Sep 2017 19:07:37 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.3.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.38]); Fri, 08 Sep 2017 17:07:41 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3938 Lines: 91 Hi, On 08-09-17 17:47, Peter Rosin wrote: > On 2017-09-05 18:42, Hans de Goede wrote: >> Add MUX_USB_* and MUX_TYPEC_* state constant defines, which can be used by >> USB device/host, resp. Type-C polarity/role/altmode mux drivers and >> consumers to ensure that they agree on the meaning of the >> mux_control_select() state argument. >> >> Signed-off-by: Hans de Goede >> --- >> Changes in v2: >> -Start numbering of defines at 0 not 1 >> -Use a new usb.h header, rather then adding these to consumer.h >> -Add separate MUX_USB_* and MUX_TYPEC_* defines >> --- >> include/linux/mux/usb.h | 32 ++++++++++++++++++++++++++++++++ >> 1 file changed, 32 insertions(+) >> create mode 100644 include/linux/mux/usb.h >> >> diff --git a/include/linux/mux/usb.h b/include/linux/mux/usb.h >> new file mode 100644 >> index 000000000000..44df5eca5256 >> --- /dev/null >> +++ b/include/linux/mux/usb.h >> @@ -0,0 +1,32 @@ >> +/* >> + * mux/usb.h - definitions for USB multiplexers >> + * >> + * Copyright (C) 2017 Hans de Goede >> + * >> + * This program is free software; you can redistribute it and/or modify >> + * it under the terms of the GNU General Public License version 2 as >> + * published by the Free Software Foundation. >> + */ >> +#ifndef _LINUX_MUX_USB_H >> +#define _LINUX_MUX_USB_H >> + >> +/* Mux state values for USB device/host role muxes */ >> +#define MUX_USB_DEVICE (0) /* USB device mode */ >> +#define MUX_USB_HOST (1) /* USB host mode */ >> +#define MUX_USB_STATES (2) >> + >> +/* >> + * Mux state values for Type-C polarity/role/altmode muxes. >> + * >> + * MUX_TYPEC_POLARITY_INV may be or-ed together with any other mux-state as >> + * inverted-polarity (Type-C plugged in upside down) can happen with any >> + * other mux-state. >> + */ >> +#define MUX_TYPEC_POLARITY_INV BIT(0) /* Polarity inverted bit */ >> +#define MUX_TYPEC_DEVICE (0 << 1) /* USB device mode */ >> +#define MUX_TYPEC_HOST (1 << 1) /* USB host mode */ >> +#define MUX_TYPEC_HOST_AND_DP_SRC (2 << 1) /* USB host + 2 lanes DP src */ >> +#define MUX_TYPEC_DP_SRC (3 << 1) /* 4 lanes Display Port src */ >> +#define MUX_TYPEC_STATES (4 << 1) > > But USB Type-C muxes need not support just these states If I read it right? > USB Type-C seems to be usable for a variety of protocols and the above list > seems pretty much like a special case for this mux (and perhaps a set of > other similar muxes). But when someone with a USB Type-C mux for different > protocols shows up, that person will probably be frustrated by these > defines, no? Or is there something I don't see that limits USB-C to DP? In general almost all hardware is limited to the above (+ analog audio over the 2 Sideband use pins, but I expect that to have a separate mux). You're right, theoretically there might be other cases, e.g. there is a spec for HDMI over Type-C (wishful thinking from the HDMI group, no one uses this), but: 1) I expect most muxes to implement the above set, that is what all hardware out there supports (well that or less). 2) We can always add extra defines here, that means that a Type-C mux may not implement all states and return -EINVAL when asked for something it does not implement, which I understand is a bit weird from a mux subsys pov. But that can be the case anyways because even though the mux supports these options, the board it is used on does no necessarily have to support these options, e.g. there may be only 2 lanes of DP hooked up to the mux (or no DP at all, but then I would them to expect a different mux). So the Type-C Port Manager already needs to be passed some platform data describing which features the board has and keep that in mind when negotiation with the dongle attached to the Type-C port, so if we do get boards which do HDMI and no DP, then the TCPM would simply never use the MUX_TYPEC_HOST_AND_DP_SRC and MUX_TYPEC_DP_SRC states. Regards, Hans