Commit bf4363ce authored by Archit Taneja's avatar Archit Taneja Committed by Thierry Reding

drm/dsi: Try to match non-DT DSI devices

Add a device name field in struct mipi_dsi_device. This name is not the
same as the device name (which is of the format "hostname.reg"). When
the device is created via DT, this name is set to the modalias string.
In the non-DT case, the driver creating the DSI device provides the
name by populating a field in struct mipi_dsi_device_info.

Matching for DT case would be as it was before. For the non-DT case, we
compare the device and driver names. Other buses (like I2C/SPI) perform
a non-DT match by comparing the device name and entries in the driver's
id_table. Such a mechanism isn't used for the DSI bus.
Reviewed-by: default avatarAndrzej Hajda <a.hajda@samsung.com>
Signed-off-by: default avatarArchit Taneja <architt@codeaurora.org>
Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
parent c63ae8a9
...@@ -47,7 +47,17 @@ ...@@ -47,7 +47,17 @@
static int mipi_dsi_device_match(struct device *dev, struct device_driver *drv) static int mipi_dsi_device_match(struct device *dev, struct device_driver *drv)
{ {
return of_driver_match_device(dev, drv); struct mipi_dsi_device *dsi = to_mipi_dsi_device(dev);
/* attempt OF style match */
if (of_driver_match_device(dev, drv))
return 1;
/* compare DSI device and driver names */
if (!strcmp(dsi->name, drv->name))
return 1;
return 0;
} }
static const struct dev_pm_ops mipi_dsi_device_pm_ops = { static const struct dev_pm_ops mipi_dsi_device_pm_ops = {
...@@ -138,6 +148,11 @@ of_mipi_dsi_device_add(struct mipi_dsi_host *host, struct device_node *node) ...@@ -138,6 +148,11 @@ of_mipi_dsi_device_add(struct mipi_dsi_host *host, struct device_node *node)
int ret; int ret;
u32 reg; u32 reg;
if (of_modalias_node(node, info.type, sizeof(info.type)) < 0) {
dev_err(dev, "modalias failure on %s\n", node->full_name);
return ERR_PTR(-EINVAL);
}
ret = of_property_read_u32(node, "reg", &reg); ret = of_property_read_u32(node, "reg", &reg);
if (ret) { if (ret) {
dev_err(dev, "device node %s has no valid reg property: %d\n", dev_err(dev, "device node %s has no valid reg property: %d\n",
...@@ -197,6 +212,7 @@ mipi_dsi_device_register_full(struct mipi_dsi_host *host, ...@@ -197,6 +212,7 @@ mipi_dsi_device_register_full(struct mipi_dsi_host *host,
dsi->dev.of_node = info->node; dsi->dev.of_node = info->node;
dsi->channel = info->channel; dsi->channel = info->channel;
strlcpy(dsi->name, info->type, sizeof(dsi->name));
ret = mipi_dsi_device_add(dsi); ret = mipi_dsi_device_add(dsi);
if (ret) { if (ret) {
......
...@@ -139,15 +139,19 @@ enum mipi_dsi_pixel_format { ...@@ -139,15 +139,19 @@ enum mipi_dsi_pixel_format {
MIPI_DSI_FMT_RGB565, MIPI_DSI_FMT_RGB565,
}; };
/** #define DSI_DEV_NAME_SIZE 20
/**
* struct mipi_dsi_device_info - template for creating a mipi_dsi_device * struct mipi_dsi_device_info - template for creating a mipi_dsi_device
* @type: DSI peripheral chip type
* @channel: DSI virtual channel assigned to peripheral * @channel: DSI virtual channel assigned to peripheral
* @node: pointer to OF device node * @node: pointer to OF device node or NULL
* *
* This is populated and passed to mipi_dsi_device_new to create a new * This is populated and passed to mipi_dsi_device_new to create a new
* DSI device * DSI device
*/ */
struct mipi_dsi_device_info { struct mipi_dsi_device_info {
char type[DSI_DEV_NAME_SIZE];
u32 channel; u32 channel;
struct device_node *node; struct device_node *node;
}; };
...@@ -156,6 +160,7 @@ struct mipi_dsi_device_info { ...@@ -156,6 +160,7 @@ struct mipi_dsi_device_info {
* struct mipi_dsi_device - DSI peripheral device * struct mipi_dsi_device - DSI peripheral device
* @host: DSI host for this peripheral * @host: DSI host for this peripheral
* @dev: driver model device node for this peripheral * @dev: driver model device node for this peripheral
* @name: DSI peripheral chip type
* @channel: virtual channel assigned to the peripheral * @channel: virtual channel assigned to the peripheral
* @format: pixel format for video mode * @format: pixel format for video mode
* @lanes: number of active data lanes * @lanes: number of active data lanes
...@@ -165,6 +170,7 @@ struct mipi_dsi_device { ...@@ -165,6 +170,7 @@ struct mipi_dsi_device {
struct mipi_dsi_host *host; struct mipi_dsi_host *host;
struct device dev; struct device dev;
char name[DSI_DEV_NAME_SIZE];
unsigned int channel; unsigned int channel;
unsigned int lanes; unsigned int lanes;
enum mipi_dsi_pixel_format format; enum mipi_dsi_pixel_format format;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment