static void __init smdk6410_machine_init(void) { unsigned int tmp; s3c_device_nand.dev.platform_data = &s3c_nand_mtd_part_info; s3c_device_onenand.dev.platform_data = &s3c_onenand_data; s3c_i2c0_set_platdata(NULL); #if defined(CONFIG_TOUCHSCREEN_S3C) s3c_ts_set_platdata(&s3c_ts_platform); #endif s3c_adc_set_platdata(&s3c_adc_platform); i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); spi_register_board_info(sam_spi_devs, ARRAY_SIZE(sam_spi_devs)); s3c_fimc0_set_platdata(NULL); s3c_fimc1_set_platdata(NULL); #ifdef CONFIG_VIDEO_FIMC //s3c_fimc_reset_camera(); #endif platform_add_devices(smdk6410_devices, ARRAY_SIZE(smdk6410_devices)); s3c6410_pm_init(); smdk_backlight_register(); }
static int __init mx_init_camera(void) { #ifdef CONFIG_VIDEO_M6MO if (machine_is_m030()) i2c_devs7[0].irq = M030_GPIO_CAMERA0_EINT; #endif s3c_i2c7_set_platdata(NULL); i2c_register_board_info(7, i2c_devs7, ARRAY_SIZE(i2c_devs7)); #ifdef CONFIG_VIDEO_FIMC s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(NULL); s3c_fimc2_set_platdata(NULL); s3c_fimc3_set_platdata(NULL); #ifndef CONFIG_PM_GENERIC_DOMAINS s3c_device_fimc0.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc1.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc2.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc3.dev.parent = &exynos4_device_pd[PD_CAM].dev; #endif #endif #ifdef CONFIG_VIDEO_FIMC_MIPI s3c_csis0_set_platdata(NULL); #ifndef CONFIG_PM_GENERIC_DOMAINS s3c_device_csis0.dev.parent = &exynos4_device_pd[PD_CAM].dev; #endif #endif return 0; }
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); //jkeqiang s3c_nand_set_platdata(&ok6410_nand_info); s3c_sdhci0_set_platdata(&ok6410_hsmmc0_pdata); s3c_sdhci1_set_platdata(&ok6410_hsmmc1_pdata); samsung_keypad_set_platdata(&smdk6410_keypad_data); // s3c24xx_ts_set_platdata(&s3c_ts_platform); s3c_ts_set_platdata(&s3c_ts_platform); s3c64xx_ac97_setup_gpio(0); /* 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"); //gpio_request(S3C64XX_GPF(15), "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); #ifdef CONFIG_S3C64XX_DEV_FIMC0 s3c_fimc0_set_platdata(NULL); #endif #ifdef CONFIG_S3C64XX_DEV_FIMC1 s3c_fimc1_set_platdata(NULL); #endif platform_add_devices(smdk6410_devices, ARRAY_SIZE(smdk6410_devices)); }
static void __init smdk6410_machine_init(void) { s3c_device_nand.dev.platform_data = &s3c_nand_mtd_part_info; s3c_device_onenand.dev.platform_data = &s3c_onenand_data; writel(readl(S3C_HCLK_GATE)|S3C_CLKCON_HCLK_SCALER,S3C_HCLK_GATE); smdk6410_smc911x_set(); s3c_i2c0_set_platdata(NULL); // s3c_i2c1_set_platdata(NULL); #if defined(CONFIG_TOUCHSCREEN_S3C) | defined(CONFIG_TOUCHSCREEN_S3C_ANDROID) s3c_ts_set_platdata(&s3c_ts_platform); s3c_adc_set_platdata(&s3c_adc_platform); #endif i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); #if defined(CONFIG_SPI_CNTRLR_0) s3cspi_set_slaves(BUSNUM(0), ARRAY_SIZE(s3c_slv_pdata_0), s3c_slv_pdata_0); #endif #if defined(CONFIG_SPI_CNTRLR_1) s3cspi_set_slaves(BUSNUM(1), ARRAY_SIZE(s3c_slv_pdata_1), s3c_slv_pdata_1); #endif spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); s3c_fimc0_set_platdata(NULL); s3c_fimc1_set_platdata(NULL); /* fb */ #ifdef CONFIG_FB_S3C_V2 s3cfb_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_FIMC // s3c_fimc_reset_camera(); #endif platform_add_devices(smdk6410_devices, ARRAY_SIZE(smdk6410_devices)); s3c6410_pm_init(); smdk_backlight_register(); smdk6410_set_qos(); real6410_set_gpio(); }
static void __init smdk6442_machine_init(void) { // s3c_device_nand.dev.platform_data = &s3c_nand_mtd_part_info; smdk6442_smc911x_set(); #ifdef CONFIG_FB_S3C_AMS320 spi_register_board_info(spi_board_info, ARRAY_SIZE(spi_board_info)); #endif s3cfb_set_platdata(NULL); s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_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)); i2c_register_board_info(2, i2c_devs2, ARRAY_SIZE(i2c_devs2)); s3c_ts_set_platdata(&s3c_ts_platform); s3c_adc_set_platdata(&s3c_adc_platform); /* fb */ // s3cfb_set_platdata(&fb_data); platform_add_devices(smdk6442_devices, ARRAY_SIZE(smdk6442_devices)); s5p6442_pm_init(); smdk_backlight_register(); #if defined(CONFIG_MMC_SDHCI_S3C) s3c_sdhci_set_platdata(); #endif s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); smdk6442_cam0_power(1); smdk6442_cam1_power(1); }
static void __init universal_machine_init(void) { int err; tl2796_gpio_setup(); universal_i2c_gpio_init(); 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)); i2c_register_board_info(I2C_GPIO_26V_BUS, i2c_gpio_26v_devs, ARRAY_SIZE(i2c_gpio_26v_devs)); i2c_register_board_info(I2C_GPIO_HDMI_BUS, i2c_gpio_hdmi_devs, ARRAY_SIZE(i2c_gpio_hdmi_devs)); i2c_register_board_info(I2C_GPIO_28V_BUS, i2c_gpio_28v_devs, ARRAY_SIZE(i2c_gpio_28v_devs)); spi_register_board_info(spi_board_info, ARRAY_SIZE(spi_board_info)); s3cfb_set_platdata(&fb_data); err = camera_pin_request(); if (err) printk(KERN_INFO "CAMERA PIN REQUEST FAILED\n"); /* Registering external camera to platform data */ /*fimc_setting.camera[0] = &camera_a;*/ fimc_setting.camera[0] = &camera_c; s3c_fimc0_set_platdata(&fimc_setting); s3c_fimc1_set_platdata(&fimc_setting); s3c_fimc2_set_platdata(&fimc_setting); /* testing MIPI */ /* CSI-2 */ s3c_csis_set_platdata(NULL); s3c_fimc_reset_camera(); platform_add_devices(universal_devices, ARRAY_SIZE(universal_devices)); }
static void __init smdkc100_machine_init(void) { s3c_device_nand.dev.platform_data = &s3c_nand_mtd_part_info; s3c_device_onenand.dev.platform_data = &s3c_onenand_data; smdkc100_smc911x_set(); s3c_ts_set_platdata(&s3c_ts_platform); s3c_adc_set_platdata(&s3c_adc_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)); /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); s3c_csis_set_platdata(NULL); smdkc100_reset_camera(); /* fb */ #ifdef CONFIG_FB_S3C s3cfb_set_platdata(&fb_data); #endif platform_add_devices(smdkc100_devices, ARRAY_SIZE(smdkc100_devices)); #if defined(CONFIG_PM) s5pc1xx_pm_init(); #endif smdk_backlight_register(); }
static void __init smdkv210_machine_init(void) { /* Find out S5PC110 chip version */ _hw_version_check(); #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif /* i2c */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); i2c_register_board_info(2, i2c_devs2, ARRAY_SIZE(i2c_devs2)); #if defined(CONFIG_HKDKC110_BOARD) && defined(CONFIG_INPUT_YAMAHA_SENSORS) && !defined(CONFIG_INPUT_BMA150_SENSOR) // i2c-gpio sda/scl set pull-up yas529,bma150,ish1000 gpio_request(GPIO_SENSORS_SDA, "GPB2"); s3c_gpio_setpull(GPIO_SENSORS_SDA, S3C_GPIO_PULL_UP); gpio_direction_input(GPIO_SENSORS_SDA); gpio_free(GPIO_SENSORS_SDA); gpio_request(GPIO_SENSORS_SCL, "GPB2"); s3c_gpio_setpull(GPIO_SENSORS_SCL, S3C_GPIO_PULL_UP); gpio_direction_input(GPIO_SENSORS_SCL); gpio_free(GPIO_SENSORS_SCL); // BMA150 CS PIN --> HIGH gpio_request(S5PV210_GPB(1), "GPB2"); s3c_gpio_setpull(S5PV210_GPB(1), S3C_GPIO_PULL_NONE); gpio_direction_output(S5PV210_GPB(1), 1); gpio_free(S5PV210_GPB(1)); i2c_register_board_info(4, i2c_devs4, ARRAY_SIZE(i2c_devs4)); #endif /* to support system shut down */ pm_power_off = smdkv210_power_off; #ifdef CONFIG_FB_S3C_LP101WH1 s3cfb_set_platdata(&lp101wh1_data); #endif #ifdef CONFIG_FB_S3C_LMS350DF s3cfb_set_platdata(&lms350df_data); #endif #if defined(CONFIG_PM) s3c_pm_init(); #endif #ifdef CONFIG_VIDEO_FIMC /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); #endif /* 5V */ hkdkc110_5V_power(1); #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_TV20 s3c_set_qos(); #endif #ifdef CONFIG_S3C_DEV_HSMMC s5pv210_default_sdhci0(); #endif #ifdef CONFIG_S3C_DEV_HSMMC1 s5pv210_default_sdhci1(); #endif #ifdef CONFIG_S3C_DEV_HSMMC2 s5pv210_default_sdhci2(); #endif #ifdef CONFIG_S5PV210_SETUP_SDHCI s3c_sdhci_set_platdata(); #endif platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); #if defined(CONFIG_HAVE_PWM) smdk_backlight_register(); #endif }
static void __init smdkc100_machine_init(void) { /* spi */ #ifdef CONFIG_SPI_S3C64XX u32 val; val = __raw_readl(S5PC1XX_GPBCON); val &= ~(0xf<<12); val |= (0x1<<12); __raw_writel(val, S5PC1XX_GPBCON); val = __raw_readl(S5PC1XX_GPBPUD); val &= ~(0x3<<6); val |= (0x2<<6); __raw_writel(val, S5PC1XX_GPBPUD); s3c64xx_spi_set_info(BUSNUM(0), S5PC1XX_SPI_SRCCLK_PCLK, ARRAY_SIZE(smdk_spi0_csi)); spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); #endif s3c_device_nand.dev.platform_data = &s3c_nand_mtd_part_info; s3c_device_onenand.dev.platform_data = &s3c_onenand_data; //smdkc100_smc911x_set(); s3c_ts_set_platdata(&s3c_ts_platform); s3c_adc_set_platdata(&s3c_adc_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)); /* pb206x i2c */ pb206x_i2c_add_bus(0, 100); pb206x_i2c_add_bus(1, 100); pb206x_i2c_add_bus(2, 100); pb206x_i2c_add_bus(3, 100); pb206x_i2c_add_bus(4, 100); //pb206x_i2c_add_bus(5, 100); /* i2c client */ pp876ax_i2c_client_init(); /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); s3c_csis_set_platdata(NULL); /* fb */ #ifdef CONFIG_FB_S3C s3cfb_set_platdata(NULL); #endif platform_add_devices(smdkc100_devices, ARRAY_SIZE(smdkc100_devices)); #if defined(CONFIG_PM) s5pc1xx_pm_init(); #endif smdk_backlight_register(); #if defined(CONFIG_MMC_SDHCI_S3C) s3c_sdhci_set_platdata(); #endif smdkc100_reset_camera(); }
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_nand_set_platdata(&ok6410_nand_info); // gjl s3c_sdhci0_set_platdata(&ok6410_hsmmc0_pdata); s3c_sdhci1_set_platdata(&ok6410_hsmmc1_pdata); samsung_keypad_set_platdata(&smdk6410_keypad_data); // s3c24xx_ts_set_platdata(&s3c_ts_platform); s3c_ts_set_platdata(&s3c_ts_platform); s3c64xx_ac97_setup_gpio(0); /* 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(&smdk6410_ide_pdata); #ifdef CONFIG_S3C64XX_DEV_FIMC0 s3c_fimc0_set_platdata(NULL); #endif #ifdef CONFIG_S3C64XX_DEV_FIMC1 s3c_fimc1_set_platdata(NULL); #endif s3c64xx_spi_set_info(0,0,3); s3c64xx_spi_set_info(1,0,2); //printk(KERN_INFO "SPI: Only Register Bus number 1, spidev for test\n"); spi_register_board_info(forlinx6410_mc251x_info,ARRAY_SIZE(forlinx6410_mc251x_info)); spi_register_board_info(spi_eeprom,ARRAY_SIZE(spi_eeprom)); samsung_keypad_set_platdata(&smdk6410_keypad_data); platform_add_devices(smdk6410_devices, ARRAY_SIZE(smdk6410_devices)); printk(KERN_INFO "Adding SPI infomation, Check SPI register v10\n"); printk(KERN_INFO "SPI: FPGA initialize....\n"); setup_spi_fpga(); }
static void __init mini6410_machine_init(void) { u32 cs1; s3c_i2c0_set_platdata(NULL); #ifdef CONFIG_S3C_DEV_I2C1 s3c_i2c1_set_platdata(NULL); #endif s3c_fb_set_platdata(&mini6410_lcd_pdata); #ifdef CONFIG_SAMSUNG_DEV_TS s3c24xx_ts_set_platdata(&s3c_ts_platform); #endif #ifdef CONFIG_TOUCHSCREEN_MINI6410 s3c_ts_set_platdata(&s3c_ts_platform); #endif s3c_sdhci0_set_platdata(&mini6410_hsmmc0_pdata); s3c_sdhci1_set_platdata(&mini6410_hsmmc1_pdata); #ifdef CONFIG_MTD_NAND_S3C s3c_device_nand.name = "s3c6410-nand"; #endif s3c_nand_set_platdata(&mini6410_nand_info); s3c64xx_ac97_setup_gpio(0); /* 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"); gpio_request(S3C64XX_GPF(15), "LCD power"); if (ARRAY_SIZE(i2c_devs0)) { i2c_register_board_info(0, i2c_devs0, ARRAY_SIZE(i2c_devs0)); } if (ARRAY_SIZE(i2c_devs1)) { i2c_register_board_info(1, i2c_devs1, ARRAY_SIZE(i2c_devs1)); } #ifdef CONFIG_S3C64XX_DEV_FIMC0 s3c_fimc0_set_platdata(NULL); #endif #ifdef CONFIG_S3C64XX_DEV_FIMC1 s3c_fimc1_set_platdata(NULL); #endif platform_add_devices(mini6410_devices, ARRAY_SIZE(mini6410_devices)); platform_device_register_simple("GPIODEV", 0, &gpiodev_resource, 1); //GPIO resource MAP if ((platform_device_register(&mini6410_leds))!=0) printk( "Failed to register LEDs.\n"); else printk( "LEDs initialized.\n"); #ifdef CONFIG_VIDEO_SAMSUNG create_proc_read_entry("videomem", 0, NULL, s3c_media_read_proc, NULL); #endif }
void __init midas_camera_init(void) { #ifdef CONFIG_VIDEO_FIMC s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(NULL); s3c_fimc3_set_platdata(NULL); #ifdef CONFIG_EXYNOS_DEV_PD s3c_device_fimc0.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc1.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc2.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_fimc3.dev.parent = &exynos4_device_pd[PD_CAM].dev; #endif #ifdef CONFIG_VIDEO_FIMC_MIPI s3c_csis0_set_platdata(NULL); s3c_csis1_set_platdata(NULL); #ifdef CONFIG_EXYNOS_DEV_PD s3c_device_csis0.dev.parent = &exynos4_device_pd[PD_CAM].dev; s3c_device_csis1.dev.parent = &exynos4_device_pd[PD_CAM].dev; #endif #endif #endif /* CONFIG_VIDEO_FIMC */ camera_class = class_create(THIS_MODULE, "camera"); if (!s5k4ecgx_dev) { s5k4ecgx_dev = device_create(camera_class, NULL, 0, NULL, "rear"); if (IS_ERR(s5k4ecgx_dev)) { pr_err("s5k4ecgx_dev : failed to create device!\n"); } else { if (device_create_file(s5k4ecgx_dev, &dev_attr_rear_flash) < 0) { pr_err("failed to create device file, %s\n", dev_attr_rear_flash.attr.name); } if (device_create_file(s5k4ecgx_dev, &dev_attr_rear_camtype) < 0) { pr_err("failed to create device file, %s\n", dev_attr_rear_camtype.attr.name); } if (device_create_file(s5k4ecgx_dev, &dev_attr_rear_camfw) < 0) { pr_err("failed to create device file, %s\n", dev_attr_rear_camfw.attr.name); } } } if (!db8131m_dev) { db8131m_dev = device_create(camera_class, NULL, 0, NULL, "front"); if (IS_ERR(db8131m_dev)) { pr_err("db8131m_dev : failed to create device!\n"); } else { if (device_create_file(db8131m_dev, &dev_attr_front_camtype) < 0) { pr_err("failed to create device file, %s\n", dev_attr_front_camtype.attr.name); } if (device_create_file(db8131m_dev, &dev_attr_front_camfw) < 0) { pr_err("failed to create device file, %s\n", dev_attr_front_camfw.attr.name); } } } }
static void __init smdkc110_machine_init(void) { /* i2c */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_set_platdata(NULL); s3c_i2c3_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)); /* spi */ #if defined(CONFIG_SPI_CNTRLR_0) s3cspi_set_slaves(BUSNUM(0), ARRAY_SIZE(s3c_slv_pdata_0), s3c_slv_pdata_0); #endif #if defined(CONFIG_SPI_CNTRLR_1) s3cspi_set_slaves(BUSNUM(1), ARRAY_SIZE(s3c_slv_pdata_1), s3c_slv_pdata_1); #endif #if defined(CONFIG_SPI_CNTRLR_2) s3cspi_set_slaves(BUSNUM(2), ARRAY_SIZE(s3c_slv_pdata_2), s3c_slv_pdata_2); #endif spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); universal_wm8994_init(); universal_sdhci2_set_platdata(); #ifdef CONFIG_FB_S3C_LVDS s3cfb_set_platdata(&lvds_data); #endif /* pmem */ #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); s3c_csis_set_platdata(NULL); smdkc110_cam0_power(1); smdkc110_cam1_power(1); smdkc110_mipi_cam_power(1); /* ipc */ s3c_ipc_set_platdata(NULL); platform_add_devices(smdkc110_devices, ARRAY_SIZE(smdkc110_devices)); #if defined(CONFIG_PM) s5pc11x_pm_init(); #endif #if defined(CONFIG_HAVE_PWM) smdk_backlight_register(); #endif s3c_gpio_cfgpin( AP_I2C_SCL_28V, 1 ); s3c_gpio_setpull( AP_I2C_SCL_28V, S3C_GPIO_PULL_UP); s3c_gpio_cfgpin( AP_I2C_SDA_28V, 1 ); s3c_gpio_setpull( AP_I2C_SDA_28V, S3C_GPIO_PULL_UP); sec_class = class_create(THIS_MODULE, "sec"); }
static void __init smdkv210_machine_init(void) { /* Find out S5PC110 chip version */ _hw_version_check(); /* OneNAND */ #ifdef CONFIG_MTD_ONENAND //s3c_device_onenand.dev.platform_data = &s5p_onenand_data; #endif #ifdef CONFIG_MTD_NAND //s3c_device_nand.dev.platform_data = &s5p_nand_data; #endif #ifdef CONFIG_DM9000 smdkv210_dm9000_set(); #endif #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif /* i2c */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_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)); i2c_register_board_info(2, i2c_devs2, ARRAY_SIZE(i2c_devs2)); /* to support system shut down */ pm_power_off = smdkv210_power_off; #if defined(CONFIG_SPI_CNTRLR_0) s3cspi_set_slaves(BUSNUM(0), ARRAY_SIZE(s3c_slv_pdata_0), s3c_slv_pdata_0); #endif #if defined(CONFIG_SPI_CNTRLR_1) s3cspi_set_slaves(BUSNUM(1), ARRAY_SIZE(s3c_slv_pdata_1), s3c_slv_pdata_1); #endif #if defined(CONFIG_SPI_CNTRLR_2) s3cspi_set_slaves(BUSNUM(2), ARRAY_SIZE(s3c_slv_pdata_2), s3c_slv_pdata_2); #endif spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); #ifdef CONFIG_FB_S3C_LTE480WV s3cfb_set_platdata(<e480wv_fb_data); #endif #if defined(CONFIG_BLK_DEV_IDE_S3C) s3c_ide_set_platdata(&smdkv210_ide_pdata); #endif #if defined(CONFIG_TOUCHSCREEN_S3C) s3c_ts_set_platdata(&s3c_ts_platform); #endif #if defined(CONFIG_S5PV210_ADC) s3c_adc_set_platdata(&s3c_adc_platform); #endif #if defined(CONFIG_PM) s3c_pm_init(); #endif #ifdef CONFIG_VIDEO_FIMC /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); s3c_csis_set_platdata(NULL); smdkv210_cam0_power(1); smdkv210_cam1_power(1); smdkv210_mipi_cam_reset(); #endif #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_TV20 s3c_set_qos(); #endif #ifdef CONFIG_S3C_DEV_HSMMC s5pv210_default_sdhci0(); #endif #ifdef CONFIG_S3C_DEV_HSMMC1 s5pv210_default_sdhci1(); #endif #ifdef CONFIG_S3C_DEV_HSMMC2 s5pv210_default_sdhci2(); #endif #ifdef CONFIG_S3C_DEV_HSMMC3 s5pv210_default_sdhci3(); #endif #ifdef CONFIG_S5PV210_SETUP_SDHCI s3c_sdhci_set_platdata(); #endif platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); #if defined(CONFIG_HAVE_PWM) smdk_backlight_register(); #endif }
static void __init mango210_machine_init(void) { /* Find out S5PC110 chip version */ _hw_version_check(); #ifdef CONFIG_MTD_NAND // s3c_device_nand.dev.platform_data = &s5p_nand_data; #endif #ifdef CONFIG_SMSC911X mango210_smsc911x_set(); #endif #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif /* i2c */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_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)); i2c_register_board_info(2, i2c_devs2, ARRAY_SIZE(i2c_devs2)); /* to support system shut down */ pm_power_off = mango210_power_off; #if defined(CONFIG_SPI_CNTRLR_0) s3cspi_set_slaves(BUSNUM(0), ARRAY_SIZE(s3c_slv_pdata_0), s3c_slv_pdata_0); #endif #if defined(CONFIG_SPI_CNTRLR_1) s3cspi_set_slaves(BUSNUM(1), ARRAY_SIZE(s3c_slv_pdata_1), s3c_slv_pdata_1); #endif #if defined(CONFIG_SPI_CNTRLR_2) s3cspi_set_slaves(BUSNUM(2), ARRAY_SIZE(s3c_slv_pdata_2), s3c_slv_pdata_2); #endif spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); #if defined(CONFIG_FB_S3C_LB070WV6) || defined(CONFIG_FB_S3C_LTN101NT05) s3cfb_set_platdata(&mango_fb_data); #endif #if defined(CONFIG_TOUCHSCREEN_S3C) s3c_ts_set_platdata(&s3c_ts_platform); #endif #if defined(CONFIG_S5PV210_ADC) s3c_adc_set_platdata(&s3c_adc_platform); #endif #if defined(CONFIG_PM) s3c_pm_init(); #endif #ifdef CONFIG_VIDEO_FIMC #ifdef CONFIG_S5PV210_SETUP_FIMC0 s3c_fimc0_set_platdata(&fimc_plat); #endif #ifdef CONFIG_S5PV210_SETUP_FIMC1 s3c_fimc1_set_platdata(&fimc_plat); #endif #ifdef CONFIG_S5PV210_SETUP_FIMC2 s3c_fimc2_set_platdata(&fimc_plat); #endif mango210_camera_set(); mango210_cam0_power(1); #else #ifdef CONFIG_S5PV210_SETUP_FIMC0 s3c_fimc0_set_platdata(NULL); #endif #ifdef CONFIG_S5PV210_SETUP_FIMC1 s3c_fimc1_set_platdata(NULL); #endif #ifdef CONFIG_S5PV210_SETUP_FIMC2 s3c_fimc2_set_platdata(NULL); #endif #endif #ifdef CONFIG_SMSC911X mango210_smsc911x_set(); #endif #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_TV20 s3c_set_qos(); #endif #ifdef CONFIG_S3C_DEV_HSMMC s5pv210_default_sdhci0(); #endif #ifdef CONFIG_S3C_DEV_HSMMC1 s5pv210_default_sdhci1(); #endif #ifdef CONFIG_S3C_DEV_HSMMC2 s5pv210_default_sdhci2(); #endif #ifdef CONFIG_S3C_DEV_HSMMC3 s5pv210_default_sdhci3(); #endif #ifdef CONFIG_S5PV210_SETUP_SDHCI s3c_sdhci_set_platdata(); #endif platform_add_devices(mango210_devices, ARRAY_SIZE(mango210_devices)); #if defined(CONFIG_HAVE_PWM) mango_backlight_register(); #endif #ifdef CONFIG_USB_SUPPORT mango210_usb_host_set(); #endif }
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();*/ }
static void __init mini210_machine_init(void) { arm_pm_restart = smdkc110_pm_restart; s3c_pm_init(); mini210_wifi_init(); #ifdef CONFIG_DM9000 mini210_dm9000_init(); #endif platform_add_devices(mini210_devices, ARRAY_SIZE(mini210_devices)); #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif #ifdef CONFIG_KEYBOARD_SAMSUNG samsung_keypad_set_platdata(&mini210_keypad_data); #endif #ifdef CONFIG_TOUCHSCREEN_S3C2410 s3c24xx_ts_set_platdata(&s3c_ts_platform); #endif s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); #ifdef CONFIG_TOUCHSCREEN_GOODIX if (mini210_get_ctp() == CTP_GT80X) { i2c2_data.frequency = 260*1000; } #endif s3c_i2c2_set_platdata(&i2c2_data); i2c_register_board_info(0, mini210_i2c_devs0, ARRAY_SIZE(mini210_i2c_devs0)); i2c_register_board_info(1, mini210_i2c_devs1, ARRAY_SIZE(mini210_i2c_devs1)); i2c_register_board_info(2, mini210_i2c_devs2, ARRAY_SIZE(mini210_i2c_devs2)); #ifdef CONFIG_TOUCHSCREEN_EGALAX i2c_register_board_info(5, i2c_devs5, ARRAY_SIZE(i2c_devs5)); #endif #ifdef CONFIG_S5PV210_SETUP_IDE s3c_ide_set_platdata(&mini210_ide_pdata); #endif #ifdef CONFIG_FB_S3C_MINI210 { struct s3cfb_lcd *mlcd = mini210_get_lcd(); if (!(mlcd->args & 0x0f)) { if (readl(S5PV210_GPF0_BASE + 0x184) & 0x10) mlcd->args |= (1 << 7); } mini210_fb_data.lcd = mlcd; s3c_fb_set_platdata(&mini210_fb_data); } #endif #ifdef CONFIG_S3C_DEV_HSMMC s3c_sdhci0_set_platdata(&mini210_hsmmc0_pdata); #endif #ifdef CONFIG_S3C_DEV_HSMMC1 s3c_sdhci1_set_platdata(&mini210_hsmmc1_pdata); #endif #ifdef CONFIG_S3C_DEV_HSMMC2 s3c_sdhci2_set_platdata(&mini210_hsmmc2_pdata); #endif #ifdef CONFIG_S3C_DEV_HSMMC3 s3c_sdhci3_set_platdata(&mini210_hsmmc3_pdata); #endif #ifdef CONFIG_VIDEO_FIMC /* fimc */ s3c_fimc0_set_platdata(&fimc_plat_lsi); s3c_fimc1_set_platdata(&fimc_plat_lsi); s3c_fimc2_set_platdata(&fimc_plat_lsi); #ifdef CONFIG_VIDEO_S5K4BA #ifdef CAM_ITU_CH_A smdkv210_cam0_power(1); #else smdkv210_cam1_power(1); #endif #endif #endif #ifdef CONFIG_VIDEO_FIMC_MIPI s3c_csis_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_JPEG_V2 s3c_jpeg_set_platdata(&jpeg_plat); #endif #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif /* spi */ #ifdef CONFIG_SPI_S3C64XX if (!gpio_request(S5PV210_GPB(1), "SPI_CS0")) { gpio_direction_output(S5PV210_GPB(1), 1); s3c_gpio_cfgpin(S5PV210_GPB(1), S3C_GPIO_SFN(1)); s3c_gpio_setpull(S5PV210_GPB(1), S3C_GPIO_PULL_UP); s5pv210_spi_set_info(0, S5PV210_SPI_SRCCLK_PCLK, ARRAY_SIZE(smdk_spi0_csi)); } if (!gpio_request(S5PV210_GPB(5), "SPI_CS1")) { gpio_direction_output(S5PV210_GPB(5), 1); s3c_gpio_cfgpin(S5PV210_GPB(5), S3C_GPIO_SFN(1)); s3c_gpio_setpull(S5PV210_GPB(5), S3C_GPIO_PULL_UP); s5pv210_spi_set_info(1, S5PV210_SPI_SRCCLK_PCLK, ARRAY_SIZE(smdk_spi1_csi)); } spi_register_board_info(s3c_spi_devs, ARRAY_SIZE(s3c_spi_devs)); #endif mini210_otg_init(); mini210_ehci_init(); mini210_ohci_init(); clk_xusbxti.rate = 24000000; regulator_has_full_constraints(); mini210_setup_clocks(); /* write something into the INFORM6 register that we can use to * differentiate an unclear reboot from a clean reboot (which * writes a small integer code to INFORM6). */ __raw_writel(0xee, S5P_INFORM6); }
static void __init smdkv210_machine_init(void) { /* Find out S5PC110 chip version */ _hw_version_check(); /* OneNAND */ #ifdef CONFIG_MTD_ONENAND //s3c_device_onenand.dev.platform_data = &s5p_onenand_data; #endif #ifdef CONFIG_DM9000 smdkv210_dm9000_set(); #endif #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif /* i2c */ s3c_i2c0_set_platdata(NULL); s3c_i2c1_set_platdata(NULL); s3c_i2c2_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)); i2c_register_board_info(2, i2c_devs2, ARRAY_SIZE(i2c_devs2)); #ifdef CONFIG_FB_S3C s3cfb_set_platdata(NULL); #endif #if defined(CONFIG_BLK_DEV_IDE_S3C) s3c_ide_set_platdata(&smdkv210_ide_pdata); #endif #if defined(CONFIG_TOUCHSCREEN_S3C) s3c_ts_set_platdata(&s3c_ts_platform); #endif #if defined(CONFIG_S5PV210_ADCTS) s3c_adcts_set_platdata(&s3c_adcts_cfgs); #endif #if defined(CONFIG_PM) s3c_pm_init(); #endif #ifdef CONFIG_VIDEO_FIMC /* fimc */ s3c_fimc0_set_platdata(&fimc_plat); s3c_fimc1_set_platdata(&fimc_plat); s3c_fimc2_set_platdata(&fimc_plat); s3c_csis_set_platdata(NULL); smdkv210_cam0_power(1); smdkv210_cam1_power(1); smdkv210_mipi_cam_reset(); #endif #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif #ifdef CONFIG_S3C_DEV_HSMMC s5pv210_default_sdhci0(); #endif #ifdef CONFIG_S3C_DEV_HSMMC1 s5pv210_default_sdhci1(); #endif #ifdef CONFIG_S3C_DEV_HSMMC2 s5pv210_default_sdhci2(); #endif #ifdef CONFIG_S3C_DEV_HSMMC3 s5pv210_default_sdhci3(); #endif #ifdef CONFIG_S5PV210_SETUP_SDHCI s3c_sdhci_set_platdata(); #endif platform_add_devices(smdkv210_devices, ARRAY_SIZE(smdkv210_devices)); }
static void __init mid_machine_init(void) { s3c_pm_init(); sound_init(); mid_audio_jack_init(); mid_dm9000_init(); platform_add_devices(mid_devices, ARRAY_SIZE(mid_devices)); pm_power_off = mid_power_off; arm_pm_restart = mid_pm_restart; // Read configuration mid_init_cfg(); mid_gpio_init(); // Setup devices mid_detect_lcd(); mid_detect_camera(); mid_detect_i2cdevs(); #ifdef CONFIG_ANDROID_PMEM android_pmem_set_platdata(); #endif s3c_adc_set_platdata(&s3c_adc_platform); s3c_nand_set_platdata(&mid_nand_info); s3c_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, mid_i2c_devs0, ARRAY_SIZE(mid_i2c_devs0)); i2c_register_board_info(1, mid_i2c_devs1, ARRAY_SIZE(mid_i2c_devs1)); i2c_register_board_info(2, mid_i2c_devs2, ARRAY_SIZE(mid_i2c_devs2)); s3c_fb_set_platdata(&mid_fb_data); s3c_ehci_set_platdata(&mid_ehci_pdata); #ifdef CONFIG_S3C_DEV_HSMMC s3c_sdhci0_set_platdata(&s5pv210_hsmmc0_pdata); s3c_sdhci1_set_platdata(&s5pv210_hsmmc1_pdata); #endif #ifdef CONFIG_VIDEO_FIMC /* fimc */ s3c_fimc0_set_platdata(&fimc_plat_lsi); s3c_fimc1_set_platdata(&fimc_plat_lsi); s3c_fimc2_set_platdata(&fimc_plat_lsi); #endif #ifdef CONFIG_VIDEO_FIMC_MIPI s3c_csis_set_platdata(NULL); #endif #ifdef CONFIG_VIDEO_JPEG_V2 s3c_jpeg_set_platdata(&jpeg_plat); #endif #ifdef CONFIG_VIDEO_MFC50 /* mfc */ s3c_mfc_set_platdata(NULL); #endif #ifdef CONFIG_MFD_MAX8998 regulator_has_full_constraints(); #endif mid_usbhost_setpower(1); }