aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm
diff options
context:
space:
mode:
authorDooHyun.Hwang <dh0421.hwang@samsung.com>2010-09-08 09:58:23 +0900
committerArve Hjønnevåg <arve@android.com>2011-11-17 17:44:05 -0800
commite0a364fccbf6ff2bceb5b246cf8b0fcd5e8bc4b1 (patch)
tree3f8c3ebb1b4dff8847d632cf5236b151e5b81d5f /arch/arm
parenta37d03018c8758059a47604e0b7eac2db9688aa7 (diff)
downloadkernel_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.c33
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