summaryrefslogtreecommitdiff
path: root/target/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch')
-rwxr-xr-xtarget/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch497
1 files changed, 0 insertions, 497 deletions
diff --git a/target/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch b/target/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch
deleted file mode 100755
index 8754eabcf5..0000000000
--- a/target/linux/s3c24xx/patches/0117--neo-Every-access-to-GPIO-bank-B-has-to-go-through.patch
+++ /dev/null
@@ -1,497 +0,0 @@
-From 81bf1ac05c1ba0d32db8fe8fb0cd52cb6b7d8e7e Mon Sep 17 00:00:00 2001
-From: Holger Freyther <zecke@openmoko.org>
-Date: Fri, 25 Jul 2008 23:06:05 +0100
-Subject: [PATCH] [neo] Every access to GPIO bank B has to go through the shadow code
-
- - Any setting of any PIN on bank B will undo the LED setting.
- Introduce neo1973_gpb_set_pin to set the PIN in a way not losing
- the LED or any other shadowed setting.
- - Update users of GPBXY for gta01 and gta02.
-
-Signed-Off-By: Holger Freyther <zecke@openmoko.org>
----
- arch/arm/mach-s3c2410/mach-gta01.c | 9 ++--
- arch/arm/mach-s3c2440/mach-gta02.c | 10 ++--
- arch/arm/plat-s3c24xx/Makefile | 4 +-
- arch/arm/plat-s3c24xx/neo1973_pm_bt.c | 15 +++---
- arch/arm/plat-s3c24xx/neo1973_pm_gps.c | 5 ++-
- arch/arm/plat-s3c24xx/neo1973_pm_gsm.c | 9 ++--
- arch/arm/plat-s3c24xx/neo1973_shadow.c | 86 ++++++++++++++++++++++++++++++++
- drivers/leds/leds-neo1973-gta02.c | 12 ++--
- drivers/leds/leds-neo1973-vibrator.c | 7 ++-
- drivers/video/backlight/gta01_bl.c | 9 ++--
- include/asm-arm/plat-s3c24xx/neo1973.h | 33 ++++++++++++
- 11 files changed, 165 insertions(+), 34 deletions(-)
- create mode 100644 arch/arm/plat-s3c24xx/neo1973_shadow.c
- create mode 100644 include/asm-arm/plat-s3c24xx/neo1973.h
-
-diff --git a/arch/arm/mach-s3c2410/mach-gta01.c b/arch/arm/mach-s3c2410/mach-gta01.c
-index 8c1a402..a4384b6 100644
---- a/arch/arm/mach-s3c2410/mach-gta01.c
-+++ b/arch/arm/mach-s3c2410/mach-gta01.c
-@@ -72,6 +72,7 @@
- #include <asm/plat-s3c24xx/cpu.h>
- #include <asm/plat-s3c24xx/pm.h>
- #include <asm/plat-s3c24xx/udc.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- static struct map_desc gta01_iodesc[] __initdata = {
- {
-@@ -416,10 +417,10 @@ static void gta01_mmc_set_power(unsigned char power_mode, unsigned short vdd)
- case GTA01Bv4_SYSTEM_REV:
- switch (power_mode) {
- case MMC_POWER_OFF:
-- s3c2410_gpio_setpin(GTA01_GPIO_SDMMC_ON, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_SDMMC_ON, 1);
- break;
- case MMC_POWER_ON:
-- s3c2410_gpio_setpin(GTA01_GPIO_SDMMC_ON, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_SDMMC_ON, 0);
- break;
- }
- break;
-@@ -442,10 +443,10 @@ static void gta01_udc_command(enum s3c2410_udc_cmd_e cmd)
-
- switch (cmd) {
- case S3C2410_UDC_P_ENABLE:
-- s3c2410_gpio_setpin(GTA01_GPIO_USB_PULLUP, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_USB_PULLUP, 1);
- break;
- case S3C2410_UDC_P_DISABLE:
-- s3c2410_gpio_setpin(GTA01_GPIO_USB_PULLUP, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_USB_PULLUP, 0);
- break;
- default:
- break;
-diff --git a/arch/arm/mach-s3c2440/mach-gta02.c b/arch/arm/mach-s3c2440/mach-gta02.c
-index f9e00d5..27babc9 100644
---- a/arch/arm/mach-s3c2440/mach-gta02.c
-+++ b/arch/arm/mach-s3c2440/mach-gta02.c
-@@ -75,6 +75,7 @@
- #include <asm/plat-s3c24xx/cpu.h>
- #include <asm/plat-s3c24xx/pm.h>
- #include <asm/plat-s3c24xx/udc.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
- #include <linux/jbt6k74.h>
-
- #include <linux/glamofb.h>
-@@ -127,11 +128,11 @@ FIQ_HANDLER_ENTRY(256, 512)
-
- if (fiq_ipc.vib_pwm_latched || fiq_ipc.vib_pwm) { /* not idle */
- if (((u8)_fiq_count_fiqs) == fiq_ipc.vib_pwm_latched)
-- s3c2410_gpio_setpin(fiq_ipc.vib_gpio_pin, 0);
-+ neo1973_gpb_setpin(fiq_ipc.vib_gpio_pin, 0);
- if (((u8)_fiq_count_fiqs) == 0) {
- fiq_ipc.vib_pwm_latched = fiq_ipc.vib_pwm;
- if (fiq_ipc.vib_pwm_latched)
-- s3c2410_gpio_setpin(fiq_ipc.vib_gpio_pin, 1);
-+ neo1973_gpb_setpin(fiq_ipc.vib_gpio_pin, 1);
- }
- divisor = FIQ_DIVISOR_VIBRATOR;
- }
-@@ -319,6 +320,7 @@ FIQ_HANDLER_ENTRY(256, 512)
- FIQ_HANDLER_END()
-
-
-+
- /**
- * returns PCB revision information in b9,b8 and b2,b1,b0
- * Pre-GTA02 A6 returns 0x000
-@@ -763,10 +765,10 @@ static void gta02_udc_command(enum s3c2410_udc_cmd_e cmd)
-
- switch (cmd) {
- case S3C2410_UDC_P_ENABLE:
-- s3c2410_gpio_setpin(GTA02_GPIO_USB_PULLUP, 1);
-+ neo1973_gpb_setpin(GTA02_GPIO_USB_PULLUP, 1);
- break;
- case S3C2410_UDC_P_DISABLE:
-- s3c2410_gpio_setpin(GTA02_GPIO_USB_PULLUP, 0);
-+ neo1973_gpb_setpin(GTA02_GPIO_USB_PULLUP, 0);
- break;
- case S3C2410_UDC_P_RESET:
- /* FIXME! */
-diff --git a/arch/arm/plat-s3c24xx/Makefile b/arch/arm/plat-s3c24xx/Makefile
-index 6b32a8a..c173f7b 100644
---- a/arch/arm/plat-s3c24xx/Makefile
-+++ b/arch/arm/plat-s3c24xx/Makefile
-@@ -33,4 +33,6 @@ obj-$(CONFIG_MACH_NEO1973) += neo1973_version.o \
- neo1973_pm_host.o \
- neo1973_pm_gsm.o \
- neo1973_pm_gps.o \
-- neo1973_pm_bt.o
-+ neo1973_pm_bt.o \
-+ neo1973_shadow.o
-+
-diff --git a/arch/arm/plat-s3c24xx/neo1973_pm_bt.c b/arch/arm/plat-s3c24xx/neo1973_pm_bt.c
-index a9694b4..dfc9ae8 100644
---- a/arch/arm/plat-s3c24xx/neo1973_pm_bt.c
-+++ b/arch/arm/plat-s3c24xx/neo1973_pm_bt.c
-@@ -18,6 +18,7 @@
-
- #include <asm/hardware.h>
- #include <asm/mach-types.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- #ifdef CONFIG_MACH_NEO1973_GTA01
- #include <asm/arch/gta01.h>
-@@ -95,20 +96,20 @@ static ssize_t bt_write(struct device *dev, struct device_attribute *attr,
- /* if we are powering up, assert reset, then power,
- * then release reset */
- if (on) {
-- s3c2410_gpio_setpin(GTA01_GPIO_BT_EN, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_BT_EN, 0);
- pcf50606_voltage_set(pcf50606_global,
- PCF50606_REGULATOR_D1REG,
- 3100);
- }
- pcf50606_onoff_set(pcf50606_global,
- PCF50606_REGULATOR_D1REG, on);
-- s3c2410_gpio_setpin(GTA01_GPIO_BT_EN, on);
-+ neo1973_gpb_setpin(GTA01_GPIO_BT_EN, on);
- break;
- #endif /* CONFIG_MACH_NEO1973_GTA01 */
-
- #ifdef CONFIG_MACH_NEO1973_GTA02
- case MACH_TYPE_NEO1973_GTA02:
-- s3c2410_gpio_setpin(GTA02_GPIO_BT_EN, on ? 0 : 1);
-+ neo1973_gpb_setpin(GTA02_GPIO_BT_EN, on ? 0 : 1);
- if (on)
- pcf50633_voltage_set(pcf50633_global,
- PCF50633_REGULATOR_LDO4, 3200);
-@@ -127,13 +128,13 @@ static ssize_t bt_write(struct device *dev, struct device_attribute *attr,
-
- #ifdef CONFIG_MACH_NEO1973_GTA01
- case MACH_TYPE_NEO1973_GTA01:
-- s3c2410_gpio_setpin(GTA01_GPIO_BT_EN, on ? 0 : 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_BT_EN, on ? 0 : 1);
- break;
- #endif /* CONFIG_MACH_NEO1973_GTA01 */
-
- #ifdef CONFIG_MACH_NEO1973_GTA02
- case MACH_TYPE_NEO1973_GTA02:
-- s3c2410_gpio_setpin(GTA02_GPIO_BT_EN, on ? 0 : 1);
-+ neo1973_gpb_setpin(GTA02_GPIO_BT_EN, on ? 0 : 1);
- break;
- #endif /* CONFIG_MACH_NEO1973_GTA02 */
-
-@@ -192,7 +193,7 @@ static int __init gta01_bt_probe(struct platform_device *pdev)
- PCF50606_REGULATOR_D1REG, 0);
- /* we pull reset to low to make sure that the chip doesn't
- * drain power through the reset line */
-- s3c2410_gpio_setpin(GTA01_GPIO_BT_EN, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_BT_EN, 0);
- break;
- #endif /* CONFIG_MACH_NEO1973_GTA01 */
-
-@@ -203,7 +204,7 @@ static int __init gta01_bt_probe(struct platform_device *pdev)
- PCF50633_REGULATOR_LDO4, 0);
- /* we pull reset to low to make sure that the chip doesn't
- * drain power through the reset line */
-- s3c2410_gpio_setpin(GTA02_GPIO_BT_EN, 0);
-+ neo1973_gpb_setpin(GTA02_GPIO_BT_EN, 0);
- break;
- #endif /* CONFIG_MACH_NEO1973_GTA02 */
-
-diff --git a/arch/arm/plat-s3c24xx/neo1973_pm_gps.c b/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
-index d882f7b..d020f8d 100644
---- a/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
-+++ b/arch/arm/plat-s3c24xx/neo1973_pm_gps.c
-@@ -20,6 +20,9 @@
- #include <asm/hardware.h>
-
- #include <asm/mach-types.h>
-+
-+#include <asm/plat-s3c24xx/neo1973.h>
-+
- #ifdef CONFIG_MACH_NEO1973_GTA01
- #include <asm/arch/gta01.h>
- #include <linux/pcf50606.h>
-@@ -264,7 +267,7 @@ static void gps_pwron_set(int on)
- {
- #ifdef CONFIG_MACH_NEO1973_GTA01
- if (machine_is_neo1973_gta01())
-- s3c2410_gpio_setpin(GTA01_GPIO_GPS_PWRON, on);
-+ neo1973_gpb_setpin(GTA01_GPIO_GPS_PWRON, on);
- #endif /* CONFIG_MACH_NEO1973_GTA01 */
-
- #ifdef CONFIG_MACH_NEO1973_GTA02
-diff --git a/arch/arm/plat-s3c24xx/neo1973_pm_gsm.c b/arch/arm/plat-s3c24xx/neo1973_pm_gsm.c
-index 5ad942e..149b866 100644
---- a/arch/arm/plat-s3c24xx/neo1973_pm_gsm.c
-+++ b/arch/arm/plat-s3c24xx/neo1973_pm_gsm.c
-@@ -22,6 +22,7 @@
- #include <asm/gpio.h>
- #include <asm/mach-types.h>
- #include <asm/arch/gta01.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- #ifdef CONFIG_MACH_NEO1973_GTA02
- #include <asm/arch/gta02.h>
-@@ -109,9 +110,9 @@ static ssize_t gsm_write(struct device *dev, struct device_attribute *attr,
- #endif
- }
-
-- s3c2410_gpio_setpin(GTA01_GPIO_MODEM_ON, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_MODEM_ON, 1);
- } else {
-- s3c2410_gpio_setpin(GTA01_GPIO_MODEM_ON, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_MODEM_ON, 0);
-
- switch (system_rev) {
- #ifdef CONFIG_MACH_NEO1973_GTA02
-@@ -138,9 +139,9 @@ static ssize_t gsm_write(struct device *dev, struct device_attribute *attr,
- }
- } else if (!strcmp(attr->attr.name, "reset")) {
- if (machine_is_neo1973_gta01())
-- s3c2410_gpio_setpin(GTA01_GPIO_MODEM_RST, on);
-+ neo1973_gpb_setpin(GTA01_GPIO_MODEM_RST, on);
- else if (machine_is_neo1973_gta02())
-- s3c2410_gpio_setpin(GTA02_GPIO_MODEM_RST, on);
-+ neo1973_gpb_setpin(GTA02_GPIO_MODEM_RST, on);
- } else if (!strcmp(attr->attr.name, "download")) {
- if (machine_is_neo1973_gta01())
- s3c2410_gpio_setpin(GTA01_GPIO_MODEM_DNLOAD, on);
-diff --git a/arch/arm/plat-s3c24xx/neo1973_shadow.c b/arch/arm/plat-s3c24xx/neo1973_shadow.c
-new file mode 100644
-index 0000000..09667da
---- /dev/null
-+++ b/arch/arm/plat-s3c24xx/neo1973_shadow.c
-@@ -0,0 +1,86 @@
-+/*
-+ * include/asm-arm/plat-s3c24xx/neo1973.h
-+ *
-+ * Common utility code for GTA01 and GTA02
-+ *
-+ * Copyright (C) 2008 by Openmoko, Inc.
-+ * Author: Holger Hans Peter Freyther <freyther@openmoko.org>
-+ * All rights reserved.
-+ *
-+ * This program is free software; you can redistribute it and/or
-+ * modify it under the terms of the GNU General Public License as
-+ * published by the Free Software Foundation; either version 2 of
-+ * the License, or (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+ * GNU General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
-+ * MA 02111-1307 USA
-+ *
-+ */
-+
-+#include <linux/io.h>
-+#include <linux/irq.h>
-+
-+#include <asm/gpio.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-+
-+/**
-+ * Shadow GPIO bank B handling. For the LEDs we need to keep track of the state
-+ * in software. The s3c2410_gpio_setpin must not be used for GPIOs on bank B
-+ */
-+static unsigned long gpb_mask;
-+static unsigned long gpb_state;
-+
-+void neo1973_gpb_add_shadow_gpio(unsigned int gpio)
-+{
-+ unsigned long offset = S3C2410_GPIO_OFFSET(gpio);
-+ unsigned long flags;
-+
-+ local_irq_save(flags);
-+ gpb_mask |= 1L << offset;
-+ local_irq_restore(flags);
-+}
-+EXPORT_SYMBOL(neo1973_gpb_add_shadow_gpio);
-+
-+static void set_shadow_gpio(unsigned long offset, unsigned int value)
-+{
-+ unsigned long state = value != 0;
-+
-+ gpb_state &= ~(1L << offset);
-+ gpb_state |= state << offset;
-+}
-+
-+void neo1973_gpb_setpin(unsigned int pin, unsigned to)
-+{
-+ void __iomem *base = S3C24XX_GPIO_BASE(S3C2410_GPB0);
-+ unsigned long offset = S3C2410_GPIO_OFFSET(pin);
-+ unsigned long flags;
-+ unsigned long dat;
-+
-+ BUG_ON(base != S3C24XX_GPIO_BASE(pin));
-+
-+ local_irq_save(flags);
-+ dat = __raw_readl(base + 0x04);
-+
-+ /* Add the shadow values */
-+ dat &= ~gpb_mask;
-+ dat |= gpb_state;
-+
-+ /* Do the operation like s3c2410_gpio_setpin */
-+ dat &= ~(1L << offset);
-+ dat |= to << offset;
-+
-+ /* Update the shadow state */
-+ if ((1L << offset) & gpb_mask)
-+ set_shadow_gpio(offset, to);
-+
-+ __raw_writel(dat, base + 0x04);
-+ local_irq_restore(flags);
-+}
-+EXPORT_SYMBOL(neo1973_gpb_setpin);
-diff --git a/drivers/leds/leds-neo1973-gta02.c b/drivers/leds/leds-neo1973-gta02.c
-index 343550a..952ad69 100644
---- a/drivers/leds/leds-neo1973-gta02.c
-+++ b/drivers/leds/leds-neo1973-gta02.c
-@@ -20,6 +20,7 @@
- #include <asm/arch/pwm.h>
- #include <asm/arch/gta02.h>
- #include <asm/plat-s3c/regs-timer.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- #define MAX_LEDS 3
- #define COUNTER 256
-@@ -60,14 +61,13 @@ static void gta02led_set(struct led_classdev *led_cdev,
- * value == 0 -> 0% duty cycle (zero power)
- */
- mutex_lock(&lp->mutex);
-+
- if (lp->has_pwm) {
-- s3c2410_pwm_duty_cycle(value, &lp->pwm);
-+ s3c2410_pwm_duty_cycle(value, &lp->pwm);
- } else {
-- if (value)
-- s3c2410_gpio_setpin(lp->gpio, 1);
-- else
-- s3c2410_gpio_setpin(lp->gpio, 0);
-+ neo1973_gpb_setpin(lp->gpio, value ? 1 : 0);
- }
-+
- mutex_unlock(&lp->mutex);
- }
-
-@@ -164,7 +164,7 @@ static int __init gta02led_probe(struct platform_device *pdev)
- case S3C2410_GPB3:
- lp->has_pwm = 0;
- s3c2410_gpio_cfgpin(lp->gpio, S3C2410_GPIO_OUTPUT);
-- s3c2410_gpio_setpin(lp->gpio, 0);
-+ neo1973_gpb_add_shadow_gpio(lp->gpio);
- break;
- default:
- break;
-diff --git a/drivers/leds/leds-neo1973-vibrator.c b/drivers/leds/leds-neo1973-vibrator.c
-index f31302d..647e860 100644
---- a/drivers/leds/leds-neo1973-vibrator.c
-+++ b/drivers/leds/leds-neo1973-vibrator.c
-@@ -24,6 +24,7 @@
- #include <asm/plat-s3c/regs-timer.h>
-
- #include <asm/arch-s3c2410/fiq_ipc_gta02.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- #define COUNTER 64
-
-@@ -56,9 +57,9 @@ static void neo1973_vib_vib_set(struct led_classdev *led_cdev,
- s3c2410_pwm_duty_cycle(value / 4, &vp->pwm);
- else {
- if (value)
-- s3c2410_gpio_setpin(vp->gpio, 1);
-+ neo1973_gpb_setpin(vp->gpio, 1);
- else
-- s3c2410_gpio_setpin(vp->gpio, 0);
-+ neo1973_gpb_setpin(vp->gpio, 0);
- }
-
- mutex_unlock(&vp->mutex);
-@@ -131,7 +132,7 @@ static int __init neo1973_vib_probe(struct platform_device *pdev)
- platform_set_drvdata(pdev, &neo1973_vib_led);
-
- if (machine_is_neo1973_gta02()) { /* use FIQ to control GPIO */
-- s3c2410_gpio_setpin(neo1973_vib_led.gpio, 0); /* off */
-+ neo1973_gpb_setpin(neo1973_vib_led.gpio, 0); /* off */
- s3c2410_gpio_cfgpin(neo1973_vib_led.gpio, S3C2410_GPIO_OUTPUT);
- /* safe, kmalloc'd copy needed for FIQ ISR */
- fiq_ipc.vib_gpio_pin = neo1973_vib_led.gpio;
-diff --git a/drivers/video/backlight/gta01_bl.c b/drivers/video/backlight/gta01_bl.c
-index bd7d41f..301ec9c 100644
---- a/drivers/video/backlight/gta01_bl.c
-+++ b/drivers/video/backlight/gta01_bl.c
-@@ -40,6 +40,7 @@
- #include <asm/arch/pwm.h>
-
- #include <asm/plat-s3c/regs-timer.h>
-+#include <asm/plat-s3c24xx/neo1973.h>
-
- static struct backlight_properties gta01bl_prop;
- static struct backlight_device *gta01_backlight_device;
-@@ -83,12 +84,12 @@ static int gta01bl_send_intensity(struct backlight_device *bd)
- mutex_lock(&gta01bl.mutex);
- #ifdef GTA01_BACKLIGHT_ONOFF_ONLY
- if (intensity)
-- s3c2410_gpio_setpin(GTA01_GPIO_BACKLIGHT, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_BACKLIGHT, 1);
- else
-- s3c2410_gpio_setpin(GTA01_GPIO_BACKLIGHT, 0);
-+ neo1973_gpb_setpin(GTA01_GPIO_BACKLIGHT, 0);
- #else
- if (intensity == bd->props.max_brightness) {
-- s3c2410_gpio_setpin(GTA01_GPIO_BACKLIGHT, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_BACKLIGHT, 1);
- s3c2410_gpio_cfgpin(GTA01_GPIO_BACKLIGHT, S3C2410_GPIO_OUTPUT);
- } else {
- s3c2410_pwm_duty_cycle(intensity & 0xffff, &gta01bl.pwm);
-@@ -222,7 +223,7 @@ static int gta01bl_remove(struct platform_device *dev)
- mutex_destroy(&gta01bl.mutex);
-
- s3c2410_gpio_cfgpin(GTA01_GPIO_BACKLIGHT, S3C2410_GPIO_OUTPUT);
-- s3c2410_gpio_setpin(GTA01_GPIO_BACKLIGHT, 1);
-+ neo1973_gpb_setpin(GTA01_GPIO_BACKLIGHT, 1);
-
- return 0;
- }
-diff --git a/include/asm-arm/plat-s3c24xx/neo1973.h b/include/asm-arm/plat-s3c24xx/neo1973.h
-new file mode 100644
-index 0000000..63297de
---- /dev/null
-+++ b/include/asm-arm/plat-s3c24xx/neo1973.h
-@@ -0,0 +1,33 @@
-+/*
-+ * include/asm-arm/plat-s3c24xx/neo1973.h
-+ *
-+ * Common utility code for GTA01 and GTA02
-+ *
-+ * Copyright (C) 2008 by Openmoko, Inc.
-+ * Author: Holger Hans Peter Freyther <freyther@openmoko.org>
-+ * All rights reserved.
-+ *
-+ * This program is free software; you can redistribute it and/or
-+ * modify it under the terms of the GNU General Public License as
-+ * published by the Free Software Foundation; either version 2 of
-+ * the License, or (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+ * GNU General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
-+ * MA 02111-1307 USA
-+ *
-+ */
-+
-+#ifndef NEO1973_H
-+#define NEO1973_H
-+
-+void neo1973_gpb_add_shadow_gpio(unsigned int gpio);
-+void neo1973_gpb_setpin(unsigned int pin, unsigned to);
-+
-+#endif
---
-1.5.6.3
-