static void __init smdkv310_machine_init(void) { s3c_i2c1_set_platdata(NULL); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); smdkv310_smsc911x_init(); s3c_sdhci0_set_platdata(&smdkv310_hsmmc0_pdata); s3c_sdhci1_set_platdata(&smdkv310_hsmmc1_pdata); s3c_sdhci2_set_platdata(&smdkv310_hsmmc2_pdata); s3c_sdhci3_set_platdata(&smdkv310_hsmmc3_pdata); s5p_tv_setup(); s5p_i2c_hdmiphy_set_platdata(NULL); samsung_keypad_set_platdata(&smdkv310_keypad_data); samsung_bl_set(&smdkv310_bl_gpio_info, &smdkv310_bl_data); #ifdef CONFIG_DRM_EXYNOS s5p_device_fimd0.dev.platform_data = &drm_fimd_pdata; exynos4_fimd0_gpio_setup_24bpp(); #else s5p_fimd0_set_platdata(&smdkv310_lcd0_pdata); #endif smdkv310_ehci_init(); smdkv310_ohci_init(); clk_xusbxti.rate = 24000000; platform_add_devices(smdkv310_devices, ARRAY_SIZE(smdkv310_devices)); }
static void __init smdkv310_machine_init(void) { s3c_i2c1_set_platdata(NULL); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); smdkv310_smsc911x_init(); s3c_sdhci0_set_platdata(&smdkv310_hsmmc0_pdata); s3c_sdhci1_set_platdata(&smdkv310_hsmmc1_pdata); s3c_sdhci2_set_platdata(&smdkv310_hsmmc2_pdata); s3c_sdhci3_set_platdata(&smdkv310_hsmmc3_pdata); s5p_tv_setup(); s5p_i2c_hdmiphy_set_platdata(NULL); samsung_keypad_set_platdata(&smdkv310_keypad_data); samsung_bl_set(&smdkv310_bl_gpio_info, &smdkv310_bl_data); s5p_fimd0_set_platdata(&smdkv310_lcd0_pdata); smdkv310_ehci_init(); smdkv310_ohci_init(); clk_xusbxti.rate = 24000000; platform_add_devices(smdkv310_devices, ARRAY_SIZE(smdkv310_devices)); }
static void __init smdk4x12_machine_init(void) { s3c_i2c0_set_platdata(NULL); i2c_register_board_info(0, smdk4x12_i2c_devs0, ARRAY_SIZE(smdk4x12_i2c_devs0)); s3c_i2c1_set_platdata(NULL); i2c_register_board_info(1, smdk4x12_i2c_devs1, ARRAY_SIZE(smdk4x12_i2c_devs1)); s3c_i2c3_set_platdata(NULL); i2c_register_board_info(3, smdk4x12_i2c_devs3, ARRAY_SIZE(smdk4x12_i2c_devs3)); s3c_i2c7_set_platdata(NULL); i2c_register_board_info(7, smdk4x12_i2c_devs7, ARRAY_SIZE(smdk4x12_i2c_devs7)); samsung_bl_set(&smdk4x12_bl_gpio_info, &smdk4x12_bl_data); samsung_keypad_set_platdata(&smdk4x12_keypad_data); s3c_sdhci2_set_platdata(&smdk4x12_hsmmc2_pdata); s3c_sdhci3_set_platdata(&smdk4x12_hsmmc3_pdata); platform_add_devices(smdk4x12_devices, ARRAY_SIZE(smdk4x12_devices)); }
static void __init origen_machine_init(void) { origen_power_init(); s3c_i2c0_set_platdata(NULL); i2c_register_board_info(0, i2c0_devs, ARRAY_SIZE(i2c0_devs)); /* * Since sdhci instance 2 can contain a bootable media, * sdhci instance 0 is registered after instance 2. */ s3c_sdhci2_set_platdata(&origen_hsmmc2_pdata); s3c_sdhci0_set_platdata(&origen_hsmmc0_pdata); origen_ehci_init(); origen_ohci_init(); clk_xusbxti.rate = 24000000; s5p_tv_setup(); s5p_i2c_hdmiphy_set_platdata(NULL); s5p_fimd0_set_platdata(&origen_lcd_pdata); platform_add_devices(origen_devices, ARRAY_SIZE(origen_devices)); samsung_bl_set(&origen_bl_gpio_info, &origen_bl_data); origen_bt_setup(); }
static void __init smdkv210_machine_init(void) { s3c_pm_init(); smdkv210_dm9000_init(); samsung_keypad_set_platdata(&smdkv210_keypad_data); s3c24xx_ts_set_platdata(&s3c_ts_platform); s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); i2c_register_board_info(0, smdkv210_i2c_devs0, ARRAY_SIZE(smdkv210_i2c_devs0)); i2c_register_board_info(1, smdkv210_i2c_devs1, ARRAY_SIZE(smdkv210_i2c_devs1)); i2c_register_board_info(2, smdkv210_i2c_devs2, ARRAY_SIZE(smdkv210_i2c_devs2)); s3c_ide_set_platdata(&smdkv210_ide_pdata); s3c_fb_set_platdata(&smdkv210_lcd0_pdata); samsung_bl_set(&smdkv210_bl_gpio_info, &smdkv210_bl_data); platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); }
void __init exynos5_universal5410_display_init(void) { #ifdef CONFIG_FB_MIPI_DSIM s5p_dsim1_set_platdata(&dsim_platform_data); #endif #ifdef CONFIG_S5P_DP s5p_dp_set_platdata(&universal5410_dp_data); #endif s5p_fimd1_set_platdata(&universal5410_lcd1_pdata); #if !defined(CONFIG_MACH_UNIVERSAL5410) samsung_bl_set(&universal5410_bl_gpio_info, &universal5410_bl_data); #endif #ifdef CONFIG_FB_S5P_EXTDSP s3cfb_extdsp_set_platdata(&default_extdsp_data); #endif platform_add_devices(universal5410_display_devices, ARRAY_SIZE(universal5410_display_devices)); #ifdef CONFIG_S5P_DP exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 267 * MHZ); #endif #ifdef CONFIG_FB_MIPI_DSIM #ifdef CONFIG_LCD_MIPI_AMS480GYXX exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 58 * MHZ); #elif defined(CONFIG_LCD_MIPI_S6E8FA0) || defined(CONFIG_LCD_MIPI_ER63311) exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 134 * MHZ); #endif #endif }
static void __init smdkc100_machine_init(void) { s3c24xx_ts_set_platdata(&s3c_ts_platform); /* I2C */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); s3c_fb_set_platdata(&smdkc100_lcd_pdata); s3c_ide_set_platdata(&smdkc100_ide_pdata); samsung_keypad_set_platdata(&smdkc100_keypad_data); s5pc100_spdif_setup_gpio(S5PC100_SPDIF_GPD); /* LCD init */ gpio_request(S5PC100_GPH0(6), "GPH0"); smdkc100_lcd_power_set(&smdkc100_lcd_power_data, 0); samsung_bl_set(&smdkc100_bl_gpio_info, &smdkc100_bl_data); platform_add_devices(smdkc100_devices, ARRAY_SIZE(smdkc100_devices)); }
void __init exynos5_odroidxu_display_init(void) { int i; if(!strncmp(VoutBootArgs, "dp", sizeof("dp"))) { printk("\n---------------------------------------------------------\n\n"); printk("%s : Display Port(DP) Monitor!\n\n", __func__); s5p_dp_set_parameter(); printk("\n---------------------------------------------------------\n\n"); odroidxu_lcd1_pdata.vidcon1 = 0, s5p_dp_set_platdata(&odroidxu_dp_data); } else { printk("\n---------------------------------------------------------\n\n"); printk("%s : LCD or HDMI or DVI Monitor!\n", __func__); printk("\n---------------------------------------------------------\n\n"); s5p_dsim1_set_platdata(&dsim_platform_data); } if(SetVirtualFB) { FrameBufferSizeX = simple_strtol(FbBootArgsX, NULL, 10); FrameBufferSizeY = simple_strtol(FbBootArgsY, NULL, 10); if(!FrameBufferSizeX || !FrameBufferSizeY) { FrameBufferSizeX = DEFAULT_FB_X; FrameBufferSizeY = DEFAULT_FB_Y; } printk("\n---------------------------------------------------------\n\n"); printk("Virtual FB Size from Boot Parameter : X(%d), y(%d)\n", FrameBufferSizeX, FrameBufferSizeY); printk("\n---------------------------------------------------------\n\n"); } else { printk("\n---------------------------------------------------------\n\n"); printk("FB Size : X(%d), y(%d)\n", FrameBufferSizeX, FrameBufferSizeY); printk("\n---------------------------------------------------------\n\n"); } odroidxu_fb_default.win_mode.xres = FrameBufferSizeX; odroidxu_fb_default.win_mode.yres = FrameBufferSizeY; odroidxu_fb_default.virtual_x = FrameBufferSizeX; odroidxu_fb_default.virtual_y = FrameBufferSizeY * 2; s5p_fimd1_set_platdata(&odroidxu_lcd1_pdata); for(i=0; i<ODROIDXU_FB_MAX; i++) memcpy(&odroidxu_fb[i], &odroidxu_fb_default, sizeof(odroidxu_fb_default)); samsung_bl_set(&odroidxu_bl_gpio_info, &odroidxu_bl_data); platform_add_devices(odroidxu_display_devices, ARRAY_SIZE(odroidxu_display_devices)); if(!strncmp(VoutBootArgs, "dp", sizeof("dp"))) { platform_add_devices(odroidxu_dp_display_devices, ARRAY_SIZE(odroidxu_dp_display_devices)); exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 267 * MHZ); } else { platform_add_devices(odroidxu_mipi_display_devices, ARRAY_SIZE(odroidxu_mipi_display_devices)); exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_cpll", 64 * MHZ); } }
void __init exynos5_manta_display_init(void) { struct resource *res; /* LCD_EN , XMMC2CDN => GPC2_2 */ gpio_request_one(GPIO_LCD_EN, GPIOF_OUT_INIT_LOW, "LCD_EN"); /* LED_BACKLIGHT_RESET: XCI1RGB_5 => GPG0_5 */ gpio_request_one(GPIO_LED_BL_RST, GPIOF_OUT_INIT_LOW, "LED_BL_RST"); s5p_gpio_set_pd_cfg(GPIO_LED_BL_RST, S5P_GPIO_PD_PREV_STATE); s5p_gpio_set_pd_pull(GPIO_LED_BL_RST, S5P_GPIO_PD_UPDOWN_DISABLE); gpio_request_one(GPIO_LCD_PWM_IN_18V, GPIOF_OUT_INIT_LOW, "PWM_IN_18V"); s5p_gpio_set_pd_cfg(GPIO_LCD_PWM_IN_18V, S5P_GPIO_PD_INPUT); s5p_gpio_set_pd_pull(GPIO_LCD_PWM_IN_18V, S5P_GPIO_PD_UP_ENABLE); gpio_free(GPIO_LCD_PWM_IN_18V); gpio_request_one(GPIO_APS_EN_18V, GPIOF_OUT_INIT_LOW, "APS_EN_18V"); s5p_gpio_set_pd_cfg(GPIO_APS_EN_18V, S5P_GPIO_PD_INPUT); s5p_gpio_set_pd_pull(GPIO_APS_EN_18V, S5P_GPIO_PD_UP_ENABLE); gpio_export(GPIO_APS_EN_18V, true); samsung_bl_set(&manta_bl_gpio_info, &manta_bl_data); s5p_fimd1_set_platdata(&manta_lcd1_pdata); dev_set_name(&s5p_device_fimd1.dev, "exynos5-fb.1"); clk_add_alias("lcd", "exynos5-fb.1", "fimd", &s5p_device_fimd1.dev); s5p_dp_set_platdata(&manta_dp_data); gpio_request_one(GPIO_HDMI_HPD, GPIOF_IN, "HDMI_HPD"); /* HDMI Companion DC/DC converter and HPD circuitry */ gpio_request_one(GPIO_HDMI_DCDC_EN, GPIOF_OUT_INIT_HIGH, "HDMI_DCDC_EN"); /* HDMI Companion level shifters and LDO */ gpio_request_one(GPIO_HDMI_LS_EN, GPIOF_OUT_INIT_HIGH, "HDMI_LS_EN"); s5p_hdmi_set_platdata(&hdmi_platdata); dev_set_name(&s5p_device_hdmi.dev, "exynos5-hdmi"); clk_add_alias("hdmi", "s5p-hdmi", "hdmi", &s5p_device_hdmi.dev); platform_set_sysmmu(&SYSMMU_PLATDEV(tv).dev, &s5p_device_mixer.dev); s5p_i2c_hdmiphy_set_platdata(NULL); platform_add_devices(manta_display_devices, ARRAY_SIZE(manta_display_devices)); exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "sclk_vpll", 268 * MHZ); res = platform_get_resource(&s5p_device_fimd1, IORESOURCE_MEM, 1); if (res) { res->start = manta_bootloader_fb_start; res->end = res->start + manta_bootloader_fb_size - 1; pr_info("bootloader fb located at %8X-%8X\n", res->start, res->end); } else { pr_err("failed to find bootloader fb resource\n"); } }
static void __init ok6410_machine_init(void) { u32 cs1; s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_fb_set_platdata(&ok6410_lcd_pdata); s3c_hsotg_set_platdata(&ok6410_hsotg_pdata); samsung_keypad_set_platdata(&ok6410_keypad_data); s3c_nand_set_platdata(&ok6410_nand_info); s3c24xx_ts_set_platdata(NULL); /* configure nCS1 width to 16 bits */ cs1 = __raw_readl(S3C64XX_SROM_BW) & ~(S3C64XX_SROM_BW__CS_MASK << S3C64XX_SROM_BW__NCS1__SHIFT); cs1 |= ((1 << S3C64XX_SROM_BW__DATAWIDTH__SHIFT) | (1 << S3C64XX_SROM_BW__WAITENABLE__SHIFT) | (1 << S3C64XX_SROM_BW__BYTEENABLE__SHIFT)) << S3C64XX_SROM_BW__NCS1__SHIFT; __raw_writel(cs1, S3C64XX_SROM_BW); /* set timing for nCS1 suitable for ethernet chip */ __raw_writel((0 << S3C64XX_SROM_BCX__PMC__SHIFT) | (6 << S3C64XX_SROM_BCX__TACP__SHIFT) | (4 << S3C64XX_SROM_BCX__TCAH__SHIFT) | (1 << S3C64XX_SROM_BCX__TCOH__SHIFT) | (0xe << S3C64XX_SROM_BCX__TACC__SHIFT) | (4 << S3C64XX_SROM_BCX__TCOS__SHIFT) | (0 << S3C64XX_SROM_BCX__TACS__SHIFT), S3C64XX_SROM_BC1); gpio_request(S3C64XX_GPN(5), "LCD power"); gpio_request(S3C64XX_GPF(13), "LCD power"); i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); s3c_ide_set_platdata(&ok6410_ide_pdata); samsung_bl_set(&ok6410_bl_gpio_info, &ok6410_bl_data); platform_add_devices(ok6410_devices, ARRAY_SIZE(ok6410_devices)); /* enable USB phy clock */ s5p_usb_phy_init(&s3c_device_usb_hsotg, USB_PHY_TYPE_DEVICE); }
static void __init smdkc210_machine_init(void) { s3c_i2c1_set_platdata(NULL); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); smdkc210_smsc911x_init(); s3c_sdhci0_set_platdata(&smdkc210_hsmmc0_pdata); s3c_sdhci1_set_platdata(&smdkc210_hsmmc1_pdata); s3c_sdhci2_set_platdata(&smdkc210_hsmmc2_pdata); s3c_sdhci3_set_platdata(&smdkc210_hsmmc3_pdata); samsung_bl_set(&smdkc210_bl_gpio_info, &smdkc210_bl_data); s5p_fimd0_set_platdata(&smdkc210_lcd0_pdata); platform_add_devices(smdkc210_devices, ARRAY_SIZE(smdkc210_devices)); }
static void __init smdk6410_machine_init(void) { u32 cs1; s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_fb_set_platdata(&smdk6410_lcd_pdata); s3c_hsotg_set_platdata(&smdk6410_hsotg_pdata); samsung_keypad_set_platdata(&smdk6410_keypad_data); s3c24xx_ts_set_platdata(NULL); cs1 = __raw_readl(S3C64XX_SROM_BW) & ~(S3C64XX_SROM_BW__CS_MASK << S3C64XX_SROM_BW__NCS1__SHIFT); cs1 |= ((1 << S3C64XX_SROM_BW__DATAWIDTH__SHIFT) | (1 << S3C64XX_SROM_BW__WAITENABLE__SHIFT) | (1 << S3C64XX_SROM_BW__BYTEENABLE__SHIFT)) << S3C64XX_SROM_BW__NCS1__SHIFT; __raw_writel(cs1, S3C64XX_SROM_BW); __raw_writel((0 << S3C64XX_SROM_BCX__PMC__SHIFT) | (6 << S3C64XX_SROM_BCX__TACP__SHIFT) | (4 << S3C64XX_SROM_BCX__TCAH__SHIFT) | (1 << S3C64XX_SROM_BCX__TCOH__SHIFT) | (0xe << S3C64XX_SROM_BCX__TACC__SHIFT) | (4 << S3C64XX_SROM_BCX__TCOS__SHIFT) | (0 << S3C64XX_SROM_BCX__TACS__SHIFT), S3C64XX_SROM_BC1); gpio_request(S3C64XX_GPN(5), "LCD power"); gpio_request(S3C64XX_GPF(13), "LCD power"); i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); s3c_ide_set_platdata(&smdk6410_ide_pdata); samsung_bl_set(&smdk6410_bl_gpio_info, &smdk6410_bl_data); platform_add_devices(smdk6410_devices, ARRAY_SIZE(smdk6410_devices)); }
static void __init smdk6440_machine_init(void) { s3c24xx_ts_set_platdata(NULL); s3c_i2c0_set_platdata(&s5p6440_i2c0_data); s3c_i2c1_set_platdata(&s5p6440_i2c1_data); i2c_register_board_info(0, smdk6440_i2c_devs0, ARRAY_SIZE(smdk6440_i2c_devs0)); i2c_register_board_info(1, smdk6440_i2c_devs1, ARRAY_SIZE(smdk6440_i2c_devs1)); samsung_bl_set(&smdk6440_bl_gpio_info, &smdk6440_bl_data); s5p6440_set_lcd_interface(); s3c_fb_set_platdata(&smdk6440_lcd_pdata); platform_add_devices(smdk6440_devices, ARRAY_SIZE(smdk6440_devices)); }
void __init exynos4_smdk4x12_display_init(void) { samsung_bl_set(&smdk4x12_bl_gpio_info, &smdk4x12_bl_data); dev_set_name(&s5p_device_fimd0.dev, "s3cfb.0"); clk_add_alias("lcd", "exynos4-fb.0", "lcd", &s5p_device_fimd0.dev); clk_add_alias("sclk_fimd", "exynos4-fb.0", "sclk_fimd", \ &s5p_device_fimd0.dev); s5p_fb_setname(0, "exynos4-fb"); spi_register_board_info(spi_board_info, ARRAY_SIZE(spi_board_info)); s5p_fimd0_set_platdata(&smdk4x12_lcd0_pdata); platform_add_devices(smdk4x12_display_devices, \ ARRAY_SIZE(smdk4x12_display_devices)); exynos4_fimd_setup_clock(&s5p_device_fimd0.dev, "sclk_fimd", \ "mout_mpll_user", 800 * MHZ); }
static void __init tiny210_machine_init(void) { s3c_pm_init(); tiny210_dm9000_init(); s3c24xx_ts_set_platdata(NULL); s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); i2c_register_board_info(0, tiny210_i2c_devs0, ARRAY_SIZE(tiny210_i2c_devs0)); i2c_register_board_info(1, tiny210_i2c_devs1, ARRAY_SIZE(tiny210_i2c_devs1)); i2c_register_board_info(2, tiny210_i2c_devs2, ARRAY_SIZE(tiny210_i2c_devs2)); samsung_bl_set(&tiny210_bl_gpio_info, &tiny210_bl_data); platform_add_devices(tiny210_devices, ARRAY_SIZE(tiny210_devices)); }
static void __init smdkv210_machine_init(void) { s3c_pm_init(); /* masked by zjh */ //smdkv210_dm9000_init(); /* add by zjh */ s3c_nand_setname("s5pv210-nand"); s3c_nand_set_platdata(&smdk_nand_info); s5pv210_nand_gpio_cfg(); gpio_request(S5PV210_GPD0(1),"beeper"); s3c_gpio_cfgpin(S5PV210_GPD0(1), S3C_GPIO_SFN(2)); gpio_free(S5PV210_GPD0(1)); samsung_keypad_set_platdata(&smdkv210_keypad_data); s3c24xx_ts_set_platdata(NULL); s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); i2c_register_board_info(0, smdkv210_i2c_devs0, ARRAY_SIZE(smdkv210_i2c_devs0)); i2c_register_board_info(1, smdkv210_i2c_devs1, ARRAY_SIZE(smdkv210_i2c_devs1)); i2c_register_board_info(2, smdkv210_i2c_devs2, ARRAY_SIZE(smdkv210_i2c_devs2)); s3c_ide_set_platdata(&smdkv210_ide_pdata); s3c_fb_set_platdata(&smdkv210_lcd0_pdata); samsung_bl_set(&smdkv210_bl_gpio_info, &smdkv210_bl_data); s3c_hsotg_set_platdata(&smdkv210_hsotg_pdata); platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); }
static void __init smdkv210_machine_init(void) { s3c_pm_init(); /**************Add by Webee*******************/ #ifdef CONFIG_S5P_DEV_USB_EHCI s5p_ehci_set_platdata(&s5p_ehci_platdata); #endif #ifdef CONFIG_S5P_DEV_USB_OHCI s5p_ohci_set_platdata(&s5p_ohci_platdata); #endif /**************Add by Webee*******************/ //smdkv210_dm9000_init(); samsung_keypad_set_platdata(&smdkv210_keypad_data); s3c24xx_ts_set_platdata(NULL); s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); i2c_register_board_info(0, smdkv210_i2c_devs0, ARRAY_SIZE(smdkv210_i2c_devs0)); i2c_register_board_info(1, smdkv210_i2c_devs1, ARRAY_SIZE(smdkv210_i2c_devs1)); i2c_register_board_info(2, smdkv210_i2c_devs2, ARRAY_SIZE(smdkv210_i2c_devs2)); s3c_ide_set_platdata(&smdkv210_ide_pdata); s3c_fb_set_platdata(&smdkv210_lcd0_pdata); samsung_bl_set(&smdkv210_bl_gpio_info, &smdkv210_bl_data); s3c_hsotg_set_platdata(&smdkv210_hsotg_pdata); platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); }
static void __init smdk4x12_machine_init(void) { s3c_i2c0_set_platdata(NULL); i2c_register_board_info(0, smdk4x12_i2c_devs0, ARRAY_SIZE(smdk4x12_i2c_devs0)); s3c_i2c1_set_platdata(NULL); i2c_register_board_info(1, smdk4x12_i2c_devs1, ARRAY_SIZE(smdk4x12_i2c_devs1)); s3c_i2c3_set_platdata(NULL); i2c_register_board_info(3, smdk4x12_i2c_devs3, ARRAY_SIZE(smdk4x12_i2c_devs3)); s3c_i2c7_set_platdata(NULL); i2c_register_board_info(7, smdk4x12_i2c_devs7, ARRAY_SIZE(smdk4x12_i2c_devs7)); samsung_bl_set(&smdk4x12_bl_gpio_info, &smdk4x12_bl_data); pwm_add_table(smdk4x12_pwm_lookup, ARRAY_SIZE(smdk4x12_pwm_lookup)); samsung_keypad_set_platdata(&smdk4x12_keypad_data); s3c_sdhci2_set_platdata(&smdk4x12_hsmmc2_pdata); s3c_sdhci3_set_platdata(&smdk4x12_hsmmc3_pdata); s3c_hsotg_set_platdata(&smdk4x12_hsotg_pdata); #ifdef CONFIG_DRM_EXYNOS_FIMD s5p_device_fimd0.dev.platform_data = &drm_fimd_pdata; exynos4_fimd0_gpio_setup_24bpp(); #else s5p_fimd0_set_platdata(&smdk4x12_lcd_pdata); #endif platform_add_devices(smdk4x12_devices, ARRAY_SIZE(smdk4x12_devices)); }
void __init exynos5_smdk5410_display_init(void) { #ifdef CONFIG_FB_MIPI_DSIM #ifdef CONFIG_S5P_DEV_MIPI_DSIM0 s5p_dsim0_set_platdata(&dsim_platform_data); #else s5p_dsim1_set_platdata(&dsim_platform_data); #endif #endif #ifdef CONFIG_S5P_DP s5p_dp_set_platdata(&smdk5410_dp_data); #endif #ifdef CONFIG_S5P_DEV_FIMD0 s5p_fimd0_set_platdata(&smdk5410_lcd0_pdata); #else s5p_fimd1_set_platdata(&smdk5410_lcd1_pdata); #endif samsung_bl_set(&smdk5410_bl_gpio_info, &smdk5410_bl_data); platform_add_devices(smdk5410_display_devices, ARRAY_SIZE(smdk5410_display_devices)); #ifdef CONFIG_S5P_DP exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 267 * MHZ); #endif #ifdef CONFIG_FB_MIPI_DSIM #if defined(CONFIG_S5P_DEV_FIMD0) exynos5_fimd0_setup_clock(&s5p_device_fimd0.dev, "sclk_fimd", "mout_mpll_bpll", 800 * MHZ); #else /* 64MHz = 320MHz@CPLL / 6 */ exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_cpll", 64 * MHZ); #endif #endif }
void __init exynos5_smdk5420_display_init(void) { #ifdef CONFIG_FB_MIPI_DSIM s5p_dsim1_set_platdata(&dsim_platform_data); #endif #ifdef CONFIG_S5P_DP s5p_dp_set_platdata(&smdk5420_dp_data); #endif s5p_fimd1_set_platdata(&smdk5420_lcd1_pdata); #ifdef CONFIG_BACKLIGHT_PWM samsung_bl_set(&smdk5420_bl_gpio_info, &smdk5420_bl_data); #endif platform_add_devices(smdk5420_display_devices, ARRAY_SIZE(smdk5420_display_devices)); #ifdef CONFIG_S5P_DP exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_rpll", 266 * MHZ); #endif #ifdef CONFIG_FB_MIPI_DSIM /* RPLL rate is 300Mhz, 300/5=60Hz */ exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_fimd1", 67 * MHZ); #endif }
void __init exynos5_xyref5260_display_init(void) { #ifdef CONFIG_S5P_DP int irq; #endif clk_add_alias("sclk_fimd", "exynos5-fb.1", "sclk_fimd1_128_extclkpl", &s5p_device_fimd1.dev); #ifdef CONFIG_FB_MIPI_DSIM s5p_dsim1_set_platdata(&dsim_platform_data); #endif #ifdef CONFIG_S5P_DP s5p_dp_set_platdata(&xyref5260_dp_data); #endif s5p_fimd1_set_platdata(&smdk5260_lcd1_pdata); #ifdef CONFIG_BACKLIGHT_PWM samsung_bl_set(&smdk5260_bl_gpio_info, &smdk5260_bl_data); #endif platform_add_devices(smdk5260_display_devices, ARRAY_SIZE(smdk5260_display_devices)); #ifdef CONFIG_S5P_DP irq = s5p_register_gpio_interrupt(EXYNOS5260_GPK0(0)); if (IS_ERR_VALUE(irq)) { pr_err("%s: Failed to configure GPK0(0) GPIO\n", __func__); return; } exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "sclk_disp_pixel", 267 * MHZ); #endif #ifdef CONFIG_FB_MIPI_DSIM /* RPLL rate is 300Mhz, 300/5=60Hz */ exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "sclk_disp_pixel", 266 * MHZ); #endif }
static void __init origen_machine_init(void) { origen_power_init(); s3c_i2c0_set_platdata(NULL); i2c_register_board_info(0, i2c0_devs, ARRAY_SIZE(i2c0_devs)); /* * Since sdhci instance 2 can contain a bootable media, * sdhci instance 0 is registered after instance 2. */ s3c_sdhci2_set_platdata(&origen_hsmmc2_pdata); s3c_sdhci0_set_platdata(&origen_hsmmc0_pdata); origen_ehci_init(); origen_ohci_init(); s3c_hsotg_set_platdata(&origen_hsotg_pdata); s5p_tv_setup(); s5p_i2c_hdmiphy_set_platdata(NULL); s5p_hdmi_set_platdata(&hdmiphy_info, NULL, 0); #ifdef CONFIG_DRM_EXYNOS_FIMD s5p_device_fimd0.dev.platform_data = &drm_fimd_pdata; exynos4_fimd0_gpio_setup_24bpp(); #else s5p_fimd0_set_platdata(&origen_lcd_pdata); #endif platform_add_devices(origen_devices, ARRAY_SIZE(origen_devices)); pwm_add_table(origen_pwm_lookup, ARRAY_SIZE(origen_pwm_lookup)); samsung_bl_set(&origen_bl_gpio_info, &origen_bl_data); origen_bt_setup(); }
static void __init smdk4210_machine_init(void) { c1_config_gpio_table(); c1_config_sleep_gpio_table(); s3c_pm_init(); s3c_gpio_cfgpin(GPIO_WLAN_EN, S3C_GPIO_OUTPUT); s3c_gpio_setpull(GPIO_WLAN_EN, S3C_GPIO_PULL_NONE); exynos4_pd_enable(&exynos4_device_pd[PD_MFC].dev); exynos4_pd_enable(&exynos4_device_pd[PD_G3D].dev); exynos4_pd_enable(&exynos4_device_pd[PD_LCD0].dev); exynos4_pd_enable(&exynos4_device_pd[PD_LCD1].dev); exynos4_pd_enable(&exynos4_device_pd[PD_CAM].dev); exynos4_pd_enable(&exynos4_device_pd[PD_TV].dev); /* SROMC Setup */ /* TODO: Move me to a separate function */ /*u32 tmp; tmp = __raw_readl(S5P_SROM_BW); tmp &= ~(0xffff); tmp |= (0x9999); __raw_writel(tmp, S5P_SROM_BW); __raw_writel(0xff1ffff1, S5P_SROM_BC1); tmp = __raw_readl(S5P_VA_GPIO + 0x120); tmp &= ~(0xffffff); tmp |= (0x221121); __raw_writel(tmp, (S5P_VA_GPIO + 0x120)); __raw_writel(0x22222222, (S5P_VA_GPIO + 0x180)); __raw_writel(0x22222222, (S5P_VA_GPIO + 0x1a0)); __raw_writel(0x22222222, (S5P_VA_GPIO + 0x1c0)); __raw_writel(0x22222222, (S5P_VA_GPIO + 0x1e0)); */ /* MMC Card init */ s3c_gpio_cfgpin(GPIO_MASSMEM_EN, S3C_GPIO_OUTPUT); gpio_set_value(GPIO_MASSMEM_EN, GPIO_MASSMEM_EN_LEVEL); /* 400 kHz for initialization of MMC Card */ __raw_writel((__raw_readl(S5P_CLKDIV_FSYS3) & 0xfffffff0) | 0x9, S5P_CLKDIV_FSYS3); __raw_writel((__raw_readl(S5P_CLKDIV_FSYS2) & 0xfff0fff0) | 0x80008, S5P_CLKDIV_FSYS2); __raw_writel((__raw_readl(S5P_CLKDIV_FSYS1) & 0xfff0fff0) | 0x90009, S5P_CLKDIV_FSYS1); /* PLATDATA init */ s3c_i2c0_set_platdata(NULL); /*i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0))*/ s3c_i2c1_set_platdata(NULL); /*i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1));*/ smdk4210_init_tsp(); s3c_i2c3_set_platdata(&i2c3_data); i2c_register_board_info(3, i2c_devs3, ARRAY_SIZE(i2c_devs3)); /* TSP */ smdk4210_init_pmic(); s3c_i2c5_set_platdata(NULL); i2c_register_board_info(5, i2c_devs5, ARRAY_SIZE(i2c_devs5)); s3c_i2c6_set_platdata(NULL); //i2c_register_board_info(6, i2c_devs6, ARRAY_SIZE(i2c_devs6)); /*s3c_i2c7_set_platdata(NULL); TVOUT i2c_register_board_info(7, i2c_devs7, ARRAY_SIZE(i2c_devs7));*/ smdk4210_init_touchkey(); i2c_register_board_info(9, i2c_gpio_gauge_devs, ARRAY_SIZE(i2c_gpio_gauge_devs)); s3cfb_set_platdata(NULL); s3c_device_fb.dev.parent = &exynos4_device_pd[PD_LCD0].dev; s3c_sdhci2_set_platdata(&smdk4210_hsmmc2_pdata); s3c_sdhci0_set_platdata(&smdk4210_hsmmc0_pdata); s3c_sdhci3_set_platdata(&smdk4210_hsmmc3_pdata); s3c_mshci_set_platdata(&smdk4210_mshc_pdata); s5p_fimg2d_set_platdata(&fimg2d_data); s5p_device_fimg2d.dev.parent = &exynos4_device_pd[PD_LCD0].dev; /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); #if 0 /* TVOUT - Will nebkat hax? */ s5p_hdmi_hpd_set_platdata(&hdmi_hpd_data); s5p_hdmi_cec_set_platdata(&hdmi_cec_data); s5p_device_tvout.dev.parent = &exynos4_device_pd[PD_TV].dev; #endif smdk4210_otg_init(); smdk4210_ohci_init(); clk_xusbxti.rate = 24000000; smdk4210_init_battery_gauge(); smdk4210_ehci_init(); platform_add_devices(smdk4210_devices, ARRAY_SIZE(smdk4210_devices)); samsung_bl_set(&smdk4210_bl_gpio_info, &smdk4210_bl_data); /*smdk4210_bt_setup();*/ }
void __init exynos5_universal5420_display_init(void) { struct resource *res; struct clk *mout_mdnie1; struct clk *mout_mpll; #ifdef CONFIG_FB_MIPI_DSIM s5p_dsim1_set_platdata(&dsim_platform_data); #endif #ifdef CONFIG_S5P_DP s5p_dp_set_platdata(&universal5420_dp_data); #endif s5p_fimd1_set_platdata(&universal5420_lcd1_pdata); #ifdef CONFIG_BACKLIGHT_PWM samsung_bl_set(&universal5420_bl_gpio_info, &smdk5420_bl_data); #endif platform_add_devices(universal5420_display_devices, ARRAY_SIZE(universal5420_display_devices)); #ifdef CONFIG_S5P_DP exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mpll_bpll", 267 * MHZ); #endif mout_mdnie1 = clk_get(NULL, "mout_mdnie1"); if ((IS_ERR(mout_mdnie1))) pr_err("Can't get clock[%s]\n", "mout_mdnie1"); mout_mpll = clk_get(NULL, "mout_mpll"); if ((IS_ERR(mout_mpll))) pr_err("Can't get clock[%s]\n", "mout_mpll"); if (mout_mdnie1 && mout_mpll) clk_set_parent(mout_mdnie1, mout_mpll); if (mout_mdnie1) clk_put(mout_mdnie1); if (mout_mpll) clk_put(mout_mpll); #ifdef CONFIG_FB_MIPI_DSIM #if defined(CONFIG_LCD_MIPI_S6E8FA0) || defined(CONFIG_LCD_MIPI_S6E3FA0) #if defined(CONFIG_FB_I80IF) && !defined(CONFIG_FB_S5P_MDNIE) exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mdnie1", 266 * MHZ); #else exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_mdnie1", 133 * MHZ); #endif #else /* RPLL rate is 300Mhz, 300/5=60Hz */ exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_fimd", "mout_rpll", 67 * MHZ); #endif #endif #ifdef CONFIG_FB_S5P_MDNIE keep_lcd_clk(&s5p_device_fimd1.dev); #if defined(CONFIG_LCD_MIPI_S6E8FA0) || defined(CONFIG_LCD_MIPI_S6E3FA0) #ifdef CONFIG_FB_I80IF exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_mdnie", "mout_mdnie1", 266 * MHZ); #else exynos5_fimd1_setup_clock(&s5p_device_fimd1.dev, "sclk_mdnie", "mout_mdnie1", 133 * MHZ); #endif #endif mdnie_device_register(); #endif res = platform_get_resource(&s5p_device_fimd1, IORESOURCE_MEM, 1); if (res) { res->start = bootloaderfb_start; res->end = res->start + bootloaderfb_size - 1; pr_info("bootloader fb located at %8X-%8X\n", res->start, res->end); } else { pr_err("failed to find bootloader fb resource\n"); } }