Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
7d84b3e9
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
7d84b3e9
编写于
10月 04, 2011
作者:
K
Kukjin Kim
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'next/topic-exynos4-devel' into next-samsung-devel
上级
59384796
95727e1f
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
790 addition
and
0 deletion
+790
-0
arch/arm/configs/exynos4_defconfig
arch/arm/configs/exynos4_defconfig
+1
-0
arch/arm/mach-exynos4/Kconfig
arch/arm/mach-exynos4/Kconfig
+30
-0
arch/arm/mach-exynos4/Makefile
arch/arm/mach-exynos4/Makefile
+1
-0
arch/arm/mach-exynos4/mach-nuri.c
arch/arm/mach-exynos4/mach-nuri.c
+34
-0
arch/arm/mach-exynos4/mach-origen.c
arch/arm/mach-exynos4/mach-origen.c
+679
-0
arch/arm/mach-exynos4/mach-smdkv310.c
arch/arm/mach-exynos4/mach-smdkv310.c
+11
-0
arch/arm/mach-exynos4/mach-universal_c210.c
arch/arm/mach-exynos4/mach-universal_c210.c
+34
-0
未找到文件。
arch/arm/configs/exynos4_defconfig
浏览文件 @
7d84b3e9
...
...
@@ -11,6 +11,7 @@ CONFIG_MACH_SMDKV310=y
CONFIG_MACH_ARMLEX4210=y
CONFIG_MACH_UNIVERSAL_C210=y
CONFIG_MACH_NURI=y
CONFIG_MACH_ORIGEN=y
CONFIG_NO_HZ=y
CONFIG_HIGH_RES_TIMERS=y
CONFIG_SMP=y
...
...
arch/arm/mach-exynos4/Kconfig
浏览文件 @
7d84b3e9
...
...
@@ -139,6 +139,7 @@ config MACH_SMDKV310
select S3C_DEV_RTC
select S3C_DEV_WDT
select S3C_DEV_I2C1
select S5P_DEV_MFC
select S3C_DEV_HSMMC
select S3C_DEV_HSMMC1
select S3C_DEV_HSMMC2
...
...
@@ -178,6 +179,7 @@ config MACH_UNIVERSAL_C210
select S5P_DEV_FIMC1
select S5P_DEV_FIMC2
select S5P_DEV_FIMC3
select S5P_DEV_FIMD0
select S3C_DEV_HSMMC
select S3C_DEV_HSMMC2
select S3C_DEV_HSMMC3
...
...
@@ -187,6 +189,7 @@ config MACH_UNIVERSAL_C210
select S5P_DEV_MFC
select S5P_DEV_ONENAND
select EXYNOS4_DEV_PD
select EXYNOS4_SETUP_FIMD0
select EXYNOS4_SETUP_I2C1
select EXYNOS4_SETUP_I2C3
select EXYNOS4_SETUP_I2C5
...
...
@@ -199,6 +202,8 @@ config MACH_NURI
bool "Mobile NURI Board"
select CPU_EXYNOS4210
select S3C_DEV_WDT
select S3C_DEV_RTC
select S5P_DEV_FIMD0
select S3C_DEV_HSMMC
select S3C_DEV_HSMMC2
select S3C_DEV_HSMMC3
...
...
@@ -208,6 +213,7 @@ config MACH_NURI
select S5P_DEV_MFC
select S5P_DEV_USB_EHCI
select EXYNOS4_DEV_PD
select EXYNOS4_SETUP_FIMD0
select EXYNOS4_SETUP_I2C1
select EXYNOS4_SETUP_I2C3
select EXYNOS4_SETUP_I2C5
...
...
@@ -218,6 +224,30 @@ config MACH_NURI
help
Machine support for Samsung Mobile NURI Board.
config MACH_ORIGEN
bool "ORIGEN"
select CPU_EXYNOS4210
select S3C_DEV_RTC
select S3C_DEV_WDT
select S3C_DEV_HSMMC
select S3C_DEV_HSMMC2
select S5P_DEV_FIMC0
select S5P_DEV_FIMC1
select S5P_DEV_FIMC2
select S5P_DEV_FIMC3
select S5P_DEV_FIMD0
select S5P_DEV_I2C_HDMIPHY
select S5P_DEV_TV
select S5P_DEV_USB_EHCI
select EXYNOS4_DEV_PD
select SAMSUNG_DEV_BACKLIGHT
select SAMSUNG_DEV_PWM
select EXYNOS4_SETUP_FIMD0
select EXYNOS4_SETUP_SDHCI
select EXYNOS4_SETUP_USB_PHY
help
Machine support for ORIGEN based on Samsung EXYNOS4210
endmenu
comment "Configuration for HSMMC bus width"
...
...
arch/arm/mach-exynos4/Makefile
浏览文件 @
7d84b3e9
...
...
@@ -30,6 +30,7 @@ obj-$(CONFIG_MACH_SMDKV310) += mach-smdkv310.o
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
# device support
...
...
arch/arm/mach-exynos4/mach-nuri.c
浏览文件 @
7d84b3e9
...
...
@@ -32,10 +32,12 @@
#include <asm/mach-types.h>
#include <plat/adc.h>
#include <plat/regs-fb-v4.h>
#include <plat/regs-serial.h>
#include <plat/exynos4.h>
#include <plat/cpu.h>
#include <plat/devs.h>
#include <plat/fb.h>
#include <plat/sdhci.h>
#include <plat/ehci.h>
#include <plat/clock.h>
...
...
@@ -199,6 +201,33 @@ static struct platform_device nuri_gpio_keys = {
},
};
/* Frame Buffer */
static
struct
s3c_fb_pd_win
nuri_fb_win0
=
{
.
win_mode
=
{
.
left_margin
=
64
,
.
right_margin
=
16
,
.
upper_margin
=
64
,
.
lower_margin
=
1
,
.
hsync_len
=
48
,
.
vsync_len
=
3
,
.
xres
=
1280
,
.
yres
=
800
,
.
refresh
=
60
,
},
.
max_bpp
=
24
,
.
default_bpp
=
16
,
.
virtual_x
=
1280
,
.
virtual_y
=
800
,
};
static
struct
s3c_fb_platdata
nuri_fb_pdata
__initdata
=
{
.
win
[
0
]
=
&
nuri_fb_win0
,
.
vidcon0
=
VIDCON0_VIDOUT_RGB
|
VIDCON0_PNRMODE_RGB
|
VIDCON0_CLKSEL_LCD
,
.
vidcon1
=
VIDCON1_INV_HSYNC
|
VIDCON1_INV_VSYNC
,
.
setup_gpio
=
exynos4_fimd0_gpio_setup_24bpp
,
};
static
void
nuri_lcd_power_on
(
struct
plat_lcd_data
*
pd
,
unsigned
int
power
)
{
int
gpio
=
EXYNOS4_GPE1
(
5
);
...
...
@@ -1092,6 +1121,7 @@ static struct platform_device *nuri_devices[] __initdata = {
/* Samsung Platform Devices */
&
s3c_device_i2c5
,
/* PMIC should initialize first */
&
emmc_fixed_voltage
,
&
s5p_device_fimd0
,
&
s3c_device_hsmmc0
,
&
s3c_device_hsmmc2
,
&
s3c_device_hsmmc3
,
...
...
@@ -1106,6 +1136,7 @@ static struct platform_device *nuri_devices[] __initdata = {
&
s5p_device_mfc_l
,
&
s5p_device_mfc_r
,
&
exynos4_device_pd
[
PD_MFC
],
&
exynos4_device_pd
[
PD_LCD0
],
/* NURI Devices */
&
nuri_gpio_keys
,
...
...
@@ -1142,12 +1173,15 @@ static void __init nuri_machine_init(void)
i2c9_devs
[
I2C9_MAX17042
].
irq
=
gpio_to_irq
(
EXYNOS4_GPX2
(
3
));
i2c_register_board_info
(
9
,
i2c9_devs
,
ARRAY_SIZE
(
i2c9_devs
));
s5p_fimd0_set_platdata
(
&
nuri_fb_pdata
);
nuri_ehci_init
();
clk_xusbxti
.
rate
=
24000000
;
/* Last */
platform_add_devices
(
nuri_devices
,
ARRAY_SIZE
(
nuri_devices
));
s5p_device_mfc
.
dev
.
parent
=
&
exynos4_device_pd
[
PD_MFC
].
dev
;
s5p_device_fimd0
.
dev
.
parent
=
&
exynos4_device_pd
[
PD_LCD0
].
dev
;
}
MACHINE_START
(
NURI
,
"NURI"
)
...
...
arch/arm/mach-exynos4/mach-origen.c
0 → 100644
浏览文件 @
7d84b3e9
/* linux/arch/arm/mach-exynos4/mach-origen.c
*
* Copyright (c) 2011 Insignal Co., Ltd.
* http://www.insignal.co.kr/
*
* 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/serial_core.h>
#include <linux/gpio.h>
#include <linux/mmc/host.h>
#include <linux/platform_device.h>
#include <linux/io.h>
#include <linux/input.h>
#include <linux/pwm_backlight.h>
#include <linux/gpio_keys.h>
#include <linux/i2c.h>
#include <linux/regulator/machine.h>
#include <linux/mfd/max8997.h>
#include <linux/lcd.h>
#include <asm/mach/arch.h>
#include <asm/mach-types.h>
#include <video/platform_lcd.h>
#include <plat/regs-serial.h>
#include <plat/regs-fb-v4.h>
#include <plat/exynos4.h>
#include <plat/cpu.h>
#include <plat/devs.h>
#include <plat/sdhci.h>
#include <plat/iic.h>
#include <plat/ehci.h>
#include <plat/clock.h>
#include <plat/gpio-cfg.h>
#include <plat/backlight.h>
#include <plat/pd.h>
#include <plat/fb.h>
#include <mach/map.h>
/* Following are default values for UCON, ULCON and UFCON UART registers */
#define ORIGEN_UCON_DEFAULT (S3C2410_UCON_TXILEVEL | \
S3C2410_UCON_RXILEVEL | \
S3C2410_UCON_TXIRQMODE | \
S3C2410_UCON_RXIRQMODE | \
S3C2410_UCON_RXFIFO_TOI | \
S3C2443_UCON_RXERR_IRQEN)
#define ORIGEN_ULCON_DEFAULT S3C2410_LCON_CS8
#define ORIGEN_UFCON_DEFAULT (S3C2410_UFCON_FIFOMODE | \
S5PV210_UFCON_TXTRIG4 | \
S5PV210_UFCON_RXTRIG4)
static
struct
s3c2410_uartcfg
origen_uartcfgs
[]
__initdata
=
{
[
0
]
=
{
.
hwport
=
0
,
.
flags
=
0
,
.
ucon
=
ORIGEN_UCON_DEFAULT
,
.
ulcon
=
ORIGEN_ULCON_DEFAULT
,
.
ufcon
=
ORIGEN_UFCON_DEFAULT
,
},
[
1
]
=
{
.
hwport
=
1
,
.
flags
=
0
,
.
ucon
=
ORIGEN_UCON_DEFAULT
,
.
ulcon
=
ORIGEN_ULCON_DEFAULT
,
.
ufcon
=
ORIGEN_UFCON_DEFAULT
,
},
[
2
]
=
{
.
hwport
=
2
,
.
flags
=
0
,
.
ucon
=
ORIGEN_UCON_DEFAULT
,
.
ulcon
=
ORIGEN_ULCON_DEFAULT
,
.
ufcon
=
ORIGEN_UFCON_DEFAULT
,
},
[
3
]
=
{
.
hwport
=
3
,
.
flags
=
0
,
.
ucon
=
ORIGEN_UCON_DEFAULT
,
.
ulcon
=
ORIGEN_ULCON_DEFAULT
,
.
ufcon
=
ORIGEN_UFCON_DEFAULT
,
},
};
static
struct
regulator_consumer_supply
__initdata
ldo3_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd11"
,
"s5p-mipi-csis.0"
),
/* MIPI */
};
static
struct
regulator_consumer_supply
__initdata
ldo6_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd18"
,
"s5p-mipi-csis.0"
),
/* MIPI */
};
static
struct
regulator_consumer_supply
__initdata
ldo7_consumer
[]
=
{
REGULATOR_SUPPLY
(
"avdd"
,
"alc5625"
),
/* Realtek ALC5625 */
};
static
struct
regulator_consumer_supply
__initdata
ldo8_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd"
,
"s5p-adc"
),
/* ADC */
};
static
struct
regulator_consumer_supply
__initdata
ldo9_consumer
[]
=
{
REGULATOR_SUPPLY
(
"dvdd"
,
"swb-a31"
),
/* AR6003 WLAN & CSR 8810 BT */
};
static
struct
regulator_consumer_supply
__initdata
ldo11_consumer
[]
=
{
REGULATOR_SUPPLY
(
"dvdd"
,
"alc5625"
),
/* Realtek ALC5625 */
};
static
struct
regulator_consumer_supply
__initdata
ldo14_consumer
[]
=
{
REGULATOR_SUPPLY
(
"avdd18"
,
"swb-a31"
),
/* AR6003 WLAN & CSR 8810 BT */
};
static
struct
regulator_consumer_supply
__initdata
ldo17_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd33"
,
"swb-a31"
),
/* AR6003 WLAN & CSR 8810 BT */
};
static
struct
regulator_consumer_supply
__initdata
buck1_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd_arm"
,
NULL
),
/* CPUFREQ */
};
static
struct
regulator_consumer_supply
__initdata
buck2_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd_int"
,
NULL
),
/* CPUFREQ */
};
static
struct
regulator_consumer_supply
__initdata
buck3_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vdd_g3d"
,
"mali_drm"
),
/* G3D */
};
static
struct
regulator_consumer_supply
__initdata
buck7_consumer
[]
=
{
REGULATOR_SUPPLY
(
"vcc"
,
"platform-lcd"
),
/* LCD */
};
static
struct
regulator_init_data
__initdata
max8997_ldo1_data
=
{
.
constraints
=
{
.
name
=
"VDD_ABB_3.3V"
,
.
min_uV
=
3300000
,
.
max_uV
=
3300000
,
.
apply_uV
=
1
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_ldo2_data
=
{
.
constraints
=
{
.
name
=
"VDD_ALIVE_1.1V"
,
.
min_uV
=
1100000
,
.
max_uV
=
1100000
,
.
apply_uV
=
1
,
.
always_on
=
1
,
.
state_mem
=
{
.
enabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_ldo3_data
=
{
.
constraints
=
{
.
name
=
"VMIPI_1.1V"
,
.
min_uV
=
1100000
,
.
max_uV
=
1100000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo3_consumer
),
.
consumer_supplies
=
ldo3_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo4_data
=
{
.
constraints
=
{
.
name
=
"VDD_RTC_1.8V"
,
.
min_uV
=
1800000
,
.
max_uV
=
1800000
,
.
apply_uV
=
1
,
.
always_on
=
1
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_ldo6_data
=
{
.
constraints
=
{
.
name
=
"VMIPI_1.8V"
,
.
min_uV
=
1800000
,
.
max_uV
=
1800000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo6_consumer
),
.
consumer_supplies
=
ldo6_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo7_data
=
{
.
constraints
=
{
.
name
=
"VDD_AUD_1.8V"
,
.
min_uV
=
1800000
,
.
max_uV
=
1800000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo7_consumer
),
.
consumer_supplies
=
ldo7_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo8_data
=
{
.
constraints
=
{
.
name
=
"VADC_3.3V"
,
.
min_uV
=
3300000
,
.
max_uV
=
3300000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo8_consumer
),
.
consumer_supplies
=
ldo8_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo9_data
=
{
.
constraints
=
{
.
name
=
"DVDD_SWB_2.8V"
,
.
min_uV
=
2800000
,
.
max_uV
=
2800000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo9_consumer
),
.
consumer_supplies
=
ldo9_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo10_data
=
{
.
constraints
=
{
.
name
=
"VDD_PLL_1.1V"
,
.
min_uV
=
1100000
,
.
max_uV
=
1100000
,
.
apply_uV
=
1
,
.
always_on
=
1
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_ldo11_data
=
{
.
constraints
=
{
.
name
=
"VDD_AUD_3V"
,
.
min_uV
=
3000000
,
.
max_uV
=
3000000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo11_consumer
),
.
consumer_supplies
=
ldo11_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo14_data
=
{
.
constraints
=
{
.
name
=
"AVDD18_SWB_1.8V"
,
.
min_uV
=
1800000
,
.
max_uV
=
1800000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo14_consumer
),
.
consumer_supplies
=
ldo14_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo17_data
=
{
.
constraints
=
{
.
name
=
"VDD_SWB_3.3V"
,
.
min_uV
=
3300000
,
.
max_uV
=
3300000
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
ldo17_consumer
),
.
consumer_supplies
=
ldo17_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_ldo21_data
=
{
.
constraints
=
{
.
name
=
"VDD_MIF_1.2V"
,
.
min_uV
=
1200000
,
.
max_uV
=
1200000
,
.
apply_uV
=
1
,
.
always_on
=
1
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_buck1_data
=
{
.
constraints
=
{
.
name
=
"VDD_ARM_1.2V"
,
.
min_uV
=
950000
,
.
max_uV
=
1350000
,
.
always_on
=
1
,
.
boot_on
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_VOLTAGE
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
buck1_consumer
),
.
consumer_supplies
=
buck1_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_buck2_data
=
{
.
constraints
=
{
.
name
=
"VDD_INT_1.1V"
,
.
min_uV
=
900000
,
.
max_uV
=
1100000
,
.
always_on
=
1
,
.
boot_on
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_VOLTAGE
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
buck2_consumer
),
.
consumer_supplies
=
buck2_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_buck3_data
=
{
.
constraints
=
{
.
name
=
"VDD_G3D_1.1V"
,
.
min_uV
=
900000
,
.
max_uV
=
1100000
,
.
valid_ops_mask
=
REGULATOR_CHANGE_VOLTAGE
|
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
buck3_consumer
),
.
consumer_supplies
=
buck3_consumer
,
};
static
struct
regulator_init_data
__initdata
max8997_buck5_data
=
{
.
constraints
=
{
.
name
=
"VDDQ_M1M2_1.2V"
,
.
min_uV
=
1200000
,
.
max_uV
=
1200000
,
.
apply_uV
=
1
,
.
always_on
=
1
,
.
state_mem
=
{
.
disabled
=
1
,
},
},
};
static
struct
regulator_init_data
__initdata
max8997_buck7_data
=
{
.
constraints
=
{
.
name
=
"VDD_LCD_3.3V"
,
.
min_uV
=
3300000
,
.
max_uV
=
3300000
,
.
boot_on
=
1
,
.
apply_uV
=
1
,
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
,
.
state_mem
=
{
.
disabled
=
1
},
},
.
num_consumer_supplies
=
ARRAY_SIZE
(
buck7_consumer
),
.
consumer_supplies
=
buck7_consumer
,
};
static
struct
max8997_regulator_data
__initdata
origen_max8997_regulators
[]
=
{
{
MAX8997_LDO1
,
&
max8997_ldo1_data
},
{
MAX8997_LDO2
,
&
max8997_ldo2_data
},
{
MAX8997_LDO3
,
&
max8997_ldo3_data
},
{
MAX8997_LDO4
,
&
max8997_ldo4_data
},
{
MAX8997_LDO6
,
&
max8997_ldo6_data
},
{
MAX8997_LDO7
,
&
max8997_ldo7_data
},
{
MAX8997_LDO8
,
&
max8997_ldo8_data
},
{
MAX8997_LDO9
,
&
max8997_ldo9_data
},
{
MAX8997_LDO10
,
&
max8997_ldo10_data
},
{
MAX8997_LDO11
,
&
max8997_ldo11_data
},
{
MAX8997_LDO14
,
&
max8997_ldo14_data
},
{
MAX8997_LDO17
,
&
max8997_ldo17_data
},
{
MAX8997_LDO21
,
&
max8997_ldo21_data
},
{
MAX8997_BUCK1
,
&
max8997_buck1_data
},
{
MAX8997_BUCK2
,
&
max8997_buck2_data
},
{
MAX8997_BUCK3
,
&
max8997_buck3_data
},
{
MAX8997_BUCK5
,
&
max8997_buck5_data
},
{
MAX8997_BUCK7
,
&
max8997_buck7_data
},
};
struct
max8997_platform_data
__initdata
origen_max8997_pdata
=
{
.
num_regulators
=
ARRAY_SIZE
(
origen_max8997_regulators
),
.
regulators
=
origen_max8997_regulators
,
.
wakeup
=
true
,
.
buck1_gpiodvs
=
false
,
.
buck2_gpiodvs
=
false
,
.
buck5_gpiodvs
=
false
,
.
irq_base
=
IRQ_GPIO_END
+
1
,
.
ignore_gpiodvs_side_effect
=
true
,
.
buck125_default_idx
=
0x0
,
.
buck125_gpios
[
0
]
=
EXYNOS4_GPX0
(
0
),
.
buck125_gpios
[
1
]
=
EXYNOS4_GPX0
(
1
),
.
buck125_gpios
[
2
]
=
EXYNOS4_GPX0
(
2
),
.
buck1_voltage
[
0
]
=
1350000
,
.
buck1_voltage
[
1
]
=
1300000
,
.
buck1_voltage
[
2
]
=
1250000
,
.
buck1_voltage
[
3
]
=
1200000
,
.
buck1_voltage
[
4
]
=
1150000
,
.
buck1_voltage
[
5
]
=
1100000
,
.
buck1_voltage
[
6
]
=
1000000
,
.
buck1_voltage
[
7
]
=
950000
,
.
buck2_voltage
[
0
]
=
1100000
,
.
buck2_voltage
[
1
]
=
1100000
,
.
buck2_voltage
[
2
]
=
1100000
,
.
buck2_voltage
[
3
]
=
1100000
,
.
buck2_voltage
[
4
]
=
1000000
,
.
buck2_voltage
[
5
]
=
1000000
,
.
buck2_voltage
[
6
]
=
1000000
,
.
buck2_voltage
[
7
]
=
1000000
,
.
buck5_voltage
[
0
]
=
1200000
,
.
buck5_voltage
[
1
]
=
1200000
,
.
buck5_voltage
[
2
]
=
1200000
,
.
buck5_voltage
[
3
]
=
1200000
,
.
buck5_voltage
[
4
]
=
1200000
,
.
buck5_voltage
[
5
]
=
1200000
,
.
buck5_voltage
[
6
]
=
1200000
,
.
buck5_voltage
[
7
]
=
1200000
,
};
/* I2C0 */
static
struct
i2c_board_info
i2c0_devs
[]
__initdata
=
{
{
I2C_BOARD_INFO
(
"max8997"
,
(
0xCC
>>
1
)),
.
platform_data
=
&
origen_max8997_pdata
,
.
irq
=
IRQ_EINT
(
4
),
},
};
static
struct
s3c_sdhci_platdata
origen_hsmmc0_pdata
__initdata
=
{
.
cd_type
=
S3C_SDHCI_CD_INTERNAL
,
.
clk_type
=
S3C_SDHCI_CLK_DIV_EXTERNAL
,
};
static
struct
s3c_sdhci_platdata
origen_hsmmc2_pdata
__initdata
=
{
.
cd_type
=
S3C_SDHCI_CD_INTERNAL
,
.
clk_type
=
S3C_SDHCI_CLK_DIV_EXTERNAL
,
};
/* USB EHCI */
static
struct
s5p_ehci_platdata
origen_ehci_pdata
;
static
void
__init
origen_ehci_init
(
void
)
{
struct
s5p_ehci_platdata
*
pdata
=
&
origen_ehci_pdata
;
s5p_ehci_set_platdata
(
pdata
);
}
static
struct
gpio_keys_button
origen_gpio_keys_table
[]
=
{
{
.
code
=
KEY_MENU
,
.
gpio
=
EXYNOS4_GPX1
(
5
),
.
desc
=
"gpio-keys: KEY_MENU"
,
.
type
=
EV_KEY
,
.
active_low
=
1
,
.
wakeup
=
1
,
.
debounce_interval
=
1
,
},
{
.
code
=
KEY_HOME
,
.
gpio
=
EXYNOS4_GPX1
(
6
),
.
desc
=
"gpio-keys: KEY_HOME"
,
.
type
=
EV_KEY
,
.
active_low
=
1
,
.
wakeup
=
1
,
.
debounce_interval
=
1
,
},
{
.
code
=
KEY_BACK
,
.
gpio
=
EXYNOS4_GPX1
(
7
),
.
desc
=
"gpio-keys: KEY_BACK"
,
.
type
=
EV_KEY
,
.
active_low
=
1
,
.
wakeup
=
1
,
.
debounce_interval
=
1
,
},
{
.
code
=
KEY_UP
,
.
gpio
=
EXYNOS4_GPX2
(
0
),
.
desc
=
"gpio-keys: KEY_UP"
,
.
type
=
EV_KEY
,
.
active_low
=
1
,
.
wakeup
=
1
,
.
debounce_interval
=
1
,
},
{
.
code
=
KEY_DOWN
,
.
gpio
=
EXYNOS4_GPX2
(
1
),
.
desc
=
"gpio-keys: KEY_DOWN"
,
.
type
=
EV_KEY
,
.
active_low
=
1
,
.
wakeup
=
1
,
.
debounce_interval
=
1
,
},
};
static
struct
gpio_keys_platform_data
origen_gpio_keys_data
=
{
.
buttons
=
origen_gpio_keys_table
,
.
nbuttons
=
ARRAY_SIZE
(
origen_gpio_keys_table
),
};
static
struct
platform_device
origen_device_gpiokeys
=
{
.
name
=
"gpio-keys"
,
.
dev
=
{
.
platform_data
=
&
origen_gpio_keys_data
,
},
};
static
void
lcd_hv070wsa_set_power
(
struct
plat_lcd_data
*
pd
,
unsigned
int
power
)
{
int
ret
;
if
(
power
)
ret
=
gpio_request_one
(
EXYNOS4_GPE3
(
4
),
GPIOF_OUT_INIT_HIGH
,
"GPE3_4"
);
else
ret
=
gpio_request_one
(
EXYNOS4_GPE3
(
4
),
GPIOF_OUT_INIT_LOW
,
"GPE3_4"
);
gpio_free
(
EXYNOS4_GPE3
(
4
));
if
(
ret
)
pr_err
(
"failed to request gpio for LCD power: %d
\n
"
,
ret
);
}
static
struct
plat_lcd_data
origen_lcd_hv070wsa_data
=
{
.
set_power
=
lcd_hv070wsa_set_power
,
};
static
struct
platform_device
origen_lcd_hv070wsa
=
{
.
name
=
"platform-lcd"
,
.
dev
.
parent
=
&
s5p_device_fimd0
.
dev
,
.
dev
.
platform_data
=
&
origen_lcd_hv070wsa_data
,
};
static
struct
s3c_fb_pd_win
origen_fb_win0
=
{
.
win_mode
=
{
.
left_margin
=
64
,
.
right_margin
=
16
,
.
upper_margin
=
64
,
.
lower_margin
=
16
,
.
hsync_len
=
48
,
.
vsync_len
=
3
,
.
xres
=
1024
,
.
yres
=
600
,
},
.
max_bpp
=
32
,
.
default_bpp
=
24
,
};
static
struct
s3c_fb_platdata
origen_lcd_pdata
__initdata
=
{
.
win
[
0
]
=
&
origen_fb_win0
,
.
vidcon0
=
VIDCON0_VIDOUT_RGB
|
VIDCON0_PNRMODE_RGB
,
.
vidcon1
=
VIDCON1_INV_HSYNC
|
VIDCON1_INV_VSYNC
,
.
setup_gpio
=
exynos4_fimd0_gpio_setup_24bpp
,
};
static
struct
platform_device
*
origen_devices
[]
__initdata
=
{
&
s3c_device_hsmmc2
,
&
s3c_device_hsmmc0
,
&
s3c_device_i2c0
,
&
s3c_device_rtc
,
&
s3c_device_wdt
,
&
s5p_device_ehci
,
&
s5p_device_fimc0
,
&
s5p_device_fimc1
,
&
s5p_device_fimc2
,
&
s5p_device_fimc3
,
&
s5p_device_fimd0
,
&
s5p_device_hdmi
,
&
s5p_device_i2c_hdmiphy
,
&
s5p_device_mixer
,
&
exynos4_device_pd
[
PD_LCD0
],
&
exynos4_device_pd
[
PD_TV
],
&
origen_device_gpiokeys
,
&
origen_lcd_hv070wsa
,
};
/* LCD Backlight data */
static
struct
samsung_bl_gpio_info
origen_bl_gpio_info
=
{
.
no
=
EXYNOS4_GPD0
(
0
),
.
func
=
S3C_GPIO_SFN
(
2
),
};
static
struct
platform_pwm_backlight_data
origen_bl_data
=
{
.
pwm_id
=
0
,
.
pwm_period_ns
=
1000
,
};
static
void
s5p_tv_setup
(
void
)
{
/* Direct HPD to HDMI chip */
gpio_request_one
(
EXYNOS4_GPX3
(
7
),
GPIOF_IN
,
"hpd-plug"
);
s3c_gpio_cfgpin
(
EXYNOS4_GPX3
(
7
),
S3C_GPIO_SFN
(
0x3
));
s3c_gpio_setpull
(
EXYNOS4_GPX3
(
7
),
S3C_GPIO_PULL_NONE
);
}
static
void
__init
origen_map_io
(
void
)
{
s5p_init_io
(
NULL
,
0
,
S5P_VA_CHIPID
);
s3c24xx_init_clocks
(
24000000
);
s3c24xx_init_uarts
(
origen_uartcfgs
,
ARRAY_SIZE
(
origen_uartcfgs
));
}
static
void
__init
origen_power_init
(
void
)
{
gpio_request
(
EXYNOS4_GPX0
(
4
),
"PMIC_IRQ"
);
s3c_gpio_cfgpin
(
EXYNOS4_GPX0
(
4
),
S3C_GPIO_SFN
(
0xf
));
s3c_gpio_setpull
(
EXYNOS4_GPX0
(
4
),
S3C_GPIO_PULL_NONE
);
}
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
();
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
));
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
;
samsung_bl_set
(
&
origen_bl_gpio_info
,
&
origen_bl_data
);
}
MACHINE_START
(
ORIGEN
,
"ORIGEN"
)
/* Maintainer: JeongHyeon Kim <jhkim@insignal.co.kr> */
.
boot_params
=
S5P_PA_SDRAM
+
0x100
,
.
init_irq
=
exynos4_init_irq
,
.
map_io
=
origen_map_io
,
.
init_machine
=
origen_machine_init
,
.
timer
=
&
exynos4_timer
,
MACHINE_END
arch/arm/mach-exynos4/mach-smdkv310.c
浏览文件 @
7d84b3e9
...
...
@@ -32,6 +32,7 @@
#include <plat/pd.h>
#include <plat/gpio-cfg.h>
#include <plat/backlight.h>
#include <plat/mfc.h>
#include <mach/map.h>
...
...
@@ -177,6 +178,9 @@ static struct platform_device *smdkv310_devices[] __initdata = {
&
exynos4_device_ac97
,
&
exynos4_device_i2s0
,
&
samsung_device_keypad
,
&
s5p_device_mfc
,
&
s5p_device_mfc_l
,
&
s5p_device_mfc_r
,
&
exynos4_device_pd
[
PD_MFC
],
&
exynos4_device_pd
[
PD_G3D
],
&
exynos4_device_pd
[
PD_LCD0
],
...
...
@@ -233,6 +237,11 @@ static void __init smdkv310_map_io(void)
s3c24xx_init_uarts
(
smdkv310_uartcfgs
,
ARRAY_SIZE
(
smdkv310_uartcfgs
));
}
static
void
__init
smdkv310_reserve
(
void
)
{
s5p_mfc_reserve_mem
(
0x43000000
,
8
<<
20
,
0x51000000
,
8
<<
20
);
}
static
void
__init
smdkv310_machine_init
(
void
)
{
s3c_i2c1_set_platdata
(
NULL
);
...
...
@@ -250,6 +259,7 @@ static void __init smdkv310_machine_init(void)
samsung_bl_set
(
&
smdkv310_bl_gpio_info
,
&
smdkv310_bl_data
);
platform_add_devices
(
smdkv310_devices
,
ARRAY_SIZE
(
smdkv310_devices
));
s5p_device_mfc
.
dev
.
parent
=
&
exynos4_device_pd
[
PD_MFC
].
dev
;
}
MACHINE_START
(
SMDKV310
,
"SMDKV310"
)
...
...
@@ -260,4 +270,5 @@ MACHINE_START(SMDKV310, "SMDKV310")
.
map_io
=
smdkv310_map_io
,
.
init_machine
=
smdkv310_machine_init
,
.
timer
=
&
exynos4_timer
,
.
reserve
=
&
smdkv310_reserve
,
MACHINE_END
arch/arm/mach-exynos4/mach-universal_c210.c
浏览文件 @
7d84b3e9
...
...
@@ -13,6 +13,7 @@
#include <linux/i2c.h>
#include <linux/gpio_keys.h>
#include <linux/gpio.h>
#include <linux/fb.h>
#include <linux/mfd/max8998.h>
#include <linux/regulator/machine.h>
#include <linux/regulator/fixed.h>
...
...
@@ -31,9 +32,11 @@
#include <plat/devs.h>
#include <plat/iic.h>
#include <plat/gpio-cfg.h>
#include <plat/fb.h>
#include <plat/mfc.h>
#include <plat/sdhci.h>
#include <plat/pd.h>
#include <plat/regs-fb-v4.h>
#include <mach/map.h>
...
...
@@ -702,6 +705,32 @@ static struct i2c_board_info i2c1_devs[] __initdata = {
/* Gyro, To be updated */
};
/* Frame Buffer */
static
struct
s3c_fb_pd_win
universal_fb_win0
=
{
.
win_mode
=
{
.
left_margin
=
16
,
.
right_margin
=
16
,
.
upper_margin
=
2
,
.
lower_margin
=
28
,
.
hsync_len
=
2
,
.
vsync_len
=
1
,
.
xres
=
480
,
.
yres
=
800
,
.
refresh
=
55
,
},
.
max_bpp
=
32
,
.
default_bpp
=
16
,
};
static
struct
s3c_fb_platdata
universal_lcd_pdata
__initdata
=
{
.
win
[
0
]
=
&
universal_fb_win0
,
.
vidcon0
=
VIDCON0_VIDOUT_RGB
|
VIDCON0_PNRMODE_RGB
|
VIDCON0_CLKSEL_LCD
,
.
vidcon1
=
VIDCON1_INV_VCLK
|
VIDCON1_INV_VDEN
|
VIDCON1_INV_HSYNC
|
VIDCON1_INV_VSYNC
,
.
setup_gpio
=
exynos4_fimd0_gpio_setup_24bpp
,
};
static
struct
platform_device
*
universal_devices
[]
__initdata
=
{
/* Samsung Platform Devices */
&
s5p_device_fimc0
,
...
...
@@ -719,10 +748,12 @@ static struct platform_device *universal_devices[] __initdata = {
&
i2c_gpio12
,
&
universal_gpio_keys
,
&
s5p_device_onenand
,
&
s5p_device_fimd0
,
&
s5p_device_mfc
,
&
s5p_device_mfc_l
,
&
s5p_device_mfc_r
,
&
exynos4_device_pd
[
PD_MFC
],
&
exynos4_device_pd
[
PD_LCD0
],
};
static
void
__init
universal_map_io
(
void
)
...
...
@@ -751,6 +782,8 @@ static void __init universal_machine_init(void)
s3c_i2c5_set_platdata
(
NULL
);
i2c_register_board_info
(
5
,
i2c5_devs
,
ARRAY_SIZE
(
i2c5_devs
));
s5p_fimd0_set_platdata
(
&
universal_lcd_pdata
);
universal_touchkey_init
();
i2c_register_board_info
(
I2C_GPIO_BUS_12
,
i2c_gpio12_devs
,
ARRAY_SIZE
(
i2c_gpio12_devs
));
...
...
@@ -758,6 +791,7 @@ static void __init universal_machine_init(void)
/* Last */
platform_add_devices
(
universal_devices
,
ARRAY_SIZE
(
universal_devices
));
s5p_device_mfc
.
dev
.
parent
=
&
exynos4_device_pd
[
PD_MFC
].
dev
;
s5p_device_fimd0
.
dev
.
parent
=
&
exynos4_device_pd
[
PD_LCD0
].
dev
;
}
MACHINE_START
(
UNIVERSAL_C210
,
"UNIVERSAL_C210"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录