mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-09 10:11:52 -04:00
drm/mediatek: Manage component's clock with function pointers
By registering component related functions to the pointers, we can easily manage them within a for-loop and simplify the logic of clock control significantly. Reviewed-by: CK Hu <ck.hu@mediatek.com> Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> Signed-off-by: Hsiao Chien Sung <shawn.sung@mediatek.com> Link: https://patchwork.kernel.org/project/dri-devel/patch/20231214055847.4936-14-shawn.sung@mediatek.com/ Signed-off-by: Chun-Kuang Hu <chunkuang.hu@kernel.org>
This commit is contained in:
committed by
Chun-Kuang Hu
parent
8daf02f03c
commit
7bacaee4f5
@@ -54,6 +54,7 @@ struct ovl_adaptor_comp_match {
|
||||
enum mtk_ovl_adaptor_comp_type type;
|
||||
enum mtk_ddp_comp_id comp_id;
|
||||
int alias_id;
|
||||
const struct mtk_ddp_comp_funcs *funcs;
|
||||
};
|
||||
|
||||
struct mtk_disp_ovl_adaptor {
|
||||
@@ -68,20 +69,35 @@ static const char * const private_comp_stem[OVL_ADAPTOR_TYPE_NUM] = {
|
||||
[OVL_ADAPTOR_TYPE_ETHDR] = "ethdr",
|
||||
};
|
||||
|
||||
static const struct mtk_ddp_comp_funcs ethdr = {
|
||||
.clk_enable = mtk_ethdr_clk_enable,
|
||||
.clk_disable = mtk_ethdr_clk_disable,
|
||||
};
|
||||
|
||||
static const struct mtk_ddp_comp_funcs merge = {
|
||||
.clk_enable = mtk_merge_clk_enable,
|
||||
.clk_disable = mtk_merge_clk_disable,
|
||||
};
|
||||
|
||||
static const struct mtk_ddp_comp_funcs rdma = {
|
||||
.clk_enable = mtk_mdp_rdma_clk_enable,
|
||||
.clk_disable = mtk_mdp_rdma_clk_disable,
|
||||
};
|
||||
|
||||
static const struct ovl_adaptor_comp_match comp_matches[OVL_ADAPTOR_ID_MAX] = {
|
||||
[OVL_ADAPTOR_MDP_RDMA0] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA0, 0 },
|
||||
[OVL_ADAPTOR_MDP_RDMA1] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA1, 1 },
|
||||
[OVL_ADAPTOR_MDP_RDMA2] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA2, 2 },
|
||||
[OVL_ADAPTOR_MDP_RDMA3] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA3, 3 },
|
||||
[OVL_ADAPTOR_MDP_RDMA4] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA4, 4 },
|
||||
[OVL_ADAPTOR_MDP_RDMA5] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA5, 5 },
|
||||
[OVL_ADAPTOR_MDP_RDMA6] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA6, 6 },
|
||||
[OVL_ADAPTOR_MDP_RDMA7] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA7, 7 },
|
||||
[OVL_ADAPTOR_MERGE0] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE1, 1 },
|
||||
[OVL_ADAPTOR_MERGE1] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE2, 2 },
|
||||
[OVL_ADAPTOR_MERGE2] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE3, 3 },
|
||||
[OVL_ADAPTOR_MERGE3] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE4, 4 },
|
||||
[OVL_ADAPTOR_ETHDR0] = { OVL_ADAPTOR_TYPE_ETHDR, DDP_COMPONENT_ETHDR_MIXER, 0 },
|
||||
[OVL_ADAPTOR_MDP_RDMA0] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA0, 0, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA1] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA1, 1, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA2] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA2, 2, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA3] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA3, 3, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA4] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA4, 4, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA5] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA5, 5, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA6] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA6, 6, &rdma },
|
||||
[OVL_ADAPTOR_MDP_RDMA7] = { OVL_ADAPTOR_TYPE_MDP_RDMA, DDP_COMPONENT_MDP_RDMA7, 7, &rdma },
|
||||
[OVL_ADAPTOR_MERGE0] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE1, 1, &merge },
|
||||
[OVL_ADAPTOR_MERGE1] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE2, 2, &merge },
|
||||
[OVL_ADAPTOR_MERGE2] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE3, 3, &merge },
|
||||
[OVL_ADAPTOR_MERGE3] = { OVL_ADAPTOR_TYPE_MERGE, DDP_COMPONENT_MERGE4, 4, &merge },
|
||||
[OVL_ADAPTOR_ETHDR0] = { OVL_ADAPTOR_TYPE_ETHDR, DDP_COMPONENT_ETHDR_MIXER, 0, ðdr },
|
||||
};
|
||||
|
||||
void mtk_ovl_adaptor_layer_config(struct device *dev, unsigned int idx,
|
||||
@@ -197,40 +213,25 @@ int mtk_ovl_adaptor_clk_enable(struct device *dev)
|
||||
ret = pm_runtime_get_sync(comp);
|
||||
if (ret < 0) {
|
||||
dev_err(dev, "Failed to enable power domain %d, err %d\n", i, ret);
|
||||
goto pwr_err;
|
||||
goto error;
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 0; i < OVL_ADAPTOR_ID_MAX; i++) {
|
||||
comp = ovl_adaptor->ovl_adaptor_comp[i];
|
||||
|
||||
if (i < OVL_ADAPTOR_MERGE0)
|
||||
ret = mtk_mdp_rdma_clk_enable(comp);
|
||||
else if (i < OVL_ADAPTOR_ETHDR0)
|
||||
ret = mtk_merge_clk_enable(comp);
|
||||
else
|
||||
ret = mtk_ethdr_clk_enable(comp);
|
||||
if (!comp || !comp_matches[i].funcs->clk_enable)
|
||||
continue;
|
||||
ret = comp_matches[i].funcs->clk_enable(comp);
|
||||
if (ret) {
|
||||
dev_err(dev, "Failed to enable clock %d, err %d\n", i, ret);
|
||||
goto clk_err;
|
||||
while (--i >= 0)
|
||||
comp_matches[i].funcs->clk_disable(comp);
|
||||
i = OVL_ADAPTOR_MERGE0;
|
||||
goto error;
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
|
||||
clk_err:
|
||||
while (--i >= 0) {
|
||||
comp = ovl_adaptor->ovl_adaptor_comp[i];
|
||||
if (i < OVL_ADAPTOR_MERGE0)
|
||||
mtk_mdp_rdma_clk_disable(comp);
|
||||
else if (i < OVL_ADAPTOR_ETHDR0)
|
||||
mtk_merge_clk_disable(comp);
|
||||
else
|
||||
mtk_ethdr_clk_disable(comp);
|
||||
}
|
||||
i = OVL_ADAPTOR_MERGE0;
|
||||
|
||||
pwr_err:
|
||||
return 0;
|
||||
error:
|
||||
while (--i >= 0)
|
||||
pm_runtime_put(ovl_adaptor->ovl_adaptor_comp[i]);
|
||||
|
||||
@@ -245,15 +246,11 @@ void mtk_ovl_adaptor_clk_disable(struct device *dev)
|
||||
|
||||
for (i = 0; i < OVL_ADAPTOR_ID_MAX; i++) {
|
||||
comp = ovl_adaptor->ovl_adaptor_comp[i];
|
||||
|
||||
if (i < OVL_ADAPTOR_MERGE0) {
|
||||
mtk_mdp_rdma_clk_disable(comp);
|
||||
if (!comp || !comp_matches[i].funcs->clk_disable)
|
||||
continue;
|
||||
comp_matches[i].funcs->clk_disable(comp);
|
||||
if (i < OVL_ADAPTOR_MERGE0)
|
||||
pm_runtime_put(comp);
|
||||
} else if (i < OVL_ADAPTOR_ETHDR0) {
|
||||
mtk_merge_clk_disable(comp);
|
||||
} else {
|
||||
mtk_ethdr_clk_disable(comp);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user