r4092 - branches/src/target/kernel/2.6.24.x/patches
werner at sita.openmoko.org
werner at sita.openmoko.org
Thu Feb 21 06:54:26 CET 2008
Author: werner
Date: 2008-02-21 06:54:23 +0100 (Thu, 21 Feb 2008)
New Revision: 4092
Modified:
branches/src/target/kernel/2.6.24.x/patches/gta02-power_control.patch
Log:
gta02-pm-gps.patch by Willie Chen
This is GPS driver for GTA02. It deals with power on/off GPS module.
The GPS data can be generated through UART1.
gta02-power_control.patch:
- arch/arm/plat-s3c24xx/neo1973_pm_gps.c (gps_pwron_set, gps_pwron_get,
gta01_pm_gps_suspend, gta01_pm_gps_resume, gta01_pm_gps_probe,
gta01_pm_gps_remove): added support for GTA02
Modified: branches/src/target/kernel/2.6.24.x/patches/gta02-power_control.patch
===================================================================
--- branches/src/target/kernel/2.6.24.x/patches/gta02-power_control.patch 2008-02-21 05:16:15 UTC (rev 4091)
+++ branches/src/target/kernel/2.6.24.x/patches/gta02-power_control.patch 2008-02-21 05:54:23 UTC (rev 4092)
@@ -295,3 +295,272 @@
return sysfs_create_group(&pdev->dev.kobj, >a01_gsm_attr_group);
}
+Index: linux-2.6.24/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
+===================================================================
+--- linux-2.6.24.orig/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
++++ linux-2.6.24/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
+@@ -17,10 +17,18 @@
+ #include <linux/delay.h>
+ #include <linux/platform_device.h>
+
+-#include <linux/pcf50606.h>
+-
+ #include <asm/hardware.h>
++
++#include <asm/mach-types.h>
++#ifdef CONFIG_MACH_NEO1973_GTA01
+ #include <asm/arch/gta01.h>
++#include <linux/pcf50606.h>
++#endif
++
++#ifdef CONFIG_MACH_NEO1973_GTA02
++#include <asm/arch/gta02.h>
++#include <linux/pcf50633.h>
++#endif
+
+ /* This is the 2.8V supply for the RTC crystal, the mail clock crystal and
+ * the input to VDD_RF */
+@@ -248,15 +256,42 @@ static int gps_power_1v5_get(void)
+ /* This is the POWERON pin */
+ static void gps_pwron_set(int on)
+ {
+- s3c2410_gpio_setpin(GTA01_GPIO_GPS_PWRON, on);
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01())
++ s3c2410_gpio_setpin(GTA01_GPIO_GPS_PWRON, on);
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
++
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ if (on)
++ pcf50633_voltage_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, 3000);
++ pcf50633_onoff_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, on);
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
+ }
+
+ static int gps_pwron_get(void)
+ {
+- if (s3c2410_gpio_getpin(GTA01_GPIO_GPS_PWRON))
+- return 1;
+- else
+- return 0;
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01()) {
++ if (s3c2410_gpio_getpin(GTA01_GPIO_GPS_PWRON))
++ return 1;
++ else
++ return 0;
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
++
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ if (pcf50633_onoff_get(pcf50633_global, PCF50633_REGULATOR_LDO5))
++ return 1;
++ else
++ return 0;
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
++ return -1;
+ }
+
+ /* This is the nRESET pin */
+@@ -441,17 +476,40 @@ static DEVICE_ATTR(power_sequence, 0644,
+ static int gta01_pm_gps_suspend(struct platform_device *pdev,
+ pm_message_t state)
+ {
+- /* FIXME */
+- gps_power_sequence_down();
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01()) {
++ /* FIXME */
++ gps_power_sequence_down();
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
++
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ /* FIXME */
++ pcf50633_onoff_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, 0);
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
+
+ return 0;
+ }
+
+ static int gta01_pm_gps_resume(struct platform_device *pdev)
+ {
+- /* FIXME */
+- gps_power_sequence_up();
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01()) {
++ /* FIXME */
++ gps_power_sequence_up();
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
+
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ /* FIXME */
++ pcf50633_onoff_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, 1);
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
++ }
+ return 0;
+ }
+ #else
+@@ -476,59 +534,109 @@ static struct attribute_group gta01_gps_
+ .attrs = gta01_gps_sysfs_entries,
+ };
+
++static struct attribute *gta02_gps_sysfs_entries[] = {
++ &dev_attr_pwron.attr,
++ NULL
++};
++
++static struct attribute_group gta02_gps_attr_group = {
++ .name = NULL,
++ .attrs = gta02_gps_sysfs_entries,
++};
++
+ static int __init gta01_pm_gps_probe(struct platform_device *pdev)
+ {
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_PWRON, S3C2410_GPIO_OUTPUT);
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01()) {
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_PWRON, S3C2410_GPIO_OUTPUT);
+
+- switch (system_rev) {
+- case GTA01v3_SYSTEM_REV:
+- break;
+- case GTA01v4_SYSTEM_REV:
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_RESET, S3C2410_GPIO_OUTPUT);
+- break;
+- case GTA01Bv3_SYSTEM_REV:
+- case GTA01Bv4_SYSTEM_REV:
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_3V3, S3C2410_GPIO_OUTPUT);
+- /* fallthrough */
+- case GTA01Bv2_SYSTEM_REV:
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_2V8, S3C2410_GPIO_OUTPUT);
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_3V, S3C2410_GPIO_OUTPUT);
+- s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_RESET, S3C2410_GPIO_OUTPUT);
+- break;
+- default:
+- dev_warn(&pdev->dev, "Unknown GTA01 Revision 0x%x, "
+- "AGPS PM features not available!!!\n",
+- system_rev);
+- return -1;
+- break;
+- }
++ switch (system_rev) {
++ case GTA01v3_SYSTEM_REV:
++ break;
++ case GTA01v4_SYSTEM_REV:
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_RESET, S3C2410_GPIO_OUTPUT);
++ break;
++ case GTA01Bv3_SYSTEM_REV:
++ case GTA01Bv4_SYSTEM_REV:
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_3V3, S3C2410_GPIO_OUTPUT);
++ /* fallthrough */
++ case GTA01Bv2_SYSTEM_REV:
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_2V8, S3C2410_GPIO_OUTPUT);
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_EN_3V, S3C2410_GPIO_OUTPUT);
++ s3c2410_gpio_cfgpin(GTA01_GPIO_GPS_RESET, S3C2410_GPIO_OUTPUT);
++ break;
++ default:
++ dev_warn(&pdev->dev, "Unknown GTA01 Revision 0x%x, "
++ "AGPS PM features not available!!!\n",
++ system_rev);
++ return -1;
++ break;
++ }
+
+- gps_power_sequence_down();
++ gps_power_sequence_down();
+
+- switch (system_rev) {
+- case GTA01v3_SYSTEM_REV:
+- case GTA01v4_SYSTEM_REV:
+- case GTA01Bv2_SYSTEM_REV:
+- gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-3] =
+- &dev_attr_power_tcxo_2v8.attr;
+- break;
+- case GTA01Bv3_SYSTEM_REV:
+- case GTA01Bv4_SYSTEM_REV:
+- gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-3] =
+- &dev_attr_power_core_1v5.attr;
+- gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-2] =
+- &dev_attr_power_vdd_core_1v5.attr;
+- break;
++ switch (system_rev) {
++ case GTA01v3_SYSTEM_REV:
++ case GTA01v4_SYSTEM_REV:
++ case GTA01Bv2_SYSTEM_REV:
++ gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-3] =
++ &dev_attr_power_tcxo_2v8.attr;
++ break;
++ case GTA01Bv3_SYSTEM_REV:
++ case GTA01Bv4_SYSTEM_REV:
++ gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-3] =
++ &dev_attr_power_core_1v5.attr;
++ gta01_gps_sysfs_entries[ARRAY_SIZE(gta01_gps_sysfs_entries)-2] =
++ &dev_attr_power_vdd_core_1v5.attr;
++ break;
++ }
++
++ return sysfs_create_group(&pdev->dev.kobj, >a01_gps_attr_group);
+ }
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
+
+- return sysfs_create_group(&pdev->dev.kobj, >a01_gps_attr_group);
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ switch (system_rev) {
++ case GTA02v2_SYSTEM_REV:
++ case GTA02v3_SYSTEM_REV:
++ case GTA02v4_SYSTEM_REV:
++ case GTA02v5_SYSTEM_REV:
++ pcf50633_voltage_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, 3000);
++ pcf50633_onoff_set(pcf50633_global,
++ PCF50633_REGULATOR_LDO5, 0);
++ dev_info(&pdev->dev, "FIC Neo1973 GPS Power Managerment:"
++ "starting\n");
++ break;
++ default:
++ dev_warn(&pdev->dev, "Unknown GTA02 Revision 0x%x, "
++ "AGPS PM features not available!!!\n",
++ system_rev);
++ return -1;
++ break;
++ }
++ return sysfs_create_group(&pdev->dev.kobj, >a02_gps_attr_group);
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
++ return -1;
+ }
+
+ static int gta01_pm_gps_remove(struct platform_device *pdev)
+ {
+- gps_power_sequence_down();
+- sysfs_remove_group(&pdev->dev.kobj, >a01_gps_attr_group);
++#ifdef CONFIG_MACH_NEO1973_GTA01
++ if (machine_is_neo1973_gta01()) {
++ gps_power_sequence_down();
++ sysfs_remove_group(&pdev->dev.kobj, >a01_gps_attr_group);
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA01 */
+
++#ifdef CONFIG_MACH_NEO1973_GTA02
++ if (machine_is_neo1973_gta02()) {
++ pcf50633_onoff_set(pcf50633_global, PCF50633_REGULATOR_LDO5, 0);
++ sysfs_remove_group(&pdev->dev.kobj, >a02_gps_attr_group);
++ }
++#endif /* CONFIG_MACH_NEO1973_GTA02 */
+ return 0;
+ }
+
More information about the commitlog
mailing list