diff options
Diffstat (limited to 'drivers/gpu/drm/omapdrm/dss/dsi.c')
| -rw-r--r-- | drivers/gpu/drm/omapdrm/dss/dsi.c | 27 | 
1 files changed, 19 insertions, 8 deletions
| diff --git a/drivers/gpu/drm/omapdrm/dss/dsi.c b/drivers/gpu/drm/omapdrm/dss/dsi.c index 00a9c2ab9e6c..64fb788b6647 100644 --- a/drivers/gpu/drm/omapdrm/dss/dsi.c +++ b/drivers/gpu/drm/omapdrm/dss/dsi.c @@ -1406,7 +1406,7 @@ static void dsi_pll_disable(struct dss_pll *pll)  static int dsi_dump_dsi_clocks(struct seq_file *s, void *p)  { -	struct dsi_data *dsi = p; +	struct dsi_data *dsi = s->private;  	struct dss_pll_clock_info *cinfo = &dsi->pll.cinfo;  	enum dss_clk_source dispc_clk_src, dsi_clk_src;  	int dsi_module = dsi->module_id; @@ -1467,7 +1467,7 @@ static int dsi_dump_dsi_clocks(struct seq_file *s, void *p)  #ifdef CONFIG_OMAP2_DSS_COLLECT_IRQ_STATS  static int dsi_dump_dsi_irqs(struct seq_file *s, void *p)  { -	struct dsi_data *dsi = p; +	struct dsi_data *dsi = s->private;  	unsigned long flags;  	struct dsi_irq_stats stats; @@ -1558,7 +1558,7 @@ static int dsi_dump_dsi_irqs(struct seq_file *s, void *p)  static int dsi_dump_dsi_regs(struct seq_file *s, void *p)  { -	struct dsi_data *dsi = p; +	struct dsi_data *dsi = s->private;  	if (dsi_runtime_get(dsi))  		return 0; @@ -4751,6 +4751,17 @@ static int dsi_set_config(struct omap_dss_device *dssdev,  	dsi->vm.flags |= DISPLAY_FLAGS_HSYNC_HIGH;  	dsi->vm.flags &= ~DISPLAY_FLAGS_VSYNC_LOW;  	dsi->vm.flags |= DISPLAY_FLAGS_VSYNC_HIGH; +	/* +	 * HACK: These flags should be handled through the omap_dss_device bus +	 * flags, but this will only be possible when the DSI encoder will be +	 * converted to the omapdrm-managed encoder model. +	 */ +	dsi->vm.flags &= ~DISPLAY_FLAGS_PIXDATA_NEGEDGE; +	dsi->vm.flags |= DISPLAY_FLAGS_PIXDATA_POSEDGE; +	dsi->vm.flags &= ~DISPLAY_FLAGS_DE_LOW; +	dsi->vm.flags |= DISPLAY_FLAGS_DE_HIGH; +	dsi->vm.flags &= ~DISPLAY_FLAGS_SYNC_POSEDGE; +	dsi->vm.flags |= DISPLAY_FLAGS_SYNC_NEGEDGE;  	dss_mgr_set_timings(&dsi->output, &dsi->vm); @@ -5083,15 +5094,15 @@ static int dsi_bind(struct device *dev, struct device *master, void *data)  	snprintf(name, sizeof(name), "dsi%u_regs", dsi->module_id + 1);  	dsi->debugfs.regs = dss_debugfs_create_file(dss, name, -						    dsi_dump_dsi_regs, &dsi); +						    dsi_dump_dsi_regs, dsi);  #ifdef CONFIG_OMAP2_DSS_COLLECT_IRQ_STATS  	snprintf(name, sizeof(name), "dsi%u_irqs", dsi->module_id + 1);  	dsi->debugfs.irqs = dss_debugfs_create_file(dss, name, -						    dsi_dump_dsi_irqs, &dsi); +						    dsi_dump_dsi_irqs, dsi);  #endif  	snprintf(name, sizeof(name), "dsi%u_clks", dsi->module_id + 1);  	dsi->debugfs.clks = dss_debugfs_create_file(dss, name, -						    dsi_dump_dsi_clocks, &dsi); +						    dsi_dump_dsi_clocks, dsi);  	return 0;  } @@ -5104,8 +5115,6 @@ static void dsi_unbind(struct device *dev, struct device *master, void *data)  	dss_debugfs_remove_file(dsi->debugfs.irqs);  	dss_debugfs_remove_file(dsi->debugfs.regs); -	of_platform_depopulate(dev); -  	WARN_ON(dsi->scp_clk_refcount > 0);  	dss_pll_unregister(&dsi->pll); @@ -5457,6 +5466,8 @@ static int dsi_remove(struct platform_device *pdev)  	dsi_uninit_output(dsi); +	of_platform_depopulate(&pdev->dev); +  	pm_runtime_disable(&pdev->dev);  	if (dsi->vdds_dsi_reg != NULL && dsi->vdds_dsi_enabled) { | 
