Commit b385b991 authored by Moudy Ho's avatar Moudy Ho Committed by Hans Verkuil

media: platform: mtk-mdp3: chip config split about subcomponents

Integrate subcomponent related information into specific config file for
further multi-chip compatibility.
Signed-off-by: default avatarMoudy Ho <moudy.ho@mediatek.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
parent b59ed26f
...@@ -144,12 +144,24 @@ static const struct mdp_comp_data mt8183_mdp_comp_data[MDP_MAX_COMP_COUNT] = { ...@@ -144,12 +144,24 @@ static const struct mdp_comp_data mt8183_mdp_comp_data[MDP_MAX_COMP_COUNT] = {
}, },
}; };
static const struct of_device_id mt8183_sub_comp_dt_ids[] = {
{
.compatible = "mediatek,mt8183-mdp3-wdma",
.data = (void *)MDP_COMP_TYPE_PATH,
}, {
.compatible = "mediatek,mt8183-mdp3-wrot",
.data = (void *)MDP_COMP_TYPE_PATH,
},
{}
};
const struct mtk_mdp_driver_data mt8183_mdp_driver_data = { const struct mtk_mdp_driver_data mt8183_mdp_driver_data = {
.mdp_probe_infra = mt8183_mdp_probe_infra, .mdp_probe_infra = mt8183_mdp_probe_infra,
.mdp_cfg = &mt8183_plat_cfg, .mdp_cfg = &mt8183_plat_cfg,
.mdp_mutex_table_idx = mt8183_mutex_idx, .mdp_mutex_table_idx = mt8183_mutex_idx,
.comp_data = mt8183_mdp_comp_data, .comp_data = mt8183_mdp_comp_data,
.comp_data_len = ARRAY_SIZE(mt8183_mdp_comp_data), .comp_data_len = ARRAY_SIZE(mt8183_mdp_comp_data),
.mdp_sub_comp_dt_ids = mt8183_sub_comp_dt_ids,
}; };
s32 mdp_cfg_get_id_inner(struct mdp_dev *mdp_dev, enum mtk_mdp_comp_id id) s32 mdp_cfg_get_id_inner(struct mdp_dev *mdp_dev, enum mtk_mdp_comp_id id)
......
...@@ -610,17 +610,6 @@ static const struct of_device_id mdp_comp_dt_ids[] = { ...@@ -610,17 +610,6 @@ static const struct of_device_id mdp_comp_dt_ids[] = {
{} {}
}; };
static const struct of_device_id mdp_sub_comp_dt_ids[] = {
{
.compatible = "mediatek,mt8183-mdp3-wdma",
.data = (void *)MDP_COMP_TYPE_PATH,
}, {
.compatible = "mediatek,mt8183-mdp3-wrot",
.data = (void *)MDP_COMP_TYPE_PATH,
},
{}
};
static inline bool is_dma_capable(const enum mdp_comp_type type) static inline bool is_dma_capable(const enum mdp_comp_type type)
{ {
return (type == MDP_COMP_TYPE_RDMA || return (type == MDP_COMP_TYPE_RDMA ||
...@@ -871,6 +860,7 @@ static int mdp_comp_sub_create(struct mdp_dev *mdp) ...@@ -871,6 +860,7 @@ static int mdp_comp_sub_create(struct mdp_dev *mdp)
{ {
struct device *dev = &mdp->pdev->dev; struct device *dev = &mdp->pdev->dev;
struct device_node *node, *parent; struct device_node *node, *parent;
const struct mtk_mdp_driver_data *data = mdp->mdp_data;
parent = dev->of_node->parent; parent = dev->of_node->parent;
...@@ -880,7 +870,7 @@ static int mdp_comp_sub_create(struct mdp_dev *mdp) ...@@ -880,7 +870,7 @@ static int mdp_comp_sub_create(struct mdp_dev *mdp)
int id, alias_id; int id, alias_id;
struct mdp_comp *comp; struct mdp_comp *comp;
of_id = of_match_node(mdp_sub_comp_dt_ids, node); of_id = of_match_node(data->mdp_sub_comp_dt_ids, node);
if (!of_id) if (!of_id)
continue; continue;
if (!of_device_is_available(node)) { if (!of_device_is_available(node)) {
......
...@@ -56,6 +56,7 @@ struct mtk_mdp_driver_data { ...@@ -56,6 +56,7 @@ struct mtk_mdp_driver_data {
const u32 *mdp_mutex_table_idx; const u32 *mdp_mutex_table_idx;
const struct mdp_comp_data *comp_data; const struct mdp_comp_data *comp_data;
unsigned int comp_data_len; unsigned int comp_data_len;
const struct of_device_id *mdp_sub_comp_dt_ids;
}; };
struct mdp_dev { struct mdp_dev {
......
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