mirror of https://gitee.com/openkylin/linux.git
usb: roles: intel_xhci: Supplying software node for the role mux
The primary purpose for this node will be to allow linking the users of the switch to it. The users will be for example USB Type-C connectors. By supplying a reference to this node in the software nodes representing the USB Type-C controllers or connectors, the drivers for those devices can access the switch. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
1666faedb5
commit
d2a90ebb65
|
@ -39,6 +39,10 @@ struct intel_xhci_usb_data {
|
|||
void __iomem *base;
|
||||
};
|
||||
|
||||
static const struct software_node intel_xhci_usb_node = {
|
||||
"intel-xhci-usb-sw",
|
||||
};
|
||||
|
||||
static int intel_xhci_usb_set_role(struct device *dev, enum usb_role role)
|
||||
{
|
||||
struct intel_xhci_usb_data *data = dev_get_drvdata(dev);
|
||||
|
@ -122,17 +126,13 @@ static enum usb_role intel_xhci_usb_get_role(struct device *dev)
|
|||
return role;
|
||||
}
|
||||
|
||||
static const struct usb_role_switch_desc sw_desc = {
|
||||
.set = intel_xhci_usb_set_role,
|
||||
.get = intel_xhci_usb_get_role,
|
||||
.allow_userspace_control = true,
|
||||
};
|
||||
|
||||
static int intel_xhci_usb_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct usb_role_switch_desc sw_desc = { };
|
||||
struct device *dev = &pdev->dev;
|
||||
struct intel_xhci_usb_data *data;
|
||||
struct resource *res;
|
||||
int ret;
|
||||
|
||||
data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
|
||||
if (!data)
|
||||
|
@ -147,9 +147,20 @@ static int intel_xhci_usb_probe(struct platform_device *pdev)
|
|||
|
||||
platform_set_drvdata(pdev, data);
|
||||
|
||||
ret = software_node_register(&intel_xhci_usb_node);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
sw_desc.set = intel_xhci_usb_set_role,
|
||||
sw_desc.get = intel_xhci_usb_get_role,
|
||||
sw_desc.allow_userspace_control = true,
|
||||
sw_desc.fwnode = software_node_fwnode(&intel_xhci_usb_node);
|
||||
|
||||
data->role_sw = usb_role_switch_register(dev, &sw_desc);
|
||||
if (IS_ERR(data->role_sw))
|
||||
if (IS_ERR(data->role_sw)) {
|
||||
fwnode_handle_put(sw_desc.fwnode);
|
||||
return PTR_ERR(data->role_sw);
|
||||
}
|
||||
|
||||
pm_runtime_set_active(dev);
|
||||
pm_runtime_enable(dev);
|
||||
|
@ -164,6 +175,8 @@ static int intel_xhci_usb_remove(struct platform_device *pdev)
|
|||
pm_runtime_disable(&pdev->dev);
|
||||
|
||||
usb_role_switch_unregister(data->role_sw);
|
||||
fwnode_handle_put(software_node_fwnode(&intel_xhci_usb_node));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue