RE: [PATCH] ARM: EXYNOS: Adds Samsung TRATS board support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Kukjun Kim, 

> -----Original Message-----
> From: linux-arm-kernel-bounces@xxxxxxxxxxxxxxxxxxx [mailto:linux-arm-kernel-
> bounces@xxxxxxxxxxxxxxxxxxx] On Behalf Of Kyungmin Park
> Sent: Monday, December 26, 2011 8:56 AM
> To: Kukjin Kim
> Cc: HeungJun, Kim; linux-samsung-soc@xxxxxxxxxxxxxxx; arm-linux
> Subject: Re: [PATCH] ARM: EXYNOS: Adds Samsung TRATS board support
> 
> On 12/24/11, Kukjin Kim <kgene.kim@xxxxxxxxxxx> wrote:
> > HeungJun, Kim wrote:
> >>
> >> This patch adds Samsung Mobile TRATS board support.
> >>
> >> Signed-off-by: HeungJun, Kim <riverful.kim@xxxxxxxxxxx>
> >> Signed-off-by: Kyungmin Park <kyungmin.park@xxxxxxxxxxx>
> >> ---
> >>  arch/arm/mach-exynos/Kconfig       |   11 ++
> >>  arch/arm/mach-exynos/Makefile      |    1 +
> >>  arch/arm/mach-exynos/board-trats.c |  340
> >> ++++++++++++++++++++++++++++++++++++
> >>  3 files changed, 352 insertions(+), 0 deletions(-)
> >>  create mode 100644 arch/arm/mach-exynos/board-trats.c
> >>
> >
> > If this is for v3.3, unfortunately, it's a little late to add board file and
> > since many things have changed I don't want to cause the conflicts with
> > others now.
> >
> > BTW, why is the name board-xxx not mach-xxx like others?
> 
> It's mentioned several times,
> How do you talk with other when talk about the smdk?
> "I'm using the smdk machine and it's based on smdk machine?"
> As board is more proper word and it's easy to know when find the board
> at source code.
> So hope to use the board if it's not big deal.
If you don't mind, I want to let you know additional information.

I also agree with Mr.Park.

Generally in the robot field, the term "machine" means the total things
including the machinery part and even the brain "board", and the machine
is more bigger concept.
Probably, in the other field, this confusion will be occurred
when they see the linux kernel source first.
So, I think these terms might be necessary to distinguish.

Thanks and Regards,
Heungjun Kim

