diff options
Diffstat (limited to 'target/linux/s3c24xx/patches-2.6.24/1097-introduce-usb-host-power-control.patch.patch')
-rw-r--r-- | target/linux/s3c24xx/patches-2.6.24/1097-introduce-usb-host-power-control.patch.patch | 167 |
1 files changed, 167 insertions, 0 deletions
diff --git a/target/linux/s3c24xx/patches-2.6.24/1097-introduce-usb-host-power-control.patch.patch b/target/linux/s3c24xx/patches-2.6.24/1097-introduce-usb-host-power-control.patch.patch new file mode 100644 index 0000000000..0192df4cab --- /dev/null +++ b/target/linux/s3c24xx/patches-2.6.24/1097-introduce-usb-host-power-control.patch.patch @@ -0,0 +1,167 @@ +From 20369a802d4df104489daeb85388554f79e7e281 Mon Sep 17 00:00:00 2001 +From: Andy Green <andy@openmoko.com> +Date: Sun, 13 Apr 2008 07:25:51 +0100 +Subject: [PATCH] introduce-usb-host-power-control.patch + +Unless I really really missed the point, there is no support for enabling +USB Host power for USB host mode. This patch adds a /sys node for GTA02 +that allows control of the charge pump for 5V out on the USB mini connector +It doesn't change any logical mode in the CPU, just enables (1) and disables +(0) USB host power. + +# cat /sys/devices/platform/neo1973-pm-host.0/hostmode +0 +# echo 1 > /sys/devices/platform/neo1973-pm-host.0/hostmode + +Signed-off-by: Andy Green <andy@openmoko.com> +--- + arch/arm/mach-s3c2440/mach-gta02.c | 6 ++ + arch/arm/plat-s3c24xx/Makefile | 2 +- + arch/arm/plat-s3c24xx/neo1973_pm_host.c | 101 +++++++++++++++++++++++++++++++ + 3 files changed, 108 insertions(+), 1 deletions(-) + create mode 100644 arch/arm/plat-s3c24xx/neo1973_pm_host.c + +diff --git a/arch/arm/mach-s3c2440/mach-gta02.c b/arch/arm/mach-s3c2440/mach-gta02.c +index f18c8fd..5bd68a6 100644 +--- a/arch/arm/mach-s3c2440/mach-gta02.c ++++ b/arch/arm/mach-s3c2440/mach-gta02.c +@@ -1030,6 +1030,11 @@ static struct platform_device gta01_pm_gsm_dev = { + .name = "neo1973-pm-gsm", + }; + ++static struct platform_device gta02_pm_usbhost_dev = { ++ .name = "neo1973-pm-host", ++}; ++ ++ + /* USB */ + static struct s3c2410_hcd_info gta02_usb_info = { + .port[0] = { +@@ -1287,6 +1292,7 @@ static void __init gta02_machine_init(void) + platform_device_register(&s3c_device_spi_acc); + platform_device_register(>a01_button_dev); + platform_device_register(>a01_pm_gsm_dev); ++ platform_device_register(>a02_pm_usbhost_dev); + + mangle_pmu_pdata_by_system_rev(); + platform_device_register(>a02_pmu_dev); +diff --git a/arch/arm/plat-s3c24xx/Makefile b/arch/arm/plat-s3c24xx/Makefile +index 7192912..e1686a0 100644 +--- a/arch/arm/plat-s3c24xx/Makefile ++++ b/arch/arm/plat-s3c24xx/Makefile +@@ -28,4 +28,4 @@ obj-$(CONFIG_PM) += pm.o + obj-$(CONFIG_PM) += sleep.o + obj-$(CONFIG_S3C2410_DMA) += dma.o + obj-$(CONFIG_MACH_SMDK) += common-smdk.o +-obj-$(CONFIG_MACH_NEO1973) += neo1973_pm_gsm.o neo1973_pm_gps.o neo1973_pm_bt.o ++obj-$(CONFIG_MACH_NEO1973) += neo1973_pm_host.o neo1973_pm_gsm.o neo1973_pm_gps.o neo1973_pm_bt.o +diff --git a/arch/arm/plat-s3c24xx/neo1973_pm_host.c b/arch/arm/plat-s3c24xx/neo1973_pm_host.c +new file mode 100644 +index 0000000..4eae341 +--- /dev/null ++++ b/arch/arm/plat-s3c24xx/neo1973_pm_host.c +@@ -0,0 +1,101 @@ ++/* ++ * Bluetooth PM code for the FIC Neo1973 GSM Phone ++ * ++ * (C) 2007 by OpenMoko Inc. ++ * Author: Harald Welte <laforge@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 version 2 as ++ * published by the Free Software Foundation ++ * ++ */ ++ ++#include <linux/module.h> ++#include <linux/init.h> ++#include <linux/kernel.h> ++#include <linux/platform_device.h> ++ ++#include <asm/hardware.h> ++#include <asm/mach-types.h> ++ ++#ifdef CONFIG_MACH_NEO1973_GTA02 ++#include <asm/arch/gta02.h> ++#include <linux/pcf50633.h> ++ ++static ssize_t pm_host_read(struct device *dev, struct device_attribute *attr, ++ char *buf) ++{ ++ return sprintf(buf, "%d\n", ++ pcf50633_gpio_get(pcf50633_global, PCF50633_GPO)); ++} ++ ++static ssize_t pm_host_write(struct device *dev, struct device_attribute *attr, ++ const char *buf, size_t count) ++{ ++ unsigned long on = simple_strtoul(buf, NULL, 10); ++ ++ pcf50633_gpio_set(pcf50633_global, PCF50633_GPO, on); ++ ++ return count; ++} ++ ++static DEVICE_ATTR(hostmode, 0644, pm_host_read, pm_host_write); ++ ++static struct attribute *neo1973_pm_host_sysfs_entries[] = { ++ &dev_attr_hostmode.attr, ++ NULL ++}; ++ ++static struct attribute_group neo1973_pm_host_attr_group = { ++ .name = NULL, ++ .attrs = neo1973_pm_host_sysfs_entries, ++}; ++ ++static int __init neo1973_pm_host_probe(struct platform_device *pdev) ++{ ++ dev_info(&pdev->dev, "starting\n"); ++ ++ switch (machine_arch_type) { ++#ifdef CONFIG_MACH_NEO1973_GTA01 ++ case MACH_TYPE_NEO1973_GTA01: ++ return -EINVAL; ++#endif /* CONFIG_MACH_NEO1973_GTA01 */ ++ default: ++ break; ++ } ++ ++ return sysfs_create_group(&pdev->dev.kobj, &neo1973_pm_host_attr_group); ++} ++ ++static int neo1973_pm_host_remove(struct platform_device *pdev) ++{ ++ sysfs_remove_group(&pdev->dev.kobj, &neo1973_pm_host_attr_group); ++ return 0; ++} ++ ++static struct platform_driver neo1973_pm_host_driver = { ++ .probe = neo1973_pm_host_probe, ++ .remove = neo1973_pm_host_remove, ++ .driver = { ++ .name = "neo1973-pm-host", ++ }, ++}; ++ ++static int __devinit neo1973_pm_host_init(void) ++{ ++ return platform_driver_register(&neo1973_pm_host_driver); ++} ++ ++static void neo1973_pm_host_exit(void) ++{ ++ platform_driver_unregister(&neo1973_pm_host_driver); ++} ++ ++module_init(neo1973_pm_host_init); ++module_exit(neo1973_pm_host_exit); ++ ++MODULE_LICENSE("GPL"); ++MODULE_AUTHOR("Andy Green <andy@openmoko.com>"); ++MODULE_DESCRIPTION("Neo1973 USB Host Power Management"); ++#endif +-- +1.5.6.5 + |