Commit babdb815 authored by Marijn Suijten's avatar Marijn Suijten Committed by Dmitry Baryshkov

drm/msm/dpu: Pass catalog pointers in RM to replace for-loop ID lookups

The Resource Manager already iterates over all available blocks from the
catalog, only to pass their ID to a dpu_hw_xxx_init() function which
uses an _xxx_offset() helper to search for and find the exact same
catalog pointer again to initialize the block with, fallible error
handling and all.

Instead, pass const pointers to the catalog entries directly to these
_init functions and drop the for loops entirely, saving on both
readability complexity and unnecessary cycles at boot.
Signed-off-by: default avatarMarijn Suijten <marijn.suijten@somainline.org>
Reviewed-by: default avatarDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Patchwork: https://patchwork.freedesktop.org/patch/533861/
Link: https://lore.kernel.org/r/20230418-dpu-drop-useless-for-lookup-v3-3-e8d869eea455@somainline.orgSigned-off-by: default avatarDmitry Baryshkov <dmitry.baryshkov@linaro.org>
parent 94fdd55b
...@@ -53,23 +53,6 @@ static const u32 fetch_tbl[SSPP_MAX] = {CTL_INVALID_BIT, 16, 17, 18, 19, ...@@ -53,23 +53,6 @@ static const u32 fetch_tbl[SSPP_MAX] = {CTL_INVALID_BIT, 16, 17, 18, 19,
CTL_INVALID_BIT, CTL_INVALID_BIT, CTL_INVALID_BIT, CTL_INVALID_BIT, 0, CTL_INVALID_BIT, CTL_INVALID_BIT, CTL_INVALID_BIT, CTL_INVALID_BIT, 0,
1, 2, 3, CTL_INVALID_BIT, CTL_INVALID_BIT}; 1, 2, 3, CTL_INVALID_BIT, CTL_INVALID_BIT};
static const struct dpu_ctl_cfg *_ctl_offset(enum dpu_ctl ctl,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->ctl_count; i++) {
if (ctl == m->ctl[i].id) {
b->blk_addr = addr + m->ctl[i].base;
b->log_mask = DPU_DBG_MASK_CTL;
return &m->ctl[i];
}
}
return ERR_PTR(-ENOMEM);
}
static int _mixer_stages(const struct dpu_lm_cfg *mixer, int count, static int _mixer_stages(const struct dpu_lm_cfg *mixer, int count,
enum dpu_lm lm) enum dpu_lm lm)
{ {
...@@ -676,29 +659,25 @@ static void _setup_ctl_ops(struct dpu_hw_ctl_ops *ops, ...@@ -676,29 +659,25 @@ static void _setup_ctl_ops(struct dpu_hw_ctl_ops *ops,
ops->set_active_pipes = dpu_hw_ctl_set_fetch_pipe_active; ops->set_active_pipes = dpu_hw_ctl_set_fetch_pipe_active;
}; };
struct dpu_hw_ctl *dpu_hw_ctl_init(enum dpu_ctl idx, struct dpu_hw_ctl *dpu_hw_ctl_init(const struct dpu_ctl_cfg *cfg,
void __iomem *addr, void __iomem *addr,
const struct dpu_mdss_cfg *m) u32 mixer_count,
const struct dpu_lm_cfg *mixer)
{ {
struct dpu_hw_ctl *c; struct dpu_hw_ctl *c;
const struct dpu_ctl_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _ctl_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_CTL;
kfree(c);
pr_err("failed to create dpu_hw_ctl %d\n", idx);
return ERR_PTR(-EINVAL);
}
c->caps = cfg; c->caps = cfg;
_setup_ctl_ops(&c->ops, c->caps->features); _setup_ctl_ops(&c->ops, c->caps->features);
c->idx = idx; c->idx = cfg->id;
c->mixer_count = m->mixer_count; c->mixer_count = mixer_count;
c->mixer_hw_caps = m->mixer; c->mixer_hw_caps = mixer;
return c; return c;
} }
......
...@@ -261,15 +261,17 @@ static inline struct dpu_hw_ctl *to_dpu_hw_ctl(struct dpu_hw_blk *hw) ...@@ -261,15 +261,17 @@ static inline struct dpu_hw_ctl *to_dpu_hw_ctl(struct dpu_hw_blk *hw)
} }
/** /**
* dpu_hw_ctl_init(): Initializes the ctl_path hw driver object. * dpu_hw_ctl_init() - Initializes the ctl_path hw driver object.
* should be called before accessing every ctl path registers. * Should be called before accessing any ctl_path register.
* @idx: ctl_path index for which driver object is required * @cfg: ctl_path catalog entry for which driver object is required
* @addr: mapped register io address of MDP * @addr: mapped register io address of MDP
* @m : pointer to mdss catalog data * @mixer_count: Number of mixers in @mixer
* @mixer: Pointer to an array of Layer Mixers defined in the catalog
*/ */
struct dpu_hw_ctl *dpu_hw_ctl_init(enum dpu_ctl idx, struct dpu_hw_ctl *dpu_hw_ctl_init(const struct dpu_ctl_cfg *cfg,
void __iomem *addr, void __iomem *addr,
const struct dpu_mdss_cfg *m); u32 mixer_count,
const struct dpu_lm_cfg *mixer);
/** /**
* dpu_hw_ctl_destroy(): Destroys ctl driver context * dpu_hw_ctl_destroy(): Destroys ctl driver context
......
...@@ -175,24 +175,6 @@ static void dpu_hw_dsc_bind_pingpong_blk( ...@@ -175,24 +175,6 @@ static void dpu_hw_dsc_bind_pingpong_blk(
DPU_REG_WRITE(c, dsc_ctl_offset, mux_cfg); DPU_REG_WRITE(c, dsc_ctl_offset, mux_cfg);
} }
static const struct dpu_dsc_cfg *_dsc_offset(enum dpu_dsc dsc,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->dsc_count; i++) {
if (dsc == m->dsc[i].id) {
b->blk_addr = addr + m->dsc[i].base;
b->log_mask = DPU_DBG_MASK_DSC;
return &m->dsc[i];
}
}
return NULL;
}
static void _setup_dsc_ops(struct dpu_hw_dsc_ops *ops, static void _setup_dsc_ops(struct dpu_hw_dsc_ops *ops,
unsigned long cap) unsigned long cap)
{ {
...@@ -203,23 +185,19 @@ static void _setup_dsc_ops(struct dpu_hw_dsc_ops *ops, ...@@ -203,23 +185,19 @@ static void _setup_dsc_ops(struct dpu_hw_dsc_ops *ops,
ops->dsc_bind_pingpong_blk = dpu_hw_dsc_bind_pingpong_blk; ops->dsc_bind_pingpong_blk = dpu_hw_dsc_bind_pingpong_blk;
}; };
struct dpu_hw_dsc *dpu_hw_dsc_init(enum dpu_dsc idx, void __iomem *addr, struct dpu_hw_dsc *dpu_hw_dsc_init(const struct dpu_dsc_cfg *cfg,
const struct dpu_mdss_cfg *m) void __iomem *addr)
{ {
struct dpu_hw_dsc *c; struct dpu_hw_dsc *c;
const struct dpu_dsc_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _dsc_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_DSC;
kfree(c);
return ERR_PTR(-EINVAL);
}
c->idx = idx; c->idx = cfg->id;
c->caps = cfg; c->caps = cfg;
_setup_dsc_ops(&c->ops, c->caps->features); _setup_dsc_ops(&c->ops, c->caps->features);
......
...@@ -61,14 +61,13 @@ struct dpu_hw_dsc { ...@@ -61,14 +61,13 @@ struct dpu_hw_dsc {
}; };
/** /**
* dpu_hw_dsc_init - initializes the dsc block for the passed dsc idx. * dpu_hw_dsc_init() - Initializes the DSC hw driver object.
* @idx: DSC index for which driver object is required * @cfg: DSC catalog entry for which driver object is required
* @addr: Mapped register io address of MDP * @addr: Mapped register io address of MDP
* @m: Pointer to mdss catalog data * Return: Error code or allocated dpu_hw_dsc context
* Returns: Error code or allocated dpu_hw_dsc context
*/ */
struct dpu_hw_dsc *dpu_hw_dsc_init(enum dpu_dsc idx, void __iomem *addr, struct dpu_hw_dsc *dpu_hw_dsc_init(const struct dpu_dsc_cfg *cfg,
const struct dpu_mdss_cfg *m); void __iomem *addr);
/** /**
* dpu_hw_dsc_destroy - destroys dsc driver context * dpu_hw_dsc_destroy - destroys dsc driver context
......
...@@ -68,49 +68,23 @@ static void _setup_dspp_ops(struct dpu_hw_dspp *c, ...@@ -68,49 +68,23 @@ static void _setup_dspp_ops(struct dpu_hw_dspp *c,
c->ops.setup_pcc = dpu_setup_dspp_pcc; c->ops.setup_pcc = dpu_setup_dspp_pcc;
} }
static const struct dpu_dspp_cfg *_dspp_offset(enum dpu_dspp dspp, struct dpu_hw_dspp *dpu_hw_dspp_init(const struct dpu_dspp_cfg *cfg,
const struct dpu_mdss_cfg *m, void __iomem *addr)
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
if (!m || !addr || !b)
return ERR_PTR(-EINVAL);
for (i = 0; i < m->dspp_count; i++) {
if (dspp == m->dspp[i].id) {
b->blk_addr = addr + m->dspp[i].base;
b->log_mask = DPU_DBG_MASK_DSPP;
return &m->dspp[i];
}
}
return ERR_PTR(-EINVAL);
}
struct dpu_hw_dspp *dpu_hw_dspp_init(enum dpu_dspp idx,
void __iomem *addr,
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_dspp *c; struct dpu_hw_dspp *c;
const struct dpu_dspp_cfg *cfg;
if (!addr || !m) if (!addr)
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _dspp_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_DSPP;
kfree(c);
return ERR_PTR(-EINVAL);
}
/* Assign ops */ /* Assign ops */
c->idx = idx; c->idx = cfg->id;
c->cap = cfg; c->cap = cfg;
_setup_dspp_ops(c, c->cap->features); _setup_dspp_ops(c, c->cap->features);
......
...@@ -79,14 +79,14 @@ static inline struct dpu_hw_dspp *to_dpu_hw_dspp(struct dpu_hw_blk *hw) ...@@ -79,14 +79,14 @@ static inline struct dpu_hw_dspp *to_dpu_hw_dspp(struct dpu_hw_blk *hw)
} }
/** /**
* dpu_hw_dspp_init - initializes the dspp hw driver object. * dpu_hw_dspp_init() - Initializes the DSPP hw driver object.
* should be called once before accessing every dspp. * should be called once before accessing every DSPP.
* @idx: DSPP index for which driver object is required * @cfg: DSPP catalog entry for which driver object is required
* @addr: Mapped register io address of MDP * @addr: Mapped register io address of MDP
* @Return: pointer to structure or ERR_PTR * Return: pointer to structure or ERR_PTR
*/ */
struct dpu_hw_dspp *dpu_hw_dspp_init(enum dpu_dspp idx, struct dpu_hw_dspp *dpu_hw_dspp_init(const struct dpu_dspp_cfg *cfg,
void __iomem *addr, const struct dpu_mdss_cfg *m); void __iomem *addr);
/** /**
* dpu_hw_dspp_destroy(): Destroys DSPP driver context * dpu_hw_dspp_destroy(): Destroys DSPP driver context
......
...@@ -67,7 +67,7 @@ struct dpu_hw_intr { ...@@ -67,7 +67,7 @@ struct dpu_hw_intr {
/** /**
* dpu_hw_intr_init(): Initializes the interrupts hw object * dpu_hw_intr_init(): Initializes the interrupts hw object
* @addr: mapped register io address of MDP * @addr: mapped register io address of MDP
* @m : pointer to mdss catalog data * @m: pointer to MDSS catalog data
*/ */
struct dpu_hw_intr *dpu_hw_intr_init(void __iomem *addr, struct dpu_hw_intr *dpu_hw_intr_init(void __iomem *addr,
const struct dpu_mdss_cfg *m); const struct dpu_mdss_cfg *m);
......
...@@ -68,25 +68,6 @@ ...@@ -68,25 +68,6 @@
#define INTF_MISR_CTRL 0x180 #define INTF_MISR_CTRL 0x180
#define INTF_MISR_SIGNATURE 0x184 #define INTF_MISR_SIGNATURE 0x184
static const struct dpu_intf_cfg *_intf_offset(enum dpu_intf intf,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->intf_count; i++) {
if ((intf == m->intf[i].id) &&
(m->intf[i].type != INTF_NONE)) {
b->blk_addr = addr + m->intf[i].base;
b->log_mask = DPU_DBG_MASK_INTF;
return &m->intf[i];
}
}
return ERR_PTR(-EINVAL);
}
static void dpu_hw_intf_setup_timing_engine(struct dpu_hw_intf *ctx, static void dpu_hw_intf_setup_timing_engine(struct dpu_hw_intf *ctx,
const struct intf_timing_params *p, const struct intf_timing_params *p,
const struct dpu_format *fmt) const struct dpu_format *fmt)
...@@ -336,28 +317,27 @@ static void _setup_intf_ops(struct dpu_hw_intf_ops *ops, ...@@ -336,28 +317,27 @@ static void _setup_intf_ops(struct dpu_hw_intf_ops *ops,
ops->collect_misr = dpu_hw_intf_collect_misr; ops->collect_misr = dpu_hw_intf_collect_misr;
} }
struct dpu_hw_intf *dpu_hw_intf_init(enum dpu_intf idx, struct dpu_hw_intf *dpu_hw_intf_init(const struct dpu_intf_cfg *cfg,
void __iomem *addr, void __iomem *addr)
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_intf *c; struct dpu_hw_intf *c;
const struct dpu_intf_cfg *cfg;
if (cfg->type == INTF_NONE) {
DPU_DEBUG("Skip intf %d with type NONE\n", cfg->id - INTF_0);
return NULL;
}
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _intf_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_INTF;
kfree(c);
pr_err("failed to create dpu_hw_intf %d\n", idx);
return ERR_PTR(-EINVAL);
}
/* /*
* Assign ops * Assign ops
*/ */
c->idx = idx; c->idx = cfg->id;
c->cap = cfg; c->cap = cfg;
_setup_intf_ops(&c->ops, c->cap->features); _setup_intf_ops(&c->ops, c->cap->features);
......
...@@ -96,15 +96,13 @@ struct dpu_hw_intf { ...@@ -96,15 +96,13 @@ struct dpu_hw_intf {
}; };
/** /**
* dpu_hw_intf_init(): Initializes the intf driver for the passed * dpu_hw_intf_init() - Initializes the INTF driver for the passed
* interface idx. * interface catalog entry.
* @idx: interface index for which driver object is required * @cfg: interface catalog entry for which driver object is required
* @addr: mapped register io address of MDP * @addr: mapped register io address of MDP
* @m : pointer to mdss catalog data
*/ */
struct dpu_hw_intf *dpu_hw_intf_init(enum dpu_intf idx, struct dpu_hw_intf *dpu_hw_intf_init(const struct dpu_intf_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
/** /**
* dpu_hw_intf_destroy(): Destroys INTF driver context * dpu_hw_intf_destroy(): Destroys INTF driver context
......
...@@ -30,24 +30,6 @@ ...@@ -30,24 +30,6 @@
#define LM_MISR_SIGNATURE 0x314 #define LM_MISR_SIGNATURE 0x314
static const struct dpu_lm_cfg *_lm_offset(enum dpu_lm mixer,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->mixer_count; i++) {
if (mixer == m->mixer[i].id) {
b->blk_addr = addr + m->mixer[i].base;
b->log_mask = DPU_DBG_MASK_LM;
return &m->mixer[i];
}
}
return ERR_PTR(-ENOMEM);
}
/** /**
* _stage_offset(): returns the relative offset of the blend registers * _stage_offset(): returns the relative offset of the blend registers
* for the stage to be setup * for the stage to be setup
...@@ -160,8 +142,7 @@ static void dpu_hw_lm_setup_color3(struct dpu_hw_mixer *ctx, ...@@ -160,8 +142,7 @@ static void dpu_hw_lm_setup_color3(struct dpu_hw_mixer *ctx,
DPU_REG_WRITE(c, LM_OP_MODE, op_mode); DPU_REG_WRITE(c, LM_OP_MODE, op_mode);
} }
static void _setup_mixer_ops(const struct dpu_mdss_cfg *m, static void _setup_mixer_ops(struct dpu_hw_lm_ops *ops,
struct dpu_hw_lm_ops *ops,
unsigned long features) unsigned long features)
{ {
ops->setup_mixer_out = dpu_hw_lm_setup_out; ops->setup_mixer_out = dpu_hw_lm_setup_out;
...@@ -175,27 +156,22 @@ static void _setup_mixer_ops(const struct dpu_mdss_cfg *m, ...@@ -175,27 +156,22 @@ static void _setup_mixer_ops(const struct dpu_mdss_cfg *m,
ops->collect_misr = dpu_hw_lm_collect_misr; ops->collect_misr = dpu_hw_lm_collect_misr;
} }
struct dpu_hw_mixer *dpu_hw_lm_init(enum dpu_lm idx, struct dpu_hw_mixer *dpu_hw_lm_init(const struct dpu_lm_cfg *cfg,
void __iomem *addr, void __iomem *addr)
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_mixer *c; struct dpu_hw_mixer *c;
const struct dpu_lm_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _lm_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_LM;
kfree(c);
return ERR_PTR(-EINVAL);
}
/* Assign ops */ /* Assign ops */
c->idx = idx; c->idx = cfg->id;
c->cap = cfg; c->cap = cfg;
_setup_mixer_ops(m, &c->ops, c->cap->features); _setup_mixer_ops(&c->ops, c->cap->features);
return c; return c;
} }
......
...@@ -93,15 +93,13 @@ static inline struct dpu_hw_mixer *to_dpu_hw_mixer(struct dpu_hw_blk *hw) ...@@ -93,15 +93,13 @@ static inline struct dpu_hw_mixer *to_dpu_hw_mixer(struct dpu_hw_blk *hw)
} }
/** /**
* dpu_hw_lm_init(): Initializes the mixer hw driver object. * dpu_hw_lm_init() - Initializes the mixer hw driver object.
* should be called once before accessing every mixer. * should be called once before accessing every mixer.
* @idx: mixer index for which driver object is required * @cfg: mixer catalog entry for which driver object is required
* @addr: mapped register io address of MDP * @addr: mapped register io address of MDP
* @m : pointer to mdss catalog data
*/ */
struct dpu_hw_mixer *dpu_hw_lm_init(enum dpu_lm idx, struct dpu_hw_mixer *dpu_hw_lm_init(const struct dpu_lm_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
/** /**
* dpu_hw_lm_destroy(): Destroys layer mixer driver context * dpu_hw_lm_destroy(): Destroys layer mixer driver context
......
...@@ -14,24 +14,6 @@ ...@@ -14,24 +14,6 @@
#define MERGE_3D_MUX 0x000 #define MERGE_3D_MUX 0x000
#define MERGE_3D_MODE 0x004 #define MERGE_3D_MODE 0x004
static const struct dpu_merge_3d_cfg *_merge_3d_offset(enum dpu_merge_3d idx,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->merge_3d_count; i++) {
if (idx == m->merge_3d[i].id) {
b->blk_addr = addr + m->merge_3d[i].base;
b->log_mask = DPU_DBG_MASK_PINGPONG;
return &m->merge_3d[i];
}
}
return ERR_PTR(-EINVAL);
}
static void dpu_hw_merge_3d_setup_3d_mode(struct dpu_hw_merge_3d *merge_3d, static void dpu_hw_merge_3d_setup_3d_mode(struct dpu_hw_merge_3d *merge_3d,
enum dpu_3d_blend_mode mode_3d) enum dpu_3d_blend_mode mode_3d)
{ {
...@@ -55,24 +37,19 @@ static void _setup_merge_3d_ops(struct dpu_hw_merge_3d *c, ...@@ -55,24 +37,19 @@ static void _setup_merge_3d_ops(struct dpu_hw_merge_3d *c,
c->ops.setup_3d_mode = dpu_hw_merge_3d_setup_3d_mode; c->ops.setup_3d_mode = dpu_hw_merge_3d_setup_3d_mode;
}; };
struct dpu_hw_merge_3d *dpu_hw_merge_3d_init(enum dpu_merge_3d idx, struct dpu_hw_merge_3d *dpu_hw_merge_3d_init(const struct dpu_merge_3d_cfg *cfg,
void __iomem *addr, void __iomem *addr)
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_merge_3d *c; struct dpu_hw_merge_3d *c;
const struct dpu_merge_3d_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _merge_3d_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_PINGPONG;
kfree(c);
return ERR_PTR(-EINVAL);
}
c->idx = idx; c->idx = cfg->id;
c->caps = cfg; c->caps = cfg;
_setup_merge_3d_ops(c, c->caps->features); _setup_merge_3d_ops(c, c->caps->features);
......
...@@ -46,16 +46,14 @@ static inline struct dpu_hw_merge_3d *to_dpu_hw_merge_3d(struct dpu_hw_blk *hw) ...@@ -46,16 +46,14 @@ static inline struct dpu_hw_merge_3d *to_dpu_hw_merge_3d(struct dpu_hw_blk *hw)
} }
/** /**
* dpu_hw_merge_3d_init - initializes the merge_3d driver for the passed * dpu_hw_merge_3d_init() - Initializes the merge_3d driver for the passed
* merge_3d idx. * merge3d catalog entry.
* @idx: Pingpong index for which driver object is required * @cfg: Pingpong catalog entry for which driver object is required
* @addr: Mapped register io address of MDP * @addr: Mapped register io address of MDP
* @m: Pointer to mdss catalog data * Return: Error code or allocated dpu_hw_merge_3d context
* Returns: Error code or allocated dpu_hw_merge_3d context
*/ */
struct dpu_hw_merge_3d *dpu_hw_merge_3d_init(enum dpu_merge_3d idx, struct dpu_hw_merge_3d *dpu_hw_merge_3d_init(const struct dpu_merge_3d_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
/** /**
* dpu_hw_merge_3d_destroy - destroys merge_3d driver context * dpu_hw_merge_3d_destroy - destroys merge_3d driver context
......
...@@ -42,24 +42,6 @@ static u32 dither_depth_map[DITHER_DEPTH_MAP_INDEX] = { ...@@ -42,24 +42,6 @@ static u32 dither_depth_map[DITHER_DEPTH_MAP_INDEX] = {
0, 0, 0, 0, 0, 0, 0, 1, 2 0, 0, 0, 0, 0, 0, 0, 1, 2
}; };
static const struct dpu_pingpong_cfg *_pingpong_offset(enum dpu_pingpong pp,
const struct dpu_mdss_cfg *m,
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->pingpong_count; i++) {
if (pp == m->pingpong[i].id) {
b->blk_addr = addr + m->pingpong[i].base;
b->log_mask = DPU_DBG_MASK_PINGPONG;
return &m->pingpong[i];
}
}
return ERR_PTR(-EINVAL);
}
static void dpu_hw_pp_setup_dither(struct dpu_hw_pingpong *pp, static void dpu_hw_pp_setup_dither(struct dpu_hw_pingpong *pp,
struct dpu_hw_dither_cfg *cfg) struct dpu_hw_dither_cfg *cfg)
{ {
...@@ -290,24 +272,19 @@ static void _setup_pingpong_ops(struct dpu_hw_pingpong *c, ...@@ -290,24 +272,19 @@ static void _setup_pingpong_ops(struct dpu_hw_pingpong *c,
c->ops.setup_dither = dpu_hw_pp_setup_dither; c->ops.setup_dither = dpu_hw_pp_setup_dither;
}; };
struct dpu_hw_pingpong *dpu_hw_pingpong_init(enum dpu_pingpong idx, struct dpu_hw_pingpong *dpu_hw_pingpong_init(const struct dpu_pingpong_cfg *cfg,
void __iomem *addr, void __iomem *addr)
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_pingpong *c; struct dpu_hw_pingpong *c;
const struct dpu_pingpong_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _pingpong_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_PINGPONG;
kfree(c);
return ERR_PTR(-EINVAL);
}
c->idx = idx; c->idx = cfg->id;
c->caps = cfg; c->caps = cfg;
_setup_pingpong_ops(c, c->caps->features); _setup_pingpong_ops(c, c->caps->features);
......
...@@ -165,16 +165,14 @@ static inline struct dpu_hw_pingpong *to_dpu_hw_pingpong(struct dpu_hw_blk *hw) ...@@ -165,16 +165,14 @@ static inline struct dpu_hw_pingpong *to_dpu_hw_pingpong(struct dpu_hw_blk *hw)
} }
/** /**
* dpu_hw_pingpong_init - initializes the pingpong driver for the passed * dpu_hw_pingpong_init() - initializes the pingpong driver for the passed
* pingpong idx. * pingpong catalog entry.
* @idx: Pingpong index for which driver object is required * @cfg: Pingpong catalog entry for which driver object is required
* @addr: Mapped register io address of MDP * @addr: Mapped register io address of MDP
* @m: Pointer to mdss catalog data * Return: Error code or allocated dpu_hw_pingpong context
* Returns: Error code or allocated dpu_hw_pingpong context
*/ */
struct dpu_hw_pingpong *dpu_hw_pingpong_init(enum dpu_pingpong idx, struct dpu_hw_pingpong *dpu_hw_pingpong_init(const struct dpu_pingpong_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
/** /**
* dpu_hw_pingpong_destroy - destroys pingpong driver context * dpu_hw_pingpong_destroy - destroys pingpong driver context
......
...@@ -771,49 +771,24 @@ int _dpu_hw_sspp_init_debugfs(struct dpu_hw_sspp *hw_pipe, struct dpu_kms *kms, ...@@ -771,49 +771,24 @@ int _dpu_hw_sspp_init_debugfs(struct dpu_hw_sspp *hw_pipe, struct dpu_kms *kms,
} }
#endif #endif
struct dpu_hw_sspp *dpu_hw_sspp_init(const struct dpu_sspp_cfg *cfg,
static const struct dpu_sspp_cfg *_sspp_offset(enum dpu_sspp sspp, void __iomem *addr, const struct dpu_ubwc_cfg *ubwc)
void __iomem *addr,
const struct dpu_mdss_cfg *catalog,
struct dpu_hw_blk_reg_map *b)
{
int i;
if ((sspp < SSPP_MAX) && catalog && addr && b) {
for (i = 0; i < catalog->sspp_count; i++) {
if (sspp == catalog->sspp[i].id) {
b->blk_addr = addr + catalog->sspp[i].base;
b->log_mask = DPU_DBG_MASK_SSPP;
return &catalog->sspp[i];
}
}
}
return ERR_PTR(-ENOMEM);
}
struct dpu_hw_sspp *dpu_hw_sspp_init(enum dpu_sspp idx,
void __iomem *addr, const struct dpu_mdss_cfg *catalog)
{ {
struct dpu_hw_sspp *hw_pipe; struct dpu_hw_sspp *hw_pipe;
const struct dpu_sspp_cfg *cfg;
if (!addr || !catalog) if (!addr || !ubwc)
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
hw_pipe = kzalloc(sizeof(*hw_pipe), GFP_KERNEL); hw_pipe = kzalloc(sizeof(*hw_pipe), GFP_KERNEL);
if (!hw_pipe) if (!hw_pipe)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _sspp_offset(idx, addr, catalog, &hw_pipe->hw); hw_pipe->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { hw_pipe->hw.log_mask = DPU_DBG_MASK_SSPP;
kfree(hw_pipe);
return ERR_PTR(-EINVAL);
}
/* Assign ops */ /* Assign ops */
hw_pipe->ubwc = catalog->ubwc; hw_pipe->ubwc = ubwc;
hw_pipe->idx = idx; hw_pipe->idx = cfg->id;
hw_pipe->cap = cfg; hw_pipe->cap = cfg;
_setup_layer_ops(hw_pipe, hw_pipe->cap->features); _setup_layer_ops(hw_pipe, hw_pipe->cap->features);
......
...@@ -341,7 +341,7 @@ struct dpu_hw_sspp_ops { ...@@ -341,7 +341,7 @@ struct dpu_hw_sspp_ops {
* struct dpu_hw_sspp - pipe description * struct dpu_hw_sspp - pipe description
* @base: hardware block base structure * @base: hardware block base structure
* @hw: block hardware details * @hw: block hardware details
* @ubwc: ubwc configuration data * @ubwc: UBWC configuration data
* @idx: pipe index * @idx: pipe index
* @cap: pointer to layer_cfg * @cap: pointer to layer_cfg
* @ops: pointer to operations possible for this pipe * @ops: pointer to operations possible for this pipe
...@@ -361,14 +361,14 @@ struct dpu_hw_sspp { ...@@ -361,14 +361,14 @@ struct dpu_hw_sspp {
struct dpu_kms; struct dpu_kms;
/** /**
* dpu_hw_sspp_init - initializes the sspp hw driver object. * dpu_hw_sspp_init() - Initializes the sspp hw driver object.
* Should be called once before accessing every pipe. * Should be called once before accessing every pipe.
* @idx: Pipe index for which driver object is required * @cfg: Pipe catalog entry for which driver object is required
* @addr: Mapped register io address of MDP * @addr: Mapped register io address of MDP
* @catalog : Pointer to mdss catalog data * @ubwc: UBWC configuration data
*/ */
struct dpu_hw_sspp *dpu_hw_sspp_init(enum dpu_sspp idx, struct dpu_hw_sspp *dpu_hw_sspp_init(const struct dpu_sspp_cfg *cfg,
void __iomem *addr, const struct dpu_mdss_cfg *catalog); void __iomem *addr, const struct dpu_ubwc_cfg *ubwc);
/** /**
* dpu_hw_sspp_destroy(): Destroys SSPP driver context * dpu_hw_sspp_destroy(): Destroys SSPP driver context
......
...@@ -211,45 +211,22 @@ static void _setup_vbif_ops(struct dpu_hw_vbif_ops *ops, ...@@ -211,45 +211,22 @@ static void _setup_vbif_ops(struct dpu_hw_vbif_ops *ops,
ops->set_write_gather_en = dpu_hw_set_write_gather_en; ops->set_write_gather_en = dpu_hw_set_write_gather_en;
} }
static const struct dpu_vbif_cfg *_top_offset(enum dpu_vbif vbif, struct dpu_hw_vbif *dpu_hw_vbif_init(const struct dpu_vbif_cfg *cfg,
const struct dpu_mdss_cfg *m, void __iomem *addr)
void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->vbif_count; i++) {
if (vbif == m->vbif[i].id) {
b->blk_addr = addr + m->vbif[i].base;
b->log_mask = DPU_DBG_MASK_VBIF;
return &m->vbif[i];
}
}
return ERR_PTR(-EINVAL);
}
struct dpu_hw_vbif *dpu_hw_vbif_init(enum dpu_vbif idx,
void __iomem *addr,
const struct dpu_mdss_cfg *m)
{ {
struct dpu_hw_vbif *c; struct dpu_hw_vbif *c;
const struct dpu_vbif_cfg *cfg;
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _top_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR_OR_NULL(cfg)) { c->hw.log_mask = DPU_DBG_MASK_VBIF;
kfree(c);
return ERR_PTR(-EINVAL);
}
/* /*
* Assign ops * Assign ops
*/ */
c->idx = idx; c->idx = cfg->id;
c->cap = cfg; c->cap = cfg;
_setup_vbif_ops(&c->ops, c->cap->features); _setup_vbif_ops(&c->ops, c->cap->features);
......
...@@ -106,14 +106,13 @@ struct dpu_hw_vbif { ...@@ -106,14 +106,13 @@ struct dpu_hw_vbif {
}; };
/** /**
* dpu_hw_vbif_init - initializes the vbif driver for the passed interface idx * dpu_hw_vbif_init() - Initializes the VBIF driver for the passed
* @idx: Interface index for which driver object is required * VBIF catalog entry.
* @cfg: VBIF catalog entry for which driver object is required
* @addr: Mapped register io address of MDSS * @addr: Mapped register io address of MDSS
* @m: Pointer to mdss catalog data
*/ */
struct dpu_hw_vbif *dpu_hw_vbif_init(enum dpu_vbif idx, struct dpu_hw_vbif *dpu_hw_vbif_init(const struct dpu_vbif_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
void dpu_hw_vbif_destroy(struct dpu_hw_vbif *vbif); void dpu_hw_vbif_destroy(struct dpu_hw_vbif *vbif);
......
...@@ -52,22 +52,6 @@ ...@@ -52,22 +52,6 @@
/* WB_QOS_CTRL */ /* WB_QOS_CTRL */
#define WB_QOS_CTRL_DANGER_SAFE_EN BIT(0) #define WB_QOS_CTRL_DANGER_SAFE_EN BIT(0)
static const struct dpu_wb_cfg *_wb_offset(enum dpu_wb wb,
const struct dpu_mdss_cfg *m, void __iomem *addr,
struct dpu_hw_blk_reg_map *b)
{
int i;
for (i = 0; i < m->wb_count; i++) {
if (wb == m->wb[i].id) {
b->blk_addr = addr + m->wb[i].base;
b->log_mask = DPU_DBG_MASK_WB;
return &m->wb[i];
}
}
return ERR_PTR(-EINVAL);
}
static void dpu_hw_wb_setup_outaddress(struct dpu_hw_wb *ctx, static void dpu_hw_wb_setup_outaddress(struct dpu_hw_wb *ctx,
struct dpu_hw_wb_cfg *data) struct dpu_hw_wb_cfg *data)
{ {
...@@ -242,28 +226,23 @@ static void _setup_wb_ops(struct dpu_hw_wb_ops *ops, ...@@ -242,28 +226,23 @@ static void _setup_wb_ops(struct dpu_hw_wb_ops *ops,
ops->bind_pingpong_blk = dpu_hw_wb_bind_pingpong_blk; ops->bind_pingpong_blk = dpu_hw_wb_bind_pingpong_blk;
} }
struct dpu_hw_wb *dpu_hw_wb_init(enum dpu_wb idx, struct dpu_hw_wb *dpu_hw_wb_init(const struct dpu_wb_cfg *cfg,
void __iomem *addr, const struct dpu_mdss_cfg *m) void __iomem *addr)
{ {
struct dpu_hw_wb *c; struct dpu_hw_wb *c;
const struct dpu_wb_cfg *cfg;
if (!addr || !m) if (!addr)
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
c = kzalloc(sizeof(*c), GFP_KERNEL); c = kzalloc(sizeof(*c), GFP_KERNEL);
if (!c) if (!c)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
cfg = _wb_offset(idx, m, addr, &c->hw); c->hw.blk_addr = addr + cfg->base;
if (IS_ERR(cfg)) { c->hw.log_mask = DPU_DBG_MASK_WB;
WARN(1, "Unable to find wb idx=%d\n", idx);
kfree(c);
return ERR_PTR(-EINVAL);
}
/* Assign ops */ /* Assign ops */
c->idx = idx; c->idx = cfg->id;
c->caps = cfg; c->caps = cfg;
_setup_wb_ops(&c->ops, c->caps->features); _setup_wb_ops(&c->ops, c->caps->features);
......
...@@ -92,14 +92,13 @@ struct dpu_hw_wb { ...@@ -92,14 +92,13 @@ struct dpu_hw_wb {
}; };
/** /**
* dpu_hw_wb_init(): Initializes and return writeback hw driver object. * dpu_hw_wb_init() - Initializes the writeback hw driver object.
* @idx: wb_path index for which driver object is required * @cfg: wb_path catalog entry for which driver object is required
* @addr: mapped register io address of MDP * @addr: mapped register io address of MDP
* @m : pointer to mdss catalog data * Return: Error code or allocated dpu_hw_wb context
*/ */
struct dpu_hw_wb *dpu_hw_wb_init(enum dpu_wb idx, struct dpu_hw_wb *dpu_hw_wb_init(const struct dpu_wb_cfg *cfg,
void __iomem *addr, void __iomem *addr);
const struct dpu_mdss_cfg *m);
/** /**
* dpu_hw_wb_destroy(): Destroy writeback hw driver object. * dpu_hw_wb_destroy(): Destroy writeback hw driver object.
......
...@@ -1125,16 +1125,17 @@ static int dpu_kms_hw_init(struct msm_kms *kms) ...@@ -1125,16 +1125,17 @@ static int dpu_kms_hw_init(struct msm_kms *kms)
} }
for (i = 0; i < dpu_kms->catalog->vbif_count; i++) { for (i = 0; i < dpu_kms->catalog->vbif_count; i++) {
u32 vbif_idx = dpu_kms->catalog->vbif[i].id; struct dpu_hw_vbif *hw;
const struct dpu_vbif_cfg *vbif = &dpu_kms->catalog->vbif[i];
dpu_kms->hw_vbif[vbif_idx] = dpu_hw_vbif_init(vbif_idx,
dpu_kms->vbif[vbif_idx], dpu_kms->catalog); hw = dpu_hw_vbif_init(vbif, dpu_kms->vbif[vbif->id]);
if (IS_ERR(dpu_kms->hw_vbif[vbif_idx])) { if (IS_ERR(hw)) {
rc = PTR_ERR(dpu_kms->hw_vbif[vbif_idx]); rc = PTR_ERR(hw);
DPU_ERROR("failed to init vbif %d: %d\n", vbif_idx, rc); DPU_ERROR("failed to init vbif %d: %d\n", vbif->id, rc);
dpu_kms->hw_vbif[vbif_idx] = NULL;
goto power_error; goto power_error;
} }
dpu_kms->hw_vbif[vbif->id] = hw;
} }
rc = dpu_core_perf_init(&dpu_kms->perf, dev, dpu_kms->catalog, rc = dpu_core_perf_init(&dpu_kms->perf, dev, dpu_kms->catalog,
......
...@@ -126,7 +126,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -126,7 +126,7 @@ int dpu_rm_init(struct dpu_rm *rm,
DPU_ERROR("skip mixer %d with invalid id\n", lm->id); DPU_ERROR("skip mixer %d with invalid id\n", lm->id);
continue; continue;
} }
hw = dpu_hw_lm_init(lm->id, mmio, cat); hw = dpu_hw_lm_init(lm, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed lm object creation: err %d\n", rc); DPU_ERROR("failed lm object creation: err %d\n", rc);
...@@ -143,7 +143,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -143,7 +143,7 @@ int dpu_rm_init(struct dpu_rm *rm,
DPU_ERROR("skip merge_3d %d with invalid id\n", merge_3d->id); DPU_ERROR("skip merge_3d %d with invalid id\n", merge_3d->id);
continue; continue;
} }
hw = dpu_hw_merge_3d_init(merge_3d->id, mmio, cat); hw = dpu_hw_merge_3d_init(merge_3d, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed merge_3d object creation: err %d\n", DPU_ERROR("failed merge_3d object creation: err %d\n",
...@@ -161,7 +161,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -161,7 +161,7 @@ int dpu_rm_init(struct dpu_rm *rm,
DPU_ERROR("skip pingpong %d with invalid id\n", pp->id); DPU_ERROR("skip pingpong %d with invalid id\n", pp->id);
continue; continue;
} }
hw = dpu_hw_pingpong_init(pp->id, mmio, cat); hw = dpu_hw_pingpong_init(pp, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed pingpong object creation: err %d\n", DPU_ERROR("failed pingpong object creation: err %d\n",
...@@ -177,15 +177,11 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -177,15 +177,11 @@ int dpu_rm_init(struct dpu_rm *rm,
struct dpu_hw_intf *hw; struct dpu_hw_intf *hw;
const struct dpu_intf_cfg *intf = &cat->intf[i]; const struct dpu_intf_cfg *intf = &cat->intf[i];
if (intf->type == INTF_NONE) {
DPU_DEBUG("skip intf %d with type none\n", i);
continue;
}
if (intf->id < INTF_0 || intf->id >= INTF_MAX) { if (intf->id < INTF_0 || intf->id >= INTF_MAX) {
DPU_ERROR("skip intf %d with invalid id\n", intf->id); DPU_ERROR("skip intf %d with invalid id\n", intf->id);
continue; continue;
} }
hw = dpu_hw_intf_init(intf->id, mmio, cat); hw = dpu_hw_intf_init(intf, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed intf object creation: err %d\n", rc); DPU_ERROR("failed intf object creation: err %d\n", rc);
...@@ -203,7 +199,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -203,7 +199,7 @@ int dpu_rm_init(struct dpu_rm *rm,
continue; continue;
} }
hw = dpu_hw_wb_init(wb->id, mmio, cat); hw = dpu_hw_wb_init(wb, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed wb object creation: err %d\n", rc); DPU_ERROR("failed wb object creation: err %d\n", rc);
...@@ -220,7 +216,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -220,7 +216,7 @@ int dpu_rm_init(struct dpu_rm *rm,
DPU_ERROR("skip ctl %d with invalid id\n", ctl->id); DPU_ERROR("skip ctl %d with invalid id\n", ctl->id);
continue; continue;
} }
hw = dpu_hw_ctl_init(ctl->id, mmio, cat); hw = dpu_hw_ctl_init(ctl, mmio, cat->mixer_count, cat->mixer);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed ctl object creation: err %d\n", rc); DPU_ERROR("failed ctl object creation: err %d\n", rc);
...@@ -237,7 +233,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -237,7 +233,7 @@ int dpu_rm_init(struct dpu_rm *rm,
DPU_ERROR("skip dspp %d with invalid id\n", dspp->id); DPU_ERROR("skip dspp %d with invalid id\n", dspp->id);
continue; continue;
} }
hw = dpu_hw_dspp_init(dspp->id, mmio, cat); hw = dpu_hw_dspp_init(dspp, mmio);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed dspp object creation: err %d\n", rc); DPU_ERROR("failed dspp object creation: err %d\n", rc);
...@@ -250,7 +246,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -250,7 +246,7 @@ int dpu_rm_init(struct dpu_rm *rm,
struct dpu_hw_dsc *hw; struct dpu_hw_dsc *hw;
const struct dpu_dsc_cfg *dsc = &cat->dsc[i]; const struct dpu_dsc_cfg *dsc = &cat->dsc[i];
hw = dpu_hw_dsc_init(dsc->id, mmio, cat); hw = dpu_hw_dsc_init(dsc, mmio);
if (IS_ERR_OR_NULL(hw)) { if (IS_ERR_OR_NULL(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed dsc object creation: err %d\n", rc); DPU_ERROR("failed dsc object creation: err %d\n", rc);
...@@ -268,7 +264,7 @@ int dpu_rm_init(struct dpu_rm *rm, ...@@ -268,7 +264,7 @@ int dpu_rm_init(struct dpu_rm *rm,
continue; continue;
} }
hw = dpu_hw_sspp_init(sspp->id, mmio, cat); hw = dpu_hw_sspp_init(sspp, mmio, cat->ubwc);
if (IS_ERR(hw)) { if (IS_ERR(hw)) {
rc = PTR_ERR(hw); rc = PTR_ERR(hw);
DPU_ERROR("failed sspp object creation: err %d\n", rc); DPU_ERROR("failed sspp object creation: err %d\n", rc);
......
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