mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 15:29:16 +00:00
usb: typec: mux: Allow the mux handles to be requested with fwnode
Introducing fwnode_typec_switch_get() and fwnode_typec_mux_get() functions that work just like typec_switch_get() and typec_mux_get() but they take struct fwnode_handle as the first parameter instead of struct device. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Link: https://lore.kernel.org/r/20200302135353.56659-4-heikki.krogerus@linux.intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
774a9df6ae
commit
d1c6a769cd
@ -49,26 +49,26 @@ static void *typec_switch_match(struct device_connection *con, int ep,
|
||||
}
|
||||
|
||||
/**
|
||||
* typec_switch_get - Find USB Type-C orientation switch
|
||||
* @dev: The caller device
|
||||
* fwnode_typec_switch_get - Find USB Type-C orientation switch
|
||||
* @fwnode: The caller device node
|
||||
*
|
||||
* Finds a switch linked with @dev. Returns a reference to the switch on
|
||||
* success, NULL if no matching connection was found, or
|
||||
* ERR_PTR(-EPROBE_DEFER) when a connection was found but the switch
|
||||
* has not been enumerated yet.
|
||||
*/
|
||||
struct typec_switch *typec_switch_get(struct device *dev)
|
||||
struct typec_switch *fwnode_typec_switch_get(struct fwnode_handle *fwnode)
|
||||
{
|
||||
struct typec_switch *sw;
|
||||
|
||||
sw = device_connection_find_match(dev, "orientation-switch", NULL,
|
||||
sw = fwnode_connection_find_match(fwnode, "orientation-switch", NULL,
|
||||
typec_switch_match);
|
||||
if (!IS_ERR_OR_NULL(sw))
|
||||
WARN_ON(!try_module_get(sw->dev.parent->driver->owner));
|
||||
|
||||
return sw;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(typec_switch_get);
|
||||
EXPORT_SYMBOL_GPL(fwnode_typec_switch_get);
|
||||
|
||||
/**
|
||||
* typec_put_switch - Release USB Type-C orientation switch
|
||||
@ -241,8 +241,8 @@ find_mux:
|
||||
}
|
||||
|
||||
/**
|
||||
* typec_mux_get - Find USB Type-C Multiplexer
|
||||
* @dev: The caller device
|
||||
* fwnode_typec_mux_get - Find USB Type-C Multiplexer
|
||||
* @fwnode: The caller device node
|
||||
* @desc: Alt Mode description
|
||||
*
|
||||
* Finds a mux linked to the caller. This function is primarily meant for the
|
||||
@ -250,19 +250,19 @@ find_mux:
|
||||
* matching connection was found, or ERR_PTR(-EPROBE_DEFER) when a connection
|
||||
* was found but the mux has not been enumerated yet.
|
||||
*/
|
||||
struct typec_mux *typec_mux_get(struct device *dev,
|
||||
const struct typec_altmode_desc *desc)
|
||||
struct typec_mux *fwnode_typec_mux_get(struct fwnode_handle *fwnode,
|
||||
const struct typec_altmode_desc *desc)
|
||||
{
|
||||
struct typec_mux *mux;
|
||||
|
||||
mux = device_connection_find_match(dev, "mode-switch", (void *)desc,
|
||||
mux = fwnode_connection_find_match(fwnode, "mode-switch", (void *)desc,
|
||||
typec_mux_match);
|
||||
if (!IS_ERR_OR_NULL(mux))
|
||||
WARN_ON(!try_module_get(mux->dev.parent->driver->owner));
|
||||
|
||||
return mux;
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(typec_mux_get);
|
||||
EXPORT_SYMBOL_GPL(fwnode_typec_mux_get);
|
||||
|
||||
/**
|
||||
* typec_mux_put - Release handle to a Multiplexer
|
||||
|
@ -3,6 +3,7 @@
|
||||
#ifndef __USB_TYPEC_MUX
|
||||
#define __USB_TYPEC_MUX
|
||||
|
||||
#include <linux/property.h>
|
||||
#include <linux/usb/typec.h>
|
||||
|
||||
struct device;
|
||||
@ -21,11 +22,16 @@ struct typec_switch_desc {
|
||||
void *drvdata;
|
||||
};
|
||||
|
||||
struct typec_switch *typec_switch_get(struct device *dev);
|
||||
struct typec_switch *fwnode_typec_switch_get(struct fwnode_handle *fwnode);
|
||||
void typec_switch_put(struct typec_switch *sw);
|
||||
int typec_switch_set(struct typec_switch *sw,
|
||||
enum typec_orientation orientation);
|
||||
|
||||
static inline struct typec_switch *typec_switch_get(struct device *dev)
|
||||
{
|
||||
return fwnode_typec_switch_get(dev_fwnode(dev));
|
||||
}
|
||||
|
||||
struct typec_switch *
|
||||
typec_switch_register(struct device *parent,
|
||||
const struct typec_switch_desc *desc);
|
||||
@ -50,11 +56,17 @@ struct typec_mux_desc {
|
||||
void *drvdata;
|
||||
};
|
||||
|
||||
struct typec_mux *
|
||||
typec_mux_get(struct device *dev, const struct typec_altmode_desc *desc);
|
||||
struct typec_mux *fwnode_typec_mux_get(struct fwnode_handle *fwnode,
|
||||
const struct typec_altmode_desc *desc);
|
||||
void typec_mux_put(struct typec_mux *mux);
|
||||
int typec_mux_set(struct typec_mux *mux, struct typec_mux_state *state);
|
||||
|
||||
static inline struct typec_mux *
|
||||
typec_mux_get(struct device *dev, const struct typec_altmode_desc *desc)
|
||||
{
|
||||
return fwnode_typec_mux_get(dev_fwnode(dev), desc);
|
||||
}
|
||||
|
||||
struct typec_mux *
|
||||
typec_mux_register(struct device *parent, const struct typec_mux_desc *desc);
|
||||
void typec_mux_unregister(struct typec_mux *mux);
|
||||
|
Loading…
x
Reference in New Issue
Block a user