> 
> BR,
> Kyungmin Park
> >
> >> diff --git a/arch/arm/mach-exynos/Kconfig b/arch/arm/mach-exynos/Kconfig
> >> index 0afcc3b..3bbbef8 100644
> >> --- a/arch/arm/mach-exynos/Kconfig
> >> +++ b/arch/arm/mach-exynos/Kconfig
> >> @@ -304,6 +304,17 @@ config MACH_ORIGEN
> >>  	help
> >>  	  Machine support for ORIGEN based on Samsung EXYNOS4210
> >>
> >> +config MACH_TRATS
> >> +	bool "Mobile TRATS Board"
> >> +	select CPU_EXYNOS4210
> >> +	select S3C_DEV_WDT
> >> +	select S3C_DEV_HSMMC
> >> +	select S3C_DEV_I2C5
> >> +	select EXYNOS4_SETUP_I2C5
> >> +	select EXYNOS4_SETUP_SDHCI
> >> +	help
> >> +	  Machine support for Samsung Mobile TRATS Board.
> >> +
> >>  comment "EXYNOS4212 Boards"
> >>
> >>  config MACH_SMDK4212
> >> diff --git a/arch/arm/mach-exynos/Makefile b/arch/arm/mach-exynos/Makefile
> >> index 57e5296..f3bdda9 100644
> >> --- a/arch/arm/mach-exynos/Makefile
> >> +++ b/arch/arm/mach-exynos/Makefile
> >> @@ -33,6 +33,7 @@ obj-$(CONFIG_MACH_ARMLEX4210)		+= mach-
> >> armlex4210.o
> >>  obj-$(CONFIG_MACH_UNIVERSAL_C210)	+= mach-universal_c210.o
> >>  obj-$(CONFIG_MACH_NURI)			+= mach-nuri.o
> >>  obj-$(CONFIG_MACH_ORIGEN)		+= mach-origen.o
> >> +obj-$(CONFIG_MACH_TRATS)		+= board-trats.o
> >>
> >>  obj-$(CONFIG_MACH_SMDK4212)		+= mach-smdk4x12.o
> >>  obj-$(CONFIG_MACH_SMDK4412)		+= mach-smdk4x12.o
> >> diff --git a/arch/arm/mach-exynos/board-trats.c b/arch/arm/mach-
> >> exynos/board-trats.c
> >> new file mode 100644
> >> index 0000000..4c13dfc
> >> --- /dev/null
> >> +++ b/arch/arm/mach-exynos/board-trats.c
> >> @@ -0,0 +1,340 @@
> >> +/*
> >> + * linux/arch/arm/mach-exynos4/board-trats.c
> >> + *
> >> + * Copyright (c) 2011 Samsung Electronics Co., Ltd.
> >> + *
> >> + * This program is free software; you can redistribute it and/or modify
> >> + * it under the terms of the GNU General Public License version 2 as
> >> + * published by the Free Software Foundation.
> >> + */
> >> +
> >> +#include <linux/platform_device.h>
> >> +#include <linux/serial_core.h>
> >> +#include <linux/i2c.h>
> >> +#include <linux/gpio.h>
> >> +#include <linux/regulator/machine.h>
> >> +#include <linux/regulator/fixed.h>
> >> +#include <linux/mfd/max8997.h>
> >> +#include <linux/mfd/max8997-private.h>
> >> +#include <linux/mmc/host.h>
> >> +
> >> +#include <asm/mach/arch.h>
> >> +#include <asm/mach-types.h>
> >> +
> >> +#include <plat/regs-serial.h>
> >> +#include <plat/exynos4.h>
> >> +#include <plat/cpu.h>
> >> +#include <plat/devs.h>
> >> +#include <plat/sdhci.h>
> >> +#include <plat/clock.h>
> >> +#include <plat/gpio-cfg.h>
> >> +#include <plat/iic.h>
> >> +
> >> +#include <mach/map.h>
> >> +
> >> +/* Following are default values for UCON, ULCON and UFCON UART registers
> >> */
> >> +#define TRATS_UCON_DEFAULT	(S3C2410_UCON_TXILEVEL |	\
> >> +				 S3C2410_UCON_RXILEVEL |	\
> >> +				 S3C2410_UCON_TXIRQMODE |	\
> >> +				 S3C2410_UCON_RXIRQMODE |	\
> >> +				 S3C2410_UCON_RXFIFO_TOI |	\
> >> +				 S3C2443_UCON_RXERR_IRQEN)
> >> +
> >> +#define TRATS_ULCON_DEFAULT	S3C2410_LCON_CS8
> >> +
> >> +#define TRATS_UFCON_DEFAULT	(S3C2410_UFCON_FIFOMODE |	\
> >> +				 S5PV210_UFCON_TXTRIG256 |	\
> >> +				 S5PV210_UFCON_RXTRIG256)
> >> +
> >> +enum fixed_regulator_id {
> >> +	FIXED_REG_ID_MMC = 0,
> >> +};
> >> +
> >> +static struct s3c2410_uartcfg trats_uartcfgs[] __initdata = {
> >> +	{
> >> +		.hwport		= 0,
> >> +		.ucon		= TRATS_UCON_DEFAULT,
> >> +		.ulcon		= TRATS_ULCON_DEFAULT,
> >> +		.ufcon		= TRATS_UFCON_DEFAULT,
> >> +	},
> >> +	{
> >> +		.hwport		= 1,
> >> +		.ucon		= TRATS_UCON_DEFAULT,
> >> +		.ulcon		= TRATS_ULCON_DEFAULT,
> >> +		.ufcon		= TRATS_UFCON_DEFAULT,
> >> +	},
> >> +	{
> >> +		.hwport		= 2,
> >> +		.ucon		= TRATS_UCON_DEFAULT,
> >> +		.ulcon		= TRATS_ULCON_DEFAULT,
> >> +		.ufcon		= TRATS_UFCON_DEFAULT,
> >> +	},
> >> +	{
> >> +		.hwport		= 3,
> >> +		.ucon		= TRATS_UCON_DEFAULT,
> >> +		.ulcon		= TRATS_ULCON_DEFAULT,
> >> +		.ufcon		= TRATS_UFCON_DEFAULT,
> >> +	},
> >> +};
> >> +
> >> +/* eMMC */
> >> +static struct s3c_sdhci_platdata trats_hsmmc0_data __initdata = {
> >> +	.max_width		= 8,
> >> +	.host_caps		= (MMC_CAP_8_BIT_DATA | MMC_CAP_4_BIT_DATA |
> >> +				MMC_CAP_MMC_HIGHSPEED | MMC_CAP_SD_HIGHSPEED
> > |
> >> +				MMC_CAP_DISABLE | MMC_CAP_ERASE),
> >> +	.cd_type		= S3C_SDHCI_CD_PERMANENT,
> >> +	.clk_type		= S3C_SDHCI_CLK_DIV_EXTERNAL,
> >> +};
> >> +
> >> +static struct regulator_consumer_supply emmc_supplies[] = {
> >> +	REGULATOR_SUPPLY("vmmc", "s3c-sdhci.0"),
> >> +};
> >> +
> >> +static struct regulator_init_data emmc_fixed_voltage_init_data = {
> >> +	.constraints		= {
> >> +		.name		= "VMEM_VDD_2.8V",
> >> +		.valid_ops_mask	= REGULATOR_CHANGE_STATUS,
> >> +	},
> >> +	.num_consumer_supplies	= ARRAY_SIZE(emmc_supplies),
> >> +	.consumer_supplies	= emmc_supplies,
> >> +};
> >> +
> >> +static struct fixed_voltage_config emmc_fixed_voltage_config = {
> >> +	.supply_name		= "MASSMEMORY_EN (inverted)",
> >> +	.microvolts		= 2800000,
> >> +	.gpio			= EXYNOS4_GPK0(2),
> >> +	.enable_high		= true,
> >> +	.init_data		= &emmc_fixed_voltage_init_data,
> >> +};
> >> +
> >> +static struct platform_device emmc_fixed_voltage = {
> >> +	.name			= "reg-fixed-voltage",
> >> +	.id			= FIXED_REG_ID_MMC,
> >> +	.dev			= {
> >> +		.platform_data	= &emmc_fixed_voltage_config,
> >> +	},
> >> +};
> >> +
> >> +static void __init trats_sdhci_init(void)
> >> +{
> >> +	s3c_sdhci0_set_platdata(&trats_hsmmc0_data);
> >> +}
> >> +
> >> +static struct regulator_consumer_supply __initdata max8997_buck1_[] = {
> >> +	REGULATOR_SUPPLY("vdd_arm", NULL), /* CPUFREQ */
> >> +};
> >> +static struct regulator_consumer_supply __initdata max8997_buck2_[] = {
> >> +	REGULATOR_SUPPLY("vdd_int", NULL), /* CPUFREQ */
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_ldo2_data = {
> >> +	.constraints	= {
> >> +		.name		= "VALIVE_1.1V_C210",
> >> +		.min_uV		= 1100000,
> >> +		.max_uV		= 1100000,
> >> +		.apply_uV	= 1,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.enabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_ldo6_data = {
> >> +	.constraints	= {
> >> +		.name		= "VCC_1.8V_PDA",
> >> +		.min_uV		= 1800000,
> >> +		.max_uV		= 1800000,
> >> +		.apply_uV	= 1,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.enabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_ldo9_data = {
> >> +	.constraints	= {
> >> +		.name		= "VCC_2.8V_PDA",
> >> +		.min_uV		= 2800000,
> >> +		.max_uV		= 2800000,
> >> +		.apply_uV	= 1,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.enabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_ldo10_data = {
> >> +	.constraints	= {
> >> +		.name		= "VPLL_1.1V_C210",
> >> +		.min_uV		= 1100000,
> >> +		.max_uV		= 1100000,
> >> +		.apply_uV	= 1,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.disabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_buck1_data = {
> >> +	.constraints	= {
> >> +		.name		= "VARM_1.2V_C210",
> >> +		.min_uV		= 900000,
> >> +		.max_uV		= 1350000,
> >> +		.valid_ops_mask	= REGULATOR_CHANGE_VOLTAGE,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.disabled	= 1,
> >> +		},
> >> +	},
> >> +	.num_consumer_supplies = ARRAY_SIZE(max8997_buck1_),
> >> +	.consumer_supplies = max8997_buck1_,
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_buck2_data = {
> >> +	.constraints	= {
> >> +		.name		= "VINT_1.1V_C210",
> >> +		.min_uV		= 900000,
> >> +		.max_uV		= 1100000,
> >> +		.valid_ops_mask	= REGULATOR_CHANGE_VOLTAGE,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.disabled	= 1,
> >> +		},
> >> +	},
> >> +	.num_consumer_supplies = ARRAY_SIZE(max8997_buck2_),
> >> +	.consumer_supplies = max8997_buck2_,
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_buck5_data = {
> >> +	.constraints	= {
> >> +		.name		= "VMEM_1.2V_C210",
> >> +		.min_uV		= 1200000,
> >> +		.max_uV		= 1200000,
> >> +		.apply_uV	= 1,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.enabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct regulator_init_data __initdata max8997_buck6_data = {
> >> +	.constraints	= {
> >> +		.name		= "V_BAT",
> >> +		.min_uV		= 2800000,
> >> +		.max_uV		= 2800000,
> >> +		.always_on	= 1,
> >> +		.state_mem	= {
> >> +			.enabled	= 1,
> >> +		},
> >> +	},
> >> +};
> >> +
> >> +static struct max8997_regulator_data __initdata
> > trats_max8997_regulators[]
> >> = {
> >> +	{ MAX8997_LDO2, &max8997_ldo2_data },
> >> +	{ MAX8997_LDO6, &max8997_ldo6_data },
> >> +	{ MAX8997_LDO9, &max8997_ldo9_data },
> >> +	{ MAX8997_LDO10, &max8997_ldo10_data },
> >> +
> >> +	{ MAX8997_BUCK1, &max8997_buck1_data },
> >> +	{ MAX8997_BUCK2, &max8997_buck2_data },
> >> +	{ MAX8997_BUCK5, &max8997_buck5_data },
> >> +	{ MAX8997_BUCK6, &max8997_buck6_data },
> >> +};
> >> +
> >> +static struct max8997_platform_data __initdata trats_max8997_pdata = {
> >> +	.wakeup			= 1,
> >> +
> >> +	.num_regulators		= ARRAY_SIZE(trats_max8997_regulators),
> >> +	.regulators		= trats_max8997_regulators,
> >> +
> >> +	.buck125_gpios = { EXYNOS4_GPX0(5), EXYNOS4_GPX0(6),
> >> EXYNOS4_GPL0(0) },
> >> +
> >> +	.buck1_voltage[0] = 1350000, /* 1.35V */
> >> +	.buck1_voltage[1] = 1300000, /* 1.3V */
> >> +	.buck1_voltage[2] = 1250000, /* 1.25V */
> >> +	.buck1_voltage[3] = 1200000, /* 1.2V */
> >> +	.buck1_voltage[4] = 1150000, /* 1.15V */
> >> +	.buck1_voltage[5] = 1100000, /* 1.1V */
> >> +	.buck1_voltage[6] = 1000000, /* 1.0V */
> >> +	.buck1_voltage[7] = 950000, /* 0.95V */
> >> +
> >> +	.buck2_voltage[0] = 1100000, /* 1.1V */
> >> +	.buck2_voltage[1] = 1000000, /* 1.0V */
> >> +	.buck2_voltage[2] = 950000, /* 0.95V */
> >> +	.buck2_voltage[3] = 900000, /* 0.9V */
> >> +	.buck2_voltage[4] = 1100000, /* 1.1V */
> >> +	.buck2_voltage[5] = 1000000, /* 1.0V */
> >> +	.buck2_voltage[6] = 950000, /* 0.95V */
> >> +	.buck2_voltage[7] = 900000, /* 0.9V */
> >> +
> >> +	.buck5_voltage[0] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[1] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[2] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[3] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[4] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[5] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[6] = 1200000, /* 1.2V */
> >> +	.buck5_voltage[7] = 1200000, /* 1.2V */
> >> +};
> >> +
> >> +/* I2C 5 (PMIC) */
> >> +enum { I2C5_MAX8997 };
> >> +static struct i2c_board_info i2c5_devs[] __initdata = {
> >> +	[I2C5_MAX8997] = {
> >> +		I2C_BOARD_INFO("max8997", 0xCC >> 1),
> >> +		.platform_data	= &trats_max8997_pdata,
> >> +	},
> >> +};
> >> +
> >> +static void __init trats_power_init(void)
> >> +{
> >> +	int gpio;
> >> +
> >> +	gpio = EXYNOS4_GPX0(7);
> >> +	gpio_request(gpio, "AP_PMIC_IRQ");
> >> +	s3c_gpio_cfgpin(gpio, S3C_GPIO_SFN(0xf));
> >> +	s3c_gpio_setpull(gpio, S3C_GPIO_PULL_NONE);
> >> +}
> >> +
> >> +static struct platform_device *trats_devices[] __initdata = {
> >> +	/* Samsung Platform Devices */
> >> +	&s3c_device_i2c5, /* PMIC should initialize first */
> >> +	&emmc_fixed_voltage,
> >> +	&s3c_device_hsmmc0,
> >> +	&s3c_device_wdt,
> >> +};
> >> +
> >> +static void __init trats_map_io(void)
> >> +{
> >> +	s5p_init_io(NULL, 0, S5P_VA_CHIPID);
> >> +	s3c24xx_init_clocks(24000000);
> >> +	s3c24xx_init_uarts(trats_uartcfgs, ARRAY_SIZE(trats_uartcfgs));
> >> +}
> >> +
> >> +static void __init trats_machine_init(void)
> >> +{
> >> +	trats_sdhci_init();
> >> +	trats_power_init();
> >> +
> >> +	s3c_i2c5_set_platdata(NULL);
> >> +	i2c5_devs[I2C5_MAX8997].irq = gpio_to_irq(EXYNOS4_GPX0(7));
> >> +	i2c_register_board_info(5, i2c5_devs, ARRAY_SIZE(i2c5_devs));
> >> +
> >> +	/* Last */
> >> +	platform_add_devices(trats_devices, ARRAY_SIZE(trats_devices));
> >> +}
> >> +
> >> +MACHINE_START(TRATS, "TRATS")
> >> +	/* Maintainer: Kyungmin Park <kyungmin.park@xxxxxxxxxxx> */
> >> +	.atag_offset	= 0x100,
> >> +	.init_irq	= exynos4_init_irq,
> >> +	.map_io		= trats_map_io,
> >> +	.init_machine	= trats_machine_init,
> >> +	.timer		= &exynos4_timer,
> >> +MACHINE_END
> >> --
> >> 1.7.4.1
> >
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc"
> > in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> >
> 
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel@xxxxxxxxxxxxxxxxxxx
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux SoC Development]     [Linux Rockchip Development]     [Linux USB Development]     [Video for Linux]     [Linux Audio Users]     [Linux SCSI]     [Yosemite News]

  Powered by Linux