ARM: EXYNOS4: Enable MFC on ORIGEN
authorSachin Kamat <sachin.kamat@linaro.org>
Thu, 13 Oct 2011 06:38:21 +0000 (15:38 +0900)
committerKukjin Kim <kgene.kim@samsung.com>
Fri, 14 Oct 2011 06:15:46 +0000 (15:15 +0900)
This patch enables multi-format codec (MFC) support on ORIGEN board.

Signed-off-by: Sachin Kamat <sachin.kamat@linaro.org>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
arch/arm/mach-exynos4/Kconfig
arch/arm/mach-exynos4/mach-origen.c

index dd660eb..d7491e1 100644 (file)
@@ -251,11 +251,12 @@ config MACH_ORIGEN
        select S5P_DEV_FIMC3
        select S5P_DEV_FIMD0
        select S5P_DEV_I2C_HDMIPHY
+       select S5P_DEV_MFC
        select S5P_DEV_TV
        select S5P_DEV_USB_EHCI
-       select EXYNOS4_DEV_PD
        select SAMSUNG_DEV_BACKLIGHT
        select SAMSUNG_DEV_PWM
+       select EXYNOS4_DEV_PD
        select EXYNOS4_SETUP_FIMD0
        select EXYNOS4_SETUP_SDHCI
        select EXYNOS4_SETUP_USB_PHY
index 311e9db..f80b563 100644 (file)
@@ -39,6 +39,7 @@
 #include <plat/backlight.h>
 #include <plat/pd.h>
 #include <plat/fb.h>
+#include <plat/mfc.h>
 
 #include <mach/map.h>
 
@@ -601,6 +602,9 @@ static struct platform_device *origen_devices[] __initdata = {
        &s5p_device_fimd0,
        &s5p_device_hdmi,
        &s5p_device_i2c_hdmiphy,
+       &s5p_device_mfc,
+       &s5p_device_mfc_l,
+       &s5p_device_mfc_r,
        &s5p_device_mixer,
        &exynos4_device_pd[PD_LCD0],
        &exynos4_device_pd[PD_TV],
@@ -608,6 +612,7 @@ static struct platform_device *origen_devices[] __initdata = {
        &exynos4_device_pd[PD_LCD1],
        &exynos4_device_pd[PD_CAM],
        &exynos4_device_pd[PD_GPS],
+       &exynos4_device_pd[PD_MFC],
        &origen_device_gpiokeys,
        &origen_lcd_hv070wsa,
 };
@@ -645,6 +650,11 @@ static void __init origen_power_init(void)
        s3c_gpio_setpull(EXYNOS4_GPX0(4), S3C_GPIO_PULL_NONE);
 }
 
+static void __init origen_reserve(void)
+{
+       s5p_mfc_reserve_mem(0x43000000, 8 << 20, 0x51000000, 8 << 20);
+}
+
 static void __init origen_machine_init(void)
 {
        origen_power_init();
@@ -668,11 +678,14 @@ static void __init origen_machine_init(void)
        s5p_fimd0_set_platdata(&origen_lcd_pdata);
 
        platform_add_devices(origen_devices, ARRAY_SIZE(origen_devices));
+
        s5p_device_fimd0.dev.parent = &exynos4_device_pd[PD_LCD0].dev;
 
        s5p_device_hdmi.dev.parent = &exynos4_device_pd[PD_TV].dev;
        s5p_device_mixer.dev.parent = &exynos4_device_pd[PD_TV].dev;
 
+       s5p_device_mfc.dev.parent = &exynos4_device_pd[PD_MFC].dev;
+
        samsung_bl_set(&origen_bl_gpio_info, &origen_bl_data);
 }
 
@@ -683,4 +696,5 @@ MACHINE_START(ORIGEN, "ORIGEN")
        .map_io         = origen_map_io,
        .init_machine   = origen_machine_init,
        .timer          = &exynos4_timer,
+       .reserve        = &origen_reserve,
 MACHINE_END