@@ -86,12 +86,56 @@ enum usb_device_speed usb_get_maximum_speed(struct device *dev)
if (ret < 0)
return USB_SPEED_UNKNOWN;
- ret = match_string(speed_names, ARRAY_SIZE(speed_names), maximum_speed);
+ if (strncmp("super-speed-plus-gen2x2", maximum_speed, 23) == 0 ||
+ strncmp("super-speed-plus-gen2x1", maximum_speed, 23) == 0 ||
+ strncmp("super-speed-plus-gen1x2", maximum_speed, 23) == 0)
+ return USB_SPEED_SUPER_PLUS;
+ ret = match_string(speed_names, ARRAY_SIZE(speed_names), maximum_speed);
return (ret < 0) ? USB_SPEED_UNKNOWN : ret;
}
EXPORT_SYMBOL_GPL(usb_get_maximum_speed);
+u8 usb_get_ssp_num_lanes(struct device *dev)
+{
+ const char *maximum_speed;
+ int ret;
+
+ ret = device_property_read_string(dev, "maximum-speed", &maximum_speed);
+ if (ret < 0)
+ return 0;
+
+ if (strncmp("super-speed-plus-gen2x1", maximum_speed, 23) == 0)
+ return 1;
+
+ if (strncmp("super-speed-plus-gen2x2", maximum_speed, 23) == 0 ||
+ strncmp("super-speed-plus-gen1x2", maximum_speed, 23) == 0)
+ return 2;
+
+ return 0;
+}
+EXPORT_SYMBOL_GPL(usb_get_ssp_num_lanes);
+
+enum usb_phy_gen usb_get_ssp_phy_gen(struct device *dev)
+{
+ const char *maximum_speed;
+ int ret;
+
+ ret = device_property_read_string(dev, "maximum-speed", &maximum_speed);
+ if (ret < 0)
+ return USB_PHY_GEN_UNKNOWN;
+
+ if (strncmp("super-speed-plus-gen1x2", maximum_speed, 23) == 0)
+ return USB_PHY_GEN_1;
+
+ if (strncmp("super-speed-plus-gen2x2", maximum_speed, 23) == 0 ||
+ strncmp("super-speed-plus-gen2x1", maximum_speed, 23) == 0)
+ return USB_PHY_GEN_2;
+
+ return USB_PHY_GEN_UNKNOWN;
+}
+EXPORT_SYMBOL_GPL(usb_get_ssp_phy_gen);
+
const char *usb_state_string(enum usb_device_state state)
{
static const char *const names[] = {
@@ -57,6 +57,13 @@ enum usb_link_protocol {
USB_LP_SSP = 1,
};
+/* USB phy signaling rate generation */
+enum usb_phy_gen {
+ USB_PHY_GEN_UNKNOWN,
+ USB_PHY_GEN_1,
+ USB_PHY_GEN_2,
+};
+
/**
* struct usb_sublink_speed - sublink speed attribute
* @id: sublink speed attribute ID (SSID)
@@ -105,6 +112,29 @@ extern const char *usb_speed_string(enum usb_device_speed speed);
*/
extern enum usb_device_speed usb_get_maximum_speed(struct device *dev);
+/**
+ * usb_get_ssp_num_lanes - Get requested number of lanes for a given
+ * super-speed-plus capable USB controller.
+ * @dev: Pointer to the given USB controller device
+ *
+ * If the string from "maximum-speed" property is super-speed-plus-genXxY where
+ * 'Y' is the number of lanes, then this function returns 1 for single lane and
+ * 2 for dual-lane base on 'Y'. If the number of lanes is not specified, then it
+ * returns 0.
+ */
+extern u8 usb_get_ssp_num_lanes(struct device *dev);
+
+/**
+ * usb_get_ssp_phy_gen - Get requested phy signaling rate generation for a given
+ * super-speed-plus capable USB controller.
+ * @dev: Pointer to the given USB controller device
+ *
+ * If the string from "maximum-speed" property is super-speed-plus-genXxY where
+ * 'X' is the Gen number, then this function returns the corresponding enum
+ * usb_phy_gen base on 'X'.
+ */
+extern enum usb_phy_gen usb_get_ssp_phy_gen(struct device *dev);
+
/**
* usb_state_string - Returns human readable name for the state.
* @state: The state to return a human-readable name for. If it's not
The USB "maximum-speed" property now can take these new strings for super-speed-plus: "super-speed-plus-gen2x2" "super-speed-plus-gen2x1" "super-speed-plus-gen1x2" As a result, let's do the follow: * Update usb_get_maximum_speed() to parse these new speed strings * Add 2 new common functions to get the Gen number and number of lanes Signed-off-by: Thinh Nguyen <thinhn@synopsys.com> --- Changes in v4: - Create 2 functions to get the SSP gen and number of lanes from "maximum-speed" property - Update usb_get_maximum_speed() to check new SSP strings with genXxY - Update commit message and subject title to reflect the new changes Changes in v3: - Add new function to parse "maximum-speed" for lanes and transfer rate - Remove separate functions getting num_lanes and transfer rate properties Changes in v2: - New commit drivers/usb/common/common.c | 46 ++++++++++++++++++++++++++++++++++++++++++++- include/linux/usb/ch9.h | 30 +++++++++++++++++++++++++++++ 2 files changed, 75 insertions(+), 1 deletion(-)