diff options
author | DooHyun.Hwang <dh0421.hwang@samsung.com> | 2010-09-08 09:58:23 +0900 |
---|---|---|
committer | Arve Hjønnevåg <arve@android.com> | 2011-11-17 17:44:05 -0800 |
commit | e0a364fccbf6ff2bceb5b246cf8b0fcd5e8bc4b1 (patch) | |
tree | 3f8c3ebb1b4dff8847d632cf5236b151e5b81d5f /arch/arm | |
parent | a37d03018c8758059a47604e0b7eac2db9688aa7 (diff) | |
download | kernel_samsung_crespo-e0a364fccbf6ff2bceb5b246cf8b0fcd5e8bc4b1.zip kernel_samsung_crespo-e0a364fccbf6ff2bceb5b246cf8b0fcd5e8bc4b1.tar.gz kernel_samsung_crespo-e0a364fccbf6ff2bceb5b246cf8b0fcd5e8bc4b1.tar.bz2 |
S5PC11X: GPS: Add GPS init driver for Herring
Add : GPS_init func. for control GPIO sysfs for GPS
GPS daemon control GPS module by using /sys/class/sec/gps/
Change-Id: Ib8cc342c816c6630a3a00104ff2501ca11b278e2
Signed-off-by: DooHyun.Hwang <dh0421.hwang@samsung.com>
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/mach-s5pv210/mach-herring.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/arch/arm/mach-s5pv210/mach-herring.c b/arch/arm/mach-s5pv210/mach-herring.c index 244a265..1ebd2a7 100644 --- a/arch/arm/mach-s5pv210/mach-herring.c +++ b/arch/arm/mach-s5pv210/mach-herring.c @@ -108,6 +108,37 @@ static struct notifier_block herring_reboot_notifier = { .notifier_call = herring_notifier_call, }; +static void gps_gpio_init(void) +{ + struct device *gps_dev; + + gps_dev = device_create(sec_class, NULL, 0, NULL, "gps"); + if (IS_ERR(gps_dev)) { + pr_err("Failed to create device(gps)!\n"); + goto err; + } + + gpio_request(GPIO_GPS_nRST, "GPS_nRST"); /* XMMC3CLK */ + s3c_gpio_setpull(GPIO_GPS_nRST, S3C_GPIO_PULL_NONE); + s3c_gpio_cfgpin(GPIO_GPS_nRST, S3C_GPIO_OUTPUT); + gpio_direction_output(GPIO_GPS_nRST, 1); + + gpio_request(GPIO_GPS_PWR_EN, "GPS_PWR_EN"); /* XMMC3CLK */ + s3c_gpio_setpull(GPIO_GPS_PWR_EN, S3C_GPIO_PULL_NONE); + s3c_gpio_cfgpin(GPIO_GPS_PWR_EN, S3C_GPIO_OUTPUT); + gpio_direction_output(GPIO_GPS_PWR_EN, 0); + + s3c_gpio_setpull(GPIO_GPS_RXD, S3C_GPIO_PULL_UP); + gpio_export(GPIO_GPS_nRST, 1); + gpio_export(GPIO_GPS_PWR_EN, 1); + + gpio_export_link(gps_dev, "GPS_nRST", GPIO_GPS_nRST); + gpio_export_link(gps_dev, "GPS_PWR_EN", GPIO_GPS_PWR_EN); + + err: + return; +} + static void jupiter_switch_init(void) { sec_class = class_create(THIS_MODULE, "sec"); @@ -2627,6 +2658,8 @@ static void __init herring_machine_init(void) register_reboot_notifier(&herring_reboot_notifier); jupiter_switch_init(); + + gps_gpio_init(); } #ifdef CONFIG_USB_SUPPORT |