diff options
Diffstat (limited to 'recipes/linux/linux-2.6.31/cm-x300/linux-2.6.31-cm-x300.patch')
-rw-r--r-- | recipes/linux/linux-2.6.31/cm-x300/linux-2.6.31-cm-x300.patch | 2267 |
1 files changed, 2267 insertions, 0 deletions
diff --git a/recipes/linux/linux-2.6.31/cm-x300/linux-2.6.31-cm-x300.patch b/recipes/linux/linux-2.6.31/cm-x300/linux-2.6.31-cm-x300.patch new file mode 100644 index 0000000000..4149d94b66 --- /dev/null +++ b/recipes/linux/linux-2.6.31/cm-x300/linux-2.6.31-cm-x300.patch @@ -0,0 +1,2267 @@ + arch/arm/configs/cm_x300_defconfig | 344 ++++++++++++++++++---------- + arch/arm/mach-pxa/Kconfig | 2 + + arch/arm/mach-pxa/Makefile | 2 +- + arch/arm/mach-pxa/cm-x300-ulpi.c | 307 +++++++++++++++++++++++++ + arch/arm/mach-pxa/cm-x300.c | 358 ++++++++++++++++++++++++++--- + arch/arm/mach-pxa/include/mach/regs-u2d.h | 199 ++++++++++++++++ + arch/arm/mach-pxa/pxa3xx.c | 67 ++++++- + arch/arm/mach-pxa/sleep.S | 5 + + drivers/power/da9030_battery.c | 95 ++++++++ + sound/soc/pxa/Kconfig | 3 +- + sound/soc/pxa/em-x270.c | 10 +- + 11 files changed, 1231 insertions(+), 161 deletions(-) + +diff --git a/arch/arm/configs/cm_x300_defconfig b/arch/arm/configs/cm_x300_defconfig +index d18d21b..6f15256 100644 +--- a/arch/arm/configs/cm_x300_defconfig ++++ b/arch/arm/configs/cm_x300_defconfig +@@ -1,15 +1,15 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.30-rc8 +-# Thu Jun 4 09:53:21 2009 ++# Linux kernel version: 2.6.31 ++# Sun Nov 22 13:04:56 2009 + # + CONFIG_ARM=y ++CONFIG_HAVE_PWM=y + CONFIG_SYS_SUPPORTS_APM_EMULATION=y + CONFIG_GENERIC_GPIO=y + CONFIG_GENERIC_TIME=y + CONFIG_GENERIC_CLOCKEVENTS=y + CONFIG_MMU=y +-# CONFIG_NO_IOPORT is not set + CONFIG_GENERIC_HARDIRQS=y + CONFIG_STACKTRACE_SUPPORT=y + CONFIG_HAVE_LATENCYTOP_SUPPORT=y +@@ -18,14 +18,13 @@ CONFIG_TRACE_IRQFLAGS_SUPPORT=y + CONFIG_HARDIRQS_SW_RESEND=y + CONFIG_GENERIC_IRQ_PROBE=y + CONFIG_RWSEM_GENERIC_SPINLOCK=y +-# CONFIG_ARCH_HAS_ILOG2_U32 is not set +-# CONFIG_ARCH_HAS_ILOG2_U64 is not set + CONFIG_GENERIC_HWEIGHT=y + CONFIG_GENERIC_CALIBRATE_DELAY=y + CONFIG_ARCH_MTD_XIP=y + CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y + CONFIG_VECTORS_BASE=0xffff0000 + CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++CONFIG_CONSTRUCTORS=y + + # + # General setup +@@ -72,18 +71,17 @@ CONFIG_NAMESPACES=y + CONFIG_BLK_DEV_INITRD=y + CONFIG_INITRAMFS_SOURCE="" + CONFIG_RD_GZIP=y +-CONFIG_RD_BZIP2=y +-CONFIG_RD_LZMA=y ++# CONFIG_RD_BZIP2 is not set ++# CONFIG_RD_LZMA is not set + # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set + CONFIG_SYSCTL=y + CONFIG_ANON_INODES=y +-# CONFIG_EMBEDDED is not set ++CONFIG_EMBEDDED=y + CONFIG_UID16=y + CONFIG_SYSCTL_SYSCALL=y + CONFIG_KALLSYMS=y + # CONFIG_KALLSYMS_ALL is not set + # CONFIG_KALLSYMS_EXTRA_PASS is not set +-# CONFIG_STRIP_ASM_SYMS is not set + CONFIG_HOTPLUG=y + CONFIG_PRINTK=y + CONFIG_BUG=y +@@ -96,8 +94,13 @@ CONFIG_TIMERFD=y + CONFIG_EVENTFD=y + CONFIG_SHMEM=y + CONFIG_AIO=y ++ ++# ++# Performance Counters ++# + CONFIG_VM_EVENT_COUNTERS=y + CONFIG_SLUB_DEBUG=y ++# CONFIG_STRIP_ASM_SYMS is not set + CONFIG_COMPAT_BRK=y + # CONFIG_SLAB is not set + CONFIG_SLUB=y +@@ -109,6 +112,11 @@ CONFIG_HAVE_OPROFILE=y + CONFIG_HAVE_KPROBES=y + CONFIG_HAVE_KRETPROBES=y + CONFIG_HAVE_CLK=y ++ ++# ++# GCOV-based kernel profiling ++# ++# CONFIG_GCOV_KERNEL is not set + # CONFIG_SLOW_WORK is not set + CONFIG_HAVE_GENERIC_DMA_COHERENT=y + CONFIG_SLABINFO=y +@@ -117,11 +125,11 @@ CONFIG_BASE_SMALL=0 + CONFIG_MODULES=y + # CONFIG_MODULE_FORCE_LOAD is not set + CONFIG_MODULE_UNLOAD=y +-# CONFIG_MODULE_FORCE_UNLOAD is not set ++CONFIG_MODULE_FORCE_UNLOAD=y + # CONFIG_MODVERSIONS is not set + # CONFIG_MODULE_SRCVERSION_ALL is not set + CONFIG_BLOCK=y +-# CONFIG_LBD is not set ++CONFIG_LBDAF=y + # CONFIG_BLK_DEV_BSG is not set + # CONFIG_BLK_DEV_INTEGRITY is not set + +@@ -148,13 +156,14 @@ CONFIG_FREEZER=y + # CONFIG_ARCH_VERSATILE is not set + # CONFIG_ARCH_AT91 is not set + # CONFIG_ARCH_CLPS711X is not set ++# CONFIG_ARCH_GEMINI is not set + # CONFIG_ARCH_EBSA110 is not set + # CONFIG_ARCH_EP93XX is not set +-# CONFIG_ARCH_GEMINI is not set + # CONFIG_ARCH_FOOTBRIDGE is not set ++# CONFIG_ARCH_MXC is not set ++# CONFIG_ARCH_STMP3XXX is not set + # CONFIG_ARCH_NETX is not set + # CONFIG_ARCH_H720X is not set +-# CONFIG_ARCH_IMX is not set + # CONFIG_ARCH_IOP13XX is not set + # CONFIG_ARCH_IOP32X is not set + # CONFIG_ARCH_IOP33X is not set +@@ -163,25 +172,25 @@ CONFIG_FREEZER=y + # CONFIG_ARCH_IXP4XX is not set + # CONFIG_ARCH_L7200 is not set + # CONFIG_ARCH_KIRKWOOD is not set +-# CONFIG_ARCH_KS8695 is not set +-# CONFIG_ARCH_NS9XXX is not set + # CONFIG_ARCH_LOKI is not set + # CONFIG_ARCH_MV78XX0 is not set +-# CONFIG_ARCH_MXC is not set + # CONFIG_ARCH_ORION5X is not set ++# CONFIG_ARCH_MMP is not set ++# CONFIG_ARCH_KS8695 is not set ++# CONFIG_ARCH_NS9XXX is not set ++# CONFIG_ARCH_W90X900 is not set + # CONFIG_ARCH_PNX4008 is not set + CONFIG_ARCH_PXA=y +-# CONFIG_ARCH_MMP is not set ++# CONFIG_ARCH_MSM is not set + # CONFIG_ARCH_RPC is not set + # CONFIG_ARCH_SA1100 is not set + # CONFIG_ARCH_S3C2410 is not set + # CONFIG_ARCH_S3C64XX is not set + # CONFIG_ARCH_SHARK is not set + # CONFIG_ARCH_LH7A40X is not set ++# CONFIG_ARCH_U300 is not set + # CONFIG_ARCH_DAVINCI is not set + # CONFIG_ARCH_OMAP is not set +-# CONFIG_ARCH_MSM is not set +-# CONFIG_ARCH_W90X900 is not set + + # + # Intel PXA2xx/PXA3xx Implementations +@@ -191,12 +200,13 @@ CONFIG_ARCH_PXA=y + # Supported PXA3xx Processor Variants + # + CONFIG_CPU_PXA300=y +-# CONFIG_CPU_PXA310 is not set ++CONFIG_CPU_PXA310=y + # CONFIG_CPU_PXA320 is not set + # CONFIG_CPU_PXA930 is not set + # CONFIG_CPU_PXA935 is not set + # CONFIG_ARCH_GUMSTIX is not set + # CONFIG_MACH_INTELMOTE2 is not set ++# CONFIG_MACH_STARGATE2 is not set + # CONFIG_ARCH_LUBBOCK is not set + # CONFIG_MACH_LOGICPD_PXA270 is not set + # CONFIG_MACH_MAINSTONE is not set +@@ -218,6 +228,7 @@ CONFIG_CPU_PXA300=y + # CONFIG_MACH_SAAR is not set + # CONFIG_MACH_ARMCORE is not set + CONFIG_MACH_CM_X300=y ++# CONFIG_MACH_H4700 is not set + # CONFIG_MACH_MAGICIAN is not set + # CONFIG_MACH_HIMALAYA is not set + # CONFIG_MACH_MIOA701 is not set +@@ -226,7 +237,6 @@ CONFIG_MACH_CM_X300=y + # CONFIG_MACH_CSB726 is not set + # CONFIG_PXA_EZX is not set + CONFIG_PXA3xx=y +-# CONFIG_PXA_PWM is not set + CONFIG_PLAT_PXA=y + + # +@@ -276,7 +286,6 @@ CONFIG_PAGE_OFFSET=0xC0000000 + CONFIG_HZ=100 + CONFIG_AEABI=y + CONFIG_OABI_COMPAT=y +-# CONFIG_ARCH_HAS_HOLES_MEMORYMODEL is not set + # CONFIG_ARCH_SPARSEMEM_DEFAULT is not set + # CONFIG_ARCH_SELECT_MEMORY_MODEL is not set + CONFIG_HIGHMEM=y +@@ -292,17 +301,18 @@ CONFIG_SPLIT_PTLOCK_CPUS=4096 + CONFIG_ZONE_DMA_FLAG=0 + CONFIG_BOUNCE=y + CONFIG_VIRT_TO_BUS=y +-CONFIG_UNEVICTABLE_LRU=y + CONFIG_HAVE_MLOCK=y + CONFIG_HAVE_MLOCKED_PAGE_BIT=y ++CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 + CONFIG_ALIGNMENT_TRAP=y ++# CONFIG_UACCESS_WITH_MEMCPY is not set + + # + # Boot options + # + CONFIG_ZBOOT_ROM_TEXT=0x0 + CONFIG_ZBOOT_ROM_BSS=0x0 +-CONFIG_CMDLINE="root=/dev/mtdblock5 rootfstype=jffs2 console=ttyS2,38400" ++CONFIG_CMDLINE="ubi.mtd=fs,2048 root=ubi0:rootfs rootfstype=ubifs console=ttyS2,38400" + # CONFIG_XIP_KERNEL is not set + # CONFIG_KEXEC is not set + +@@ -350,9 +360,12 @@ CONFIG_HAVE_AOUT=y + # Power management options + # + CONFIG_PM=y +-# CONFIG_PM_DEBUG is not set ++CONFIG_PM_DEBUG=y ++CONFIG_PM_VERBOSE=y ++CONFIG_CAN_PM_TRACE=y + CONFIG_PM_SLEEP=y + CONFIG_SUSPEND=y ++# CONFIG_PM_TEST_SUSPEND is not set + CONFIG_SUSPEND_FREEZER=y + CONFIG_APM_EMULATION=y + CONFIG_ARCH_SUSPEND_POSSIBLE=y +@@ -410,6 +423,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" + # CONFIG_ECONET is not set + # CONFIG_WAN_ROUTER is not set + # CONFIG_PHONET is not set ++# CONFIG_IEEE802154 is not set + # CONFIG_NET_SCHED is not set + # CONFIG_DCB is not set + +@@ -433,7 +447,7 @@ CONFIG_BT_HIDP=m + # + # Bluetooth device drivers + # +-# CONFIG_BT_HCIBTUSB is not set ++CONFIG_BT_HCIBTUSB=m + # CONFIG_BT_HCIBTSDIO is not set + # CONFIG_BT_HCIUART is not set + # CONFIG_BT_HCIBCM203X is not set +@@ -448,7 +462,11 @@ CONFIG_WIRELESS_EXT=y + CONFIG_WIRELESS_EXT_SYSFS=y + CONFIG_LIB80211=m + # CONFIG_LIB80211_DEBUG is not set +-# CONFIG_MAC80211 is not set ++ ++# ++# CFG80211 needs to be enabled for MAC80211 ++# ++CONFIG_MAC80211_DEFAULT_PS_VALUE=0 + # CONFIG_WIMAX is not set + # CONFIG_RFKILL is not set + # CONFIG_NET_9P is not set +@@ -521,6 +539,8 @@ CONFIG_MTD_CFI_I2=y + # + # Self-contained MTD device drivers + # ++# CONFIG_MTD_DATAFLASH is not set ++# CONFIG_MTD_M25P80 is not set + # CONFIG_MTD_SLRAM is not set + # CONFIG_MTD_PHRAM is not set + # CONFIG_MTD_MTDRAM is not set +@@ -556,7 +576,15 @@ CONFIG_MTD_NAND_PXA3xx=y + # + # UBI - Unsorted block images + # +-# CONFIG_MTD_UBI is not set ++CONFIG_MTD_UBI=y ++CONFIG_MTD_UBI_WL_THRESHOLD=4096 ++CONFIG_MTD_UBI_BEB_RESERVE=1 ++CONFIG_MTD_UBI_GLUEBI=y ++ ++# ++# UBI debugging options ++# ++# CONFIG_MTD_UBI_DEBUG is not set + # CONFIG_PARPORT is not set + CONFIG_BLK_DEV=y + # CONFIG_BLK_DEV_COW_COMMON is not set +@@ -570,6 +598,7 @@ CONFIG_BLK_DEV_RAM_SIZE=4096 + # CONFIG_BLK_DEV_XIP is not set + # CONFIG_CDROM_PKTCDVD is not set + # CONFIG_ATA_OVER_ETH is not set ++# CONFIG_MG_DISK is not set + # CONFIG_MISC_DEVICES is not set + CONFIG_HAVE_IDE=y + # CONFIG_IDE is not set +@@ -593,10 +622,6 @@ CONFIG_BLK_DEV_SD=y + # CONFIG_BLK_DEV_SR is not set + # CONFIG_CHR_DEV_SG is not set + # CONFIG_CHR_DEV_SCH is not set +- +-# +-# Some SCSI devices (e.g. CD jukebox) support multiple LUNs +-# + # CONFIG_SCSI_MULTI_LUN is not set + # CONFIG_SCSI_CONSTANTS is not set + # CONFIG_SCSI_LOGGING is not set +@@ -621,7 +646,6 @@ CONFIG_SCSI_LOWLEVEL=y + # CONFIG_ATA is not set + # CONFIG_MD is not set + CONFIG_NETDEVICES=y +-CONFIG_COMPAT_NET_DEV_OPS=y + # CONFIG_DUMMY is not set + # CONFIG_BONDING is not set + # CONFIG_MACVLAN is not set +@@ -636,6 +660,7 @@ CONFIG_MII=y + CONFIG_DM9000=y + CONFIG_DM9000_DEBUGLEVEL=0 + CONFIG_DM9000_FORCE_SIMPLE_PHY_POLL=y ++# CONFIG_ENC28J60 is not set + # CONFIG_ETHOC is not set + # CONFIG_SMC911X is not set + # CONFIG_SMSC911X is not set +@@ -648,6 +673,8 @@ CONFIG_DM9000_FORCE_SIMPLE_PHY_POLL=y + # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set + # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set + # CONFIG_B44 is not set ++# CONFIG_KS8842 is not set ++# CONFIG_KS8851 is not set + # CONFIG_NETDEV_1000 is not set + # CONFIG_NETDEV_10000 is not set + +@@ -659,9 +686,9 @@ CONFIG_WLAN_80211=y + CONFIG_LIBERTAS=m + # CONFIG_LIBERTAS_USB is not set + CONFIG_LIBERTAS_SDIO=m ++# CONFIG_LIBERTAS_SPI is not set + # CONFIG_LIBERTAS_DEBUG is not set + # CONFIG_USB_ZD1201 is not set +-# CONFIG_USB_NET_RNDIS_WLAN is not set + # CONFIG_HOSTAP is not set + + # +@@ -701,25 +728,33 @@ CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 + # CONFIG_INPUT_JOYDEV is not set + CONFIG_INPUT_EVDEV=y + # CONFIG_INPUT_EVBUG is not set ++# CONFIG_INPUT_APMPOWER is not set + + # + # Input Device Drivers + # + CONFIG_INPUT_KEYBOARD=y + # CONFIG_KEYBOARD_ATKBD is not set +-# CONFIG_KEYBOARD_SUNKBD is not set + # CONFIG_KEYBOARD_LKKBD is not set +-# CONFIG_KEYBOARD_XTKBD is not set ++# CONFIG_KEYBOARD_GPIO is not set ++# CONFIG_KEYBOARD_MATRIX is not set ++# CONFIG_KEYBOARD_LM8323 is not set + # CONFIG_KEYBOARD_NEWTON is not set +-# CONFIG_KEYBOARD_STOWAWAY is not set + CONFIG_KEYBOARD_PXA27x=m +-# CONFIG_KEYBOARD_GPIO is not set ++# CONFIG_KEYBOARD_STOWAWAY is not set ++# CONFIG_KEYBOARD_SUNKBD is not set ++# CONFIG_KEYBOARD_XTKBD is not set + # CONFIG_INPUT_MOUSE is not set + # CONFIG_INPUT_JOYSTICK is not set + # CONFIG_INPUT_TABLET is not set + CONFIG_INPUT_TOUCHSCREEN=y ++# CONFIG_TOUCHSCREEN_ADS7846 is not set ++# CONFIG_TOUCHSCREEN_AD7877 is not set + # CONFIG_TOUCHSCREEN_AD7879_I2C is not set ++# CONFIG_TOUCHSCREEN_AD7879_SPI is not set + # CONFIG_TOUCHSCREEN_AD7879 is not set ++# CONFIG_TOUCHSCREEN_DA9034 is not set ++# CONFIG_TOUCHSCREEN_EETI is not set + # CONFIG_TOUCHSCREEN_FUJITSU is not set + # CONFIG_TOUCHSCREEN_GUNZE is not set + # CONFIG_TOUCHSCREEN_ELO is not set +@@ -730,9 +765,15 @@ CONFIG_INPUT_TOUCHSCREEN=y + # CONFIG_TOUCHSCREEN_PENMOUNT is not set + # CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set + # CONFIG_TOUCHSCREEN_TOUCHWIN is not set ++CONFIG_TOUCHSCREEN_WM97XX=m ++# CONFIG_TOUCHSCREEN_WM9705 is not set ++CONFIG_TOUCHSCREEN_WM9712=y ++# CONFIG_TOUCHSCREEN_WM9713 is not set ++# CONFIG_TOUCHSCREEN_WM97XX_MAINSTONE is not set + # CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set + # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set + # CONFIG_TOUCHSCREEN_TSC2007 is not set ++# CONFIG_TOUCHSCREEN_W90X900 is not set + # CONFIG_INPUT_MISC is not set + + # +@@ -760,6 +801,7 @@ CONFIG_DEVKMEM=y + # + # Non-8250 serial port support + # ++# CONFIG_SERIAL_MAX3100 is not set + CONFIG_SERIAL_PXA=y + CONFIG_SERIAL_PXA_CONSOLE=y + CONFIG_SERIAL_CORE=y +@@ -784,6 +826,7 @@ CONFIG_I2C_HELPER_AUTO=y + # + # I2C system bus drivers (mostly embedded / system-on-chip) + # ++# CONFIG_I2C_DESIGNWARE is not set + # CONFIG_I2C_GPIO is not set + # CONFIG_I2C_OCORES is not set + CONFIG_I2C_PXA=y +@@ -809,17 +852,31 @@ CONFIG_I2C_PXA=y + # CONFIG_DS1682 is not set + # CONFIG_SENSORS_PCF8574 is not set + # CONFIG_PCF8575 is not set +-# CONFIG_SENSORS_MAX6875 is not set + # CONFIG_SENSORS_TSL2550 is not set + # CONFIG_I2C_DEBUG_CORE is not set + # CONFIG_I2C_DEBUG_ALGO is not set + # CONFIG_I2C_DEBUG_BUS is not set + # CONFIG_I2C_DEBUG_CHIP is not set +-# CONFIG_SPI is not set ++CONFIG_SPI=y ++# CONFIG_SPI_DEBUG is not set ++CONFIG_SPI_MASTER=y ++ ++# ++# SPI Master Controller Drivers ++# ++CONFIG_SPI_BITBANG=y ++CONFIG_SPI_GPIO=y ++# CONFIG_SPI_PXA2XX is not set ++ ++# ++# SPI Protocol Masters ++# ++# CONFIG_SPI_SPIDEV is not set ++# CONFIG_SPI_TLE62X0 is not set + CONFIG_ARCH_REQUIRE_GPIOLIB=y + CONFIG_GPIOLIB=y + # CONFIG_DEBUG_GPIO is not set +-# CONFIG_GPIO_SYSFS is not set ++CONFIG_GPIO_SYSFS=y + + # + # Memory mapped GPIO expanders: +@@ -839,8 +896,18 @@ CONFIG_GPIO_PCA953X=y + # + # SPI GPIO expanders: + # ++# CONFIG_GPIO_MAX7301 is not set ++# CONFIG_GPIO_MCP23S08 is not set + # CONFIG_W1 is not set +-# CONFIG_POWER_SUPPLY is not set ++CONFIG_POWER_SUPPLY=y ++# CONFIG_POWER_SUPPLY_DEBUG is not set ++# CONFIG_PDA_POWER is not set ++CONFIG_APM_POWER=y ++# CONFIG_BATTERY_DS2760 is not set ++# CONFIG_BATTERY_DS2782 is not set ++# CONFIG_BATTERY_BQ27x00 is not set ++CONFIG_BATTERY_DA9030=y ++# CONFIG_BATTERY_MAX17040 is not set + # CONFIG_HWMON is not set + # CONFIG_THERMAL is not set + # CONFIG_THERMAL_HWMON is not set +@@ -860,32 +927,20 @@ CONFIG_SSB_POSSIBLE=y + # CONFIG_MFD_ASIC3 is not set + # CONFIG_HTC_EGPIO is not set + # CONFIG_HTC_PASIC3 is not set ++# CONFIG_UCB1400_CORE is not set + # CONFIG_TPS65010 is not set + # CONFIG_TWL4030_CORE is not set + # CONFIG_MFD_TMIO is not set + # CONFIG_MFD_T7L66XB is not set + # CONFIG_MFD_TC6387XB is not set + # CONFIG_MFD_TC6393XB is not set +-# CONFIG_PMIC_DA903X is not set ++CONFIG_PMIC_DA903X=y + # CONFIG_MFD_WM8400 is not set + # CONFIG_MFD_WM8350_I2C is not set + # CONFIG_MFD_PCF50633 is not set +- +-# +-# Multimedia devices +-# +- +-# +-# Multimedia core support +-# +-# CONFIG_VIDEO_DEV is not set +-# CONFIG_DVB_CORE is not set +-# CONFIG_VIDEO_MEDIA is not set +- +-# +-# Multimedia drivers +-# +-# CONFIG_DAB is not set ++# CONFIG_AB3100_CORE is not set ++# CONFIG_EZX_PCAP is not set ++# CONFIG_MEDIA_SUPPORT is not set + + # + # Graphics support +@@ -925,7 +980,17 @@ CONFIG_FB_PXA=y + # CONFIG_FB_METRONOME is not set + # CONFIG_FB_MB862XX is not set + # CONFIG_FB_BROADSHEET is not set +-# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++CONFIG_BACKLIGHT_LCD_SUPPORT=y ++CONFIG_LCD_CLASS_DEVICE=y ++# CONFIG_LCD_LTV350QV is not set ++# CONFIG_LCD_ILI9320 is not set ++CONFIG_LCD_TDO24M=y ++# CONFIG_LCD_VGG2432A4 is not set ++# CONFIG_LCD_PLATFORM is not set ++CONFIG_BACKLIGHT_CLASS_DEVICE=m ++# CONFIG_BACKLIGHT_GENERIC is not set ++CONFIG_BACKLIGHT_PWM=m ++# CONFIG_BACKLIGHT_DA903X is not set + + # + # Display device support +@@ -956,35 +1021,45 @@ CONFIG_LOGO_LINUX_MONO=y + CONFIG_LOGO_LINUX_VGA16=y + CONFIG_LOGO_LINUX_CLUT224=y + CONFIG_SOUND=m +-# CONFIG_SOUND_OSS_CORE is not set ++CONFIG_SOUND_OSS_CORE=y + CONFIG_SND=m + CONFIG_SND_TIMER=m + CONFIG_SND_PCM=m + CONFIG_SND_JACK=y + # CONFIG_SND_SEQUENCER is not set +-# CONFIG_SND_MIXER_OSS is not set +-# CONFIG_SND_PCM_OSS is not set ++CONFIG_SND_OSSEMUL=y ++CONFIG_SND_MIXER_OSS=m ++CONFIG_SND_PCM_OSS=m ++CONFIG_SND_PCM_OSS_PLUGINS=y + # CONFIG_SND_DYNAMIC_MINORS is not set + CONFIG_SND_SUPPORT_OLD_API=y + CONFIG_SND_VERBOSE_PROCFS=y + # CONFIG_SND_VERBOSE_PRINTK is not set + # CONFIG_SND_DEBUG is not set +-CONFIG_SND_DRIVERS=y +-# CONFIG_SND_DUMMY is not set +-# CONFIG_SND_MTPAV is not set +-# CONFIG_SND_SERIAL_U16550 is not set +-# CONFIG_SND_MPU401 is not set ++CONFIG_SND_VMASTER=y ++# CONFIG_SND_RAWMIDI_SEQ is not set ++# CONFIG_SND_OPL3_LIB_SEQ is not set ++# CONFIG_SND_OPL4_LIB_SEQ is not set ++# CONFIG_SND_SBAWE_SEQ is not set ++# CONFIG_SND_EMU10K1_SEQ is not set ++CONFIG_SND_AC97_CODEC=m ++# CONFIG_SND_DRIVERS is not set + CONFIG_SND_ARM=y + CONFIG_SND_PXA2XX_LIB=m ++CONFIG_SND_PXA2XX_LIB_AC97=y + # CONFIG_SND_PXA2XX_AC97 is not set +-CONFIG_SND_USB=y +-# CONFIG_SND_USB_AUDIO is not set +-# CONFIG_SND_USB_CAIAQ is not set ++# CONFIG_SND_SPI is not set ++# CONFIG_SND_USB is not set + CONFIG_SND_SOC=m ++CONFIG_SND_SOC_AC97_BUS=y + CONFIG_SND_PXA2XX_SOC=m ++CONFIG_SND_PXA2XX_SOC_AC97=m ++CONFIG_SND_PXA2XX_SOC_EM_X270=m + CONFIG_SND_SOC_I2C_AND_SPI=m + # CONFIG_SND_SOC_ALL_CODECS is not set ++CONFIG_SND_SOC_WM9712=m + # CONFIG_SOUND_PRIME is not set ++CONFIG_AC97_BUS=m + CONFIG_HID_SUPPORT=y + CONFIG_HID=y + CONFIG_HID_DEBUG=y +@@ -1000,33 +1075,32 @@ CONFIG_USB_HID=y + # + # Special HID drivers + # +-CONFIG_HID_A4TECH=y +-CONFIG_HID_APPLE=y +-CONFIG_HID_BELKIN=y +-CONFIG_HID_CHERRY=y +-CONFIG_HID_CHICONY=y +-CONFIG_HID_CYPRESS=y +-# CONFIG_DRAGONRISE_FF is not set +-CONFIG_HID_EZKEY=y +-CONFIG_HID_KYE=y +-CONFIG_HID_GYRATION=y +-CONFIG_HID_KENSINGTON=y +-CONFIG_HID_LOGITECH=y +-# CONFIG_LOGITECH_FF is not set +-# CONFIG_LOGIRUMBLEPAD2_FF is not set +-CONFIG_HID_MICROSOFT=y +-CONFIG_HID_MONTEREY=y +-CONFIG_HID_NTRIG=y +-CONFIG_HID_PANTHERLORD=y +-# CONFIG_PANTHERLORD_FF is not set +-CONFIG_HID_PETALYNX=y +-CONFIG_HID_SAMSUNG=y +-CONFIG_HID_SONY=y +-CONFIG_HID_SUNPLUS=y +-# CONFIG_GREENASIA_FF is not set +-CONFIG_HID_TOPSEED=y +-# CONFIG_THRUSTMASTER_FF is not set +-# CONFIG_ZEROPLUS_FF is not set ++# CONFIG_HID_A4TECH is not set ++# CONFIG_HID_APPLE is not set ++# CONFIG_HID_BELKIN is not set ++# CONFIG_HID_CHERRY is not set ++# CONFIG_HID_CHICONY is not set ++# CONFIG_HID_CYPRESS is not set ++# CONFIG_HID_DRAGONRISE is not set ++# CONFIG_HID_EZKEY is not set ++# CONFIG_HID_KYE is not set ++# CONFIG_HID_GYRATION is not set ++# CONFIG_HID_KENSINGTON is not set ++# CONFIG_HID_LOGITECH is not set ++# CONFIG_HID_MICROSOFT is not set ++# CONFIG_HID_MONTEREY is not set ++# CONFIG_HID_NTRIG is not set ++# CONFIG_HID_PANTHERLORD is not set ++# CONFIG_HID_PETALYNX is not set ++# CONFIG_HID_SAMSUNG is not set ++# CONFIG_HID_SONY is not set ++# CONFIG_HID_SUNPLUS is not set ++# CONFIG_HID_GREENASIA is not set ++# CONFIG_HID_SMARTJOYPLUS is not set ++# CONFIG_HID_TOPSEED is not set ++# CONFIG_HID_THRUSTMASTER is not set ++# CONFIG_HID_WACOM is not set ++# CONFIG_HID_ZEROPLUS is not set + CONFIG_USB_SUPPORT=y + CONFIG_USB_ARCH_HAS_HCD=y + CONFIG_USB_ARCH_HAS_OHCI=y +@@ -1043,6 +1117,8 @@ CONFIG_USB_DEVICEFS=y + # CONFIG_USB_DYNAMIC_MINORS is not set + # CONFIG_USB_SUSPEND is not set + # CONFIG_USB_OTG is not set ++# CONFIG_USB_OTG_WHITELIST is not set ++# CONFIG_USB_OTG_BLACKLIST_HUB is not set + CONFIG_USB_MON=y + # CONFIG_USB_WUSB is not set + # CONFIG_USB_WUSB_CBAF is not set +@@ -1162,8 +1238,11 @@ CONFIG_LEDS_CLASS=y + # CONFIG_LEDS_PCA9532 is not set + CONFIG_LEDS_GPIO=y + CONFIG_LEDS_GPIO_PLATFORM=y +-# CONFIG_LEDS_LP5521 is not set ++# CONFIG_LEDS_LP3944 is not set + # CONFIG_LEDS_PCA955X is not set ++# CONFIG_LEDS_DA903X is not set ++# CONFIG_LEDS_DAC124S085 is not set ++# CONFIG_LEDS_PWM is not set + # CONFIG_LEDS_BD2802 is not set + + # +@@ -1210,10 +1289,18 @@ CONFIG_RTC_INTF_DEV=y + # CONFIG_RTC_DRV_S35390A is not set + # CONFIG_RTC_DRV_FM3130 is not set + # CONFIG_RTC_DRV_RX8581 is not set ++# CONFIG_RTC_DRV_RX8025 is not set + + # + # SPI RTC drivers + # ++# CONFIG_RTC_DRV_M41T94 is not set ++# CONFIG_RTC_DRV_DS1305 is not set ++# CONFIG_RTC_DRV_DS1390 is not set ++# CONFIG_RTC_DRV_MAX6902 is not set ++# CONFIG_RTC_DRV_R9701 is not set ++# CONFIG_RTC_DRV_RS5C348 is not set ++# CONFIG_RTC_DRV_DS3234 is not set + + # + # Platform RTC drivers +@@ -1237,7 +1324,15 @@ CONFIG_RTC_DRV_SA1100=y + # CONFIG_RTC_DRV_PXA is not set + # CONFIG_DMADEVICES is not set + # CONFIG_AUXDISPLAY is not set +-# CONFIG_REGULATOR is not set ++CONFIG_REGULATOR=y ++# CONFIG_REGULATOR_DEBUG is not set ++# CONFIG_REGULATOR_FIXED_VOLTAGE is not set ++# CONFIG_REGULATOR_VIRTUAL_CONSUMER is not set ++# CONFIG_REGULATOR_USERSPACE_CONSUMER is not set ++# CONFIG_REGULATOR_BQ24022 is not set ++# CONFIG_REGULATOR_MAX1586 is not set ++CONFIG_REGULATOR_DA903X=y ++# CONFIG_REGULATOR_LP3971 is not set + # CONFIG_UIO is not set + # CONFIG_STAGING is not set + +@@ -1256,10 +1351,12 @@ CONFIG_JBD=y + # CONFIG_REISERFS_FS is not set + # CONFIG_JFS_FS is not set + CONFIG_FS_POSIX_ACL=y +-CONFIG_FILE_LOCKING=y + # CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set + # CONFIG_OCFS2_FS is not set + # CONFIG_BTRFS_FS is not set ++CONFIG_FILE_LOCKING=y ++CONFIG_FSNOTIFY=y + CONFIG_DNOTIFY=y + CONFIG_INOTIFY=y + CONFIG_INOTIFY_USER=y +@@ -1282,9 +1379,9 @@ CONFIG_INOTIFY_USER=y + # + # DOS/FAT/NT Filesystems + # +-CONFIG_FAT_FS=m ++CONFIG_FAT_FS=y + CONFIG_MSDOS_FS=m +-CONFIG_VFAT_FS=m ++CONFIG_VFAT_FS=y + CONFIG_FAT_DEFAULT_CODEPAGE=437 + CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" + # CONFIG_NTFS_FS is not set +@@ -1319,6 +1416,12 @@ CONFIG_JFFS2_ZLIB=y + # CONFIG_JFFS2_LZO is not set + CONFIG_JFFS2_RTIME=y + # CONFIG_JFFS2_RUBIN is not set ++CONFIG_UBIFS_FS=y ++# CONFIG_UBIFS_FS_XATTR is not set ++# CONFIG_UBIFS_FS_ADVANCED_COMPR is not set ++CONFIG_UBIFS_FS_LZO=y ++CONFIG_UBIFS_FS_ZLIB=y ++# CONFIG_UBIFS_FS_DEBUG is not set + # CONFIG_CRAMFS is not set + # CONFIG_SQUASHFS is not set + # CONFIG_VXFS_FS is not set +@@ -1335,6 +1438,7 @@ CONFIG_NFS_FS=y + CONFIG_NFS_V3=y + CONFIG_NFS_V3_ACL=y + CONFIG_NFS_V4=y ++# CONFIG_NFS_V4_1 is not set + CONFIG_ROOT_NFS=y + # CONFIG_NFSD is not set + CONFIG_LOCKD=y +@@ -1378,9 +1482,9 @@ CONFIG_MSDOS_PARTITION=y + # CONFIG_KARMA_PARTITION is not set + # CONFIG_EFI_PARTITION is not set + # CONFIG_SYSV68_PARTITION is not set +-CONFIG_NLS=m ++CONFIG_NLS=y + CONFIG_NLS_DEFAULT="iso8859-1" +-CONFIG_NLS_CODEPAGE_437=m ++CONFIG_NLS_CODEPAGE_437=y + # CONFIG_NLS_CODEPAGE_737 is not set + # CONFIG_NLS_CODEPAGE_775 is not set + # CONFIG_NLS_CODEPAGE_850 is not set +@@ -1404,7 +1508,7 @@ CONFIG_NLS_CODEPAGE_437=m + # CONFIG_NLS_CODEPAGE_1250 is not set + # CONFIG_NLS_CODEPAGE_1251 is not set + # CONFIG_NLS_ASCII is not set +-CONFIG_NLS_ISO8859_1=m ++CONFIG_NLS_ISO8859_1=y + # CONFIG_NLS_ISO8859_2 is not set + # CONFIG_NLS_ISO8859_3 is not set + # CONFIG_NLS_ISO8859_4 is not set +@@ -1441,6 +1545,7 @@ CONFIG_DEBUG_KERNEL=y + # CONFIG_DEBUG_OBJECTS is not set + # CONFIG_SLUB_DEBUG_ON is not set + # CONFIG_SLUB_STATS is not set ++# CONFIG_DEBUG_KMEMLEAK is not set + # CONFIG_DEBUG_RT_MUTEXES is not set + # CONFIG_RT_MUTEX_TESTER is not set + # CONFIG_DEBUG_SPINLOCK is not set +@@ -1452,11 +1557,11 @@ CONFIG_DEBUG_KERNEL=y + # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set + # CONFIG_DEBUG_KOBJECT is not set + # CONFIG_DEBUG_HIGHMEM is not set +-CONFIG_DEBUG_BUGVERBOSE=y ++# CONFIG_DEBUG_BUGVERBOSE is not set + # CONFIG_DEBUG_INFO is not set + # CONFIG_DEBUG_VM is not set + # CONFIG_DEBUG_WRITECOUNT is not set +-CONFIG_DEBUG_MEMORY_INIT=y ++# CONFIG_DEBUG_MEMORY_INIT is not set + # CONFIG_DEBUG_LIST is not set + # CONFIG_DEBUG_SG is not set + # CONFIG_DEBUG_NOTIFIERS is not set +@@ -1471,17 +1576,15 @@ CONFIG_SYSCTL_SYSCALL_CHECK=y + # CONFIG_PAGE_POISONING is not set + CONFIG_HAVE_FUNCTION_TRACER=y + CONFIG_TRACING_SUPPORT=y +- +-# +-# Tracers +-# ++CONFIG_FTRACE=y + # CONFIG_FUNCTION_TRACER is not set + # CONFIG_IRQSOFF_TRACER is not set + # CONFIG_SCHED_TRACER is not set +-# CONFIG_CONTEXT_SWITCH_TRACER is not set +-# CONFIG_EVENT_TRACER is not set ++# CONFIG_ENABLE_DEFAULT_TRACERS is not set + # CONFIG_BOOT_TRACER is not set +-# CONFIG_TRACE_BRANCH_PROFILING is not set ++CONFIG_BRANCH_PROFILE_NONE=y ++# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set ++# CONFIG_PROFILE_ALL_BRANCHES is not set + # CONFIG_STACK_TRACER is not set + # CONFIG_KMEMTRACE is not set + # CONFIG_WORKQUEUE_TRACER is not set +@@ -1490,6 +1593,7 @@ CONFIG_TRACING_SUPPORT=y + # CONFIG_SAMPLES is not set + CONFIG_HAVE_ARCH_KGDB=y + # CONFIG_KGDB is not set ++# CONFIG_KMEMCHECK is not set + CONFIG_ARM_UNWIND=y + CONFIG_DEBUG_USER=y + # CONFIG_DEBUG_ERRORS is not set +@@ -1591,9 +1695,9 @@ CONFIG_CRYPTO_DES=y + # + # Compression + # +-# CONFIG_CRYPTO_DEFLATE is not set ++CONFIG_CRYPTO_DEFLATE=y + # CONFIG_CRYPTO_ZLIB is not set +-# CONFIG_CRYPTO_LZO is not set ++CONFIG_CRYPTO_LZO=y + + # + # Random Number Generation +@@ -1608,7 +1712,7 @@ CONFIG_CRYPTO_DES=y + CONFIG_BITREVERSE=y + CONFIG_GENERIC_FIND_LAST_BIT=y + # CONFIG_CRC_CCITT is not set +-# CONFIG_CRC16 is not set ++CONFIG_CRC16=y + CONFIG_CRC_T10DIF=y + # CONFIG_CRC_ITU_T is not set + CONFIG_CRC32=y +@@ -1616,9 +1720,9 @@ CONFIG_CRC32=y + # CONFIG_LIBCRC32C is not set + CONFIG_ZLIB_INFLATE=y + CONFIG_ZLIB_DEFLATE=y ++CONFIG_LZO_COMPRESS=y ++CONFIG_LZO_DECOMPRESS=y + CONFIG_DECOMPRESS_GZIP=y +-CONFIG_DECOMPRESS_BZIP2=y +-CONFIG_DECOMPRESS_LZMA=y + CONFIG_HAS_IOMEM=y + CONFIG_HAS_IOPORT=y + CONFIG_HAS_DMA=y +diff --git a/arch/arm/mach-pxa/Kconfig b/arch/arm/mach-pxa/Kconfig +index 89c992b..c2a0717 100644 +--- a/arch/arm/mach-pxa/Kconfig ++++ b/arch/arm/mach-pxa/Kconfig +@@ -318,6 +318,8 @@ config MACH_CM_X300 + bool "CompuLab CM-X300 modules" + select PXA3xx + select CPU_PXA300 ++ select CPU_PXA310 ++ select HAVE_PWM + + config MACH_H4700 + bool "HP iPAQ hx4700" +diff --git a/arch/arm/mach-pxa/Makefile b/arch/arm/mach-pxa/Makefile +index d4c6122..7f1b88e 100644 +--- a/arch/arm/mach-pxa/Makefile ++++ b/arch/arm/mach-pxa/Makefile +@@ -75,7 +75,7 @@ obj-$(CONFIG_MACH_TAVOREVB) += tavorevb.o + obj-$(CONFIG_MACH_SAAR) += saar.o + + obj-$(CONFIG_MACH_ARMCORE) += cm-x2xx.o cm-x255.o cm-x270.o +-obj-$(CONFIG_MACH_CM_X300) += cm-x300.o ++obj-$(CONFIG_MACH_CM_X300) += cm-x300.o cm-x300-ulpi.o + obj-$(CONFIG_PXA_EZX) += ezx.o + + obj-$(CONFIG_MACH_INTELMOTE2) += imote2.o +diff --git a/arch/arm/mach-pxa/cm-x300-ulpi.c b/arch/arm/mach-pxa/cm-x300-ulpi.c +new file mode 100644 +index 0000000..ee02d50 +--- /dev/null ++++ b/arch/arm/mach-pxa/cm-x300-ulpi.c +@@ -0,0 +1,307 @@ ++/* ++ * linux/arch/arm/mach-pxa/cm-x300.c ++ * ++ * Support for the CompuLab CM-X300 modules ++ * ++ * Copyright (C) 2009 CompuLab Ltd. ++ * ++ * Igor Grinberg <grinberg@compulab.co.il> ++ * ++ * 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/kernel.h> ++#include <linux/platform_device.h> ++#include <linux/errno.h> ++#include <linux/err.h> ++#include <linux/io.h> ++#include <linux/interrupt.h> ++#include <linux/irq.h> ++#include <linux/delay.h> ++#include <linux/gpio.h> ++#include <linux/init.h> ++#include <linux/clk.h> ++ ++#include <asm/mach-types.h> ++#include <asm/mach/arch.h> ++ ++#include <mach/pxa300.h> ++#include <mach/regs-u2d.h> ++ ++/* OTG Interrupts */ ++#define U2DOTGICR_MASK 0x37F7F ++ ++/* PXA310 USB OTG Controller */ ++#define ULPI_VENDOR_LOW 0x0 ++#define ULPI_VENDOR_HIGH 0x1 ++#define ULPI_PRODUCT_LOW 0x2 ++#define ULPI_PRODUCT_HIGH 0x3 ++#define ULPI_FUNCTION_CONTROL 0x4 ++#define ULPI_FUNCTION_CONTROL_SET 0x5 ++#define ULPI_FUNCTION_CONTROL_CLEAR 0x6 ++#define ULPI_INTERFACE_CONTROL 0x7 ++#define ULPI_INTERFACE_CONTROL_SET 0x8 ++#define ULPI_INTERFACE_CONTROL_CLEAR 0x9 ++#define ULPI_OTG_CONTROL 0xA ++#define ULPI_OTG_CONTROL_SET 0xB ++#define ULPI_OTG_CONTROL_CLEAR 0xC ++#define ULPI_INT_RISE 0xD ++#define ULPI_INT_RISE_SET 0xE ++#define ULPI_INT_RISE_CLEAR 0xF ++#define ULPI_INT_FALL 0x10 ++#define ULPI_INT_FALL_SET 0x11 ++#define ULPI_INT_FALL_CLEAR 0x12 ++#define ULPI_INT_STATUS 0x13 ++#define ULPI_INT_LATCH 0x14 ++#define ULPI_DEBUG 0x15 ++#define ULPI_SCRATCH 0x16 ++#define ULPI_SCRATCH_SET 0x17 ++#define ULPI_SCRATCH_CLEAR 0x18 ++ ++#define ULPI_FC_RESET (1 << 5) /* XCVR Reset */ ++#define ULPI_FC_SUSPENDM (1 << 6) /* XCVR SuspendM, Low Power Mode */ ++ ++#define ULPI_IC_6PIN (1 << 0) /* XCVR 6 pin mode */ ++#define ULPI_IC_3PIN (1 << 1) /* XCVR 3 pin mode */ ++#define ULPI_IC_CARKIT (1 << 2) /* Carkit mode */ ++#define ULPI_IC_CLKSUSPENDM (1 << 3) /* Active low clock suspend */ ++ ++#define ULPI_OC_IDPULLUP (1 << 0) /* ID Pull Up, enable sampling of ID line */ ++#define ULPI_OC_DPPULLDOWN (1 << 1) /* Enable the 15K Ohm pull down resistor on D+ */ ++#define ULPI_OC_DMPULLDOWN (1 << 2) /* Enable the 15K Ohm pull down resistor on D- */ ++#define ULPI_OC_DISCHRGVBUS (1 << 3) /* Discharge Vbus */ ++#define ULPI_OC_CHRGVBUS (1 << 4) /* Charge Vbus, for Vbus pulsing SRP */ ++#define ULPI_OC_DRVVBUS (1 << 5) /* Drive 5V on Vbus */ ++#define ULPI_OC_DRVVBUSEXT (1 << 6) /* Drive Vbus using external supply */ ++ ++#define ULPI_INT_HOSTDISCON (1 << 0) /* Host Disconnect */ ++#define ULPI_INT_VBUSVALID (1 << 1) /* Vbus Valid */ ++#define ULPI_INT_SESSIONVALID (1 << 2) /* Session Valid */ ++#define ULPI_INT_SESSIONEND (1 << 3) /* Session End */ ++#define ULPI_INT_IDGND (1 << 4) /* current status of IDGND */ ++ ++#define U2DOTGUCR_ADDR_S (16) ++#define U2DOTGUCR_WDATA_S (8) ++ ++#define U2DOTGINT_DEFAULT (U2DOTGINT_RID | U2DOTGINT_FID | U2DOTGINT_SI \ ++ | U2DOTGINT_RVV | U2DOTGINT_FVV | U2DOTGINT_SF \ ++ | U2DOTGINT_RSV) ++ ++#define U2D_PHYS_BASE 0x54100000 ++static void __iomem *u2d_mmio_base; ++ ++enum u2d_phy_mode { ++ SYNCH = 0, ++ CARKIT = 0x1, ++ SER_3PIN = 0x2, ++ SER_6PIN = 0x4, ++ LOWPOWER = 0x8, ++ /* rtsm mode */ ++ PRE_SYNCH = 0x10, ++}; ++ ++static inline unsigned int u2d_readl(unsigned int off) ++{ ++ return __raw_readl(u2d_mmio_base + off); ++} ++ ++static inline void u2d_writel(unsigned int off, unsigned int val) ++{ ++ __raw_writel(val, u2d_mmio_base + off); ++} ++ ++static inline enum u2d_phy_mode ulpi_get_phymode(void) ++{ ++ return (u2d_readl(U2DOTGUSR) & 0xF0000000) >> 28; ++} ++ ++static int ulpi_reg_read(u8 reg, u8 *value) ++{ ++ int i = 50000; ++ enum u2d_phy_mode state = ulpi_get_phymode(); ++ ++ if ((state != SYNCH) && (state != PRE_SYNCH)) { ++ pr_err("%s: PHY is not in SYNCH mode!!!\n", __func__); ++ return -1; ++ } ++ ++ u2d_writel(U2DOTGUCR, ++ U2DOTGUCR_RUN | U2DOTGUCR_RNW | (reg << U2DOTGUCR_ADDR_S)); ++ msleep(5); ++ ++ while ((u2d_readl(U2DOTGUCR) & U2DOTGUCR_RUN) && i--); ++ ++ if (i <= 0) { ++ printk(KERN_INFO "Read ULPI register Time out," ++ " reg %x otgucr %x, usr %x ucr %x\n", ++ reg, u2d_readl(U2DOTGUCR), u2d_readl(U2DOTGUSR), ++ u2d_readl(U2DOTGCR)); ++ return -1; ++ } ++ ++ *value = (u8)(u2d_readl(U2DOTGUCR) & U2DOTGUCR_RDATA); ++ ++ return 0; ++} ++ ++static int ulpi_reg_write(u8 reg, u8 value) ++{ ++ int i = 500000; ++ enum u2d_phy_mode state = ulpi_get_phymode(); ++ ++ if ((state != SYNCH) && (state != PRE_SYNCH)) { ++ pr_err("%s: PHY is not in SYNCH mode!!!\n", __func__); ++ return -1; ++ } ++ ++ u2d_writel(U2DOTGUCR, U2DOTGUCR_RUN | (reg << U2DOTGUCR_ADDR_S) ++ | (value << U2DOTGUCR_WDATA_S)); ++ msleep(5); ++ ++ while ((u2d_readl(U2DOTGUCR) & U2DOTGUCR_RUN) && i--); ++ ++ if (i <= 0) { ++ printk(KERN_INFO "Write ULPI register Time out," ++ " reg %x val %x\n", reg, (int)value); ++ return -1; ++ } ++ ++ return 0; ++} ++ ++static int cm_x300_ulpi_phy_reset(void) ++{ ++ int err; ++ ++ err = gpio_request(127, "ulpi reset"); ++ if (err) { ++ pr_err("failed to request ULPI reset GPIO:%d\n", err); ++ return -EBUSY; ++ } ++ gpio_direction_output(127, 0); ++ msleep(10); ++ gpio_set_value(127, 1); ++ msleep(10); ++ gpio_free(127); ++ ++ return 0; ++} ++ ++/* Turn U2D clocks on and enable */ ++static int cm_x300_u2d_clks_enable(void) ++{ ++ int err = 0; ++ struct clk *u2d_clk; ++ struct clk *pout_clk; ++ ++ u2d_clk = clk_get(NULL, "U2DCLK"); ++ if (IS_ERR(u2d_clk)) { ++ err = PTR_ERR(u2d_clk); ++ pr_err("get_u2d_clk failed: %d\n", err); ++ return err; ++ } ++ clk_enable(u2d_clk); ++ ++ pout_clk = clk_get(NULL, "CLK_POUT"); ++ if (IS_ERR(pout_clk)) { ++ err = PTR_ERR(pout_clk); ++ pr_err("get_pout_clk failed: %d\n", err); ++ clk_disable(u2d_clk); ++ return err; ++ } ++ clk_enable(pout_clk); ++ ++ return 0; ++} ++ ++static void cm_x300_otg_init(void) ++{ ++ u32 u2dreg; ++ ++ /* setup OTG */ ++ u2dreg = u2d_readl(U2DOTGCR); ++ u2dreg |= U2DOTGCR_ULAF | U2DOTGCR_UTMID; ++ u2dreg &= ~(U2DOTGCR_SMAF | U2DOTGCR_CKAF); ++ u2d_writel(U2DOTGCR, u2dreg); ++ msleep(5); ++ u2d_writel(U2DOTGCR, u2dreg | U2DOTGCR_ULE); ++ msleep(5); ++ ++ /* according to pxa3xx manual vol. IV (p.145) */ ++ /* here we need to enable OTG interrups, */ ++ /* but we support only host mode, and will not switch to device mode */ ++ /* so we disable the otg interrupts */ ++ u2d_writel(U2DOTGICR, u2d_readl(U2DOTGICR) & ~U2DOTGICR_MASK); ++} ++ ++static void cm_x300_ulpi_rtsm(void) ++{ ++ u32 u2dreg; ++ ++ /* put PHY to sync mode */ ++ u2d_writel(U2DOTGCR, u2d_readl(U2DOTGCR) | U2DOTGCR_RTSM); ++ msleep(10); ++ ++ /* setup OTG sync mode */ ++ u2dreg = u2d_readl(U2DOTGCR) | U2DOTGCR_ULAF; ++ u2dreg &= ~(U2DOTGCR_SMAF | U2DOTGCR_CKAF); ++ u2d_writel(U2DOTGCR, u2dreg); ++} ++ ++static void cm_x300_set_ulpi_serial6(void) ++{ ++ u32 u2dreg; ++ ++ /* enable the 15K Ohm pull-down resistor on D+ & D- and drive 5V */ ++ ulpi_reg_write(ULPI_OTG_CONTROL_SET, ULPI_OC_DPPULLDOWN); ++ ulpi_reg_write(ULPI_OTG_CONTROL_SET, ULPI_OC_DMPULLDOWN); ++ ulpi_reg_write(ULPI_OTG_CONTROL_SET, ULPI_OC_DRVVBUS); ++ ++ /* configure UHC for 6-pin serial mode */ ++ u2d_writel(U2DP3CR, u2d_readl(U2DP3CR) & ~U2DP3CR_P2SS); ++ ++ /* set PHY into host and serial mode */ ++ ulpi_reg_write(ULPI_FUNCTION_CONTROL_SET, 0x45); ++ ulpi_reg_write(ULPI_INTERFACE_CONTROL, ULPI_IC_6PIN); ++ ++ /* enable the serial mode */ ++ u2dreg = u2d_readl(U2DOTGCR) | U2DOTGCR_SMAF; ++ u2d_writel(U2DOTGCR, u2dreg & ~(U2DOTGCR_ULAF | U2DOTGCR_CKAF)); ++} ++ ++int cm_x300_ulpi_init(void) ++{ ++ int err; ++ ++ err = cm_x300_u2d_clks_enable(); ++ if (err) ++ return err; ++ ++ u2d_mmio_base = ioremap(U2D_PHYS_BASE, 0x1300); ++ if (u2d_mmio_base == NULL) { ++ pr_info("%s: failed to remap U2D registers addr space\n", ++ __func__); ++ return -ENOMEM; ++ } ++ ++ cm_x300_ulpi_phy_reset(); ++ cm_x300_otg_init(); ++ cm_x300_ulpi_rtsm(); ++ ++ /* disable USB2 Device (slave) controller */ ++ u2d_writel(U2DCR, u2d_readl(U2DCR) & ~U2DCR_UDE); ++ u2d_writel(U2DOTGCR, u2d_readl(U2DOTGCR) | U2DOTGCR_UTMID); ++ ++ /* according to pxa3xx manual vol. IV (p.145) */ ++ /* here also we need to enable OTG interrups, */ ++ /* but we support only host mode, and will not switch to device mode */ ++ /* so we disable the otg interrupts */ ++ u2d_writel(U2DOTGICR, u2d_readl(U2DOTGICR) & ~U2DOTGICR_MASK); ++ ++ cm_x300_set_ulpi_serial6(); ++ ++ return 0; ++} +diff --git a/arch/arm/mach-pxa/cm-x300.c b/arch/arm/mach-pxa/cm-x300.c +index 465da26..6129adb 100644 +--- a/arch/arm/mach-pxa/cm-x300.c ++++ b/arch/arm/mach-pxa/cm-x300.c +@@ -3,9 +3,10 @@ + * + * Support for the CompuLab CM-X300 modules + * +- * Copyright (C) 2008 CompuLab Ltd. ++ * Copyright (C) 2008,2009 CompuLab Ltd. + * + * Mike Rapoport <mike@compulab.co.il> ++ * Igor Grinberg <grinberg@compulab.co.il> + * + * 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 +@@ -16,21 +17,33 @@ + #include <linux/kernel.h> + #include <linux/interrupt.h> + #include <linux/init.h> ++#include <linux/delay.h> + #include <linux/platform_device.h> + + #include <linux/gpio.h> + #include <linux/dm9000.h> + #include <linux/leds.h> + #include <linux/rtc-v3020.h> ++#include <linux/pwm_backlight.h> + + #include <linux/i2c.h> + #include <linux/i2c/pca953x.h> + ++#include <linux/mfd/da903x.h> ++#include <linux/power_supply.h> ++#include <linux/apm-emulation.h> ++ ++#include <linux/spi/spi.h> ++#include <linux/spi/spi_gpio.h> ++#include <linux/spi/tdo24m.h> ++ + #include <asm/mach-types.h> + #include <asm/mach/arch.h> + #include <asm/setup.h> + + #include <mach/pxa300.h> ++#include <mach/pxa27x-udc.h> ++#include <mach/audio.h> + #include <mach/pxafb.h> + #include <mach/mmc.h> + #include <mach/ohci.h> +@@ -40,6 +53,7 @@ + #include <asm/mach/map.h> + + #include "generic.h" ++#include "devices.h" + + #define CM_X300_ETH_PHYS 0x08000010 + +@@ -53,7 +67,7 @@ + #define GPIO97_RTC_RD (97) + #define GPIO98_RTC_IO (98) + +-static mfp_cfg_t cm_x300_mfp_cfg[] __initdata = { ++static mfp_cfg_t cm_x3xx_mfp_cfg[] __initdata = { + /* LCD */ + GPIO54_LCD_LDD_0, + GPIO55_LCD_LDD_1, +@@ -137,7 +151,6 @@ static mfp_cfg_t cm_x300_mfp_cfg[] __initdata = { + GPIO36_UART1_DTR, + + /* GPIOs */ +- GPIO79_GPIO, /* LED */ + GPIO82_GPIO | MFP_PULL_HIGH, /* MMC CD */ + GPIO85_GPIO, /* MMC WP */ + GPIO99_GPIO, /* Ethernet IRQ */ +@@ -151,6 +164,50 @@ static mfp_cfg_t cm_x300_mfp_cfg[] __initdata = { + /* Standard I2C */ + GPIO21_I2C_SCL, + GPIO22_I2C_SDA, ++ ++ /* PWM Backlight */ ++ GPIO19_PWM2_OUT, ++}; ++ ++static mfp_cfg_t cm_x3xx_rev_lt130_mfp_cfg[] __initdata = { ++ /* GPIOs */ ++ GPIO79_GPIO, /* LED */ ++ GPIO77_GPIO, /* WiFi reset */ ++ GPIO78_GPIO, /* BT reset */ ++}; ++ ++static mfp_cfg_t cm_x3xx_rev_ge130_mfp_cfg[] __initdata = { ++ /* GPIOs */ ++ GPIO76_GPIO, /* LED */ ++ GPIO71_GPIO, /* WiFi reset */ ++ GPIO70_GPIO, /* BT reset */ ++}; ++ ++static mfp_cfg_t cm_x310_mfp_cfg[] __initdata = { ++ /* USB PORT 2 */ ++ ULPI_STP, ++ ULPI_NXT, ++ ULPI_DIR, ++ GPIO30_ULPI_DATA_OUT_0, ++ GPIO31_ULPI_DATA_OUT_1, ++ GPIO32_ULPI_DATA_OUT_2, ++ GPIO33_ULPI_DATA_OUT_3, ++ GPIO34_ULPI_DATA_OUT_4, ++ GPIO35_ULPI_DATA_OUT_5, ++ GPIO36_ULPI_DATA_OUT_6, ++ GPIO37_ULPI_DATA_OUT_7, ++ GPIO38_ULPI_CLK, ++ /* external PHY reset pin */ ++ GPIO127_GPIO, ++ ++ /* USB PORT 3 */ ++ GPIO77_USB_P3_1, ++ GPIO78_USB_P3_2, ++ GPIO79_USB_P3_3, ++ GPIO80_USB_P3_4, ++ GPIO81_USB_P3_5, ++ GPIO82_USB_P3_6, ++ GPIO0_2_USBH_PEN, + }; + + #if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE) +@@ -195,17 +252,18 @@ static void __init cm_x300_init_dm9000(void) + static inline void cm_x300_init_dm9000(void) {} + #endif + ++/* LCD */ + #if defined(CONFIG_FB_PXA) || defined(CONFIG_FB_PXA_MODULE) + static struct pxafb_mode_info cm_x300_lcd_modes[] = { + [0] = { +- .pixclock = 38000, ++ .pixclock = 38250, + .bpp = 16, + .xres = 480, + .yres = 640, + .hsync_len = 8, + .vsync_len = 2, + .left_margin = 8, +- .upper_margin = 0, ++ .upper_margin = 2, + .right_margin = 24, + .lower_margin = 4, + .cmap_greyscale = 0, +@@ -227,7 +285,7 @@ static struct pxafb_mode_info cm_x300_lcd_modes[] = { + + static struct pxafb_mach_info cm_x300_lcd = { + .modes = cm_x300_lcd_modes, +- .num_modes = 2, ++ .num_modes = ARRAY_SIZE(cm_x300_lcd_modes), + .lcd_conn = LCD_COLOR_TFT_16BPP | LCD_PCLK_EDGE_FALL, + }; + +@@ -239,6 +297,87 @@ static void __init cm_x300_init_lcd(void) + static inline void cm_x300_init_lcd(void) {} + #endif + ++#if defined(CONFIG_BACKLIGHT_PWM) || defined(CONFIG_BACKLIGHT_PWM_MODULE) ++static struct platform_pwm_backlight_data cm_x300_backlight_data = { ++ .pwm_id = 2, ++ .max_brightness = 100, ++ .dft_brightness = 100, ++ .pwm_period_ns = 10000, ++}; ++ ++static struct platform_device cm_x300_backlight_device = { ++ .name = "pwm-backlight", ++ .dev = { ++ .parent = &pxa27x_device_pwm0.dev, ++ .platform_data = &cm_x300_backlight_data, ++ }, ++}; ++ ++static void cm_x300_init_bl(void) ++{ ++ platform_device_register(&cm_x300_backlight_device); ++} ++#else ++static inline void cm_x300_init_bl(void) {} ++#endif ++ ++#if defined(CONFIG_SPI_GPIO) || defined(CONFIG_SPI_GPIO_MODULE) ++#define GPIO_LCD_BASE (144) ++#define GPIO_LCD_DIN (GPIO_LCD_BASE + 8) /* aux_gpio3_0 */ ++#define GPIO_LCD_DOUT (GPIO_LCD_BASE + 9) /* aux_gpio3_1 */ ++#define GPIO_LCD_SCL (GPIO_LCD_BASE + 10) /* aux_gpio3_2 */ ++#define GPIO_LCD_CS (GPIO_LCD_BASE + 11) /* aux_gpio3_3 */ ++#define LCD_SPI_BUS_NUM (1) ++ ++static struct spi_gpio_platform_data cm_x300_spi_gpio_pdata = { ++ .sck = GPIO_LCD_SCL, ++ .mosi = GPIO_LCD_DIN, ++ .miso = GPIO_LCD_DOUT, ++ .num_chipselect = 1, ++}; ++ ++static struct platform_device cm_x300_spi_gpio = { ++ .name = "spi_gpio", ++ .id = LCD_SPI_BUS_NUM, ++ .dev = { ++ .platform_data = &cm_x300_spi_gpio_pdata, ++ }, ++}; ++ ++static struct tdo24m_platform_data cm_x300_tdo24m_pdata = { ++ .model = TDO35S, ++}; ++ ++static struct spi_board_info cm_x300_spi_devices[] __initdata = { ++ { ++ .modalias = "tdo24m", ++ .max_speed_hz = 1000000, ++ .bus_num = LCD_SPI_BUS_NUM, ++ .chip_select = 0, ++ .controller_data = (void *) GPIO_LCD_CS, ++ .platform_data = &cm_x300_tdo24m_pdata, ++ }, ++}; ++ ++static void __init cm_x300_init_spi(void) ++{ ++ spi_register_board_info(cm_x300_spi_devices, ++ ARRAY_SIZE(cm_x300_spi_devices)); ++ platform_device_register(&cm_x300_spi_gpio); ++} ++#else ++static inline void cm_x300_init_spi(void) {} ++#endif ++ ++#if defined(CONFIG_SND_PXA2XX_LIB_AC97) ++static void __init cm_x300_init_ac97(void) ++{ ++ pxa_set_ac97_info(NULL); ++} ++#else ++static inline void cm_x300_init_ac97(void) {} ++#endif ++ + #if defined(CONFIG_MTD_NAND_PXA3xx) || defined(CONFIG_MTD_NAND_PXA3xx_MODULE) + static struct mtd_partition cm_x300_nand_partitions[] = { + [0] = { +@@ -292,32 +431,12 @@ static inline void cm_x300_init_nand(void) {} + #endif + + #if defined(CONFIG_MMC) || defined(CONFIG_MMC_MODULE) +-/* The first MMC slot of CM-X300 is hardwired to Libertas card and has +- no detection/ro pins */ +-static int cm_x300_mci_init(struct device *dev, +- irq_handler_t cm_x300_detect_int, +- void *data) +-{ +- return 0; +-} +- +-static void cm_x300_mci_exit(struct device *dev, void *data) +-{ +-} +- +-static struct pxamci_platform_data cm_x300_mci_platform_data = { +- .detect_delay = 20, +- .ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34, +- .init = cm_x300_mci_init, +- .exit = cm_x300_mci_exit, +-}; +- +-static int cm_x300_mci2_ro(struct device *dev) ++static int cm_x300_mci_ro(struct device *dev) + { + return gpio_get_value(GPIO85_MMC2_WP); + } + +-static int cm_x300_mci2_init(struct device *dev, ++static int cm_x300_mci_init(struct device *dev, + irq_handler_t cm_x300_detect_int, + void *data) + { +@@ -355,19 +474,39 @@ err_request_cd: + return err; + } + +-static void cm_x300_mci2_exit(struct device *dev, void *data) ++static void cm_x300_mci_exit(struct device *dev, void *data) + { + free_irq(CM_X300_MMC2_IRQ, data); + gpio_free(GPIO82_MMC2_IRQ); + gpio_free(GPIO85_MMC2_WP); + } + ++static struct pxamci_platform_data cm_x300_mci_platform_data = { ++ .detect_delay = 20, ++ .ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34, ++ .init = cm_x300_mci_init, ++ .exit = cm_x300_mci_exit, ++ .get_ro = cm_x300_mci_ro, ++}; ++ ++/* The second MMC slot of CM-X300 is hardwired to Libertas card and has ++ no detection/ro pins */ ++static int cm_x300_mci2_init(struct device *dev, ++ irq_handler_t cm_x300_detect_int, ++ void *data) ++{ ++ return 0; ++} ++ ++static void cm_x300_mci2_exit(struct device *dev, void *data) ++{ ++} ++ + static struct pxamci_platform_data cm_x300_mci2_platform_data = { + .detect_delay = 20, + .ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34, + .init = cm_x300_mci2_init, + .exit = cm_x300_mci2_exit, +- .get_ro = cm_x300_mci2_ro, + }; + + static void __init cm_x300_init_mmc(void) +@@ -380,9 +519,25 @@ static inline void cm_x300_init_mmc(void) {} + #endif + + #if defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE) ++ ++extern int cm_x300_ulpi_init(void); ++ ++static int cm_x300_ohci_init(struct device *dev) ++{ ++ if (cpu_is_pxa300()) ++ UP2OCR = UP2OCR_HXS ++ | UP2OCR_HXOE | UP2OCR_DMPDE | UP2OCR_DPPDE; ++ ++ if (cpu_is_pxa310()) ++ cm_x300_ulpi_init(); ++ ++ return 0; ++} ++ + static struct pxaohci_platform_data cm_x300_ohci_platform_data = { + .port_mode = PMM_PERPORT_MODE, +- .flags = ENABLE_PORT1 | ENABLE_PORT2 | POWER_CONTROL_LOW, ++ .flags = ENABLE_PORT_ALL | POWER_CONTROL_LOW, ++ .init = cm_x300_ohci_init, + }; + + static void __init cm_x300_init_ohci(void) +@@ -398,7 +553,6 @@ static struct gpio_led cm_x300_leds[] = { + [0] = { + .name = "cm-x300:green", + .default_trigger = "heartbeat", +- .gpio = 79, + .active_low = 1, + }, + }; +@@ -418,6 +572,11 @@ static struct platform_device cm_x300_led_device = { + + static void __init cm_x300_init_leds(void) + { ++ if (system_rev < 130) ++ cm_x300_leds[0].gpio = 79; ++ else ++ cm_x300_leds[0].gpio = 76; ++ + platform_device_register(&cm_x300_led_device); + } + #else +@@ -480,19 +639,150 @@ static void __init cm_x300_init_rtc(void) + static inline void cm_x300_init_rtc(void) {} + #endif + +-static void __init cm_x300_init(void) ++/* Battery */ ++struct power_supply_info cm_x300_psy_info = { ++ .name = "battery", ++ .technology = POWER_SUPPLY_TECHNOLOGY_LIPO, ++ .voltage_max_design = 4200000, ++ .voltage_min_design = 3000000, ++ .use_for_apm = 1, ++}; ++ ++static void cm_x300_battery_low(void) ++{ ++#if defined(CONFIG_APM_EMULATION) ++ apm_queue_event(APM_LOW_BATTERY); ++#endif ++} ++ ++static void cm_x300_battery_critical(void) ++{ ++#if defined(CONFIG_APM_EMULATION) ++ apm_queue_event(APM_CRITICAL_SUSPEND); ++#endif ++} ++ ++struct da9030_battery_info cm_x300_battery_info = { ++ .battery_info = &cm_x300_psy_info, ++ ++ .charge_milliamp = 1000, ++ .charge_millivolt = 4200, ++ ++ .vbat_low = 3600, ++ .vbat_crit = 3400, ++ .vbat_charge_start = 4100, ++ .vbat_charge_stop = 4200, ++ .vbat_charge_restart = 4000, ++ ++ .vcharge_min = 3200, ++ .vcharge_max = 5500, ++ ++ .tbat_low = 197, ++ .tbat_high = 78, ++ .tbat_restart = 100, ++ ++ .batmon_interval = 0, ++ ++ .battery_low = cm_x300_battery_low, ++ .battery_critical = cm_x300_battery_critical, ++}; ++ ++/* DA9030 */ ++struct da903x_subdev_info cm_x300_da9030_subdevs[] = { ++ { ++ .name = "da903x-battery", ++ .id = DA9030_ID_BAT, ++ .platform_data = &cm_x300_battery_info, ++ }, ++}; ++ ++static struct da903x_platform_data cm_x300_da9030_info = { ++ .num_subdevs = ARRAY_SIZE(cm_x300_da9030_subdevs), ++ .subdevs = cm_x300_da9030_subdevs, ++}; ++ ++static struct i2c_board_info cm_x300_pmic_info = { ++ I2C_BOARD_INFO("da9030", 0x49), ++ .irq = IRQ_WAKEUP0, ++ .platform_data = &cm_x300_da9030_info, ++}; ++ ++static struct i2c_pxa_platform_data cm_x300_pwr_i2c_info = { ++ .use_pio = 1, ++}; ++ ++static void __init cm_x300_init_da9030(void) ++{ ++ pxa3xx_set_i2c_power_info(&cm_x300_pwr_i2c_info); ++ i2c_register_board_info(1, &cm_x300_pmic_info, 1); ++} ++ ++static void __init cm_x300_init_wi2wi(void) ++{ ++ int bt_reset, wlan_en; ++ int err; ++ ++ if (system_rev < 130) { ++ wlan_en = 77; ++ bt_reset = 78; ++ } else { ++ wlan_en = 71; ++ bt_reset = 70; ++ } ++ ++ /* Libertas and CSR reset */ ++ err = gpio_request(wlan_en, "wlan en"); ++ if (err) { ++ pr_err("CM-X300: failed to request wlan en gpio: %d\n", err); ++ } else { ++ gpio_direction_output(wlan_en, 1); ++ gpio_free(wlan_en); ++ } ++ ++ err = gpio_request(bt_reset, "bt reset"); ++ if (err) { ++ pr_err("CM-X300: failed to request bt reset gpio: %d\n", err); ++ } else { ++ gpio_direction_output(bt_reset, 1); ++ udelay(10); ++ gpio_set_value(bt_reset, 0); ++ udelay(10); ++ gpio_set_value(bt_reset, 1); ++ gpio_free(bt_reset); ++ } ++} ++ ++/* MFP */ ++static void __init cm_x300_init_mfp(void) + { + /* board-processor specific GPIO initialization */ +- pxa3xx_mfp_config(ARRAY_AND_SIZE(cm_x300_mfp_cfg)); ++ pxa3xx_mfp_config(ARRAY_AND_SIZE(cm_x3xx_mfp_cfg)); ++ ++ if (system_rev < 130) ++ pxa3xx_mfp_config(ARRAY_AND_SIZE(cm_x3xx_rev_lt130_mfp_cfg)); ++ else ++ pxa3xx_mfp_config(ARRAY_AND_SIZE(cm_x3xx_rev_ge130_mfp_cfg)); + ++ if (cpu_is_pxa310()) ++ pxa3xx_mfp_config(ARRAY_AND_SIZE(cm_x310_mfp_cfg)); ++} ++ ++static void __init cm_x300_init(void) ++{ ++ cm_x300_init_mfp(); ++ cm_x300_init_da9030(); + cm_x300_init_dm9000(); + cm_x300_init_lcd(); ++ cm_x300_init_bl(); + cm_x300_init_ohci(); + cm_x300_init_mmc(); + cm_x300_init_nand(); + cm_x300_init_leds(); + cm_x300_init_i2c(); ++ cm_x300_init_spi(); + cm_x300_init_rtc(); ++ cm_x300_init_ac97(); ++ cm_x300_init_wi2wi(); + } + + static void __init cm_x300_fixup(struct machine_desc *mdesc, struct tag *tags, +diff --git a/arch/arm/mach-pxa/include/mach/regs-u2d.h b/arch/arm/mach-pxa/include/mach/regs-u2d.h +new file mode 100644 +index 0000000..44b0b20 +--- /dev/null ++++ b/arch/arm/mach-pxa/include/mach/regs-u2d.h +@@ -0,0 +1,199 @@ ++#ifndef __ASM_ARCH_PXA3xx_U2D_H ++#define __ASM_ARCH_PXA3xx_U2D_H ++ ++#include <mach/bitfield.h> ++ ++/* ++ * USB2 device controller registers and bits definitions ++ */ ++#define U2DCR (0x0000) /* U2D Control Register */ ++#define U2DCR_NDC (1 << 31) /* NAK During Config */ ++#define U2DCR_HSTC (0x7 << 28) /* High Speed Timeout Calibration */ ++#define U2DCR_SPEOREN (1 << 27) /* Short Packet EOR INTR generation Enable */ ++#define U2DCR_FSTC (0x7 << 24) /* Full Speed Timeout Calibration */ ++#define U2DCR_UCLKOVR (1 << 22) /* UTM Clock Override */ ++#define U2DCR_ABP (1 << 21) /* Application Bus Power */ ++#define U2DCR_ADD (1 << 20) /* Application Device Disconnect */ ++#define U2DCR_CC (1 << 19) /* Configuration Change */ ++#define U2DCR_HS (1 << 18) /* High Speed USB Detection */ ++#define U2DCR_SMAC (1 << 17) /* Switch Endpoint Memory to Active Configuration */ ++#define U2DCR_DWRE (1 << 16) /* Device Remote Wake-up Feature */ ++#define U2DCR_ACN (0xf << 12) /* Active U2D Configuration Number */ ++#define U2DCR_AIN (0xf << 8) /* Active U2D Interface Number */ ++#define U2DCR_AAISN (0xf << 4) /* Active U2D Alternate Interface Setting Number */ ++#define U2DCR_EMCE (1 << 3) /* Endpoint Memory Configuration Error */ ++#define U2DCR_UDR (1 << 2) /* U2D Resume */ ++#define U2DCR_UDA (1 << 1) /* U2D Active */ ++#define U2DCR_UDE (1 << 0) /* U2D Enable */ ++ ++#define U2DICR (0x0004) /* U2D Interrupt Control Register */ ++#define U2DISR (0x000C) /* U2D Interrupt Status Register */ ++#define U2DINT_CC (1 << 31) /* Interrupt - Configuration Change */ ++#define U2DINT_SOF (1 << 30) /* Interrupt - SOF */ ++#define U2DINT_USOF (1 << 29) /* Interrupt - micro SOF */ ++#define U2DINT_RU (1 << 28) /* Interrupt - Resume */ ++#define U2DINT_SU (1 << 27) /* Interrupt - Suspend */ ++#define U2DINT_RS (1 << 26) /* Interrupt - Reset */ ++#define U2DINT_DPE (1 << 25) /* Interrupt - Data Packet Error */ ++#define U2DINT_FIFOERR (0x4) /* Interrupt - endpoint FIFO error */ ++#define U2DINT_PACKETCMP (0x2) /* Interrupt - endpoint packet complete */ ++#define U2DINT_SPACKETCMP (0x1) /* Interrupt - endpoint short packet complete */ ++ ++#define U2DFNR (0x0014) /* U2D Frame Number Register */ ++ ++#define U2DINT(n, intr) (((intr) & 0x07) << (((n) & 0x07) * 3)) ++#define U2DICR2 (0x0008) /* U2D Interrupt Control Register 2 */ ++#define U2DISR2 (0x0010) /* U2D Interrupt Status Register 2 */ ++ ++#define U2DOTGCR (0x0020) /* U2D OTG Control Register */ ++#define U2DOTGCR_OTGEN (1 << 31) /* On-The-Go Enable */ ++#define U2DOTGCR_AALTHNP (1 << 30) /* A-device Alternate Host Negotiation Protocal Port Support */ ++#define U2DOTGCR_AHNP (1 << 29) /* A-device Host Negotiation Protocal Support */ ++#define U2DOTGCR_BHNP (1 << 28) /* B-device Host Negotiation Protocal Enable */ ++ ++#ifdef CONFIG_CPU_PXA930 ++#define U2DOTGCR_LPA (1 << 15) /* ULPI low power mode active */ ++#define U2DOTGCR_IESI (1 << 13) /* OTG interrupt Enable */ ++#define U2DOTGCR_ISSI (1 << 12) /* OTG interrupt status */ ++#endif ++ ++#define U2DOTGCR_CKAF (1 << 5) /* Carkit Mode Alternate Function Select */ ++#define U2DOTGCR_UTMID (1 << 4) /* UTMI Interface Disable */ ++#define U2DOTGCR_ULAF (1 << 3) /* ULPI Mode Alternate Function Select */ ++#define U2DOTGCR_SMAF (1 << 2) /* Serial Mode Alternate Function Select */ ++#define U2DOTGCR_RTSM (1 << 1) /* Return to Synchronous Mode (ULPI Mode) */ ++#define U2DOTGCR_ULE (1 << 0) /* ULPI Wrapper Enable */ ++ ++#define U2DOTGICR (0x0024) /* U2D OTG Interrupt Control Register */ ++#define U2DOTGISR (0x0028) /* U2D OTG Interrupt Status Register */ ++ ++#define U2DOTGINT_SF (1 << 17) /* OTG Set Feature Command Received */ ++#define U2DOTGINT_SI (1 << 16) /* OTG Interrupt */ ++#define U2DOTGINT_RLS1 (1 << 14) /* RXCMD Linestate[1] Change Interrupt Rise */ ++#define U2DOTGINT_RLS0 (1 << 13) /* RXCMD Linestate[0] Change Interrupt Rise */ ++#define U2DOTGINT_RID (1 << 12) /* RXCMD OTG ID Change Interrupt Rise */ ++#define U2DOTGINT_RSE (1 << 11) /* RXCMD OTG Session End Interrupt Rise */ ++#define U2DOTGINT_RSV (1 << 10) /* RXCMD OTG Session Valid Interrupt Rise */ ++#define U2DOTGINT_RVV (1 << 9) /* RXCMD OTG Vbus Valid Interrupt Rise */ ++#define U2DOTGINT_RCK (1 << 8) /* RXCMD Carkit Interrupt Rise */ ++#define U2DOTGINT_FLS1 (1 << 6) /* RXCMD Linestate[1] Change Interrupt Fall */ ++#define U2DOTGINT_FLS0 (1 << 5) /* RXCMD Linestate[0] Change Interrupt Fall */ ++#define U2DOTGINT_FID (1 << 4) /* RXCMD OTG ID Change Interrupt Fall */ ++#define U2DOTGINT_FSE (1 << 3) /* RXCMD OTG Session End Interrupt Fall */ ++#define U2DOTGINT_FSV (1 << 2) /* RXCMD OTG Session Valid Interrupt Fall */ ++#define U2DOTGINT_FVV (1 << 1) /* RXCMD OTG Vbus Valid Interrupt Fall */ ++#define U2DOTGINT_FCK (1 << 0) /* RXCMD Carkit Interrupt Fall */ ++ ++#define U2DOTGUSR (0x002C) /* U2D OTG ULPI Status Register */ ++#define U2DOTGUSR_LPA (1 << 31) /* ULPI Low Power Mode Active */ ++#define U2DOTGUSR_S6A (1 << 30) /* ULPI Serial Mode (6-pin) Active */ ++#define U2DOTGUSR_S3A (1 << 29) /* ULPI Serial Mode (3-pin) Active */ ++#define U2DOTGUSR_CKA (1 << 28) /* ULPI Car Kit Mode Active */ ++#define U2DOTGUSR_LS1 (1 << 6) /* RXCMD Linestate 1 Status */ ++#define U2DOTGUSR_LS0 (1 << 5) /* RXCMD Linestate 0 Status */ ++#define U2DOTGUSR_ID (1 << 4) /* OTG IDGnd Status */ ++#define U2DOTGUSR_SE (1 << 3) /* OTG Session End Status */ ++#define U2DOTGUSR_SV (1 << 2) /* OTG Session Valid Status */ ++#define U2DOTGUSR_VV (1 << 1) /* OTG Vbus Valid Status */ ++#define U2DOTGUSR_CK (1 << 0) /* Carkit Interrupt Status */ ++ ++#define U2DOTGUCR (0x0030) /* U2D OTG ULPI Control Register */ ++#define U2DOTGUCR_RUN (1 << 25) /* RUN */ ++#define U2DOTGUCR_RNW (1 << 24) /* Read or Write operation */ ++#define U2DOTGUCR_ADDR (0x3f << 16) /* Address of the ULPI PHY register */ ++#define U2DOTGUCR_WDATA (0xff << 8) /* The data for a WRITE command */ ++#define U2DOTGUCR_RDATA (0xff << 0) /* The data for a READ command */ ++ ++#define U2DP3CR (0x0034) /* U2D Port 3 Control Register */ ++#define U2DP3CR_P2SS (0x3 << 8) /* Host Port 2 Serial Mode Select */ ++#define U2DP3CR_P3SS (0x7 << 4) /* Host Port 3 Serial Mode Select */ ++#define U2DP3CR_VPVMBEN (0x1 << 2) /* Host Port 3 Vp/Vm Block Enable */ ++#define U2DP3CR_CFG (0x3 << 0) /* Host Port 3 Configuration */ ++ ++#define U2DCSR0 (0x0100) /* U2D Control/Status Register - Endpoint 0 */ ++#define U2DCSR0_IPA (1 << 8) /* IN Packet Adjusted */ ++#define U2DCSR0_SA (1 << 7) /* SETUP Active */ ++#define U2DCSR0_RNE (1 << 6) /* Receive FIFO Not Empty */ ++#define U2DCSR0_FST (1 << 5) /* Force Stall */ ++#define U2DCSR0_SST (1 << 4) /* Send Stall */ ++#define U2DCSR0_DME (1 << 3) /* DMA Enable */ ++#define U2DCSR0_FTF (1 << 2) /* Flush Transmit FIFO */ ++#define U2DCSR0_IPR (1 << 1) /* IN Packet Ready */ ++#define U2DCSR0_OPC (1 << 0) /* OUT Packet Complete */ ++ ++#define U2DCSR(x) (0x0100 + ((x) << 2)) /* U2D Control/Status Register - Endpoint x */ ++#define U2DCSR_BF (1 << 10) /* Buffer Full, for OUT eps */ ++#define U2DCSR_BE (1 << 10) /* Buffer Empty, for IN eps */ ++#define U2DCSR_DPE (1 << 9) /* Data Packet Error, for ISO eps only */ ++#define U2DCSR_FEF (1 << 8) /* Flush Endpoint FIFO */ ++#define U2DCSR_SP (1 << 7) /* Short Packet Control/Status, for OUT eps only, readonly */ ++#define U2DCSR_BNE (1 << 6) /* Buffer Not Empty, for OUT eps */ ++#define U2DCSR_BNF (1 << 6) /* Buffer Not Full, for IN eps */ ++#define U2DCSR_FST (1 << 5) /* Force STALL, write 1 set */ ++#define U2DCSR_SST (1 << 4) /* Sent STALL, write 1 clear */ ++#define U2DCSR_DME (1 << 3) /* DMA Enable */ ++#define U2DCSR_TRN (1 << 2) /* Tx/Rx NAK, write 1 clear */ ++#define U2DCSR_PC (1 << 1) /* Packet Complete, write 1 clear */ ++#define U2DCSR_FS (1 << 0) /* FIFO needs Service */ ++ ++#define U2DBCR0 (0x0200) /* U2D Byte Count Register - Endpoint 0 */ ++#define U2DBCR(x) (0x0200 + ((x) << 2)) /* U2D Byte Count Register - Endpoint x */ ++ ++#define U2DDR0 (0x0300) /* U2D Data Register - Endpoint 0 */ ++ ++#define U2DEPCR(x) (0x0400 + ((x) << 2)) /* U2D Configuration Register - Endpoint x */ ++#define U2DEPCR_EE (1 << 0) /* Endpoint Enable */ ++#define U2DEPCR_BS_MASK (0x3FE) /* Buffer Size, BS*8=FIFO size, max 8184B = 8KB */ ++ ++#define U2DSCA (0x0500) /* U2D Setup Command Address */ ++#define U2DSCA_VALUE (0x0120) ++ ++#define U2DEN0 (0x0504) /* U2D Endpoint Information Register - Endpoint 0 */ ++#define U2DEN(x) (0x0504 + ((x) << 2)) /* U2D Endpoint Information Register - Endpoint x */ ++ ++/* U2DMA registers */ ++#define U2DMACSR0 (0x1000) /* U2DMA Control/Status Register - Channel 0 */ ++#define U2DMACSR(x) (0x1000 + ((x) << 2)) /* U2DMA Control/Status Register - Channel x */ ++#define U2DMACSR_RUN (1 << 31) /* Run Bit (read / write) */ ++#define U2DMACSR_STOPIRQEN (1 << 29) /* Stop Interrupt Enable (read / write) */ ++#define U2DMACSR_EORIRQEN (1 << 28) /* End of Receive Interrupt Enable (R/W) */ ++#define U2DMACSR_EORJMPEN (1 << 27) /* Jump to next descriptor on EOR */ ++#define U2DMACSR_EORSTOPEN (1 << 26) /* STOP on an EOR */ ++#define U2DMACSR_RASIRQEN (1 << 23) /* Request After Cnannel Stopped Interrupt Enable */ ++#define U2DMACSR_MASKRUN (1 << 22) /* Mask Run */ ++#define U2DMACSR_SCEMC (3 << 18) /* System Bus Split Completion Error Message Class */ ++#define U2DMACSR_SCEMI (0x1f << 13) /* System Bus Split Completion Error Message Index */ ++#define U2DMACSR_BUSERRTYPE (7 << 10) /* PX Bus Error Type */ ++#define U2DMACSR_EORINTR (1 << 9) /* End Of Receive */ ++#define U2DMACSR_REQPEND (1 << 8) /* Request Pending */ ++#define U2DMACSR_RASINTR (1 << 4) /* Request After Channel Stopped (read / write 1 clear) */#define U2DMACSR_STOPINTR (1 << 3) /* Stop Interrupt (read only) */ ++#define U2DMACSR_ENDINTR (1 << 2) /* End Interrupt (read / write 1 clear) */ ++#define U2DMACSR_STARTINTR (1 << 1) /* Start Interrupt (read / write 1 clear) */ ++#define U2DMACSR_BUSERRINTR (1 << 0) /* Bus Error Interrupt (read / write 1 clear) */ ++ ++#define U2DMACR (0x1080) /* U2DMA Control Register */ ++#define U2DMAINT (0x10F0) /* U2DMA Interrupt Register */ ++ ++#define U2DMABR0 (0x1100) /* U2DMA Branch Register - Channel 0 */ ++#define U2DMABR(x) (0x1100 + (x) << 2) /* U2DMA Branch Register - Channel x */ ++ ++#define U2DMADADR0 (0x1200) /* U2DMA Descriptor Address Register - Channel 0 */ ++#define U2DMADADR(x) (0x1200 + (x) * 0x10) /* U2DMA Descriptor Address Register - Channel x */ ++ ++#define U2DMADADR_STOP (1U << 0) ++ ++#define U2DMASADR0 (0x1204) /* U2DMA Source Address Register - Channel 0 */ ++#define U2DMASADR(x) (0x1204 + (x) * 0x10) /* U2DMA Source Address Register - Channel x */ ++#define U2DMATADR0 (0x1208) /* U2DMA Target Address Register - Channel 0 */ ++#define U2DMATADR(x) (0x1208 + (x) * 0x10) /* U2DMA Target Address Register - Channel x */ ++ ++#define U2DMACMDR0 (0x120C) /* U2DMA Command Address Register - Channel 0 */ ++#define U2DMACMDR(x) (0x120C + (x) * 0x10) /* U2DMA Command Address Register - Channel x */ ++ ++#define U2DMACMDR_XFRDIS (1 << 31) /* Transfer Direction */ ++#define U2DMACMDR_STARTIRQEN (1 << 22) /* Start Interrupt Enable */ ++#define U2DMACMDR_ENDIRQEN (1 << 21) /* End Interrupt Enable */ ++#define U2DMACMDR_PACKCOMP (1 << 13) /* Packet Complete */ ++#define U2DMACMDR_LEN (0x07ff) /* length mask (max = 2K - 1) */ ++ ++#endif /* __ASM_ARCH_PXA3xx_U2D_H */ +diff --git a/arch/arm/mach-pxa/pxa3xx.c b/arch/arm/mach-pxa/pxa3xx.c +index 09b7b1a..dd238ac 100644 +--- a/arch/arm/mach-pxa/pxa3xx.c ++++ b/arch/arm/mach-pxa/pxa3xx.c +@@ -30,6 +30,8 @@ + #include <mach/pm.h> + #include <mach/dma.h> + #include <mach/ssp.h> ++#include <mach/regs-intc.h> ++#include <mach/regs-ost.h> + #include <plat/i2c.h> + + #include "generic.h" +@@ -45,6 +47,9 @@ + #define ACCR_D0CS (1 << 26) + #define ACCR_PCCE (1 << 11) + ++#define PECR_IE(n) ((1 << ((n) * 2)) << 28) ++#define PECR_IS(n) ((1 << ((n) * 2)) << 29) ++ + /* crystal frequency to static memory controller multiplier (SMCFS) */ + static unsigned char smcfs_mult[8] = { 6, 0, 8, 0, 0, 16, }; + +@@ -237,6 +242,7 @@ static DEFINE_PXA3_CKEN(pxa3xx_stuart, STUART, 14857000, 1); + static DEFINE_PXA3_CKEN(pxa3xx_i2c, I2C, 32842000, 0); + static DEFINE_PXA3_CKEN(pxa3xx_udc, UDC, 48000000, 5); + static DEFINE_PXA3_CKEN(pxa3xx_usbh, USBH, 48000000, 0); ++static DEFINE_PXA3_CKEN(pxa3xx_u2d, USB2, 48000000, 0); + static DEFINE_PXA3_CKEN(pxa3xx_keypad, KEYPAD, 32768, 0); + static DEFINE_PXA3_CKEN(pxa3xx_ssp1, SSP1, 13000000, 0); + static DEFINE_PXA3_CKEN(pxa3xx_ssp2, SSP2, 13000000, 0); +@@ -261,6 +267,7 @@ static struct clk_lookup pxa3xx_clkregs[] = { + INIT_CLKREG(&clk_pxa3xx_i2c, "pxa2xx-i2c.0", NULL), + INIT_CLKREG(&clk_pxa3xx_udc, "pxa27x-udc", NULL), + INIT_CLKREG(&clk_pxa3xx_usbh, "pxa27x-ohci", NULL), ++ INIT_CLKREG(&clk_pxa3xx_u2d, NULL, "U2DCLK"), + INIT_CLKREG(&clk_pxa3xx_keypad, "pxa27x-keypad", NULL), + INIT_CLKREG(&clk_pxa3xx_ssp1, "pxa27x-ssp.0", NULL), + INIT_CLKREG(&clk_pxa3xx_ssp2, "pxa27x-ssp.1", NULL), +@@ -286,6 +293,7 @@ static unsigned long wakeup_src; + enum { SLEEP_SAVE_CKENA, + SLEEP_SAVE_CKENB, + SLEEP_SAVE_ACCR, ++ SLEEP_SAVE_OSCR, + + SLEEP_SAVE_COUNT, + }; +@@ -295,6 +303,7 @@ static void pxa3xx_cpu_pm_save(unsigned long *sleep_save) + SAVE(CKENA); + SAVE(CKENB); + SAVE(ACCR); ++ SAVE(OSCR); + } + + static void pxa3xx_cpu_pm_restore(unsigned long *sleep_save) +@@ -302,6 +311,7 @@ static void pxa3xx_cpu_pm_restore(unsigned long *sleep_save) + RESTORE(ACCR); + RESTORE(CKENA); + RESTORE(CKENB); ++ RESTORE(OSCR); + } + + /* +@@ -345,13 +355,20 @@ static void pxa3xx_cpu_standby(unsigned int pwrmode) + static void pxa3xx_cpu_pm_suspend(void) + { + volatile unsigned long *p = (volatile void *)0xc0000000; +- unsigned long saved_data = *p; ++ unsigned long saved_data[3]; ++ ++ saved_data[0] = *p; ++ p = (volatile void *)0xc0000800; ++ saved_data[1] = *p; ++ p = (volatile void *)0xc0000804; ++ saved_data[2] = *p; + + extern void pxa3xx_cpu_suspend(void); + extern void pxa3xx_cpu_resume(void); + + /* resuming from D2 requires the HSIO2/BOOT/TPM clocks enabled */ + CKENA |= (1 << CKEN_BOOT) | (1 << CKEN_TPM); ++ CKENA &= ~(1 << CKEN_USBH); + CKENB |= 1 << (CKEN_HSIO2 & 0x1f); + + /* clear and setup wakeup source */ +@@ -366,11 +383,19 @@ static void pxa3xx_cpu_pm_suspend(void) + PSPR = 0x5c014000; + + /* overwrite with the resume address */ ++ p = (volatile void *)0xc0000000; ++ *p = virt_to_phys(pxa3xx_cpu_resume); ++ p = (volatile void *)0xc0000800; + *p = virt_to_phys(pxa3xx_cpu_resume); + + pxa3xx_cpu_suspend(); + +- *p = saved_data; ++ p = (volatile void *)0xc0000000; ++ *p = saved_data[0]; ++ p = (volatile void *)0xc0000800; ++ *p = saved_data[1]; ++ p = (volatile void *)0xc0000804; ++ *p = saved_data[2]; + + AD3ER = 0; + } +@@ -530,6 +555,43 @@ static inline void pxa3xx_init_pm(void) {} + #define pxa3xx_set_wake NULL + #endif + ++static void pxa_ack_ext_wakeup(unsigned int irq) ++{ ++ PECR |= PECR_IS(irq - IRQ_WAKEUP0); ++} ++ ++static void pxa_mask_ext_wakeup(unsigned int irq) ++{ ++ ICMR2 &= ~(1 << ((irq - PXA_IRQ(0)) & 0x1f)); ++ PECR &= ~PECR_IE(irq - IRQ_WAKEUP0); ++} ++ ++static void pxa_unmask_ext_wakeup(unsigned int irq) ++{ ++ ICMR2 |= 1 << ((irq - PXA_IRQ(0)) & 0x1f); ++ PECR |= PECR_IE(irq - IRQ_WAKEUP0); ++} ++ ++static struct irq_chip pxa_ext_wakeup_chip = { ++ .name = "WAKEUP", ++ .ack = pxa_ack_ext_wakeup, ++ .mask = pxa_mask_ext_wakeup, ++ .unmask = pxa_unmask_ext_wakeup, ++}; ++ ++static void __init pxa_init_ext_wakeup_irq(set_wake_t fn) ++{ ++ int irq; ++ ++ for (irq = IRQ_WAKEUP0; irq <= IRQ_WAKEUP1; irq++) { ++ set_irq_chip(irq, &pxa_ext_wakeup_chip); ++ set_irq_handler(irq, handle_edge_irq); ++ set_irq_flags(irq, IRQF_VALID); ++ } ++ ++ pxa_ext_wakeup_chip.set_wake = fn; ++} ++ + void __init pxa3xx_init_irq(void) + { + /* enable CP6 access */ +@@ -539,6 +601,7 @@ void __init pxa3xx_init_irq(void) + __asm__ __volatile__("mcr p15, 0, %0, c15, c1, 0\n": :"r"(value)); + + pxa_init_irq(56, pxa3xx_set_wake); ++ pxa_init_ext_wakeup_irq(pxa3xx_set_wake); + pxa_init_gpio(IRQ_GPIO_2_x, 2, 127, NULL); + } + +diff --git a/arch/arm/mach-pxa/sleep.S b/arch/arm/mach-pxa/sleep.S +index 2ed95f3..aa7cf5f 100644 +--- a/arch/arm/mach-pxa/sleep.S ++++ b/arch/arm/mach-pxa/sleep.S +@@ -104,6 +104,11 @@ ENTRY(pxa3xx_cpu_resume) + mov r0, #PSR_I_BIT | PSR_F_BIT | SVC_MODE @ set SVC, irqs off + msr cpsr_c, r0 + ++ ldr r0, =0x48100000 @ MDCNFG ++ ldr r1, [r0] ++ orr r1, r1, #0x3 @ Enable both SDRAM partitions ++ str r1, [r0] ++ + ldr r0, sleep_save_sp @ stack phys addr + ldmfd r0, {r3 - r9, sp} @ CP regs + virt stack ptr + +diff --git a/drivers/power/da9030_battery.c b/drivers/power/da9030_battery.c +index 3364198..a478d76 100644 +--- a/drivers/power/da9030_battery.c ++++ b/drivers/power/da9030_battery.c +@@ -300,6 +300,76 @@ static void da9030_charging_monitor(struct work_struct *work) + schedule_delayed_work(&charger->work, charger->interval); + } + ++struct em_x270_battery_thresh { ++ int voltage; ++ int percentage; ++}; ++ ++static struct em_x270_battery_thresh vbat_ranges[] = { ++ {76, 0}, ++ {77, 0}, ++ {78, 0}, ++ {79, 1}, ++ {80, 1}, ++ {81, 1}, ++ {82, 2}, ++ {83, 2}, ++ {84, 2}, ++ {85, 3}, ++ {86, 3}, ++ {87, 4}, ++ {88, 6}, ++ {89, 8}, ++ {90, 11}, ++ {91, 13}, ++ {92, 15}, ++ {93, 18}, ++ {94, 22}, ++ {95, 25}, ++ {96, 29}, ++ {97, 33}, ++ {98, 37}, ++ {99, 41}, ++ {100, 45}, ++ {101, 48}, ++ {102, 51}, ++ {103, 54}, ++ {104, 56}, ++ {105, 59}, ++ {106, 61}, ++ {107, 63}, ++ {108, 65}, ++ {109, 67}, ++ {110, 68}, ++ {111, 70}, ++ {112, 72}, ++ {113, 74}, ++ {114, 75}, ++ {115, 77}, ++ {116, 78}, ++ {117, 80}, ++ {118, 82}, ++ {119, 83}, ++ {120, 84}, ++ {121, 85}, ++ {122, 86}, ++ {123, 87}, ++ {124, 89}, ++ {125, 90}, ++ {126, 91}, ++ {127, 92}, ++ {128, 94}, ++ {129, 95}, ++ {130, 96}, ++ {131, 97}, ++ {132, 98}, ++ {133, 98}, ++ {134, 99}, ++ {135, 100}, ++ {136, 100}, ++ {137, 100}, ++}; ++ + static enum power_supply_property da9030_battery_props[] = { + POWER_SUPPLY_PROP_MODEL_NAME, + POWER_SUPPLY_PROP_STATUS, +@@ -309,6 +379,7 @@ static enum power_supply_property da9030_battery_props[] = { + POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN, + POWER_SUPPLY_PROP_VOLTAGE_NOW, + POWER_SUPPLY_PROP_CURRENT_AVG, ++ POWER_SUPPLY_PROP_CAPACITY, /* in percents! */ + }; + + static void da9030_battery_check_status(struct da9030_charger *charger, +@@ -335,6 +406,27 @@ static void da9030_battery_check_health(struct da9030_charger *charger, + val->intval = POWER_SUPPLY_HEALTH_GOOD; + } + ++static int vbat_interpolate(int reg) ++{ ++ int i; ++ ++ if (reg > vbat_ranges[ARRAY_SIZE(vbat_ranges) - 1].voltage) ++ return 100; ++ ++ if (reg < vbat_ranges[0].voltage) ++ return 0; ++ ++ for (i = 0; i < ARRAY_SIZE(vbat_ranges); i++ ) ++ if (vbat_ranges[i].voltage == reg) { ++ pr_debug("%s: voltage = %d, percentage = %d\n", ++ __FUNCTION__, vbat_ranges[i].voltage, ++ vbat_ranges[i].percentage); ++ return vbat_ranges[i].percentage; ++ } ++ ++ return 0; ++} ++ + static int da9030_battery_get_property(struct power_supply *psy, + enum power_supply_property psp, + union power_supply_propval *val) +@@ -365,6 +457,9 @@ static int da9030_battery_get_property(struct power_supply *psy, + val->intval = + da9030_reg_to_mA(charger->adc.ichaverage_res) * 1000; + break; ++ case POWER_SUPPLY_PROP_CAPACITY: ++ val->intval = vbat_interpolate(charger->adc.vbat_res); ++ break; + case POWER_SUPPLY_PROP_MODEL_NAME: + val->strval = charger->battery_info->name; + break; +diff --git a/sound/soc/pxa/Kconfig b/sound/soc/pxa/Kconfig +index 6375b4e..8734045 100644 +--- a/sound/soc/pxa/Kconfig ++++ b/sound/soc/pxa/Kconfig +@@ -90,7 +90,8 @@ config SND_PXA2XX_SOC_E800 + + config SND_PXA2XX_SOC_EM_X270 + tristate "SoC Audio support for CompuLab EM-x270, eXeda and CM-X300" +- depends on SND_PXA2XX_SOC && MACH_EM_X270 ++ depends on SND_PXA2XX_SOC && (MACH_EM_X270 || MACH_EXEDA || \ ++ MACH_CM_X300) + select SND_PXA2XX_SOC_AC97 + select SND_SOC_WM9712 + help +diff --git a/sound/soc/pxa/em-x270.c b/sound/soc/pxa/em-x270.c +index f4756e4..9dab379 100644 +--- a/sound/soc/pxa/em-x270.c ++++ b/sound/soc/pxa/em-x270.c +@@ -51,7 +51,6 @@ static struct snd_soc_dai_link em_x270_dai[] = { + }; + + static struct snd_soc_card em_x270 = { +- .name = "EM-X270", + .platform = &pxa2xx_soc_platform, + .dai_link = em_x270_dai, + .num_links = ARRAY_SIZE(em_x270_dai), +@@ -68,8 +67,13 @@ static int __init em_x270_init(void) + { + int ret; + +- if (!(machine_is_em_x270() || machine_is_exeda() +- || machine_is_cm_x300())) ++ if (machine_is_em_x270()) ++ em_x270.name = "EM-X270"; ++ else if (machine_is_exeda()) ++ em_x270.name = "EXEDA"; ++ else if (machine_is_cm_x300()) ++ em_x270.name = "CM-X300"; ++ else + return -ENODEV; + + em_x270_snd_device = platform_device_alloc("soc-audio", -1); |