Commit 1e123441 authored by Rahul Sharma's avatar Rahul Sharma Committed by Inki Dae

drm: exynos: hdmi: add support for platform variants for mixer

This patch adds the support for multiple mixer versions avaialble in
various platform variants. Version is passed as a driver data field
instead of paltform data.
Signed-off-by: default avatarRahul Sharma <rahul.sharma@samsung.com>
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: default avatarInki Dae <inki.dae@samsung.com>
parent 93c645ee
...@@ -73,6 +73,11 @@ struct mixer_resources { ...@@ -73,6 +73,11 @@ struct mixer_resources {
struct clk *sclk_dac; struct clk *sclk_dac;
}; };
enum mixer_version_id {
MXR_VER_0_0_0_16,
MXR_VER_16_0_33_0,
};
struct mixer_context { struct mixer_context {
struct device *dev; struct device *dev;
int pipe; int pipe;
...@@ -83,6 +88,11 @@ struct mixer_context { ...@@ -83,6 +88,11 @@ struct mixer_context {
struct mutex mixer_mutex; struct mutex mixer_mutex;
struct mixer_resources mixer_res; struct mixer_resources mixer_res;
struct hdmi_win_data win_data[MIXER_WIN_NR]; struct hdmi_win_data win_data[MIXER_WIN_NR];
enum mixer_version_id mxr_ver;
};
struct mixer_drv_data {
enum mixer_version_id version;
}; };
static const u8 filter_y_horiz_tap8[] = { static const u8 filter_y_horiz_tap8[] = {
...@@ -1023,11 +1033,25 @@ static int __devinit mixer_resources_init(struct exynos_drm_hdmi_context *ctx, ...@@ -1023,11 +1033,25 @@ static int __devinit mixer_resources_init(struct exynos_drm_hdmi_context *ctx,
return ret; return ret;
} }
static struct mixer_drv_data exynos4_mxr_drv_data = {
.version = MXR_VER_0_0_0_16,
};
static struct platform_device_id mixer_driver_types[] = {
{
.name = "s5p-mixer",
.driver_data = (unsigned long)&exynos4_mxr_drv_data,
}, {
/* end node */
}
};
static int __devinit mixer_probe(struct platform_device *pdev) static int __devinit mixer_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct exynos_drm_hdmi_context *drm_hdmi_ctx; struct exynos_drm_hdmi_context *drm_hdmi_ctx;
struct mixer_context *ctx; struct mixer_context *ctx;
struct mixer_drv_data *drv;
int ret; int ret;
dev_info(dev, "probe start\n"); dev_info(dev, "probe start\n");
...@@ -1047,8 +1071,11 @@ static int __devinit mixer_probe(struct platform_device *pdev) ...@@ -1047,8 +1071,11 @@ static int __devinit mixer_probe(struct platform_device *pdev)
mutex_init(&ctx->mixer_mutex); mutex_init(&ctx->mixer_mutex);
drv = (struct mixer_drv_data *)platform_get_device_id(
pdev)->driver_data;
ctx->dev = &pdev->dev; ctx->dev = &pdev->dev;
drm_hdmi_ctx->ctx = (void *)ctx; drm_hdmi_ctx->ctx = (void *)ctx;
ctx->mxr_ver = drv->version;
platform_set_drvdata(pdev, drm_hdmi_ctx); platform_set_drvdata(pdev, drm_hdmi_ctx);
...@@ -1101,4 +1128,5 @@ struct platform_driver mixer_driver = { ...@@ -1101,4 +1128,5 @@ struct platform_driver mixer_driver = {
}, },
.probe = mixer_probe, .probe = mixer_probe,
.remove = __devexit_p(mixer_remove), .remove = __devexit_p(mixer_remove),
.id_table = mixer_driver_types,
}; };
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