Commit dac62bca authored by Tomi Valkeinen's avatar Tomi Valkeinen

drm/omap: remove dispc_ops

dispc_ops was created to help with the multi-module architecture and
giving us the possibility of multiple dispc implementations. Neither of
these is valid anymore, and we can remove dispc_ops and use direct
calls to dispc.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
Acked-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: default avatarSebastian Reichel <sebastian.reichel@collabora.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20201215104657.802264-54-tomi.valkeinen@ti.com
parent 96f44185
...@@ -21,11 +21,6 @@ struct dispc_device *dispc_get_dispc(struct dss_device *dss) ...@@ -21,11 +21,6 @@ struct dispc_device *dispc_get_dispc(struct dss_device *dss)
return dss->dispc; return dss->dispc;
} }
const struct dispc_ops *dispc_get_ops(struct dss_device *dss)
{
return dss->dispc_ops;
}
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
* OMAP DSS Devices Handling * OMAP DSS Devices Handling
*/ */
......
...@@ -351,8 +351,6 @@ static unsigned long dispc_plane_pclk_rate(struct dispc_device *dispc, ...@@ -351,8 +351,6 @@ static unsigned long dispc_plane_pclk_rate(struct dispc_device *dispc,
static unsigned long dispc_plane_lclk_rate(struct dispc_device *dispc, static unsigned long dispc_plane_lclk_rate(struct dispc_device *dispc,
enum omap_plane_id plane); enum omap_plane_id plane);
static void dispc_clear_irqstatus(struct dispc_device *dispc, u32 mask);
static inline void dispc_write_reg(struct dispc_device *dispc, u16 idx, u32 val) static inline void dispc_write_reg(struct dispc_device *dispc, u16 idx, u32 val)
{ {
__raw_writel(val, dispc->base + idx); __raw_writel(val, dispc->base + idx);
...@@ -379,12 +377,12 @@ static void mgr_fld_write(struct dispc_device *dispc, enum omap_channel channel, ...@@ -379,12 +377,12 @@ static void mgr_fld_write(struct dispc_device *dispc, enum omap_channel channel,
REG_FLD_MOD(dispc, rfld->reg, val, rfld->high, rfld->low); REG_FLD_MOD(dispc, rfld->reg, val, rfld->high, rfld->low);
} }
static int dispc_get_num_ovls(struct dispc_device *dispc) int dispc_get_num_ovls(struct dispc_device *dispc)
{ {
return dispc->feat->num_ovls; return dispc->feat->num_ovls;
} }
static int dispc_get_num_mgrs(struct dispc_device *dispc) int dispc_get_num_mgrs(struct dispc_device *dispc)
{ {
return dispc->feat->num_mgrs; return dispc->feat->num_mgrs;
} }
...@@ -670,13 +668,13 @@ void dispc_runtime_put(struct dispc_device *dispc) ...@@ -670,13 +668,13 @@ void dispc_runtime_put(struct dispc_device *dispc)
WARN_ON(r < 0 && r != -ENOSYS); WARN_ON(r < 0 && r != -ENOSYS);
} }
static u32 dispc_mgr_get_vsync_irq(struct dispc_device *dispc, u32 dispc_mgr_get_vsync_irq(struct dispc_device *dispc,
enum omap_channel channel) enum omap_channel channel)
{ {
return mgr_desc[channel].vsync_irq; return mgr_desc[channel].vsync_irq;
} }
static u32 dispc_mgr_get_framedone_irq(struct dispc_device *dispc, u32 dispc_mgr_get_framedone_irq(struct dispc_device *dispc,
enum omap_channel channel) enum omap_channel channel)
{ {
if (channel == OMAP_DSS_CHANNEL_DIGIT && dispc->feat->no_framedone_tv) if (channel == OMAP_DSS_CHANNEL_DIGIT && dispc->feat->no_framedone_tv)
...@@ -685,18 +683,18 @@ static u32 dispc_mgr_get_framedone_irq(struct dispc_device *dispc, ...@@ -685,18 +683,18 @@ static u32 dispc_mgr_get_framedone_irq(struct dispc_device *dispc,
return mgr_desc[channel].framedone_irq; return mgr_desc[channel].framedone_irq;
} }
static u32 dispc_mgr_get_sync_lost_irq(struct dispc_device *dispc, u32 dispc_mgr_get_sync_lost_irq(struct dispc_device *dispc,
enum omap_channel channel) enum omap_channel channel)
{ {
return mgr_desc[channel].sync_lost_irq; return mgr_desc[channel].sync_lost_irq;
} }
static u32 dispc_wb_get_framedone_irq(struct dispc_device *dispc) u32 dispc_wb_get_framedone_irq(struct dispc_device *dispc)
{ {
return DISPC_IRQ_FRAMEDONEWB; return DISPC_IRQ_FRAMEDONEWB;
} }
static void dispc_mgr_enable(struct dispc_device *dispc, void dispc_mgr_enable(struct dispc_device *dispc,
enum omap_channel channel, bool enable) enum omap_channel channel, bool enable)
{ {
mgr_fld_write(dispc, channel, DISPC_MGR_FLD_ENABLE, enable); mgr_fld_write(dispc, channel, DISPC_MGR_FLD_ENABLE, enable);
...@@ -710,13 +708,13 @@ static bool dispc_mgr_is_enabled(struct dispc_device *dispc, ...@@ -710,13 +708,13 @@ static bool dispc_mgr_is_enabled(struct dispc_device *dispc,
return !!mgr_fld_read(dispc, channel, DISPC_MGR_FLD_ENABLE); return !!mgr_fld_read(dispc, channel, DISPC_MGR_FLD_ENABLE);
} }
static bool dispc_mgr_go_busy(struct dispc_device *dispc, bool dispc_mgr_go_busy(struct dispc_device *dispc,
enum omap_channel channel) enum omap_channel channel)
{ {
return mgr_fld_read(dispc, channel, DISPC_MGR_FLD_GO) == 1; return mgr_fld_read(dispc, channel, DISPC_MGR_FLD_GO) == 1;
} }
static void dispc_mgr_go(struct dispc_device *dispc, enum omap_channel channel) void dispc_mgr_go(struct dispc_device *dispc, enum omap_channel channel)
{ {
WARN_ON(!dispc_mgr_is_enabled(dispc, channel)); WARN_ON(!dispc_mgr_is_enabled(dispc, channel));
WARN_ON(dispc_mgr_go_busy(dispc, channel)); WARN_ON(dispc_mgr_go_busy(dispc, channel));
...@@ -726,12 +724,12 @@ static void dispc_mgr_go(struct dispc_device *dispc, enum omap_channel channel) ...@@ -726,12 +724,12 @@ static void dispc_mgr_go(struct dispc_device *dispc, enum omap_channel channel)
mgr_fld_write(dispc, channel, DISPC_MGR_FLD_GO, 1); mgr_fld_write(dispc, channel, DISPC_MGR_FLD_GO, 1);
} }
static bool dispc_wb_go_busy(struct dispc_device *dispc) bool dispc_wb_go_busy(struct dispc_device *dispc)
{ {
return REG_GET(dispc, DISPC_CONTROL2, 6, 6) == 1; return REG_GET(dispc, DISPC_CONTROL2, 6, 6) == 1;
} }
static void dispc_wb_go(struct dispc_device *dispc) void dispc_wb_go(struct dispc_device *dispc)
{ {
enum omap_plane_id plane = OMAP_DSS_WB; enum omap_plane_id plane = OMAP_DSS_WB;
bool enable, go; bool enable, go;
...@@ -1297,7 +1295,7 @@ static bool dispc_ovl_color_mode_supported(struct dispc_device *dispc, ...@@ -1297,7 +1295,7 @@ static bool dispc_ovl_color_mode_supported(struct dispc_device *dispc,
return false; return false;
} }
static const u32 *dispc_ovl_get_color_modes(struct dispc_device *dispc, const u32 *dispc_ovl_get_color_modes(struct dispc_device *dispc,
enum omap_plane_id plane) enum omap_plane_id plane)
{ {
return dispc->feat->supported_color_modes[plane]; return dispc->feat->supported_color_modes[plane];
...@@ -2781,7 +2779,7 @@ static int dispc_ovl_setup_common(struct dispc_device *dispc, ...@@ -2781,7 +2779,7 @@ static int dispc_ovl_setup_common(struct dispc_device *dispc,
return 0; return 0;
} }
static int dispc_ovl_setup(struct dispc_device *dispc, int dispc_ovl_setup(struct dispc_device *dispc,
enum omap_plane_id plane, enum omap_plane_id plane,
const struct omap_overlay_info *oi, const struct omap_overlay_info *oi,
const struct videomode *vm, bool mem_to_mem, const struct videomode *vm, bool mem_to_mem,
...@@ -2809,7 +2807,7 @@ static int dispc_ovl_setup(struct dispc_device *dispc, ...@@ -2809,7 +2807,7 @@ static int dispc_ovl_setup(struct dispc_device *dispc,
return r; return r;
} }
static int dispc_wb_setup(struct dispc_device *dispc, int dispc_wb_setup(struct dispc_device *dispc,
const struct omap_dss_writeback_info *wi, const struct omap_dss_writeback_info *wi,
bool mem_to_mem, const struct videomode *vm, bool mem_to_mem, const struct videomode *vm,
enum dss_writeback_channel channel_in) enum dss_writeback_channel channel_in)
...@@ -2893,12 +2891,12 @@ static int dispc_wb_setup(struct dispc_device *dispc, ...@@ -2893,12 +2891,12 @@ static int dispc_wb_setup(struct dispc_device *dispc,
return 0; return 0;
} }
static bool dispc_has_writeback(struct dispc_device *dispc) bool dispc_has_writeback(struct dispc_device *dispc)
{ {
return dispc->feat->has_writeback; return dispc->feat->has_writeback;
} }
static int dispc_ovl_enable(struct dispc_device *dispc, int dispc_ovl_enable(struct dispc_device *dispc,
enum omap_plane_id plane, bool enable) enum omap_plane_id plane, bool enable)
{ {
DSSDBG("dispc_enable_plane %d, %d\n", plane, enable); DSSDBG("dispc_enable_plane %d, %d\n", plane, enable);
...@@ -2989,7 +2987,7 @@ static void dispc_mgr_enable_alpha_fixed_zorder(struct dispc_device *dispc, ...@@ -2989,7 +2987,7 @@ static void dispc_mgr_enable_alpha_fixed_zorder(struct dispc_device *dispc,
REG_FLD_MOD(dispc, DISPC_CONFIG, enable, 19, 19); REG_FLD_MOD(dispc, DISPC_CONFIG, enable, 19, 19);
} }
static void dispc_mgr_setup(struct dispc_device *dispc, void dispc_mgr_setup(struct dispc_device *dispc,
enum omap_channel channel, enum omap_channel channel,
const struct omap_overlay_manager_info *info) const struct omap_overlay_manager_info *info)
{ {
...@@ -3068,7 +3066,7 @@ static void dispc_mgr_enable_stallmode(struct dispc_device *dispc, ...@@ -3068,7 +3066,7 @@ static void dispc_mgr_enable_stallmode(struct dispc_device *dispc,
mgr_fld_write(dispc, channel, DISPC_MGR_FLD_STALLMODE, enable); mgr_fld_write(dispc, channel, DISPC_MGR_FLD_STALLMODE, enable);
} }
static void dispc_mgr_set_lcd_config(struct dispc_device *dispc, void dispc_mgr_set_lcd_config(struct dispc_device *dispc,
enum omap_channel channel, enum omap_channel channel,
const struct dss_lcd_mgr_config *config) const struct dss_lcd_mgr_config *config)
{ {
...@@ -3117,7 +3115,7 @@ static bool _dispc_mgr_pclk_ok(struct dispc_device *dispc, ...@@ -3117,7 +3115,7 @@ static bool _dispc_mgr_pclk_ok(struct dispc_device *dispc,
return pclk <= dispc->feat->max_tv_pclk; return pclk <= dispc->feat->max_tv_pclk;
} }
static int dispc_mgr_check_timings(struct dispc_device *dispc, int dispc_mgr_check_timings(struct dispc_device *dispc,
enum omap_channel channel, enum omap_channel channel,
const struct videomode *vm) const struct videomode *vm)
{ {
...@@ -3210,7 +3208,7 @@ static int vm_flag_to_int(enum display_flags flags, enum display_flags high, ...@@ -3210,7 +3208,7 @@ static int vm_flag_to_int(enum display_flags flags, enum display_flags high,
} }
/* change name to mode? */ /* change name to mode? */
static void dispc_mgr_set_timings(struct dispc_device *dispc, void dispc_mgr_set_timings(struct dispc_device *dispc,
enum omap_channel channel, enum omap_channel channel,
const struct videomode *vm) const struct videomode *vm)
{ {
...@@ -3754,17 +3752,17 @@ int dispc_mgr_get_clock_div(struct dispc_device *dispc, ...@@ -3754,17 +3752,17 @@ int dispc_mgr_get_clock_div(struct dispc_device *dispc,
return 0; return 0;
} }
static u32 dispc_read_irqstatus(struct dispc_device *dispc) u32 dispc_read_irqstatus(struct dispc_device *dispc)
{ {
return dispc_read_reg(dispc, DISPC_IRQSTATUS); return dispc_read_reg(dispc, DISPC_IRQSTATUS);
} }
static void dispc_clear_irqstatus(struct dispc_device *dispc, u32 mask) void dispc_clear_irqstatus(struct dispc_device *dispc, u32 mask)
{ {
dispc_write_reg(dispc, DISPC_IRQSTATUS, mask); dispc_write_reg(dispc, DISPC_IRQSTATUS, mask);
} }
static void dispc_write_irqenable(struct dispc_device *dispc, u32 mask) void dispc_write_irqenable(struct dispc_device *dispc, u32 mask)
{ {
u32 old_mask = dispc_read_reg(dispc, DISPC_IRQENABLE); u32 old_mask = dispc_read_reg(dispc, DISPC_IRQENABLE);
...@@ -3788,7 +3786,7 @@ void dispc_disable_sidle(struct dispc_device *dispc) ...@@ -3788,7 +3786,7 @@ void dispc_disable_sidle(struct dispc_device *dispc)
REG_FLD_MOD(dispc, DISPC_SYSCONFIG, 1, 4, 3); /* SIDLEMODE: no idle */ REG_FLD_MOD(dispc, DISPC_SYSCONFIG, 1, 4, 3); /* SIDLEMODE: no idle */
} }
static u32 dispc_mgr_gamma_size(struct dispc_device *dispc, u32 dispc_mgr_gamma_size(struct dispc_device *dispc,
enum omap_channel channel) enum omap_channel channel)
{ {
const struct dispc_gamma_desc *gdesc = &mgr_desc[channel].gamma; const struct dispc_gamma_desc *gdesc = &mgr_desc[channel].gamma;
...@@ -3843,7 +3841,7 @@ static const struct drm_color_lut dispc_mgr_gamma_default_lut[] = { ...@@ -3843,7 +3841,7 @@ static const struct drm_color_lut dispc_mgr_gamma_default_lut[] = {
{ .red = U16_MAX, .green = U16_MAX, .blue = U16_MAX, }, { .red = U16_MAX, .green = U16_MAX, .blue = U16_MAX, },
}; };
static void dispc_mgr_set_gamma(struct dispc_device *dispc, void dispc_mgr_set_gamma(struct dispc_device *dispc,
enum omap_channel channel, enum omap_channel channel,
const struct drm_color_lut *lut, const struct drm_color_lut *lut,
unsigned int length) unsigned int length)
...@@ -4499,7 +4497,7 @@ static irqreturn_t dispc_irq_handler(int irq, void *arg) ...@@ -4499,7 +4497,7 @@ static irqreturn_t dispc_irq_handler(int irq, void *arg)
return dispc->user_handler(irq, dispc->user_data); return dispc->user_handler(irq, dispc->user_data);
} }
static int dispc_request_irq(struct dispc_device *dispc, irq_handler_t handler, int dispc_request_irq(struct dispc_device *dispc, irq_handler_t handler,
void *dev_id) void *dev_id)
{ {
int r; int r;
...@@ -4523,7 +4521,7 @@ static int dispc_request_irq(struct dispc_device *dispc, irq_handler_t handler, ...@@ -4523,7 +4521,7 @@ static int dispc_request_irq(struct dispc_device *dispc, irq_handler_t handler,
return r; return r;
} }
static void dispc_free_irq(struct dispc_device *dispc, void *dev_id) void dispc_free_irq(struct dispc_device *dispc, void *dev_id)
{ {
devm_free_irq(&dispc->pdev->dev, dispc->irq, dispc); devm_free_irq(&dispc->pdev->dev, dispc->irq, dispc);
...@@ -4531,7 +4529,7 @@ static void dispc_free_irq(struct dispc_device *dispc, void *dev_id) ...@@ -4531,7 +4529,7 @@ static void dispc_free_irq(struct dispc_device *dispc, void *dev_id)
dispc->user_data = NULL; dispc->user_data = NULL;
} }
static u32 dispc_get_memory_bandwidth_limit(struct dispc_device *dispc) u32 dispc_get_memory_bandwidth_limit(struct dispc_device *dispc)
{ {
u32 limit = 0; u32 limit = 0;
...@@ -4701,47 +4699,6 @@ static void dispc_errata_i734_wa(struct dispc_device *dispc) ...@@ -4701,47 +4699,6 @@ static void dispc_errata_i734_wa(struct dispc_device *dispc)
REG_FLD_MOD(dispc, DISPC_CONFIG, gatestate, 8, 4); REG_FLD_MOD(dispc, DISPC_CONFIG, gatestate, 8, 4);
} }
static const struct dispc_ops dispc_ops = {
.read_irqstatus = dispc_read_irqstatus,
.clear_irqstatus = dispc_clear_irqstatus,
.write_irqenable = dispc_write_irqenable,
.request_irq = dispc_request_irq,
.free_irq = dispc_free_irq,
.runtime_get = dispc_runtime_get,
.runtime_put = dispc_runtime_put,
.get_num_ovls = dispc_get_num_ovls,
.get_num_mgrs = dispc_get_num_mgrs,
.get_memory_bandwidth_limit = dispc_get_memory_bandwidth_limit,
.mgr_enable = dispc_mgr_enable,
.mgr_is_enabled = dispc_mgr_is_enabled,
.mgr_get_vsync_irq = dispc_mgr_get_vsync_irq,
.mgr_get_framedone_irq = dispc_mgr_get_framedone_irq,
.mgr_get_sync_lost_irq = dispc_mgr_get_sync_lost_irq,
.mgr_go_busy = dispc_mgr_go_busy,
.mgr_go = dispc_mgr_go,
.mgr_set_lcd_config = dispc_mgr_set_lcd_config,
.mgr_check_timings = dispc_mgr_check_timings,
.mgr_set_timings = dispc_mgr_set_timings,
.mgr_setup = dispc_mgr_setup,
.mgr_gamma_size = dispc_mgr_gamma_size,
.mgr_set_gamma = dispc_mgr_set_gamma,
.ovl_enable = dispc_ovl_enable,
.ovl_setup = dispc_ovl_setup,
.ovl_get_color_modes = dispc_ovl_get_color_modes,
.wb_get_framedone_irq = dispc_wb_get_framedone_irq,
.wb_setup = dispc_wb_setup,
.has_writeback = dispc_has_writeback,
.wb_go_busy = dispc_wb_go_busy,
.wb_go = dispc_wb_go,
};
/* DISPC HW IP initialisation */ /* DISPC HW IP initialisation */
static const struct of_device_id dispc_of_match[] = { static const struct of_device_id dispc_of_match[] = {
{ .compatible = "ti,omap2-dispc", .data = &omap24xx_dispc_feats }, { .compatible = "ti,omap2-dispc", .data = &omap24xx_dispc_feats },
...@@ -4843,7 +4800,6 @@ static int dispc_bind(struct device *dev, struct device *master, void *data) ...@@ -4843,7 +4800,6 @@ static int dispc_bind(struct device *dev, struct device *master, void *data)
dispc_runtime_put(dispc); dispc_runtime_put(dispc);
dss->dispc = dispc; dss->dispc = dispc;
dss->dispc_ops = &dispc_ops;
dispc->debugfs = dss_debugfs_create_file(dss, "dispc", dispc_dump_regs, dispc->debugfs = dss_debugfs_create_file(dss, "dispc", dispc_dump_regs,
dispc); dispc);
...@@ -4865,7 +4821,6 @@ static void dispc_unbind(struct device *dev, struct device *master, void *data) ...@@ -4865,7 +4821,6 @@ static void dispc_unbind(struct device *dev, struct device *master, void *data)
dss_debugfs_remove_file(dispc->debugfs); dss_debugfs_remove_file(dispc->debugfs);
dss->dispc = NULL; dss->dispc = NULL;
dss->dispc_ops = NULL;
pm_runtime_disable(dev); pm_runtime_disable(dev);
......
...@@ -257,7 +257,6 @@ struct dss_device { ...@@ -257,7 +257,6 @@ struct dss_device {
struct dss_pll *video2_pll; struct dss_pll *video2_pll;
struct dispc_device *dispc; struct dispc_device *dispc;
const struct dispc_ops *dispc_ops;
const struct dss_mgr_ops *mgr_ops; const struct dss_mgr_ops *mgr_ops;
struct omap_drm_private *mgr_ops_priv; struct omap_drm_private *mgr_ops_priv;
}; };
...@@ -393,6 +392,76 @@ void dispc_dump_clocks(struct dispc_device *dispc, struct seq_file *s); ...@@ -393,6 +392,76 @@ void dispc_dump_clocks(struct dispc_device *dispc, struct seq_file *s);
int dispc_runtime_get(struct dispc_device *dispc); int dispc_runtime_get(struct dispc_device *dispc);
void dispc_runtime_put(struct dispc_device *dispc); void dispc_runtime_put(struct dispc_device *dispc);
int dispc_get_num_ovls(struct dispc_device *dispc);
int dispc_get_num_mgrs(struct dispc_device *dispc);
const u32 *dispc_ovl_get_color_modes(struct dispc_device *dispc,
enum omap_plane_id plane);
u32 dispc_read_irqstatus(struct dispc_device *dispc);
void dispc_clear_irqstatus(struct dispc_device *dispc, u32 mask);
void dispc_write_irqenable(struct dispc_device *dispc, u32 mask);
int dispc_request_irq(struct dispc_device *dispc, irq_handler_t handler,
void *dev_id);
void dispc_free_irq(struct dispc_device *dispc, void *dev_id);
u32 dispc_mgr_get_vsync_irq(struct dispc_device *dispc,
enum omap_channel channel);
u32 dispc_mgr_get_framedone_irq(struct dispc_device *dispc,
enum omap_channel channel);
u32 dispc_mgr_get_sync_lost_irq(struct dispc_device *dispc,
enum omap_channel channel);
u32 dispc_wb_get_framedone_irq(struct dispc_device *dispc);
u32 dispc_get_memory_bandwidth_limit(struct dispc_device *dispc);
void dispc_mgr_enable(struct dispc_device *dispc,
enum omap_channel channel, bool enable);
bool dispc_mgr_go_busy(struct dispc_device *dispc,
enum omap_channel channel);
void dispc_mgr_go(struct dispc_device *dispc, enum omap_channel channel);
void dispc_mgr_set_lcd_config(struct dispc_device *dispc,
enum omap_channel channel,
const struct dss_lcd_mgr_config *config);
void dispc_mgr_set_timings(struct dispc_device *dispc,
enum omap_channel channel,
const struct videomode *vm);
void dispc_mgr_setup(struct dispc_device *dispc,
enum omap_channel channel,
const struct omap_overlay_manager_info *info);
int dispc_mgr_check_timings(struct dispc_device *dispc,
enum omap_channel channel,
const struct videomode *vm);
u32 dispc_mgr_gamma_size(struct dispc_device *dispc,
enum omap_channel channel);
void dispc_mgr_set_gamma(struct dispc_device *dispc,
enum omap_channel channel,
const struct drm_color_lut *lut,
unsigned int length);
int dispc_ovl_setup(struct dispc_device *dispc,
enum omap_plane_id plane,
const struct omap_overlay_info *oi,
const struct videomode *vm, bool mem_to_mem,
enum omap_channel channel);
int dispc_ovl_enable(struct dispc_device *dispc,
enum omap_plane_id plane, bool enable);
bool dispc_has_writeback(struct dispc_device *dispc);
int dispc_wb_setup(struct dispc_device *dispc,
const struct omap_dss_writeback_info *wi,
bool mem_to_mem, const struct videomode *vm,
enum dss_writeback_channel channel_in);
bool dispc_wb_go_busy(struct dispc_device *dispc);
void dispc_wb_go(struct dispc_device *dispc);
void dispc_enable_sidle(struct dispc_device *dispc); void dispc_enable_sidle(struct dispc_device *dispc);
void dispc_disable_sidle(struct dispc_device *dispc); void dispc_disable_sidle(struct dispc_device *dispc);
......
...@@ -379,78 +379,7 @@ int dss_mgr_register_framedone_handler(struct omap_dss_device *dssdev, ...@@ -379,78 +379,7 @@ int dss_mgr_register_framedone_handler(struct omap_dss_device *dssdev,
void dss_mgr_unregister_framedone_handler(struct omap_dss_device *dssdev, void dss_mgr_unregister_framedone_handler(struct omap_dss_device *dssdev,
void (*handler)(void *), void *data); void (*handler)(void *), void *data);
/* dispc ops */
struct dispc_ops {
u32 (*read_irqstatus)(struct dispc_device *dispc);
void (*clear_irqstatus)(struct dispc_device *dispc, u32 mask);
void (*write_irqenable)(struct dispc_device *dispc, u32 mask);
int (*request_irq)(struct dispc_device *dispc, irq_handler_t handler,
void *dev_id);
void (*free_irq)(struct dispc_device *dispc, void *dev_id);
int (*runtime_get)(struct dispc_device *dispc);
void (*runtime_put)(struct dispc_device *dispc);
int (*get_num_ovls)(struct dispc_device *dispc);
int (*get_num_mgrs)(struct dispc_device *dispc);
u32 (*get_memory_bandwidth_limit)(struct dispc_device *dispc);
void (*mgr_enable)(struct dispc_device *dispc,
enum omap_channel channel, bool enable);
bool (*mgr_is_enabled)(struct dispc_device *dispc,
enum omap_channel channel);
u32 (*mgr_get_vsync_irq)(struct dispc_device *dispc,
enum omap_channel channel);
u32 (*mgr_get_framedone_irq)(struct dispc_device *dispc,
enum omap_channel channel);
u32 (*mgr_get_sync_lost_irq)(struct dispc_device *dispc,
enum omap_channel channel);
bool (*mgr_go_busy)(struct dispc_device *dispc,
enum omap_channel channel);
void (*mgr_go)(struct dispc_device *dispc, enum omap_channel channel);
void (*mgr_set_lcd_config)(struct dispc_device *dispc,
enum omap_channel channel,
const struct dss_lcd_mgr_config *config);
int (*mgr_check_timings)(struct dispc_device *dispc,
enum omap_channel channel,
const struct videomode *vm);
void (*mgr_set_timings)(struct dispc_device *dispc,
enum omap_channel channel,
const struct videomode *vm);
void (*mgr_setup)(struct dispc_device *dispc, enum omap_channel channel,
const struct omap_overlay_manager_info *info);
u32 (*mgr_gamma_size)(struct dispc_device *dispc,
enum omap_channel channel);
void (*mgr_set_gamma)(struct dispc_device *dispc,
enum omap_channel channel,
const struct drm_color_lut *lut,
unsigned int length);
int (*ovl_enable)(struct dispc_device *dispc, enum omap_plane_id plane,
bool enable);
int (*ovl_setup)(struct dispc_device *dispc, enum omap_plane_id plane,
const struct omap_overlay_info *oi,
const struct videomode *vm, bool mem_to_mem,
enum omap_channel channel);
const u32 *(*ovl_get_color_modes)(struct dispc_device *dispc,
enum omap_plane_id plane);
u32 (*wb_get_framedone_irq)(struct dispc_device *dispc);
int (*wb_setup)(struct dispc_device *dispc,
const struct omap_dss_writeback_info *wi,
bool mem_to_mem, const struct videomode *vm,
enum dss_writeback_channel channel_in);
bool (*has_writeback)(struct dispc_device *dispc);
bool (*wb_go_busy)(struct dispc_device *dispc);
void (*wb_go)(struct dispc_device *dispc);
};
struct dispc_device *dispc_get_dispc(struct dss_device *dss); struct dispc_device *dispc_get_dispc(struct dss_device *dss);
const struct dispc_ops *dispc_get_ops(struct dss_device *dss);
bool omapdss_stack_is_ready(void); bool omapdss_stack_is_ready(void);
void omapdss_gather_components(struct device *dev); void omapdss_gather_components(struct device *dev);
......
...@@ -103,7 +103,7 @@ int omap_crtc_wait_pending(struct drm_crtc *crtc) ...@@ -103,7 +103,7 @@ int omap_crtc_wait_pending(struct drm_crtc *crtc)
static void omap_crtc_dss_start_update(struct omap_drm_private *priv, static void omap_crtc_dss_start_update(struct omap_drm_private *priv,
enum omap_channel channel) enum omap_channel channel)
{ {
priv->dispc_ops->mgr_enable(priv->dispc, channel, true); dispc_mgr_enable(priv->dispc, channel, true);
} }
/* Called only from the encoder enable/disable and suspend/resume handlers. */ /* Called only from the encoder enable/disable and suspend/resume handlers. */
...@@ -128,7 +128,7 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable) ...@@ -128,7 +128,7 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable)
} }
if (omap_crtc->pipe->output->type == OMAP_DISPLAY_TYPE_HDMI) { if (omap_crtc->pipe->output->type == OMAP_DISPLAY_TYPE_HDMI) {
priv->dispc_ops->mgr_enable(priv->dispc, channel, enable); dispc_mgr_enable(priv->dispc, channel, enable);
omap_crtc->enabled = enable; omap_crtc->enabled = enable;
return; return;
} }
...@@ -141,9 +141,9 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable) ...@@ -141,9 +141,9 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable)
omap_crtc->ignore_digit_sync_lost = true; omap_crtc->ignore_digit_sync_lost = true;
} }
framedone_irq = priv->dispc_ops->mgr_get_framedone_irq(priv->dispc, framedone_irq = dispc_mgr_get_framedone_irq(priv->dispc,
channel); channel);
vsync_irq = priv->dispc_ops->mgr_get_vsync_irq(priv->dispc, channel); vsync_irq = dispc_mgr_get_vsync_irq(priv->dispc, channel);
if (enable) { if (enable) {
wait = omap_irq_wait_init(dev, vsync_irq, 1); wait = omap_irq_wait_init(dev, vsync_irq, 1);
...@@ -163,7 +163,7 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable) ...@@ -163,7 +163,7 @@ static void omap_crtc_set_enabled(struct drm_crtc *crtc, bool enable)
wait = omap_irq_wait_init(dev, vsync_irq, 2); wait = omap_irq_wait_init(dev, vsync_irq, 2);
} }
priv->dispc_ops->mgr_enable(priv->dispc, channel, enable); dispc_mgr_enable(priv->dispc, channel, enable);
omap_crtc->enabled = enable; omap_crtc->enabled = enable;
ret = omap_irq_wait(dev, wait, msecs_to_jiffies(100)); ret = omap_irq_wait(dev, wait, msecs_to_jiffies(100));
...@@ -186,7 +186,7 @@ static int omap_crtc_dss_enable(struct omap_drm_private *priv, ...@@ -186,7 +186,7 @@ static int omap_crtc_dss_enable(struct omap_drm_private *priv,
struct drm_crtc *crtc = priv->channels[channel]->crtc; struct drm_crtc *crtc = priv->channels[channel]->crtc;
struct omap_crtc *omap_crtc = to_omap_crtc(crtc); struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
priv->dispc_ops->mgr_set_timings(priv->dispc, omap_crtc->channel, dispc_mgr_set_timings(priv->dispc, omap_crtc->channel,
&omap_crtc->vm); &omap_crtc->vm);
omap_crtc_set_enabled(&omap_crtc->base, true); omap_crtc_set_enabled(&omap_crtc->base, true);
...@@ -221,7 +221,7 @@ static void omap_crtc_dss_set_lcd_config(struct omap_drm_private *priv, ...@@ -221,7 +221,7 @@ static void omap_crtc_dss_set_lcd_config(struct omap_drm_private *priv,
struct omap_crtc *omap_crtc = to_omap_crtc(crtc); struct omap_crtc *omap_crtc = to_omap_crtc(crtc);
DBG("%s", omap_crtc->name); DBG("%s", omap_crtc->name);
priv->dispc_ops->mgr_set_lcd_config(priv->dispc, omap_crtc->channel, dispc_mgr_set_lcd_config(priv->dispc, omap_crtc->channel,
config); config);
} }
...@@ -300,7 +300,7 @@ void omap_crtc_vblank_irq(struct drm_crtc *crtc) ...@@ -300,7 +300,7 @@ void omap_crtc_vblank_irq(struct drm_crtc *crtc)
* If the dispc is busy we're racing the flush operation. Try again on * If the dispc is busy we're racing the flush operation. Try again on
* the next vblank interrupt. * the next vblank interrupt.
*/ */
if (priv->dispc_ops->mgr_go_busy(priv->dispc, omap_crtc->channel)) { if (dispc_mgr_go_busy(priv->dispc, omap_crtc->channel)) {
spin_unlock(&crtc->dev->event_lock); spin_unlock(&crtc->dev->event_lock);
return; return;
} }
...@@ -426,7 +426,7 @@ static void omap_crtc_write_crtc_properties(struct drm_crtc *crtc) ...@@ -426,7 +426,7 @@ static void omap_crtc_write_crtc_properties(struct drm_crtc *crtc)
info.cpr_enable = false; info.cpr_enable = false;
} }
priv->dispc_ops->mgr_setup(priv->dispc, omap_crtc->channel, &info); dispc_mgr_setup(priv->dispc, omap_crtc->channel, &info);
} }
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
...@@ -467,7 +467,7 @@ static void omap_crtc_atomic_enable(struct drm_crtc *crtc, ...@@ -467,7 +467,7 @@ static void omap_crtc_atomic_enable(struct drm_crtc *crtc,
DBG("%s", omap_crtc->name); DBG("%s", omap_crtc->name);
priv->dispc_ops->runtime_get(priv->dispc); dispc_runtime_get(priv->dispc);
/* manual updated display will not trigger vsync irq */ /* manual updated display will not trigger vsync irq */
if (omap_state->manually_updated) if (omap_state->manually_updated)
...@@ -506,7 +506,7 @@ static void omap_crtc_atomic_disable(struct drm_crtc *crtc, ...@@ -506,7 +506,7 @@ static void omap_crtc_atomic_disable(struct drm_crtc *crtc,
drm_crtc_vblank_off(crtc); drm_crtc_vblank_off(crtc);
priv->dispc_ops->runtime_put(priv->dispc); dispc_runtime_put(priv->dispc);
} }
static enum drm_mode_status omap_crtc_mode_valid(struct drm_crtc *crtc, static enum drm_mode_status omap_crtc_mode_valid(struct drm_crtc *crtc,
...@@ -525,7 +525,7 @@ static enum drm_mode_status omap_crtc_mode_valid(struct drm_crtc *crtc, ...@@ -525,7 +525,7 @@ static enum drm_mode_status omap_crtc_mode_valid(struct drm_crtc *crtc,
* proper DISPC mode later. * proper DISPC mode later.
*/ */
if (omap_crtc->pipe->output->type != OMAP_DISPLAY_TYPE_DSI) { if (omap_crtc->pipe->output->type != OMAP_DISPLAY_TYPE_DSI) {
r = priv->dispc_ops->mgr_check_timings(priv->dispc, r = dispc_mgr_check_timings(priv->dispc,
omap_crtc->channel, omap_crtc->channel,
&vm); &vm);
if (r) if (r)
...@@ -643,7 +643,7 @@ static void omap_crtc_atomic_flush(struct drm_crtc *crtc, ...@@ -643,7 +643,7 @@ static void omap_crtc_atomic_flush(struct drm_crtc *crtc,
length = crtc->state->degamma_lut->length / length = crtc->state->degamma_lut->length /
sizeof(*lut); sizeof(*lut);
} }
priv->dispc_ops->mgr_set_gamma(priv->dispc, omap_crtc->channel, dispc_mgr_set_gamma(priv->dispc, omap_crtc->channel,
lut, length); lut, length);
} }
...@@ -668,7 +668,7 @@ static void omap_crtc_atomic_flush(struct drm_crtc *crtc, ...@@ -668,7 +668,7 @@ static void omap_crtc_atomic_flush(struct drm_crtc *crtc,
WARN_ON(ret != 0); WARN_ON(ret != 0);
spin_lock_irq(&crtc->dev->event_lock); spin_lock_irq(&crtc->dev->event_lock);
priv->dispc_ops->mgr_go(priv->dispc, omap_crtc->channel); dispc_mgr_go(priv->dispc, omap_crtc->channel);
omap_crtc_arm_event(crtc); omap_crtc_arm_event(crtc);
spin_unlock_irq(&crtc->dev->event_lock); spin_unlock_irq(&crtc->dev->event_lock);
} }
...@@ -858,7 +858,7 @@ struct drm_crtc *omap_crtc_init(struct drm_device *dev, ...@@ -858,7 +858,7 @@ struct drm_crtc *omap_crtc_init(struct drm_device *dev,
* extracted with dispc_mgr_gamma_size(). If it returns 0 * extracted with dispc_mgr_gamma_size(). If it returns 0
* gamma table is not supported. * gamma table is not supported.
*/ */
if (priv->dispc_ops->mgr_gamma_size(priv->dispc, channel)) { if (dispc_mgr_gamma_size(priv->dispc, channel)) {
unsigned int gamma_lut_size = 256; unsigned int gamma_lut_size = 256;
drm_crtc_enable_color_mgmt(crtc, gamma_lut_size, true, 0); drm_crtc_enable_color_mgmt(crtc, gamma_lut_size, true, 0);
......
...@@ -69,7 +69,7 @@ static void omap_atomic_commit_tail(struct drm_atomic_state *old_state) ...@@ -69,7 +69,7 @@ static void omap_atomic_commit_tail(struct drm_atomic_state *old_state)
struct drm_device *dev = old_state->dev; struct drm_device *dev = old_state->dev;
struct omap_drm_private *priv = dev->dev_private; struct omap_drm_private *priv = dev->dev_private;
priv->dispc_ops->runtime_get(priv->dispc); dispc_runtime_get(priv->dispc);
/* Apply the atomic update. */ /* Apply the atomic update. */
drm_atomic_helper_commit_modeset_disables(dev, old_state); drm_atomic_helper_commit_modeset_disables(dev, old_state);
...@@ -113,7 +113,7 @@ static void omap_atomic_commit_tail(struct drm_atomic_state *old_state) ...@@ -113,7 +113,7 @@ static void omap_atomic_commit_tail(struct drm_atomic_state *old_state)
drm_atomic_helper_cleanup_planes(dev, old_state); drm_atomic_helper_cleanup_planes(dev, old_state);
priv->dispc_ops->runtime_put(priv->dispc); dispc_runtime_put(priv->dispc);
} }
static const struct drm_mode_config_helper_funcs omap_mode_config_helper_funcs = { static const struct drm_mode_config_helper_funcs omap_mode_config_helper_funcs = {
...@@ -192,7 +192,7 @@ static int omap_compare_pipelines(const void *a, const void *b) ...@@ -192,7 +192,7 @@ static int omap_compare_pipelines(const void *a, const void *b)
static int omap_modeset_init_properties(struct drm_device *dev) static int omap_modeset_init_properties(struct drm_device *dev)
{ {
struct omap_drm_private *priv = dev->dev_private; struct omap_drm_private *priv = dev->dev_private;
unsigned int num_planes = priv->dispc_ops->get_num_ovls(priv->dispc); unsigned int num_planes = dispc_get_num_ovls(priv->dispc);
priv->zorder_prop = drm_property_create_range(dev, 0, "zorder", 0, priv->zorder_prop = drm_property_create_range(dev, 0, "zorder", 0,
num_planes - 1); num_planes - 1);
...@@ -221,8 +221,8 @@ static int omap_display_id(struct omap_dss_device *output) ...@@ -221,8 +221,8 @@ static int omap_display_id(struct omap_dss_device *output)
static int omap_modeset_init(struct drm_device *dev) static int omap_modeset_init(struct drm_device *dev)
{ {
struct omap_drm_private *priv = dev->dev_private; struct omap_drm_private *priv = dev->dev_private;
int num_ovls = priv->dispc_ops->get_num_ovls(priv->dispc); int num_ovls = dispc_get_num_ovls(priv->dispc);
int num_mgrs = priv->dispc_ops->get_num_mgrs(priv->dispc); int num_mgrs = dispc_get_num_mgrs(priv->dispc);
unsigned int i; unsigned int i;
int ret; int ret;
u32 plane_crtc_mask; u32 plane_crtc_mask;
...@@ -571,7 +571,6 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev) ...@@ -571,7 +571,6 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev)
priv->dev = dev; priv->dev = dev;
priv->dss = pdata->dss; priv->dss = pdata->dss;
priv->dispc = dispc_get_dispc(priv->dss); priv->dispc = dispc_get_dispc(priv->dss);
priv->dispc_ops = dispc_get_ops(priv->dss);
omap_crtc_pre_init(priv); omap_crtc_pre_init(priv);
...@@ -583,9 +582,7 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev) ...@@ -583,9 +582,7 @@ static int omapdrm_init(struct omap_drm_private *priv, struct device *dev)
INIT_LIST_HEAD(&priv->obj_list); INIT_LIST_HEAD(&priv->obj_list);
/* Get memory bandwidth limits */ /* Get memory bandwidth limits */
if (priv->dispc_ops->get_memory_bandwidth_limit) priv->max_bandwidth = dispc_get_memory_bandwidth_limit(priv->dispc);
priv->max_bandwidth =
priv->dispc_ops->get_memory_bandwidth_limit(priv->dispc);
omap_gem_init(ddev); omap_gem_init(ddev);
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include "dss/omapdss.h" #include "dss/omapdss.h"
#include "dss/dss.h"
#include <drm/drm_gem.h> #include <drm/drm_gem.h>
#include <drm/omap_drm.h> #include <drm/omap_drm.h>
...@@ -46,7 +47,6 @@ struct omap_drm_private { ...@@ -46,7 +47,6 @@ struct omap_drm_private {
struct dss_device *dss; struct dss_device *dss;
struct dispc_device *dispc; struct dispc_device *dispc;
const struct dispc_ops *dispc_ops;
unsigned int num_pipes; unsigned int num_pipes;
struct omap_drm_pipeline pipes[8]; struct omap_drm_pipeline pipes[8];
......
...@@ -29,7 +29,7 @@ static void omap_irq_update(struct drm_device *dev) ...@@ -29,7 +29,7 @@ static void omap_irq_update(struct drm_device *dev)
DBG("irqmask=%08x", irqmask); DBG("irqmask=%08x", irqmask);
priv->dispc_ops->write_irqenable(priv->dispc, irqmask); dispc_write_irqenable(priv->dispc, irqmask);
} }
static void omap_irq_wait_handler(struct omap_irq_wait *wait) static void omap_irq_wait_handler(struct omap_irq_wait *wait)
...@@ -83,7 +83,7 @@ int omap_irq_enable_framedone(struct drm_crtc *crtc, bool enable) ...@@ -83,7 +83,7 @@ int omap_irq_enable_framedone(struct drm_crtc *crtc, bool enable)
unsigned long flags; unsigned long flags;
enum omap_channel channel = omap_crtc_channel(crtc); enum omap_channel channel = omap_crtc_channel(crtc);
int framedone_irq = int framedone_irq =
priv->dispc_ops->mgr_get_framedone_irq(priv->dispc, channel); dispc_mgr_get_framedone_irq(priv->dispc, channel);
DBG("dev=%p, crtc=%u, enable=%d", dev, channel, enable); DBG("dev=%p, crtc=%u, enable=%d", dev, channel, enable);
...@@ -120,7 +120,7 @@ int omap_irq_enable_vblank(struct drm_crtc *crtc) ...@@ -120,7 +120,7 @@ int omap_irq_enable_vblank(struct drm_crtc *crtc)
DBG("dev=%p, crtc=%u", dev, channel); DBG("dev=%p, crtc=%u", dev, channel);
spin_lock_irqsave(&priv->wait_lock, flags); spin_lock_irqsave(&priv->wait_lock, flags);
priv->irq_mask |= priv->dispc_ops->mgr_get_vsync_irq(priv->dispc, priv->irq_mask |= dispc_mgr_get_vsync_irq(priv->dispc,
channel); channel);
omap_irq_update(dev); omap_irq_update(dev);
spin_unlock_irqrestore(&priv->wait_lock, flags); spin_unlock_irqrestore(&priv->wait_lock, flags);
...@@ -146,7 +146,7 @@ void omap_irq_disable_vblank(struct drm_crtc *crtc) ...@@ -146,7 +146,7 @@ void omap_irq_disable_vblank(struct drm_crtc *crtc)
DBG("dev=%p, crtc=%u", dev, channel); DBG("dev=%p, crtc=%u", dev, channel);
spin_lock_irqsave(&priv->wait_lock, flags); spin_lock_irqsave(&priv->wait_lock, flags);
priv->irq_mask &= ~priv->dispc_ops->mgr_get_vsync_irq(priv->dispc, priv->irq_mask &= ~dispc_mgr_get_vsync_irq(priv->dispc,
channel); channel);
omap_irq_update(dev); omap_irq_update(dev);
spin_unlock_irqrestore(&priv->wait_lock, flags); spin_unlock_irqrestore(&priv->wait_lock, flags);
...@@ -211,9 +211,9 @@ static irqreturn_t omap_irq_handler(int irq, void *arg) ...@@ -211,9 +211,9 @@ static irqreturn_t omap_irq_handler(int irq, void *arg)
unsigned int id; unsigned int id;
u32 irqstatus; u32 irqstatus;
irqstatus = priv->dispc_ops->read_irqstatus(priv->dispc); irqstatus = dispc_read_irqstatus(priv->dispc);
priv->dispc_ops->clear_irqstatus(priv->dispc, irqstatus); dispc_clear_irqstatus(priv->dispc, irqstatus);
priv->dispc_ops->read_irqstatus(priv->dispc); /* flush posted write */ dispc_read_irqstatus(priv->dispc); /* flush posted write */
VERB("irqs: %08x", irqstatus); VERB("irqs: %08x", irqstatus);
...@@ -221,15 +221,15 @@ static irqreturn_t omap_irq_handler(int irq, void *arg) ...@@ -221,15 +221,15 @@ static irqreturn_t omap_irq_handler(int irq, void *arg)
struct drm_crtc *crtc = priv->pipes[id].crtc; struct drm_crtc *crtc = priv->pipes[id].crtc;
enum omap_channel channel = omap_crtc_channel(crtc); enum omap_channel channel = omap_crtc_channel(crtc);
if (irqstatus & priv->dispc_ops->mgr_get_vsync_irq(priv->dispc, channel)) { if (irqstatus & dispc_mgr_get_vsync_irq(priv->dispc, channel)) {
drm_handle_vblank(dev, id); drm_handle_vblank(dev, id);
omap_crtc_vblank_irq(crtc); omap_crtc_vblank_irq(crtc);
} }
if (irqstatus & priv->dispc_ops->mgr_get_sync_lost_irq(priv->dispc, channel)) if (irqstatus & dispc_mgr_get_sync_lost_irq(priv->dispc, channel))
omap_crtc_error_irq(crtc, irqstatus); omap_crtc_error_irq(crtc, irqstatus);
if (irqstatus & priv->dispc_ops->mgr_get_framedone_irq(priv->dispc, channel)) if (irqstatus & dispc_mgr_get_framedone_irq(priv->dispc, channel))
omap_crtc_framedone_irq(crtc, irqstatus); omap_crtc_framedone_irq(crtc, irqstatus);
} }
...@@ -263,7 +263,7 @@ static const u32 omap_underflow_irqs[] = { ...@@ -263,7 +263,7 @@ static const u32 omap_underflow_irqs[] = {
int omap_drm_irq_install(struct drm_device *dev) int omap_drm_irq_install(struct drm_device *dev)
{ {
struct omap_drm_private *priv = dev->dev_private; struct omap_drm_private *priv = dev->dev_private;
unsigned int num_mgrs = priv->dispc_ops->get_num_mgrs(priv->dispc); unsigned int num_mgrs = dispc_get_num_mgrs(priv->dispc);
unsigned int max_planes; unsigned int max_planes;
unsigned int i; unsigned int i;
int ret; int ret;
...@@ -281,13 +281,13 @@ int omap_drm_irq_install(struct drm_device *dev) ...@@ -281,13 +281,13 @@ int omap_drm_irq_install(struct drm_device *dev)
} }
for (i = 0; i < num_mgrs; ++i) for (i = 0; i < num_mgrs; ++i)
priv->irq_mask |= priv->dispc_ops->mgr_get_sync_lost_irq(priv->dispc, i); priv->irq_mask |= dispc_mgr_get_sync_lost_irq(priv->dispc, i);
priv->dispc_ops->runtime_get(priv->dispc); dispc_runtime_get(priv->dispc);
priv->dispc_ops->clear_irqstatus(priv->dispc, 0xffffffff); dispc_clear_irqstatus(priv->dispc, 0xffffffff);
priv->dispc_ops->runtime_put(priv->dispc); dispc_runtime_put(priv->dispc);
ret = priv->dispc_ops->request_irq(priv->dispc, omap_irq_handler, dev); ret = dispc_request_irq(priv->dispc, omap_irq_handler, dev);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -305,5 +305,5 @@ void omap_drm_irq_uninstall(struct drm_device *dev) ...@@ -305,5 +305,5 @@ void omap_drm_irq_uninstall(struct drm_device *dev)
dev->irq_enabled = false; dev->irq_enabled = false;
priv->dispc_ops->free_irq(priv->dispc, dev); dispc_free_irq(priv->dispc, dev);
} }
...@@ -72,17 +72,17 @@ static void omap_plane_atomic_update(struct drm_plane *plane, ...@@ -72,17 +72,17 @@ static void omap_plane_atomic_update(struct drm_plane *plane,
&info.paddr, &info.p_uv_addr); &info.paddr, &info.p_uv_addr);
/* and finally, update omapdss: */ /* and finally, update omapdss: */
ret = priv->dispc_ops->ovl_setup(priv->dispc, omap_plane->id, &info, ret = dispc_ovl_setup(priv->dispc, omap_plane->id, &info,
omap_crtc_timings(state->crtc), false, omap_crtc_timings(state->crtc), false,
omap_crtc_channel(state->crtc)); omap_crtc_channel(state->crtc));
if (ret) { if (ret) {
dev_err(plane->dev->dev, "Failed to setup plane %s\n", dev_err(plane->dev->dev, "Failed to setup plane %s\n",
omap_plane->name); omap_plane->name);
priv->dispc_ops->ovl_enable(priv->dispc, omap_plane->id, false); dispc_ovl_enable(priv->dispc, omap_plane->id, false);
return; return;
} }
priv->dispc_ops->ovl_enable(priv->dispc, omap_plane->id, true); dispc_ovl_enable(priv->dispc, omap_plane->id, true);
} }
static void omap_plane_atomic_disable(struct drm_plane *plane, static void omap_plane_atomic_disable(struct drm_plane *plane,
...@@ -95,7 +95,7 @@ static void omap_plane_atomic_disable(struct drm_plane *plane, ...@@ -95,7 +95,7 @@ static void omap_plane_atomic_disable(struct drm_plane *plane,
plane->state->zpos = plane->type == DRM_PLANE_TYPE_PRIMARY plane->state->zpos = plane->type == DRM_PLANE_TYPE_PRIMARY
? 0 : omap_plane->id; ? 0 : omap_plane->id;
priv->dispc_ops->ovl_enable(priv->dispc, omap_plane->id, false); dispc_ovl_enable(priv->dispc, omap_plane->id, false);
} }
static int omap_plane_atomic_check(struct drm_plane *plane, static int omap_plane_atomic_check(struct drm_plane *plane,
...@@ -240,8 +240,7 @@ static bool omap_plane_supports_yuv(struct drm_plane *plane) ...@@ -240,8 +240,7 @@ static bool omap_plane_supports_yuv(struct drm_plane *plane)
{ {
struct omap_drm_private *priv = plane->dev->dev_private; struct omap_drm_private *priv = plane->dev->dev_private;
struct omap_plane *omap_plane = to_omap_plane(plane); struct omap_plane *omap_plane = to_omap_plane(plane);
const u32 *formats = const u32 *formats = dispc_ovl_get_color_modes(priv->dispc, omap_plane->id);
priv->dispc_ops->ovl_get_color_modes(priv->dispc, omap_plane->id);
u32 i; u32 i;
for (i = 0; formats[i]; i++) for (i = 0; formats[i]; i++)
...@@ -273,7 +272,7 @@ struct drm_plane *omap_plane_init(struct drm_device *dev, ...@@ -273,7 +272,7 @@ struct drm_plane *omap_plane_init(struct drm_device *dev,
u32 possible_crtcs) u32 possible_crtcs)
{ {
struct omap_drm_private *priv = dev->dev_private; struct omap_drm_private *priv = dev->dev_private;
unsigned int num_planes = priv->dispc_ops->get_num_ovls(priv->dispc); unsigned int num_planes = dispc_get_num_ovls(priv->dispc);
struct drm_plane *plane; struct drm_plane *plane;
struct omap_plane *omap_plane; struct omap_plane *omap_plane;
enum omap_plane_id id; enum omap_plane_id id;
...@@ -292,7 +291,7 @@ struct drm_plane *omap_plane_init(struct drm_device *dev, ...@@ -292,7 +291,7 @@ struct drm_plane *omap_plane_init(struct drm_device *dev,
if (!omap_plane) if (!omap_plane)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
formats = priv->dispc_ops->ovl_get_color_modes(priv->dispc, id); formats = dispc_ovl_get_color_modes(priv->dispc, id);
for (nformats = 0; formats[nformats]; ++nformats) for (nformats = 0; formats[nformats]; ++nformats)
; ;
omap_plane->id = id; omap_plane->id = id;
......
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