[oe] [PATCHv2 3/5] linux-omap-psp-2.6.32:add patch for am3517-crane board support

Koen Kooi k.kooi at student.utwente.nl
Fri Nov 26 17:24:40 UTC 2010


-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

Hi,

This patch is done against an old version of the metadata, could you
please update it?

regards,

Koen

On 26-11-10 16:41, Anil Kumar wrote:
>         * This patch adds linux-omap-psp kernel support for am3517-crane board.
> 
>         * CraneBoard is a hardware development platform based
>           on the Sitara AM3517 ARM Cortex - A8 microprocessor
>           device. This is a low cost reference design.
> 
>         * You can find more about CraneBoard here:
>                [1] http://www.ti.com/arm
>                [2] http://www.mistralsolutions.com/products/craneboard.php
> 
> Signed-off-by: Anil Kumar <anilm at mistralsolutions.com>
> ---
>  .../0001-Added-support-for-AM3517-CraneBoard.patch | 5223 ++++++++++++++++++++
>  .../linux-omap-psp-2.6.32/am3517-crane/defconfig   | 1769 +++++++
>  recipes/linux/linux-omap-psp_2.6.32.bb             |    4 +-
>  3 files changed, 6995 insertions(+), 1 deletions(-)
>  create mode 100644 recipes/linux/linux-omap-psp-2.6.32/0001-Added-support-for-AM3517-CraneBoard.patch
>  create mode 100644 recipes/linux/linux-omap-psp-2.6.32/am3517-crane/defconfig
> 
> diff --git a/recipes/linux/linux-omap-psp-2.6.32/0001-Added-support-for-AM3517-CraneBoard.patch b/recipes/linux/linux-omap-psp-2.6.32/0001-Added-support-for-AM3517-CraneBoard.patch
> new file mode 100644
> index 0000000..781e432
> --- /dev/null
> +++ b/recipes/linux/linux-omap-psp-2.6.32/0001-Added-support-for-AM3517-CraneBoard.patch
> @@ -0,0 +1,5223 @@
> +From 692dcda5db10ad69661fa57896493f56d6da5c67 Mon Sep 17 00:00:00 2001
> +From: Anil Kumar <anilm at mistralsolutions.com>
> +Date: Thu, 25 Nov 2010 17:50:14 +0530
> +Subject: [PATCH] Added support for AM3517 CraneBoard
> +
> +Signed-off-by: Anil Kumar <anilm at mistralsolutions.com>
> +---
> + arch/arm/configs/am3517_crane_defconfig      | 1769 ++++++++++++++++++++++++++
> + arch/arm/mach-omap2/Kconfig                  |    6 +
> + arch/arm/mach-omap2/Makefile                 |    2 +
> + arch/arm/mach-omap2/board-am3517crane.c      |  773 +++++++++++
> + arch/arm/mach-omap2/mmc-am3517crane.c        |  267 ++++
> + arch/arm/mach-omap2/mmc-am3517crane.h        |   22 +
> + arch/arm/mach-omap2/tps65910-pmic.c          |  195 +++
> + arch/arm/tools/mach-types                    |    1 +
> + drivers/i2c/busses/i2c-omap.c                |    3 +-
> + drivers/mfd/Kconfig                          |   12 +
> + drivers/mfd/Makefile                         |    4 +-
> + drivers/mfd/tps65910-core.c                  |  741 +++++++++++
> + drivers/rtc/Kconfig                          |    8 +
> + drivers/rtc/Makefile                         |    1 +
> + drivers/rtc/rtc-tps65910.c                   |  657 ++++++++++
> + drivers/usb/host/ehci-hub.c                  |    9 +-
> + drivers/usb/musb/Kconfig                     |    6 +-
> + drivers/usb/musb/Makefile                    |    3 +-
> + drivers/usb/musb/musb_core.c                 |    2 +-
> + drivers/usb/musb/musb_core.h                 |    2 +-
> + drivers/usb/musb/musb_gadget.c               |    2 +-
> + drivers/usb/musb/musb_gadget_ep0.c           |    2 +-
> + drivers/usb/musb/musb_io.h                   |    5 +-
> + drivers/usb/musb/musb_virthub.c              |    8 +-
> + drivers/video/omap2/displays/panel-generic.c |   11 +-
> + drivers/video/omap2/dss/venc.c               |   15 +-
> + include/linux/i2c/tps65910.h                 |  278 ++++
> + 27 files changed, 4779 insertions(+), 25 deletions(-)
> + create mode 100644 arch/arm/configs/am3517_crane_defconfig
> + create mode 100644 arch/arm/mach-omap2/board-am3517crane.c
> + create mode 100644 arch/arm/mach-omap2/mmc-am3517crane.c
> + create mode 100644 arch/arm/mach-omap2/mmc-am3517crane.h
> + create mode 100644 arch/arm/mach-omap2/tps65910-pmic.c
> + create mode 100644 drivers/mfd/tps65910-core.c
> + create mode 100644 drivers/rtc/rtc-tps65910.c
> + create mode 100644 include/linux/i2c/tps65910.h
> +
> +diff --git a/arch/arm/configs/am3517_crane_defconfig b/arch/arm/configs/am3517_crane_defconfig
> +new file mode 100644
> +index 0000000..7af351e
> +--- /dev/null
> ++++ b/arch/arm/configs/am3517_crane_defconfig
> +@@ -0,0 +1,1769 @@
> ++#
> ++# Automatically generated make config: don't edit
> ++# Linux kernel version: 2.6.32
> ++# Fri Sep  3 09:45:07 2010
> ++#
> ++CONFIG_ARM=y
> ++CONFIG_SYS_SUPPORTS_APM_EMULATION=y
> ++CONFIG_GENERIC_GPIO=y
> ++CONFIG_GENERIC_TIME=y
> ++CONFIG_GENERIC_CLOCKEVENTS=y
> ++CONFIG_GENERIC_HARDIRQS=y
> ++CONFIG_STACKTRACE_SUPPORT=y
> ++CONFIG_HAVE_LATENCYTOP_SUPPORT=y
> ++CONFIG_LOCKDEP_SUPPORT=y
> ++CONFIG_TRACE_IRQFLAGS_SUPPORT=y
> ++CONFIG_HARDIRQS_SW_RESEND=y
> ++CONFIG_GENERIC_IRQ_PROBE=y
> ++CONFIG_RWSEM_GENERIC_SPINLOCK=y
> ++CONFIG_ARCH_HAS_CPUFREQ=y
> ++CONFIG_GENERIC_HWEIGHT=y
> ++CONFIG_GENERIC_CALIBRATE_DELAY=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
> ++#
> ++CONFIG_EXPERIMENTAL=y
> ++CONFIG_BROKEN_ON_SMP=y
> ++CONFIG_INIT_ENV_ARG_LIMIT=32
> ++CONFIG_LOCALVERSION=""
> ++# CONFIG_LOCALVERSION_AUTO is not set
> ++CONFIG_SWAP=y
> ++CONFIG_SYSVIPC=y
> ++CONFIG_SYSVIPC_SYSCTL=y
> ++# CONFIG_POSIX_MQUEUE is not set
> ++CONFIG_BSD_PROCESS_ACCT=y
> ++# CONFIG_BSD_PROCESS_ACCT_V3 is not set
> ++# CONFIG_TASKSTATS is not set
> ++# CONFIG_AUDIT is not set
> ++
> ++#
> ++# RCU Subsystem
> ++#
> ++CONFIG_TREE_RCU=y
> ++# CONFIG_TREE_PREEMPT_RCU is not set
> ++# CONFIG_TINY_RCU is not set
> ++# CONFIG_RCU_TRACE is not set
> ++CONFIG_RCU_FANOUT=32
> ++# CONFIG_RCU_FANOUT_EXACT is not set
> ++# CONFIG_TREE_RCU_TRACE is not set
> ++CONFIG_IKCONFIG=y
> ++CONFIG_IKCONFIG_PROC=y
> ++CONFIG_LOG_BUF_SHIFT=14
> ++CONFIG_GROUP_SCHED=y
> ++CONFIG_FAIR_GROUP_SCHED=y
> ++# CONFIG_RT_GROUP_SCHED is not set
> ++CONFIG_USER_SCHED=y
> ++# CONFIG_CGROUP_SCHED is not set
> ++# CONFIG_CGROUPS is not set
> ++CONFIG_SYSFS_DEPRECATED=y
> ++CONFIG_SYSFS_DEPRECATED_V2=y
> ++# CONFIG_RELAY is not set
> ++# CONFIG_NAMESPACES is not set
> ++CONFIG_BLK_DEV_INITRD=y
> ++CONFIG_INITRAMFS_SOURCE=""
> ++CONFIG_RD_GZIP=y
> ++# CONFIG_RD_BZIP2 is not set
> ++# CONFIG_RD_LZMA is not set
> ++CONFIG_CC_OPTIMIZE_FOR_SIZE=y
> ++CONFIG_SYSCTL=y
> ++CONFIG_ANON_INODES=y
> ++CONFIG_EMBEDDED=y
> ++CONFIG_UID16=y
> ++# CONFIG_SYSCTL_SYSCALL is not set
> ++CONFIG_KALLSYMS=y
> ++# CONFIG_KALLSYMS_ALL is not set
> ++CONFIG_KALLSYMS_EXTRA_PASS=y
> ++CONFIG_HOTPLUG=y
> ++CONFIG_PRINTK=y
> ++CONFIG_BUG=y
> ++CONFIG_ELF_CORE=y
> ++CONFIG_BASE_FULL=y
> ++CONFIG_FUTEX=y
> ++CONFIG_EPOLL=y
> ++CONFIG_SIGNALFD=y
> ++CONFIG_TIMERFD=y
> ++CONFIG_EVENTFD=y
> ++CONFIG_SHMEM=y
> ++CONFIG_AIO=y
> ++
> ++#
> ++# Kernel Performance Events And Counters
> ++#
> ++CONFIG_VM_EVENT_COUNTERS=y
> ++CONFIG_COMPAT_BRK=y
> ++CONFIG_SLAB=y
> ++# CONFIG_SLUB is not set
> ++# CONFIG_SLOB is not set
> ++# CONFIG_PROFILING is not set
> ++CONFIG_HAVE_OPROFILE=y
> ++# CONFIG_KPROBES is not set
> ++CONFIG_HAVE_KPROBES=y
> ++CONFIG_HAVE_KRETPROBES=y
> ++CONFIG_HAVE_CLK=y
> ++
> ++#
> ++# GCOV-based kernel profiling
> ++#
> ++# CONFIG_SLOW_WORK is not set
> ++CONFIG_HAVE_GENERIC_DMA_COHERENT=y
> ++CONFIG_SLABINFO=y
> ++CONFIG_RT_MUTEXES=y
> ++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_MODVERSIONS=y
> ++CONFIG_MODULE_SRCVERSION_ALL=y
> ++CONFIG_BLOCK=y
> ++CONFIG_LBDAF=y
> ++# CONFIG_BLK_DEV_BSG is not set
> ++# CONFIG_BLK_DEV_INTEGRITY is not set
> ++
> ++#
> ++# IO Schedulers
> ++#
> ++CONFIG_IOSCHED_NOOP=y
> ++CONFIG_IOSCHED_DEADLINE=y
> ++CONFIG_IOSCHED_CFQ=y
> ++# CONFIG_DEFAULT_DEADLINE is not set
> ++CONFIG_DEFAULT_CFQ=y
> ++# CONFIG_DEFAULT_NOOP is not set
> ++CONFIG_DEFAULT_IOSCHED="cfq"
> ++# CONFIG_INLINE_SPIN_TRYLOCK is not set
> ++# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
> ++# CONFIG_INLINE_SPIN_LOCK is not set
> ++# CONFIG_INLINE_SPIN_LOCK_BH is not set
> ++# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
> ++# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
> ++CONFIG_INLINE_SPIN_UNLOCK=y
> ++# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
> ++CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
> ++# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
> ++# CONFIG_INLINE_READ_TRYLOCK is not set
> ++# CONFIG_INLINE_READ_LOCK is not set
> ++# CONFIG_INLINE_READ_LOCK_BH is not set
> ++# CONFIG_INLINE_READ_LOCK_IRQ is not set
> ++# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
> ++CONFIG_INLINE_READ_UNLOCK=y
> ++# CONFIG_INLINE_READ_UNLOCK_BH is not set
> ++CONFIG_INLINE_READ_UNLOCK_IRQ=y
> ++# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
> ++# CONFIG_INLINE_WRITE_TRYLOCK is not set
> ++# CONFIG_INLINE_WRITE_LOCK is not set
> ++# CONFIG_INLINE_WRITE_LOCK_BH is not set
> ++# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
> ++# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
> ++CONFIG_INLINE_WRITE_UNLOCK=y
> ++# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
> ++CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
> ++# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
> ++# CONFIG_MUTEX_SPIN_ON_OWNER is not set
> ++CONFIG_FREEZER=y
> ++
> ++#
> ++# System Type
> ++#
> ++CONFIG_MMU=y
> ++# CONFIG_ARCH_AAEC2000 is not set
> ++# CONFIG_ARCH_INTEGRATOR is not set
> ++# CONFIG_ARCH_REALVIEW is not set
> ++# 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_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_NOMADIK is not set
> ++# CONFIG_ARCH_IOP13XX is not set
> ++# CONFIG_ARCH_IOP32X is not set
> ++# CONFIG_ARCH_IOP33X is not set
> ++# CONFIG_ARCH_IXP23XX is not set
> ++# CONFIG_ARCH_IXP2000 is not set
> ++# CONFIG_ARCH_IXP4XX is not set
> ++# CONFIG_ARCH_L7200 is not set
> ++# CONFIG_ARCH_DOVE is not set
> ++# CONFIG_ARCH_KIRKWOOD is not set
> ++# CONFIG_ARCH_LOKI is not set
> ++# CONFIG_ARCH_MV78XX0 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 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_S5PC1XX 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=y
> ++# CONFIG_ARCH_BCMRING is not set
> ++# CONFIG_ARCH_U8500 is not set
> ++
> ++#
> ++# TI OMAP Implementations
> ++#
> ++CONFIG_ARCH_OMAP_OTG=y
> ++# CONFIG_ARCH_OMAP1 is not set
> ++# CONFIG_ARCH_OMAP2 is not set
> ++CONFIG_ARCH_OMAP3=y
> ++# CONFIG_ARCH_OMAP4 is not set
> ++
> ++#
> ++# OMAP Feature Selections
> ++#
> ++CONFIG_OMAP_RESET_CLOCKS=y
> ++CONFIG_OMAP_MUX=y
> ++# CONFIG_OMAP_MUX_DEBUG is not set
> ++CONFIG_OMAP_MUX_WARNINGS=y
> ++CONFIG_OMAP_MCBSP=y
> ++# CONFIG_OMAP_MBOX_FWK is not set
> ++# CONFIG_OMAP_MPU_TIMER is not set
> ++CONFIG_OMAP_32K_TIMER=y
> ++# CONFIG_OMAP3_L2_AUX_SECURE_SAVE_RESTORE is not set
> ++CONFIG_OMAP_32K_TIMER_HZ=128
> ++CONFIG_OMAP_DM_TIMER=y
> ++# CONFIG_OMAP_LL_DEBUG_UART1 is not set
> ++# CONFIG_OMAP_LL_DEBUG_UART2 is not set
> ++CONFIG_OMAP_LL_DEBUG_UART3=y
> ++# CONFIG_OMAP_LL_DEBUG_NONE is not set
> ++# CONFIG_OMAP_PM_NONE is not set
> ++CONFIG_OMAP_PM_NOOP=y
> ++# CONFIG_OMAP_PM_SRF is not set
> ++CONFIG_ARCH_OMAP34XX=y
> ++CONFIG_ARCH_OMAP3430=y
> ++CONFIG_OMAP_PACKAGE_CBB=y
> ++
> ++#
> ++# OMAP Board Type
> ++#
> ++# CONFIG_MACH_OMAP3_BEAGLE is not set
> ++# CONFIG_MACH_OMAP_LDP is not set
> ++# CONFIG_MACH_OVERO is not set
> ++# CONFIG_MACH_OMAP3EVM is not set
> ++# CONFIG_MACH_OMAP3517EVM is not set
> ++CONFIG_MACH_CRANEBOARD=y
> ++# CONFIG_MACH_OMAP3_PANDORA is not set
> ++# CONFIG_MACH_OMAP3_TOUCHBOOK is not set
> ++# CONFIG_MACH_OMAP_3430SDP is not set
> ++# CONFIG_MACH_NOKIA_RX51 is not set
> ++# CONFIG_MACH_OMAP_ZOOM2 is not set
> ++# CONFIG_MACH_OMAP_ZOOM3 is not set
> ++# CONFIG_MACH_CM_T35 is not set
> ++# CONFIG_MACH_IGEP0020 is not set
> ++# CONFIG_MACH_OMAP_3630SDP is not set
> ++# CONFIG_OMAP3_EMU is not set
> ++# CONFIG_OMAP3_SDRC_AC_TIMING is not set
> ++
> ++#
> ++# Processor Type
> ++#
> ++CONFIG_CPU_32=y
> ++CONFIG_CPU_32v6K=y
> ++CONFIG_CPU_V7=y
> ++CONFIG_CPU_32v7=y
> ++CONFIG_CPU_ABRT_EV7=y
> ++CONFIG_CPU_PABRT_V7=y
> ++CONFIG_CPU_CACHE_V7=y
> ++CONFIG_CPU_CACHE_VIPT=y
> ++CONFIG_CPU_COPY_V6=y
> ++CONFIG_CPU_TLB_V7=y
> ++CONFIG_CPU_HAS_ASID=y
> ++CONFIG_CPU_CP15=y
> ++CONFIG_CPU_CP15_MMU=y
> ++
> ++#
> ++# Processor Features
> ++#
> ++CONFIG_ARM_THUMB=y
> ++# CONFIG_ARM_THUMBEE is not set
> ++# CONFIG_CPU_ICACHE_DISABLE is not set
> ++# CONFIG_CPU_DCACHE_DISABLE is not set
> ++# CONFIG_CPU_BPREDICT_DISABLE is not set
> ++CONFIG_HAS_TLS_REG=y
> ++CONFIG_ARM_L1_CACHE_SHIFT=6
> ++CONFIG_ARM_ERRATA_430973=y
> ++CONFIG_ARM_ERRATA_458693=y
> ++CONFIG_ARM_ERRATA_460075=y
> ++CONFIG_COMMON_CLKDEV=y
> ++
> ++#
> ++# Bus support
> ++#
> ++# CONFIG_PCI_SYSCALL is not set
> ++# CONFIG_ARCH_SUPPORTS_MSI is not set
> ++# CONFIG_PCCARD is not set
> ++
> ++#
> ++# Kernel Features
> ++#
> ++CONFIG_TICK_ONESHOT=y
> ++CONFIG_NO_HZ=y
> ++CONFIG_HIGH_RES_TIMERS=y
> ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
> ++CONFIG_VMSPLIT_3G=y
> ++# CONFIG_VMSPLIT_2G is not set
> ++# CONFIG_VMSPLIT_1G is not set
> ++CONFIG_PAGE_OFFSET=0xC0000000
> ++CONFIG_PREEMPT_NONE=y
> ++# CONFIG_PREEMPT_VOLUNTARY is not set
> ++# CONFIG_PREEMPT is not set
> ++CONFIG_HZ=128
> ++# CONFIG_THUMB2_KERNEL is not set
> ++CONFIG_AEABI=y
> ++CONFIG_OABI_COMPAT=y
> ++CONFIG_ARCH_HAS_HOLES_MEMORYMODEL=y
> ++# CONFIG_ARCH_SPARSEMEM_DEFAULT is not set
> ++# CONFIG_ARCH_SELECT_MEMORY_MODEL is not set
> ++# CONFIG_HIGHMEM is not set
> ++CONFIG_SELECT_MEMORY_MODEL=y
> ++CONFIG_FLATMEM_MANUAL=y
> ++# CONFIG_DISCONTIGMEM_MANUAL is not set
> ++# CONFIG_SPARSEMEM_MANUAL is not set
> ++CONFIG_FLATMEM=y
> ++CONFIG_FLAT_NODE_MEM_MAP=y
> ++CONFIG_PAGEFLAGS_EXTENDED=y
> ++CONFIG_SPLIT_PTLOCK_CPUS=4
> ++# CONFIG_PHYS_ADDR_T_64BIT is not set
> ++CONFIG_ZONE_DMA_FLAG=0
> ++CONFIG_VIRT_TO_BUS=y
> ++# CONFIG_KSM is not set
> ++CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
> ++# CONFIG_LEDS is not set
> ++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/nfs nfsroot=192.168.0.1:/home/user/buildroot ip=192.168.0.2:192.168.0.1:192.168.0.1:255.255.255.0:tgt:eth0:off rw console=ttyS2,115200n8"
> ++# CONFIG_XIP_KERNEL is not set
> ++# CONFIG_KEXEC is not set
> ++
> ++#
> ++# CPU Power Management
> ++#
> ++# CONFIG_CPU_FREQ is not set
> ++# CONFIG_CPU_IDLE is not set
> ++
> ++#
> ++# Floating point emulation
> ++#
> ++
> ++#
> ++# At least one emulation must be selected
> ++#
> ++CONFIG_FPE_NWFPE=y
> ++# CONFIG_FPE_NWFPE_XP is not set
> ++# CONFIG_FPE_FASTFPE is not set
> ++CONFIG_VFP=y
> ++CONFIG_VFPv3=y
> ++CONFIG_NEON=y
> ++
> ++#
> ++# Userspace binary formats
> ++#
> ++CONFIG_BINFMT_ELF=y
> ++# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
> ++CONFIG_HAVE_AOUT=y
> ++# CONFIG_BINFMT_AOUT is not set
> ++CONFIG_BINFMT_MISC=y
> ++
> ++#
> ++# Power management options
> ++#
> ++CONFIG_PM=y
> ++CONFIG_PM_DEBUG=y
> ++# CONFIG_PM_VERBOSE is not set
> ++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 is not set
> ++# CONFIG_PM_RUNTIME is not set
> ++CONFIG_ARCH_SUSPEND_POSSIBLE=y
> ++CONFIG_NET=y
> ++
> ++#
> ++# Networking options
> ++#
> ++CONFIG_PACKET=y
> ++# CONFIG_PACKET_MMAP is not set
> ++CONFIG_UNIX=y
> ++CONFIG_XFRM=y
> ++# CONFIG_XFRM_USER is not set
> ++# CONFIG_XFRM_SUB_POLICY is not set
> ++# CONFIG_XFRM_MIGRATE is not set
> ++# CONFIG_XFRM_STATISTICS is not set
> ++CONFIG_NET_KEY=y
> ++# CONFIG_NET_KEY_MIGRATE is not set
> ++CONFIG_INET=y
> ++# CONFIG_IP_MULTICAST is not set
> ++# CONFIG_IP_ADVANCED_ROUTER is not set
> ++CONFIG_IP_FIB_HASH=y
> ++CONFIG_IP_PNP=y
> ++CONFIG_IP_PNP_DHCP=y
> ++CONFIG_IP_PNP_BOOTP=y
> ++CONFIG_IP_PNP_RARP=y
> ++# CONFIG_NET_IPIP is not set
> ++# CONFIG_NET_IPGRE is not set
> ++# CONFIG_ARPD is not set
> ++# CONFIG_SYN_COOKIES is not set
> ++# CONFIG_INET_AH is not set
> ++# CONFIG_INET_ESP is not set
> ++# CONFIG_INET_IPCOMP is not set
> ++# CONFIG_INET_XFRM_TUNNEL is not set
> ++# CONFIG_INET_TUNNEL is not set
> ++CONFIG_INET_XFRM_MODE_TRANSPORT=y
> ++CONFIG_INET_XFRM_MODE_TUNNEL=y
> ++CONFIG_INET_XFRM_MODE_BEET=y
> ++# CONFIG_INET_LRO is not set
> ++CONFIG_INET_DIAG=y
> ++CONFIG_INET_TCP_DIAG=y
> ++# CONFIG_TCP_CONG_ADVANCED is not set
> ++CONFIG_TCP_CONG_CUBIC=y
> ++CONFIG_DEFAULT_TCP_CONG="cubic"
> ++# CONFIG_TCP_MD5SIG is not set
> ++# CONFIG_IPV6 is not set
> ++# CONFIG_NETWORK_SECMARK is not set
> ++# CONFIG_NETFILTER is not set
> ++# CONFIG_IP_DCCP is not set
> ++# CONFIG_IP_SCTP is not set
> ++# CONFIG_RDS is not set
> ++# CONFIG_TIPC is not set
> ++# CONFIG_ATM is not set
> ++# CONFIG_BRIDGE is not set
> ++# CONFIG_NET_DSA is not set
> ++# CONFIG_VLAN_8021Q is not set
> ++# CONFIG_DECNET is not set
> ++# CONFIG_LLC2 is not set
> ++# CONFIG_IPX is not set
> ++# CONFIG_ATALK is not set
> ++# CONFIG_X25 is not set
> ++# CONFIG_LAPB is not set
> ++# 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
> ++
> ++#
> ++# Network testing
> ++#
> ++# CONFIG_NET_PKTGEN is not set
> ++# CONFIG_HAMRADIO is not set
> ++CONFIG_CAN=y
> ++CONFIG_CAN_RAW=y
> ++CONFIG_CAN_BCM=y
> ++
> ++#
> ++# CAN Device Drivers
> ++#
> ++CONFIG_CAN_VCAN=y
> ++CONFIG_CAN_DEV=y
> ++CONFIG_CAN_CALC_BITTIMING=y
> ++CONFIG_CAN_TI_HECC=y
> ++# CONFIG_CAN_SJA1000 is not set
> ++
> ++#
> ++# CAN USB interfaces
> ++#
> ++# CONFIG_CAN_EMS_USB is not set
> ++CONFIG_CAN_DEBUG_DEVICES=y
> ++# CONFIG_IRDA is not set
> ++# CONFIG_BT is not set
> ++# CONFIG_AF_RXRPC is not set
> ++CONFIG_WIRELESS=y
> ++# CONFIG_CFG80211 is not set
> ++# CONFIG_LIB80211 is not set
> ++
> ++#
> ++# CFG80211 needs to be enabled for MAC80211
> ++#
> ++# CONFIG_WIMAX is not set
> ++# CONFIG_RFKILL is not set
> ++# CONFIG_NET_9P is not set
> ++
> ++#
> ++# Device Drivers
> ++#
> ++
> ++#
> ++# Generic Driver Options
> ++#
> ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
> ++# CONFIG_DEVTMPFS is not set
> ++CONFIG_STANDALONE=y
> ++CONFIG_PREVENT_FIRMWARE_BUILD=y
> ++# CONFIG_FW_LOADER is not set
> ++# CONFIG_DEBUG_DRIVER is not set
> ++# CONFIG_DEBUG_DEVRES is not set
> ++# CONFIG_SYS_HYPERVISOR is not set
> ++# CONFIG_CONNECTOR is not set
> ++CONFIG_MTD=y
> ++# CONFIG_MTD_DEBUG is not set
> ++# CONFIG_MTD_TESTS is not set
> ++CONFIG_MTD_CONCAT=y
> ++CONFIG_MTD_PARTITIONS=y
> ++# CONFIG_MTD_REDBOOT_PARTS is not set
> ++CONFIG_MTD_CMDLINE_PARTS=y
> ++# CONFIG_MTD_AFS_PARTS is not set
> ++# CONFIG_MTD_AR7_PARTS is not set
> ++
> ++#
> ++# User Modules And Translation Layers
> ++#
> ++CONFIG_MTD_CHAR=y
> ++CONFIG_MTD_BLKDEVS=y
> ++CONFIG_MTD_BLOCK=y
> ++# CONFIG_FTL is not set
> ++# CONFIG_NFTL is not set
> ++# CONFIG_INFTL is not set
> ++# CONFIG_RFD_FTL is not set
> ++# CONFIG_SSFDC is not set
> ++# CONFIG_MTD_OOPS is not set
> ++
> ++#
> ++# RAM/ROM/Flash chip drivers
> ++#
> ++# CONFIG_MTD_CFI is not set
> ++# CONFIG_MTD_JEDECPROBE is not set
> ++CONFIG_MTD_MAP_BANK_WIDTH_1=y
> ++CONFIG_MTD_MAP_BANK_WIDTH_2=y
> ++CONFIG_MTD_MAP_BANK_WIDTH_4=y
> ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
> ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
> ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
> ++CONFIG_MTD_CFI_I1=y
> ++CONFIG_MTD_CFI_I2=y
> ++# CONFIG_MTD_CFI_I4 is not set
> ++# CONFIG_MTD_CFI_I8 is not set
> ++# CONFIG_MTD_RAM is not set
> ++# CONFIG_MTD_ROM is not set
> ++# CONFIG_MTD_ABSENT is not set
> ++
> ++#
> ++# Mapping drivers for chip access
> ++#
> ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set
> ++# CONFIG_MTD_PLATRAM is not set
> ++
> ++#
> ++# Self-contained MTD device drivers
> ++#
> ++# CONFIG_MTD_SLRAM is not set
> ++# CONFIG_MTD_PHRAM is not set
> ++# CONFIG_MTD_MTDRAM is not set
> ++# CONFIG_MTD_BLOCK2MTD is not set
> ++
> ++#
> ++# Disk-On-Chip Device Drivers
> ++#
> ++# CONFIG_MTD_DOC2000 is not set
> ++# CONFIG_MTD_DOC2001 is not set
> ++# CONFIG_MTD_DOC2001PLUS is not set
> ++CONFIG_MTD_NAND=y
> ++# CONFIG_MTD_NAND_VERIFY_WRITE is not set
> ++# CONFIG_MTD_NAND_ECC_SMC is not set
> ++# CONFIG_MTD_NAND_MUSEUM_IDS is not set
> ++# CONFIG_MTD_NAND_GPIO is not set
> ++CONFIG_MTD_NAND_OMAP2=y
> ++# CONFIG_MTD_NAND_OMAP_PREFETCH is not set
> ++CONFIG_MTD_NAND_IDS=y
> ++# CONFIG_MTD_NAND_DISKONCHIP is not set
> ++# CONFIG_MTD_NAND_NANDSIM is not set
> ++# CONFIG_MTD_NAND_PLATFORM is not set
> ++# CONFIG_MTD_ALAUDA is not set
> ++# CONFIG_MTD_ONENAND is not set
> ++
> ++#
> ++# LPDDR flash memory drivers
> ++#
> ++# CONFIG_MTD_LPDDR is not set
> ++
> ++#
> ++# UBI - Unsorted block images
> ++#
> ++# CONFIG_MTD_UBI is not set
> ++# CONFIG_PARPORT is not set
> ++CONFIG_BLK_DEV=y
> ++# CONFIG_BLK_DEV_COW_COMMON is not set
> ++CONFIG_BLK_DEV_LOOP=y
> ++# CONFIG_BLK_DEV_CRYPTOLOOP is not set
> ++
> ++#
> ++# DRBD disabled because PROC_FS, INET or CONNECTOR not selected
> ++#
> ++# CONFIG_BLK_DEV_NBD is not set
> ++# CONFIG_BLK_DEV_UB is not set
> ++CONFIG_BLK_DEV_RAM=y
> ++CONFIG_BLK_DEV_RAM_COUNT=16
> ++CONFIG_BLK_DEV_RAM_SIZE=32768
> ++# 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
> ++
> ++#
> ++# SCSI device support
> ++#
> ++# CONFIG_RAID_ATTRS is not set
> ++CONFIG_SCSI=y
> ++CONFIG_SCSI_DMA=y
> ++# CONFIG_SCSI_TGT is not set
> ++# CONFIG_SCSI_NETLINK is not set
> ++CONFIG_SCSI_PROC_FS=y
> ++
> ++#
> ++# SCSI support type (disk, tape, CD-ROM)
> ++#
> ++CONFIG_BLK_DEV_SD=y
> ++# CONFIG_CHR_DEV_ST is not set
> ++# CONFIG_CHR_DEV_OSST is not set
> ++# CONFIG_BLK_DEV_SR is not set
> ++# CONFIG_CHR_DEV_SG is not set
> ++# CONFIG_CHR_DEV_SCH is not set
> ++# CONFIG_SCSI_MULTI_LUN is not set
> ++# CONFIG_SCSI_CONSTANTS is not set
> ++# CONFIG_SCSI_LOGGING is not set
> ++# CONFIG_SCSI_SCAN_ASYNC is not set
> ++CONFIG_SCSI_WAIT_SCAN=m
> ++
> ++#
> ++# SCSI Transports
> ++#
> ++# CONFIG_SCSI_SPI_ATTRS is not set
> ++# CONFIG_SCSI_FC_ATTRS is not set
> ++# CONFIG_SCSI_ISCSI_ATTRS is not set
> ++# CONFIG_SCSI_SAS_LIBSAS is not set
> ++# CONFIG_SCSI_SRP_ATTRS is not set
> ++CONFIG_SCSI_LOWLEVEL=y
> ++# CONFIG_ISCSI_TCP is not set
> ++# CONFIG_LIBFC is not set
> ++# CONFIG_LIBFCOE is not set
> ++# CONFIG_SCSI_DEBUG is not set
> ++# CONFIG_SCSI_DH is not set
> ++# CONFIG_SCSI_OSD_INITIATOR is not set
> ++# CONFIG_ATA is not set
> ++# CONFIG_MD is not set
> ++CONFIG_NETDEVICES=y
> ++# CONFIG_DUMMY is not set
> ++# CONFIG_BONDING is not set
> ++# CONFIG_MACVLAN is not set
> ++# CONFIG_EQUALIZER is not set
> ++# CONFIG_TUN is not set
> ++# CONFIG_VETH is not set
> ++CONFIG_PHYLIB=y
> ++
> ++#
> ++# MII PHY device drivers
> ++#
> ++# CONFIG_MARVELL_PHY is not set
> ++# CONFIG_DAVICOM_PHY is not set
> ++# CONFIG_QSEMI_PHY is not set
> ++# CONFIG_LXT_PHY is not set
> ++# CONFIG_CICADA_PHY is not set
> ++# CONFIG_VITESSE_PHY is not set
> ++# CONFIG_SMSC_PHY is not set
> ++# CONFIG_BROADCOM_PHY is not set
> ++# CONFIG_ICPLUS_PHY is not set
> ++# CONFIG_REALTEK_PHY is not set
> ++# CONFIG_NATIONAL_PHY is not set
> ++# CONFIG_STE10XP is not set
> ++# CONFIG_LSI_ET1011C_PHY is not set
> ++# CONFIG_FIXED_PHY is not set
> ++# CONFIG_MDIO_BITBANG is not set
> ++CONFIG_NET_ETHERNET=y
> ++CONFIG_MII=y
> ++# CONFIG_AX88796 is not set
> ++# CONFIG_SMC91X is not set
> ++CONFIG_TI_DAVINCI_EMAC=y
> ++# CONFIG_DM9000 is not set
> ++# CONFIG_ETHOC is not set
> ++# CONFIG_SMC911X is not set
> ++# CONFIG_SMSC911X is not set
> ++# CONFIG_DNET is not set
> ++# CONFIG_IBM_NEW_EMAC_ZMII is not set
> ++# CONFIG_IBM_NEW_EMAC_RGMII is not set
> ++# CONFIG_IBM_NEW_EMAC_TAH is not set
> ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set
> ++# CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set
> ++# 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_MLL is not set
> ++CONFIG_NETDEV_1000=y
> ++CONFIG_NETDEV_10000=y
> ++CONFIG_WLAN=y
> ++# CONFIG_USB_ZD1201 is not set
> ++# CONFIG_HOSTAP is not set
> ++
> ++#
> ++# Enable WiMAX (Networking options) to see the WiMAX drivers
> ++#
> ++
> ++#
> ++# USB Network Adapters
> ++#
> ++# CONFIG_USB_CATC is not set
> ++# CONFIG_USB_KAWETH is not set
> ++# CONFIG_USB_PEGASUS is not set
> ++# CONFIG_USB_RTL8150 is not set
> ++CONFIG_USB_USBNET=y
> ++# CONFIG_USB_NET_AX8817X is not set
> ++CONFIG_USB_NET_CDCETHER=y
> ++# CONFIG_USB_NET_CDC_EEM is not set
> ++CONFIG_USB_NET_DM9601=y
> ++# CONFIG_USB_NET_SMSC95XX is not set
> ++# CONFIG_USB_NET_GL620A is not set
> ++# CONFIG_USB_NET_NET1080 is not set
> ++# CONFIG_USB_NET_PLUSB is not set
> ++# CONFIG_USB_NET_MCS7830 is not set
> ++# CONFIG_USB_NET_RNDIS_HOST is not set
> ++# CONFIG_USB_NET_CDC_SUBSET is not set
> ++# CONFIG_USB_NET_ZAURUS is not set
> ++# CONFIG_USB_NET_INT51X1 is not set
> ++# CONFIG_WAN is not set
> ++# CONFIG_PPP is not set
> ++# CONFIG_SLIP is not set
> ++# CONFIG_NETCONSOLE is not set
> ++# CONFIG_NETPOLL is not set
> ++# CONFIG_NET_POLL_CONTROLLER is not set
> ++# CONFIG_ISDN is not set
> ++# CONFIG_PHONE is not set
> ++
> ++#
> ++# Input device support
> ++#
> ++CONFIG_INPUT=y
> ++# CONFIG_INPUT_FF_MEMLESS is not set
> ++# CONFIG_INPUT_POLLDEV is not set
> ++# CONFIG_INPUT_SPARSEKMAP is not set
> ++
> ++#
> ++# Userland interfaces
> ++#
> ++# CONFIG_INPUT_MOUSEDEV is not set
> ++# CONFIG_INPUT_JOYDEV is not set
> ++CONFIG_INPUT_EVDEV=y
> ++# CONFIG_INPUT_EVBUG is not set
> ++
> ++#
> ++# Input Device Drivers
> ++#
> ++# CONFIG_INPUT_KEYBOARD is not set
> ++# CONFIG_INPUT_MOUSE is not set
> ++# CONFIG_INPUT_JOYSTICK is not set
> ++# CONFIG_INPUT_TABLET is not set
> ++# CONFIG_INPUT_TOUCHSCREEN is not set
> ++# CONFIG_INPUT_MISC is not set
> ++
> ++#
> ++# Hardware I/O ports
> ++#
> ++CONFIG_SERIO=y
> ++CONFIG_SERIO_SERPORT=y
> ++CONFIG_SERIO_LIBPS2=y
> ++# CONFIG_SERIO_RAW is not set
> ++# CONFIG_SERIO_ALTERA_PS2 is not set
> ++# CONFIG_GAMEPORT is not set
> ++
> ++#
> ++# Character devices
> ++#
> ++CONFIG_VT=y
> ++CONFIG_CONSOLE_TRANSLATIONS=y
> ++CONFIG_VT_CONSOLE=y
> ++CONFIG_HW_CONSOLE=y
> ++# CONFIG_VT_HW_CONSOLE_BINDING is not set
> ++CONFIG_DEVKMEM=y
> ++# CONFIG_SERIAL_NONSTANDARD is not set
> ++
> ++#
> ++# Serial drivers
> ++#
> ++CONFIG_SERIAL_8250=y
> ++CONFIG_SERIAL_8250_CONSOLE=y
> ++CONFIG_SERIAL_8250_NR_UARTS=32
> ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4
> ++CONFIG_SERIAL_8250_EXTENDED=y
> ++CONFIG_SERIAL_8250_MANY_PORTS=y
> ++CONFIG_SERIAL_8250_SHARE_IRQ=y
> ++CONFIG_SERIAL_8250_DETECT_IRQ=y
> ++CONFIG_SERIAL_8250_RSA=y
> ++
> ++#
> ++# Non-8250 serial port support
> ++#
> ++CONFIG_SERIAL_CORE=y
> ++CONFIG_SERIAL_CORE_CONSOLE=y
> ++CONFIG_UNIX98_PTYS=y
> ++# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set
> ++# CONFIG_LEGACY_PTYS is not set
> ++# CONFIG_IPMI_HANDLER is not set
> ++CONFIG_HW_RANDOM=y
> ++# CONFIG_HW_RANDOM_TIMERIOMEM is not set
> ++# CONFIG_R3964 is not set
> ++# CONFIG_RAW_DRIVER is not set
> ++# CONFIG_TCG_TPM is not set
> ++CONFIG_I2C=y
> ++CONFIG_I2C_BOARDINFO=y
> ++CONFIG_I2C_COMPAT=y
> ++# CONFIG_I2C_CHARDEV is not set
> ++CONFIG_I2C_HELPER_AUTO=y
> ++
> ++#
> ++# I2C Hardware Bus support
> ++#
> ++
> ++#
> ++# 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_OMAP=y
> ++# CONFIG_I2C_SIMTEC is not set
> ++
> ++#
> ++# External I2C/SMBus adapter drivers
> ++#
> ++# CONFIG_I2C_PARPORT_LIGHT is not set
> ++# CONFIG_I2C_TAOS_EVM is not set
> ++# CONFIG_I2C_TINY_USB is not set
> ++
> ++#
> ++# Other I2C/SMBus bus drivers
> ++#
> ++# CONFIG_I2C_PCA_PLATFORM is not set
> ++# CONFIG_I2C_STUB is not set
> ++
> ++#
> ++# Miscellaneous I2C Chip support
> ++#
> ++# 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
> ++
> ++#
> ++# PPS support
> ++#
> ++# CONFIG_PPS is not set
> ++CONFIG_ARCH_REQUIRE_GPIOLIB=y
> ++CONFIG_GPIOLIB=y
> ++# CONFIG_DEBUG_GPIO is not set
> ++CONFIG_GPIO_SYSFS=y
> ++
> ++#
> ++# Memory mapped GPIO expanders:
> ++#
> ++
> ++#
> ++# I2C GPIO expanders:
> ++#
> ++# CONFIG_GPIO_MAX732X is not set
> ++# CONFIG_GPIO_PCA953X is not set
> ++# CONFIG_GPIO_PCF857X is not set
> ++# CONFIG_GPIO_TPS65910 is not set
> ++
> ++#
> ++# PCI GPIO expanders:
> ++#
> ++
> ++#
> ++# SPI GPIO expanders:
> ++#
> ++
> ++#
> ++# AC97 GPIO expanders:
> ++#
> ++# CONFIG_W1 is not set
> ++# CONFIG_POWER_SUPPLY is not set
> ++# CONFIG_HWMON is not set
> ++# CONFIG_THERMAL is not set
> ++CONFIG_WATCHDOG=y
> ++CONFIG_WATCHDOG_NOWAYOUT=y
> ++
> ++#
> ++# Watchdog Device Drivers
> ++#
> ++# CONFIG_SOFT_WATCHDOG is not set
> ++CONFIG_OMAP_WATCHDOG=y
> ++
> ++#
> ++# USB-based Watchdog Cards
> ++#
> ++# CONFIG_USBPCWATCHDOG is not set
> ++CONFIG_SSB_POSSIBLE=y
> ++
> ++#
> ++# Sonics Silicon Backplane
> ++#
> ++# CONFIG_SSB is not set
> ++
> ++#
> ++# Multifunction device drivers
> ++#
> ++# CONFIG_MFD_CORE is not set
> ++# CONFIG_MFD_SM501 is not set
> ++# CONFIG_MFD_ASIC3 is not set
> ++# CONFIG_HTC_EGPIO is not set
> ++# CONFIG_HTC_PASIC3 is not set
> ++# CONFIG_TPS65010 is not set
> ++# CONFIG_TWL4030_CORE is not set
> ++CONFIG_TPS65910_CORE=y
> ++# 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_ADP5520 is not set
> ++# CONFIG_MFD_WM8400 is not set
> ++# CONFIG_MFD_WM831X is not set
> ++# CONFIG_MFD_WM8350_I2C is not set
> ++# CONFIG_MFD_PCF50633 is not set
> ++# CONFIG_AB3100_CORE is not set
> ++# CONFIG_MFD_88PM8607 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_TPS65910 is not set
> ++# CONFIG_REGULATOR_LP3971 is not set
> ++# CONFIG_REGULATOR_TPS65023 is not set
> ++# CONFIG_REGULATOR_TPS6507X is not set
> ++CONFIG_MEDIA_SUPPORT=y
> ++
> ++#
> ++# Multimedia core support
> ++#
> ++CONFIG_VIDEO_DEV=y
> ++CONFIG_VIDEO_V4L2_COMMON=y
> ++CONFIG_VIDEO_ALLOW_V4L1=y
> ++CONFIG_VIDEO_V4L1_COMPAT=y
> ++# CONFIG_DVB_CORE is not set
> ++CONFIG_VIDEO_MEDIA=y
> ++
> ++#
> ++# Multimedia drivers
> ++#
> ++# CONFIG_MEDIA_ATTACH is not set
> ++CONFIG_MEDIA_TUNER=y
> ++# CONFIG_MEDIA_TUNER_CUSTOMISE is not set
> ++CONFIG_MEDIA_TUNER_SIMPLE=y
> ++CONFIG_MEDIA_TUNER_TDA8290=y
> ++CONFIG_MEDIA_TUNER_TDA9887=y
> ++CONFIG_MEDIA_TUNER_TEA5761=y
> ++CONFIG_MEDIA_TUNER_TEA5767=y
> ++CONFIG_MEDIA_TUNER_MT20XX=y
> ++CONFIG_MEDIA_TUNER_XC2028=y
> ++CONFIG_MEDIA_TUNER_XC5000=y
> ++CONFIG_MEDIA_TUNER_MC44S803=y
> ++CONFIG_VIDEO_V4L2=y
> ++CONFIG_VIDEO_V4L1=y
> ++# CONFIG_VIDEO_CAPTURE_DRIVERS is not set
> ++# CONFIG_RADIO_ADAPTERS is not set
> ++# CONFIG_DAB is not set
> ++
> ++#
> ++# Graphics support
> ++#
> ++# CONFIG_VGASTATE is not set
> ++# CONFIG_VIDEO_OUTPUT_CONTROL is not set
> ++CONFIG_FB=y
> ++# CONFIG_FIRMWARE_EDID is not set
> ++# CONFIG_FB_DDC is not set
> ++# CONFIG_FB_BOOT_VESA_SUPPORT is not set
> ++CONFIG_FB_CFB_FILLRECT=y
> ++CONFIG_FB_CFB_COPYAREA=y
> ++CONFIG_FB_CFB_IMAGEBLIT=y
> ++# CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set
> ++# CONFIG_FB_SYS_FILLRECT is not set
> ++# CONFIG_FB_SYS_COPYAREA is not set
> ++# CONFIG_FB_SYS_IMAGEBLIT is not set
> ++# CONFIG_FB_FOREIGN_ENDIAN is not set
> ++# CONFIG_FB_SYS_FOPS is not set
> ++# CONFIG_FB_SVGALIB is not set
> ++# CONFIG_FB_MACMODES is not set
> ++# CONFIG_FB_BACKLIGHT is not set
> ++# CONFIG_FB_MODE_HELPERS is not set
> ++# CONFIG_FB_TILEBLITTING is not set
> ++
> ++#
> ++# Frame buffer hardware drivers
> ++#
> ++# CONFIG_FB_S1D13XXX is not set
> ++# CONFIG_FB_VIRTUAL is not set
> ++# CONFIG_FB_METRONOME is not set
> ++# CONFIG_FB_MB862XX is not set
> ++# CONFIG_FB_BROADSHEET is not set
> ++# CONFIG_FB_OMAP_BOOTLOADER_INIT is not set
> ++CONFIG_OMAP2_VRAM=y
> ++CONFIG_OMAP2_VRFB=y
> ++CONFIG_OMAP2_DSS=y
> ++CONFIG_OMAP2_VRAM_SIZE=4
> ++# CONFIG_OMAP2_DSS_DEBUG_SUPPORT is not set
> ++# CONFIG_OMAP2_DSS_RFBI is not set
> ++CONFIG_OMAP2_DSS_VENC=y
> ++# CONFIG_OMAP2_VENC_OUT_TYPE_SVIDEO is not set
> ++CONFIG_OMAP2_VENC_OUT_TYPE_COMPOSITE=y
> ++# CONFIG_OMAP2_DSS_SDI is not set
> ++# CONFIG_OMAP2_DSS_DSI is not set
> ++# CONFIG_OMAP2_DSS_FAKE_VSYNC is not set
> ++CONFIG_OMAP2_DSS_MIN_FCK_PER_PCK=1
> ++CONFIG_FB_OMAP2=y
> ++# CONFIG_FB_OMAP2_DEBUG_SUPPORT is not set
> ++# CONFIG_FB_OMAP2_FORCE_AUTO_UPDATE is not set
> ++CONFIG_FB_OMAP2_NUM_FBS=1
> ++
> ++#
> ++# OMAP2/3 Display Device Drivers
> ++#
> ++CONFIG_PANEL_GENERIC=y
> ++# CONFIG_PANEL_SHARP_LS037V7DW01 is not set
> ++# CONFIG_PANEL_SHARP_LQ043T1DG01 is not set
> ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
> ++
> ++#
> ++# Display device support
> ++#
> ++# CONFIG_DISPLAY_SUPPORT is not set
> ++
> ++#
> ++# Console display driver support
> ++#
> ++# CONFIG_VGA_CONSOLE is not set
> ++CONFIG_DUMMY_CONSOLE=y
> ++# CONFIG_FRAMEBUFFER_CONSOLE is not set
> ++CONFIG_LOGO=y
> ++CONFIG_LOGO_LINUX_MONO=y
> ++CONFIG_LOGO_LINUX_VGA16=y
> ++CONFIG_LOGO_LINUX_CLUT224=y
> ++# CONFIG_SOUND is not set
> ++CONFIG_HID_SUPPORT=y
> ++CONFIG_HID=y
> ++# CONFIG_HIDRAW is not set
> ++
> ++#
> ++# USB Input Devices
> ++#
> ++CONFIG_USB_HID=y
> ++# CONFIG_HID_PID is not set
> ++# CONFIG_USB_HIDDEV is not set
> ++
> ++#
> ++# Special HID drivers
> ++#
> ++# 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_TWINHAN 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_ZEROPLUS is not set
> ++CONFIG_USB_SUPPORT=y
> ++CONFIG_USB_ARCH_HAS_HCD=y
> ++CONFIG_USB_ARCH_HAS_OHCI=y
> ++CONFIG_USB_ARCH_HAS_EHCI=y
> ++CONFIG_USB=y
> ++# CONFIG_USB_DEBUG is not set
> ++CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
> ++
> ++#
> ++# Miscellaneous USB options
> ++#
> ++CONFIG_USB_DEVICEFS=y
> ++CONFIG_USB_DEVICE_CLASS=y
> ++# CONFIG_USB_DYNAMIC_MINORS is not set
> ++CONFIG_USB_SUSPEND=y
> ++CONFIG_USB_OTG=y
> ++# CONFIG_USB_OTG_WHITELIST is not set
> ++# CONFIG_USB_OTG_BLACKLIST_HUB is not set
> ++# CONFIG_USB_MON is not set
> ++# CONFIG_USB_WUSB is not set
> ++# CONFIG_USB_WUSB_CBAF is not set
> ++
> ++#
> ++# USB Host Controller Drivers
> ++#
> ++# CONFIG_USB_C67X00_HCD is not set
> ++CONFIG_USB_EHCI_HCD=y
> ++# CONFIG_USB_EHCI_ROOT_HUB_TT is not set
> ++CONFIG_USB_EHCI_TT_NEWSCHED=y
> ++# CONFIG_USB_OXU210HP_HCD is not set
> ++# CONFIG_USB_ISP116X_HCD is not set
> ++# CONFIG_USB_ISP1760_HCD is not set
> ++# CONFIG_USB_ISP1362_HCD is not set
> ++# CONFIG_USB_OHCI_HCD is not set
> ++# CONFIG_USB_SL811_HCD is not set
> ++# CONFIG_USB_R8A66597_HCD is not set
> ++# CONFIG_USB_HWA_HCD is not set
> ++CONFIG_USB_MUSB_HDRC=y
> ++CONFIG_USB_MUSB_SOC=y
> ++
> ++#
> ++# OMAP 343x high speed USB support
> ++#
> ++# CONFIG_USB_MUSB_HOST is not set
> ++# CONFIG_USB_MUSB_PERIPHERAL is not set
> ++CONFIG_USB_MUSB_OTG=y
> ++CONFIG_USB_GADGET_MUSB_HDRC=y
> ++CONFIG_USB_MUSB_HDRC_HCD=y
> ++# CONFIG_MUSB_PIO_ONLY is not set
> ++# CONFIG_USB_TI_CPPI_DMA is not set
> ++CONFIG_USB_TI_CPPI41_DMA=y
> ++CONFIG_USB_MUSB_DEBUG=y
> ++
> ++#
> ++# USB Device Class drivers
> ++#
> ++# CONFIG_USB_ACM is not set
> ++# CONFIG_USB_PRINTER is not set
> ++# CONFIG_USB_WDM is not set
> ++# CONFIG_USB_TMC is not set
> ++
> ++#
> ++# NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may
> ++#
> ++
> ++#
> ++# also be needed; see USB_STORAGE Help for more info
> ++#
> ++CONFIG_USB_STORAGE=y
> ++# CONFIG_USB_STORAGE_DEBUG is not set
> ++# CONFIG_USB_STORAGE_DATAFAB is not set
> ++# CONFIG_USB_STORAGE_FREECOM is not set
> ++# CONFIG_USB_STORAGE_ISD200 is not set
> ++# CONFIG_USB_STORAGE_USBAT is not set
> ++# CONFIG_USB_STORAGE_SDDR09 is not set
> ++# CONFIG_USB_STORAGE_SDDR55 is not set
> ++# CONFIG_USB_STORAGE_JUMPSHOT is not set
> ++# CONFIG_USB_STORAGE_ALAUDA is not set
> ++# CONFIG_USB_STORAGE_ONETOUCH is not set
> ++# CONFIG_USB_STORAGE_KARMA is not set
> ++# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set
> ++# CONFIG_USB_LIBUSUAL is not set
> ++
> ++#
> ++# USB Imaging devices
> ++#
> ++# CONFIG_USB_MDC800 is not set
> ++# CONFIG_USB_MICROTEK is not set
> ++
> ++#
> ++# USB port drivers
> ++#
> ++# CONFIG_USB_SERIAL is not set
> ++
> ++#
> ++# USB Miscellaneous drivers
> ++#
> ++# CONFIG_USB_EMI62 is not set
> ++# CONFIG_USB_EMI26 is not set
> ++# CONFIG_USB_ADUTUX is not set
> ++# CONFIG_USB_SEVSEG is not set
> ++# CONFIG_USB_RIO500 is not set
> ++# CONFIG_USB_LEGOTOWER is not set
> ++# CONFIG_USB_LCD is not set
> ++# CONFIG_USB_BERRY_CHARGE is not set
> ++# CONFIG_USB_LED is not set
> ++# CONFIG_USB_CYPRESS_CY7C63 is not set
> ++# CONFIG_USB_CYTHERM is not set
> ++# CONFIG_USB_IDMOUSE is not set
> ++# CONFIG_USB_FTDI_ELAN is not set
> ++# CONFIG_USB_APPLEDISPLAY is not set
> ++# CONFIG_USB_SISUSBVGA is not set
> ++# CONFIG_USB_LD is not set
> ++# CONFIG_USB_TRANCEVIBRATOR is not set
> ++# CONFIG_USB_IOWARRIOR is not set
> ++CONFIG_USB_TEST=y
> ++# CONFIG_USB_ISIGHTFW is not set
> ++# CONFIG_USB_VST is not set
> ++CONFIG_USB_GADGET=y
> ++# CONFIG_USB_GADGET_DEBUG is not set
> ++# CONFIG_USB_GADGET_DEBUG_FILES is not set
> ++CONFIG_USB_GADGET_VBUS_DRAW=2
> ++CONFIG_USB_GADGET_SELECTED=y
> ++# CONFIG_USB_GADGET_AT91 is not set
> ++# CONFIG_USB_GADGET_ATMEL_USBA is not set
> ++# CONFIG_USB_GADGET_FSL_USB2 is not set
> ++# CONFIG_USB_GADGET_LH7A40X is not set
> ++# CONFIG_USB_GADGET_OMAP is not set
> ++# CONFIG_USB_GADGET_PXA25X is not set
> ++# CONFIG_USB_GADGET_R8A66597 is not set
> ++# CONFIG_USB_GADGET_PXA27X is not set
> ++# CONFIG_USB_GADGET_S3C_HSOTG is not set
> ++# CONFIG_USB_GADGET_IMX is not set
> ++# CONFIG_USB_GADGET_S3C2410 is not set
> ++# CONFIG_USB_GADGET_M66592 is not set
> ++# CONFIG_USB_GADGET_AMD5536UDC is not set
> ++# CONFIG_USB_GADGET_FSL_QE is not set
> ++# CONFIG_USB_GADGET_CI13XXX is not set
> ++# CONFIG_USB_GADGET_NET2280 is not set
> ++# CONFIG_USB_GADGET_GOKU is not set
> ++# CONFIG_USB_GADGET_LANGWELL is not set
> ++# CONFIG_USB_GADGET_DUMMY_HCD is not set
> ++CONFIG_USB_GADGET_DUALSPEED=y
> ++# CONFIG_USB_ZERO is not set
> ++# CONFIG_USB_AUDIO is not set
> ++CONFIG_USB_ETH=y
> ++CONFIG_USB_ETH_RNDIS=y
> ++# CONFIG_USB_ETH_EEM is not set
> ++# CONFIG_USB_GADGETFS is not set
> ++# CONFIG_USB_FILE_STORAGE is not set
> ++# CONFIG_USB_MASS_STORAGE is not set
> ++# CONFIG_USB_G_SERIAL is not set
> ++# CONFIG_USB_MIDI_GADGET is not set
> ++# CONFIG_USB_G_PRINTER is not set
> ++# CONFIG_USB_CDC_COMPOSITE is not set
> ++# CONFIG_USB_G_MULTI is not set
> ++
> ++#
> ++# OTG and related infrastructure
> ++#
> ++CONFIG_USB_OTG_UTILS=y
> ++# CONFIG_USB_GPIO_VBUS is not set
> ++# CONFIG_ISP1301_OMAP is not set
> ++# CONFIG_USB_ULPI is not set
> ++CONFIG_NOP_USB_XCEIV=y
> ++CONFIG_MMC=y
> ++# CONFIG_MMC_DEBUG is not set
> ++# CONFIG_MMC_UNSAFE_RESUME is not set
> ++
> ++#
> ++# MMC/SD/SDIO Card Drivers
> ++#
> ++CONFIG_MMC_BLOCK=y
> ++CONFIG_MMC_BLOCK_BOUNCE=y
> ++# CONFIG_SDIO_UART is not set
> ++# CONFIG_MMC_TEST is not set
> ++
> ++#
> ++# MMC/SD/SDIO Host Controller Drivers
> ++#
> ++# CONFIG_MMC_SDHCI is not set
> ++# CONFIG_MMC_OMAP is not set
> ++CONFIG_MMC_OMAP_HS=y
> ++# CONFIG_MMC_AT91 is not set
> ++# CONFIG_MMC_ATMELMCI is not set
> ++# CONFIG_MEMSTICK is not set
> ++# CONFIG_NEW_LEDS is not set
> ++# CONFIG_ACCESSIBILITY is not set
> ++CONFIG_RTC_LIB=y
> ++CONFIG_RTC_CLASS=y
> ++CONFIG_RTC_HCTOSYS=y
> ++CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
> ++# CONFIG_RTC_DEBUG is not set
> ++
> ++#
> ++# RTC interfaces
> ++#
> ++CONFIG_RTC_INTF_SYSFS=y
> ++CONFIG_RTC_INTF_PROC=y
> ++CONFIG_RTC_INTF_DEV=y
> ++# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
> ++# CONFIG_RTC_DRV_TEST is not set
> ++
> ++#
> ++# I2C RTC drivers
> ++#
> ++# CONFIG_RTC_DRV_DS1307 is not set
> ++# CONFIG_RTC_DRV_DS1374 is not set
> ++# CONFIG_RTC_DRV_DS1672 is not set
> ++# CONFIG_RTC_DRV_MAX6900 is not set
> ++# CONFIG_RTC_DRV_RS5C372 is not set
> ++# CONFIG_RTC_DRV_ISL1208 is not set
> ++# CONFIG_RTC_DRV_X1205 is not set
> ++# CONFIG_RTC_DRV_PCF8563 is not set
> ++# CONFIG_RTC_DRV_PCF8583 is not set
> ++# CONFIG_RTC_DRV_M41T80 is not set
> ++CONFIG_RTC_DRV_TPS65910=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
> ++#
> ++
> ++#
> ++# Platform RTC drivers
> ++#
> ++# CONFIG_RTC_DRV_CMOS is not set
> ++# CONFIG_RTC_DRV_DS1286 is not set
> ++# CONFIG_RTC_DRV_DS1511 is not set
> ++# CONFIG_RTC_DRV_DS1553 is not set
> ++# CONFIG_RTC_DRV_DS1742 is not set
> ++# CONFIG_RTC_DRV_STK17TA8 is not set
> ++# CONFIG_RTC_DRV_M48T86 is not set
> ++# CONFIG_RTC_DRV_M48T35 is not set
> ++# CONFIG_RTC_DRV_M48T59 is not set
> ++# CONFIG_RTC_DRV_MSM6242 is not set
> ++# CONFIG_RTC_DRV_BQ4802 is not set
> ++# CONFIG_RTC_DRV_RP5C01 is not set
> ++# CONFIG_RTC_DRV_V3020 is not set
> ++
> ++#
> ++# on-CPU RTC drivers
> ++#
> ++# CONFIG_DMADEVICES is not set
> ++# CONFIG_AUXDISPLAY is not set
> ++# CONFIG_UIO is not set
> ++
> ++#
> ++# TI VLYNQ
> ++#
> ++# CONFIG_STAGING is not set
> ++
> ++#
> ++# CBUS support
> ++#
> ++# CONFIG_CBUS is not set
> ++
> ++#
> ++# File systems
> ++#
> ++CONFIG_FS_JOURNAL_INFO=y
> ++CONFIG_EXT2_FS=y
> ++# CONFIG_EXT2_FS_XATTR is not set
> ++# CONFIG_EXT2_FS_XIP is not set
> ++CONFIG_EXT3_FS=y
> ++# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
> ++# CONFIG_EXT3_FS_XATTR is not set
> ++# CONFIG_EXT4_FS is not set
> ++CONFIG_JBD=y
> ++# CONFIG_REISERFS_FS is not set
> ++# CONFIG_JFS_FS is not set
> ++# CONFIG_FS_POSIX_ACL is not set
> ++# 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_NILFS2_FS is not set
> ++CONFIG_FILE_LOCKING=y
> ++CONFIG_FSNOTIFY=y
> ++CONFIG_DNOTIFY=y
> ++CONFIG_INOTIFY=y
> ++CONFIG_INOTIFY_USER=y
> ++CONFIG_QUOTA=y
> ++# CONFIG_QUOTA_NETLINK_INTERFACE is not set
> ++CONFIG_PRINT_QUOTA_WARNING=y
> ++CONFIG_QUOTA_TREE=y
> ++# CONFIG_QFMT_V1 is not set
> ++CONFIG_QFMT_V2=y
> ++CONFIG_QUOTACTL=y
> ++# CONFIG_AUTOFS_FS is not set
> ++# CONFIG_AUTOFS4_FS is not set
> ++# CONFIG_FUSE_FS is not set
> ++
> ++#
> ++# Caches
> ++#
> ++# CONFIG_FSCACHE is not set
> ++
> ++#
> ++# CD-ROM/DVD Filesystems
> ++#
> ++# CONFIG_ISO9660_FS is not set
> ++# CONFIG_UDF_FS is not set
> ++
> ++#
> ++# DOS/FAT/NT Filesystems
> ++#
> ++CONFIG_FAT_FS=y
> ++CONFIG_MSDOS_FS=y
> ++CONFIG_VFAT_FS=y
> ++CONFIG_FAT_DEFAULT_CODEPAGE=437
> ++CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1"
> ++# CONFIG_NTFS_FS is not set
> ++
> ++#
> ++# Pseudo filesystems
> ++#
> ++CONFIG_PROC_FS=y
> ++CONFIG_PROC_SYSCTL=y
> ++CONFIG_PROC_PAGE_MONITOR=y
> ++CONFIG_SYSFS=y
> ++CONFIG_TMPFS=y
> ++# CONFIG_TMPFS_POSIX_ACL is not set
> ++# CONFIG_HUGETLB_PAGE is not set
> ++# CONFIG_CONFIGFS_FS is not set
> ++CONFIG_MISC_FILESYSTEMS=y
> ++# CONFIG_ADFS_FS is not set
> ++# CONFIG_AFFS_FS is not set
> ++# CONFIG_HFS_FS is not set
> ++# CONFIG_HFSPLUS_FS is not set
> ++# CONFIG_BEFS_FS is not set
> ++# CONFIG_BFS_FS is not set
> ++# CONFIG_EFS_FS is not set
> ++CONFIG_JFFS2_FS=y
> ++CONFIG_JFFS2_FS_DEBUG=0
> ++CONFIG_JFFS2_FS_WRITEBUFFER=y
> ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set
> ++# CONFIG_JFFS2_SUMMARY is not set
> ++# CONFIG_JFFS2_FS_XATTR is not set
> ++CONFIG_JFFS2_COMPRESSION_OPTIONS=y
> ++CONFIG_JFFS2_ZLIB=y
> ++# CONFIG_JFFS2_LZO is not set
> ++CONFIG_JFFS2_RTIME=y
> ++# CONFIG_JFFS2_RUBIN is not set
> ++# CONFIG_JFFS2_CMODE_NONE is not set
> ++CONFIG_JFFS2_CMODE_PRIORITY=y
> ++# CONFIG_JFFS2_CMODE_SIZE is not set
> ++# CONFIG_JFFS2_CMODE_FAVOURLZO is not set
> ++# CONFIG_CRAMFS is not set
> ++# CONFIG_SQUASHFS is not set
> ++# CONFIG_VXFS_FS is not set
> ++# CONFIG_MINIX_FS is not set
> ++# CONFIG_OMFS_FS is not set
> ++# CONFIG_HPFS_FS is not set
> ++# CONFIG_QNX4FS_FS is not set
> ++# CONFIG_ROMFS_FS is not set
> ++# CONFIG_SYSV_FS is not set
> ++# CONFIG_UFS_FS is not set
> ++CONFIG_NETWORK_FILESYSTEMS=y
> ++CONFIG_NFS_FS=y
> ++CONFIG_NFS_V3=y
> ++# CONFIG_NFS_V3_ACL is not set
> ++CONFIG_NFS_V4=y
> ++# CONFIG_NFS_V4_1 is not set
> ++CONFIG_ROOT_NFS=y
> ++# CONFIG_NFSD is not set
> ++CONFIG_LOCKD=y
> ++CONFIG_LOCKD_V4=y
> ++CONFIG_NFS_COMMON=y
> ++CONFIG_SUNRPC=y
> ++CONFIG_SUNRPC_GSS=y
> ++CONFIG_RPCSEC_GSS_KRB5=y
> ++# CONFIG_RPCSEC_GSS_SPKM3 is not set
> ++# CONFIG_SMB_FS is not set
> ++# CONFIG_CIFS is not set
> ++# CONFIG_NCP_FS is not set
> ++# CONFIG_CODA_FS is not set
> ++# CONFIG_AFS_FS is not set
> ++
> ++#
> ++# Partition Types
> ++#
> ++CONFIG_PARTITION_ADVANCED=y
> ++# CONFIG_ACORN_PARTITION is not set
> ++# CONFIG_OSF_PARTITION is not set
> ++# CONFIG_AMIGA_PARTITION is not set
> ++# CONFIG_ATARI_PARTITION is not set
> ++# CONFIG_MAC_PARTITION is not set
> ++CONFIG_MSDOS_PARTITION=y
> ++# CONFIG_BSD_DISKLABEL is not set
> ++# CONFIG_MINIX_SUBPARTITION is not set
> ++# CONFIG_SOLARIS_X86_PARTITION is not set
> ++# CONFIG_UNIXWARE_DISKLABEL is not set
> ++# CONFIG_LDM_PARTITION is not set
> ++# CONFIG_SGI_PARTITION is not set
> ++# CONFIG_ULTRIX_PARTITION is not set
> ++# CONFIG_SUN_PARTITION is not set
> ++# CONFIG_KARMA_PARTITION is not set
> ++# CONFIG_EFI_PARTITION is not set
> ++# CONFIG_SYSV68_PARTITION is not set
> ++CONFIG_NLS=y
> ++CONFIG_NLS_DEFAULT="iso8859-1"
> ++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
> ++# CONFIG_NLS_CODEPAGE_852 is not set
> ++# CONFIG_NLS_CODEPAGE_855 is not set
> ++# CONFIG_NLS_CODEPAGE_857 is not set
> ++# CONFIG_NLS_CODEPAGE_860 is not set
> ++# CONFIG_NLS_CODEPAGE_861 is not set
> ++# CONFIG_NLS_CODEPAGE_862 is not set
> ++# CONFIG_NLS_CODEPAGE_863 is not set
> ++# CONFIG_NLS_CODEPAGE_864 is not set
> ++# CONFIG_NLS_CODEPAGE_865 is not set
> ++# CONFIG_NLS_CODEPAGE_866 is not set
> ++# CONFIG_NLS_CODEPAGE_869 is not set
> ++# CONFIG_NLS_CODEPAGE_936 is not set
> ++# CONFIG_NLS_CODEPAGE_950 is not set
> ++# CONFIG_NLS_CODEPAGE_932 is not set
> ++# CONFIG_NLS_CODEPAGE_949 is not set
> ++# CONFIG_NLS_CODEPAGE_874 is not set
> ++# CONFIG_NLS_ISO8859_8 is not set
> ++# CONFIG_NLS_CODEPAGE_1250 is not set
> ++# CONFIG_NLS_CODEPAGE_1251 is not set
> ++# CONFIG_NLS_ASCII is not set
> ++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
> ++# CONFIG_NLS_ISO8859_5 is not set
> ++# CONFIG_NLS_ISO8859_6 is not set
> ++# CONFIG_NLS_ISO8859_7 is not set
> ++# CONFIG_NLS_ISO8859_9 is not set
> ++# CONFIG_NLS_ISO8859_13 is not set
> ++# CONFIG_NLS_ISO8859_14 is not set
> ++# CONFIG_NLS_ISO8859_15 is not set
> ++# CONFIG_NLS_KOI8_R is not set
> ++# CONFIG_NLS_KOI8_U is not set
> ++# CONFIG_NLS_UTF8 is not set
> ++# CONFIG_DLM is not set
> ++
> ++#
> ++# Kernel hacking
> ++#
> ++# CONFIG_PRINTK_TIME is not set
> ++CONFIG_ENABLE_WARN_DEPRECATED=y
> ++CONFIG_ENABLE_MUST_CHECK=y
> ++CONFIG_FRAME_WARN=1024
> ++CONFIG_MAGIC_SYSRQ=y
> ++# CONFIG_STRIP_ASM_SYMS is not set
> ++# CONFIG_UNUSED_SYMBOLS is not set
> ++# CONFIG_DEBUG_FS is not set
> ++# CONFIG_HEADERS_CHECK is not set
> ++CONFIG_DEBUG_KERNEL=y
> ++# CONFIG_DEBUG_SHIRQ is not set
> ++CONFIG_DETECT_SOFTLOCKUP=y
> ++# CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set
> ++CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0
> ++CONFIG_DETECT_HUNG_TASK=y
> ++# CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set
> ++CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0
> ++# CONFIG_SCHED_DEBUG is not set
> ++# CONFIG_SCHEDSTATS is not set
> ++# CONFIG_TIMER_STATS is not set
> ++# CONFIG_DEBUG_OBJECTS is not set
> ++# CONFIG_DEBUG_SLAB 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
> ++CONFIG_DEBUG_MUTEXES=y
> ++# CONFIG_DEBUG_LOCK_ALLOC is not set
> ++# CONFIG_PROVE_LOCKING is not set
> ++# CONFIG_LOCK_STAT is not set
> ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
> ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
> ++# CONFIG_DEBUG_KOBJECT is not set
> ++# CONFIG_DEBUG_BUGVERBOSE is not set
> ++CONFIG_DEBUG_INFO=y
> ++# CONFIG_DEBUG_VM is not set
> ++# CONFIG_DEBUG_WRITECOUNT is not set
> ++# 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
> ++# CONFIG_DEBUG_CREDENTIALS is not set
> ++# CONFIG_BOOT_PRINTK_DELAY is not set
> ++# CONFIG_RCU_TORTURE_TEST is not set
> ++# CONFIG_RCU_CPU_STALL_DETECTOR is not set
> ++# CONFIG_BACKTRACE_SELF_TEST is not set
> ++# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
> ++# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
> ++# CONFIG_FAULT_INJECTION is not set
> ++# CONFIG_LATENCYTOP is not set
> ++# CONFIG_SYSCTL_SYSCALL_CHECK is not set
> ++# CONFIG_PAGE_POISONING is not set
> ++CONFIG_HAVE_FUNCTION_TRACER=y
> ++CONFIG_TRACING_SUPPORT=y
> ++CONFIG_FTRACE=y
> ++# CONFIG_FUNCTION_TRACER is not set
> ++# CONFIG_IRQSOFF_TRACER is not set
> ++# CONFIG_SCHED_TRACER is not set
> ++# CONFIG_ENABLE_DEFAULT_TRACERS is not set
> ++# CONFIG_BOOT_TRACER 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
> ++# CONFIG_BLK_DEV_IO_TRACE is not set
> ++# CONFIG_SAMPLES is not set
> ++CONFIG_HAVE_ARCH_KGDB=y
> ++# CONFIG_KGDB is not set
> ++CONFIG_ARM_UNWIND=y
> ++# CONFIG_DEBUG_USER is not set
> ++# CONFIG_DEBUG_ERRORS is not set
> ++# CONFIG_DEBUG_STACK_USAGE is not set
> ++CONFIG_DEBUG_LL=y
> ++# CONFIG_EARLY_PRINTK is not set
> ++# CONFIG_DEBUG_ICEDCC is not set
> ++# CONFIG_OC_ETM is not set
> ++
> ++#
> ++# Security options
> ++#
> ++# CONFIG_KEYS is not set
> ++# CONFIG_SECURITY is not set
> ++# CONFIG_SECURITYFS is not set
> ++# CONFIG_DEFAULT_SECURITY_SELINUX is not set
> ++# CONFIG_DEFAULT_SECURITY_SMACK is not set
> ++# CONFIG_DEFAULT_SECURITY_TOMOYO is not set
> ++CONFIG_DEFAULT_SECURITY_DAC=y
> ++CONFIG_DEFAULT_SECURITY=""
> ++CONFIG_CRYPTO=y
> ++
> ++#
> ++# Crypto core or helper
> ++#
> ++CONFIG_CRYPTO_ALGAPI=y
> ++CONFIG_CRYPTO_ALGAPI2=y
> ++CONFIG_CRYPTO_AEAD2=y
> ++CONFIG_CRYPTO_BLKCIPHER=y
> ++CONFIG_CRYPTO_BLKCIPHER2=y
> ++CONFIG_CRYPTO_HASH=y
> ++CONFIG_CRYPTO_HASH2=y
> ++CONFIG_CRYPTO_RNG2=y
> ++CONFIG_CRYPTO_PCOMP=y
> ++CONFIG_CRYPTO_MANAGER=y
> ++CONFIG_CRYPTO_MANAGER2=y
> ++# CONFIG_CRYPTO_GF128MUL is not set
> ++# CONFIG_CRYPTO_NULL is not set
> ++CONFIG_CRYPTO_WORKQUEUE=y
> ++# CONFIG_CRYPTO_CRYPTD is not set
> ++# CONFIG_CRYPTO_AUTHENC is not set
> ++# CONFIG_CRYPTO_TEST is not set
> ++
> ++#
> ++# Authenticated Encryption with Associated Data
> ++#
> ++# CONFIG_CRYPTO_CCM is not set
> ++# CONFIG_CRYPTO_GCM is not set
> ++# CONFIG_CRYPTO_SEQIV is not set
> ++
> ++#
> ++# Block modes
> ++#
> ++CONFIG_CRYPTO_CBC=y
> ++# CONFIG_CRYPTO_CTR is not set
> ++# CONFIG_CRYPTO_CTS is not set
> ++CONFIG_CRYPTO_ECB=m
> ++# CONFIG_CRYPTO_LRW is not set
> ++CONFIG_CRYPTO_PCBC=m
> ++# CONFIG_CRYPTO_XTS is not set
> ++
> ++#
> ++# Hash modes
> ++#
> ++# CONFIG_CRYPTO_HMAC is not set
> ++# CONFIG_CRYPTO_XCBC is not set
> ++# CONFIG_CRYPTO_VMAC is not set
> ++
> ++#
> ++# Digest
> ++#
> ++CONFIG_CRYPTO_CRC32C=y
> ++# CONFIG_CRYPTO_GHASH is not set
> ++# CONFIG_CRYPTO_MD4 is not set
> ++CONFIG_CRYPTO_MD5=y
> ++# CONFIG_CRYPTO_MICHAEL_MIC is not set
> ++# CONFIG_CRYPTO_RMD128 is not set
> ++# CONFIG_CRYPTO_RMD160 is not set
> ++# CONFIG_CRYPTO_RMD256 is not set
> ++# CONFIG_CRYPTO_RMD320 is not set
> ++# CONFIG_CRYPTO_SHA1 is not set
> ++# CONFIG_CRYPTO_SHA256 is not set
> ++# CONFIG_CRYPTO_SHA512 is not set
> ++# CONFIG_CRYPTO_TGR192 is not set
> ++# CONFIG_CRYPTO_WP512 is not set
> ++
> ++#
> ++# Ciphers
> ++#
> ++# CONFIG_CRYPTO_AES is not set
> ++# CONFIG_CRYPTO_ANUBIS is not set
> ++# CONFIG_CRYPTO_ARC4 is not set
> ++# CONFIG_CRYPTO_BLOWFISH is not set
> ++# CONFIG_CRYPTO_CAMELLIA is not set
> ++# CONFIG_CRYPTO_CAST5 is not set
> ++# CONFIG_CRYPTO_CAST6 is not set
> ++CONFIG_CRYPTO_DES=y
> ++# CONFIG_CRYPTO_FCRYPT is not set
> ++# CONFIG_CRYPTO_KHAZAD is not set
> ++# CONFIG_CRYPTO_SALSA20 is not set
> ++# CONFIG_CRYPTO_SEED is not set
> ++# CONFIG_CRYPTO_SERPENT is not set
> ++# CONFIG_CRYPTO_TEA is not set
> ++# CONFIG_CRYPTO_TWOFISH is not set
> ++
> ++#
> ++# Compression
> ++#
> ++# CONFIG_CRYPTO_DEFLATE is not set
> ++# CONFIG_CRYPTO_ZLIB is not set
> ++# CONFIG_CRYPTO_LZO is not set
> ++
> ++#
> ++# Random Number Generation
> ++#
> ++# CONFIG_CRYPTO_ANSI_CPRNG is not set
> ++CONFIG_CRYPTO_HW=y
> ++# CONFIG_BINARY_PRINTF is not set
> ++
> ++#
> ++# Library routines
> ++#
> ++CONFIG_BITREVERSE=y
> ++CONFIG_GENERIC_FIND_LAST_BIT=y
> ++CONFIG_CRC_CCITT=y
> ++# CONFIG_CRC16 is not set
> ++# CONFIG_CRC_T10DIF is not set
> ++# CONFIG_CRC_ITU_T is not set
> ++CONFIG_CRC32=y
> ++# CONFIG_CRC7 is not set
> ++CONFIG_LIBCRC32C=y
> ++CONFIG_ZLIB_INFLATE=y
> ++CONFIG_ZLIB_DEFLATE=y
> ++CONFIG_DECOMPRESS_GZIP=y
> ++CONFIG_HAS_IOMEM=y
> ++CONFIG_HAS_IOPORT=y
> ++CONFIG_HAS_DMA=y
> ++CONFIG_NLATTR=y
> +diff --git a/arch/arm/mach-omap2/Kconfig b/arch/arm/mach-omap2/Kconfig
> +index b72ae06..d965d58 100644
> +--- a/arch/arm/mach-omap2/Kconfig
> ++++ b/arch/arm/mach-omap2/Kconfig
> +@@ -96,6 +96,11 @@ config MACH_OMAP3517EVM
> + 	depends on ARCH_OMAP3 && ARCH_OMAP34XX
> + 	select OMAP_PACKAGE_CBB
> +
> ++config MACH_CRANEBOARD
> ++	bool "AM3517/05 Crane board"
> ++	depends on ARCH_OMAP3 && ARCH_OMAP34XX
> ++	select OMAP_PACKAGE_CBB
> ++
> + config PMIC_TPS65023
> + 	bool "TPS65023 Power Module"
> + 	default y
> +@@ -171,6 +176,7 @@ config MACH_OMAP_4430SDP
> + 	bool "OMAP 4430 SDP board"
> + 	depends on ARCH_OMAP4
> +
> ++
> + config OMAP3_EMU
> + 	bool "OMAP3 debugging peripherals"
> + 	depends on ARCH_OMAP3
> +diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile
> +index 4d9dcdd..a49d436 100644
> +--- a/arch/arm/mach-omap2/Makefile
> ++++ b/arch/arm/mach-omap2/Makefile
> +@@ -131,6 +131,8 @@ obj-$(CONFIG_MACH_OMAP_4430SDP)		+= board-4430sdp.o
> + obj-$(CONFIG_MACH_OMAP3517EVM)     	+= board-am3517evm.o \
> + 					   mmc-am3517evm.o
> +
> ++obj-$(CONFIG_MACH_CRANEBOARD) 		+= board-am3517crane.o \
> ++					   mmc-am3517crane.o
> + # Platform specific device init code
> + obj-y					+= usb-musb.o
> + obj-$(CONFIG_MACH_OMAP2_TUSB6010)	+= usb-tusb6010.o
> +diff --git a/arch/arm/mach-omap2/board-am3517crane.c b/arch/arm/mach-omap2/board-am3517crane.c
> +new file mode 100644
> +index 0000000..4880ace
> +--- /dev/null
> ++++ b/arch/arm/mach-omap2/board-am3517crane.c
> +@@ -0,0 +1,773 @@
> ++/*
> ++ * linux/arch/arm/mach-omap2/board-am3517crane.c
> ++ *
> ++ * Copyright (C) 2010 Mistral Solutions Pvt LtD <www.mistralsolutions.com>
> ++ * Author: Srinath.R <srinath at mistralsolutions.com>
> ++ *
> ++ * Based on mach-omap2/board-am3517evm.c
> ++ *
> ++ * 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 version 2.
> ++ *
> ++ * This program is distributed "as is" WITHOUT ANY WARRANTY of any kind,
> ++ * whether express or implied; without even the implied warranty of
> ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> ++ * General Public License for more details.
> ++ */
> ++
> ++#include <linux/kernel.h>
> ++#include <linux/init.h>
> ++#include <linux/platform_device.h>
> ++#include <linux/gpio.h>
> ++#include <linux/irq.h>
> ++#include <linux/i2c/tsc2004.h>
> ++#include <linux/mtd/mtd.h>
> ++#include <linux/mtd/partitions.h>
> ++#include <linux/mtd/nand.h>
> ++#include <linux/input.h>
> ++#include <linux/tca6416_keypad.h>
> ++#include <linux/davinci_emac.h>
> ++#include <linux/i2c/pca953x.h>
> ++#include <linux/regulator/machine.h>
> ++#include <linux/can/platform/ti_hecc.h>
> ++#include <linux/i2c/tps65910.h>
> ++
> ++#include <mach/hardware.h>
> ++#include <mach/am35xx.h>
> ++#include <asm/mach-types.h>
> ++#include <asm/mach/arch.h>
> ++#include <asm/mach/map.h>
> ++
> ++#include <plat/board.h>
> ++#include <plat/common.h>
> ++#include <plat/control.h>
> ++#include <plat/usb.h>
> ++#include <plat/display.h>
> ++#include <plat/gpmc.h>
> ++#include <plat/nand.h>
> ++
> ++#include "mmc-am3517crane.h"
> ++#include "mux.h"
> ++
> ++#define GPMC_CS0_BASE  0x60
> ++#define GPMC_CS_SIZE   0x30
> ++
> ++#define NAND_BLOCK_SIZE        SZ_128K
> ++
> ++static struct mtd_partition am3517crane_nand_partitions[] = {
> ++	/* All the partition sizes are listed in terms of NAND block size */
> ++	{
> ++		.name           = "xloader-nand",
> ++		.offset         = 0,
> ++		.size           = 4*(SZ_128K),
> ++		.mask_flags     = MTD_WRITEABLE
> ++	},
> ++	{
> ++		.name           = "uboot-nand",
> ++		.offset         = MTDPART_OFS_APPEND,
> ++		.size           = 14*(SZ_128K),
> ++		.mask_flags     = MTD_WRITEABLE
> ++	},
> ++	{
> ++		.name           = "params-nand",
> ++		.offset         = MTDPART_OFS_APPEND,
> ++		.size           = 2*(SZ_128K)
> ++	},
> ++	{
> ++		.name           = "linux-nand",
> ++		.offset         = MTDPART_OFS_APPEND,
> ++		.size           = 40*(SZ_128K)
> ++	},
> ++	{
> ++		.name           = "jffs2-nand",
> ++		.size           = MTDPART_SIZ_FULL,
> ++		.offset         = MTDPART_OFS_APPEND,
> ++	},
> ++};
> ++
> ++static struct omap_nand_platform_data am3517crane_nand_data = {
> ++	.parts          = am3517crane_nand_partitions,
> ++	.nr_parts       = ARRAY_SIZE(am3517crane_nand_partitions),
> ++	.nand_setup     = NULL,
> ++	.dma_channel    = -1,           /* disable DMA in OMAP NAND driver */
> ++	.dev_ready      = NULL,
> ++};
> ++
> ++static struct resource am3517crane_nand_resource = {
> ++	.flags          = IORESOURCE_MEM,
> ++};
> ++
> ++static struct platform_device am3517crane_nand_device = {
> ++	.name           = "omap2-nand",
> ++	.id             = 0,
> ++	.dev            = {
> ++		.platform_data  = &am3517crane_nand_data,
> ++	},
> ++	.num_resources  = 1,
> ++	.resource       = &am3517crane_nand_resource,
> ++};
> ++
> ++void __init am3517crane_flash_init(void)
> ++{
> ++	u8 cs = 0;
> ++	u8 nandcs = GPMC_CS_NUM + 1;
> ++	u32 gpmc_base_add = OMAP34XX_GPMC_VIRT;
> ++
> ++	while (cs < GPMC_CS_NUM) {
> ++		u32 ret = 0;
> ++		ret = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG1);
> ++
> ++		if ((ret & 0xC00) == 0x800) {
> ++			/* Found it!! */
> ++			if (nandcs > GPMC_CS_NUM)
> ++				nandcs = cs;
> ++		}
> ++		cs++;
> ++	}
> ++	if (nandcs > GPMC_CS_NUM) {
> ++		printk(KERN_INFO "NAND: Unable to find configuration "
> ++				" in GPMC\n ");
> ++		return;
> ++	}
> ++
> ++	if (nandcs < GPMC_CS_NUM) {
> ++		am3517crane_nand_data.cs   = nandcs;
> ++		am3517crane_nand_data.gpmc_cs_baseaddr =
> ++		(void *)(gpmc_base_add + GPMC_CS0_BASE + nandcs*GPMC_CS_SIZE);
> ++
> ++		am3517crane_nand_data.gpmc_baseaddr = (void *)(gpmc_base_add);
> ++
> ++		if (platform_device_register(&am3517crane_nand_device) < 0)
> ++			printk(KERN_ERR "Unable to register NAND device\n");
> ++
> ++	}
> ++}
> ++
> ++
> ++#define AM35XX_EVM_PHY_MASK		(0xF)
> ++#define AM35XX_EVM_MDIO_FREQUENCY    	(1000000)
> ++
> ++static struct emac_platform_data am3517_crane_emac_pdata = {
> ++	.phy_mask       = AM35XX_EVM_PHY_MASK,
> ++	.mdio_max_freq  = AM35XX_EVM_MDIO_FREQUENCY,
> ++	.rmii_en        = 1,
> ++};
> ++
> ++static int __init eth_addr_setup(char *str)
> ++{
> ++	int i;
> ++
> ++	if (str == NULL)
> ++		return 0;
> ++	for (i = 0; i < ETH_ALEN; i++)
> ++		am3517_crane_emac_pdata.mac_addr[i] = simple_strtol(&str[i*3],
> ++							(char **)NULL, 16);
> ++	return 1;
> ++}
> ++
> ++/* Get MAC address from kernel boot parameter eth=AA:BB:CC:DD:EE:FF */
> ++__setup("eth=", eth_addr_setup);
> ++
> ++static struct resource am3517_emac_resources[] = {
> ++	{
> ++		.start  = AM35XX_IPSS_EMAC_BASE,
> ++		.end    = AM35XX_IPSS_EMAC_BASE + 0x3FFFF,
> ++		.flags  = IORESOURCE_MEM,
> ++	},
> ++	{
> ++		.start  = INT_35XX_EMAC_C0_RXTHRESH_IRQ,
> ++		.end    = INT_35XX_EMAC_C0_RXTHRESH_IRQ,
> ++		.flags  = IORESOURCE_IRQ,
> ++	},
> ++	{
> ++		.start  = INT_35XX_EMAC_C0_RX_PULSE_IRQ,
> ++		.end    = INT_35XX_EMAC_C0_RX_PULSE_IRQ,
> ++		.flags  = IORESOURCE_IRQ,
> ++	},
> ++	{
> ++		.start  = INT_35XX_EMAC_C0_TX_PULSE_IRQ,
> ++		.end    = INT_35XX_EMAC_C0_TX_PULSE_IRQ,
> ++		.flags  = IORESOURCE_IRQ,
> ++	},
> ++	{
> ++		.start  = INT_35XX_EMAC_C0_MISC_PULSE_IRQ,
> ++		.end    = INT_35XX_EMAC_C0_MISC_PULSE_IRQ,
> ++		.flags  = IORESOURCE_IRQ,
> ++	},
> ++};
> ++
> ++static struct platform_device am3517_emac_device = {
> ++	.name           = "davinci_emac",
> ++	.id             = -1,
> ++	.num_resources  = ARRAY_SIZE(am3517_emac_resources),
> ++	.resource       = am3517_emac_resources,
> ++};
> ++
> ++static void am3517_enable_ethernet_int(void)
> ++{
> ++	u32 regval;
> ++
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++	regval = (regval | AM35XX_CPGMAC_C0_RX_PULSE_CLR |
> ++		AM35XX_CPGMAC_C0_TX_PULSE_CLR |
> ++		AM35XX_CPGMAC_C0_MISC_PULSE_CLR |
> ++		AM35XX_CPGMAC_C0_RX_THRESH_CLR);
> ++
> ++	omap_ctrl_writel(regval, AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++}
> ++
> ++static void am3517_disable_ethernet_int(void)
> ++{
> ++	u32 regval;
> ++
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++	regval = (regval | AM35XX_CPGMAC_C0_RX_PULSE_CLR |
> ++			AM35XX_CPGMAC_C0_TX_PULSE_CLR);
> ++	omap_ctrl_writel(regval, AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_LVL_INTR_CLEAR);
> ++}
> ++
> ++void am3517_crane_ethernet_init(struct emac_platform_data *pdata)
> ++{
> ++	unsigned int regval;
> ++
> ++	pdata->ctrl_reg_offset          = AM35XX_EMAC_CNTRL_OFFSET;
> ++	pdata->ctrl_mod_reg_offset      = AM35XX_EMAC_CNTRL_MOD_OFFSET;
> ++	pdata->ctrl_ram_offset          = AM35XX_EMAC_CNTRL_RAM_OFFSET;
> ++	pdata->mdio_reg_offset          = AM35XX_EMAC_MDIO_OFFSET;
> ++	pdata->ctrl_ram_size            = AM35XX_EMAC_CNTRL_RAM_SIZE;
> ++	pdata->version                  = EMAC_VERSION_2;
> ++	pdata->hw_ram_addr              = AM35XX_EMAC_HW_RAM_ADDR;
> ++	pdata->interrupt_enable 	= am3517_enable_ethernet_int;
> ++	pdata->interrupt_disable 	= am3517_disable_ethernet_int;
> ++	am3517_emac_device.dev.platform_data     = pdata;
> ++	platform_device_register(&am3517_emac_device);
> ++
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_IP_SW_RESET);
> ++	regval = regval & (~(AM35XX_CPGMACSS_SW_RST));
> ++	omap_ctrl_writel(regval, AM35XX_CONTROL_IP_SW_RESET);
> ++	regval = omap_ctrl_readl(AM35XX_CONTROL_IP_SW_RESET);
> ++
> ++	return ;
> ++}
> ++
> ++static void __init am3517_crane_display_init(void)
> ++{
> ++	omap_mux_init_gpio(52, OMAP_PIN_OUTPUT);
> ++	gpio_request(52, "dvi_enable");
> ++	gpio_direction_output(52, 1);
> ++}
> ++
> ++
> ++
> ++static struct omap_dss_device am3517_crane_tv_device = {
> ++	.type 			= OMAP_DISPLAY_TYPE_VENC,
> ++	.name 			= "tv",
> ++	.driver_name		= "venc",
> ++	.phy.venc.type          = OMAP_DSS_VENC_TYPE_COMPOSITE,
> ++	.platform_enable	= NULL,
> ++	.platform_disable	= NULL,
> ++};
> ++
> ++static int am3517_crane_panel_enable_dvi(struct omap_dss_device *dssdev)
> ++{
> ++	gpio_set_value(52, 1);
> ++	return 0;
> ++}
> ++
> ++static void am3517_crane_panel_disable_dvi(struct omap_dss_device *dssdev)
> ++{
> ++	gpio_set_value(52, 0);
> ++}
> ++
> ++static struct omap_dss_device am3517_crane_dvi_device = {
> ++	.type			= OMAP_DISPLAY_TYPE_DPI,
> ++	.name			= "dvi",
> ++	.driver_name		= "generic_panel",
> ++	.phy.dpi.data_lines	= 24,
> ++	.platform_enable	= am3517_crane_panel_enable_dvi,
> ++	.platform_disable	= am3517_crane_panel_disable_dvi,
> ++};
> ++
> ++static struct omap_dss_device *am3517_crane_dss_devices[] = {
> ++	&am3517_crane_tv_device,
> ++	&am3517_crane_dvi_device,
> ++};
> ++
> ++static struct omap_dss_board_info am3517_crane_dss_data = {
> ++	.num_devices	= ARRAY_SIZE(am3517_crane_dss_devices),
> ++	.devices	= am3517_crane_dss_devices,
> ++	.default_device	= &am3517_crane_dvi_device,
> ++};
> ++
> ++struct platform_device am3517_crane_dss_device = {
> ++	.name		= "omapdss",
> ++	.id		= -1,
> ++	.dev		= {
> ++		.platform_data	= &am3517_crane_dss_data,
> ++	},
> ++};
> ++
> ++static u64 vpfe_capture_dma_mask = DMA_BIT_MASK(32);
> ++static struct resource dm644x_ccdc_resource[] = {
> ++	/* CCDC Base address */
> ++	{
> ++		.start	= AM35XX_IPSS_VPFE_BASE,
> ++		.end	= AM35XX_IPSS_VPFE_BASE + 0xffff,
> ++		.flags	= IORESOURCE_MEM,
> ++	},
> ++};
> ++
> ++static struct platform_device dm644x_ccdc_dev = {
> ++	.name		= "dm644x_ccdc",
> ++	.id		= -1,
> ++	.num_resources	= ARRAY_SIZE(dm644x_ccdc_resource),
> ++	.resource	= dm644x_ccdc_resource,
> ++	.dev = {
> ++		.dma_mask		= &vpfe_capture_dma_mask,
> ++		.coherent_dma_mask	= DMA_BIT_MASK(32),
> ++	},
> ++};
> ++
> ++static struct regulator_consumer_supply am3517_crane_vdd1_supplies[] = {
> ++	{
> ++		.supply = "vdd_core",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vdd1 = {
> ++	.constraints = {
> ++		.min_uV = 1200000,
> ++		.max_uV = 1200000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vdd1_supplies),
> ++	.consumer_supplies = am3517_crane_vdd1_supplies,
> ++};
> ++
> ++static struct regulator_consumer_supply am3517_crane_vdd2_supplies[] = {
> ++	{
> ++		.supply = "vddshv",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vdd2 = {
> ++	.constraints = {
> ++		.min_uV = 3300000,
> ++		.max_uV = 3300000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vdd2_supplies),
> ++	.consumer_supplies = am3517_crane_vdd2_supplies,
> ++};
> ++
> ++
> ++static struct regulator_consumer_supply am3517_crane_vio_supplies[] = {
> ++	{
> ++		.supply = "vdds",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vio = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vio_supplies),
> ++	.consumer_supplies = am3517_crane_vio_supplies,
> ++};
> ++
> ++
> ++static struct regulator_consumer_supply am3517_crane_vaux1_supplies[] = {
> ++	{
> ++		.supply = "vdd_sram_mpu",
> ++	},
> ++	{
> ++		.supply = "vdd_sram_core_bg0",
> ++	},
> ++	{
> ++		.supply = "vddsosc",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vaux1 = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vaux1_supplies),
> ++	.consumer_supplies = am3517_crane_vaux1_supplies,
> ++};
> ++
> ++
> ++static struct regulator_consumer_supply am3517_crane_vaux2_supplies[] = {
> ++	{
> ++		.supply = "vdda1p8v_usbphy",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vaux2 = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vaux2_supplies),
> ++	.consumer_supplies = am3517_crane_vaux2_supplies,
> ++};
> ++
> ++
> ++static struct regulator_consumer_supply am3517_crane_vdac_supplies[] = {
> ++	{
> ++		.supply = "vdda_dac",
> ++		.dev    = &am3517_crane_dss_device.dev,
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vdac = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_MODE,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vdac_supplies),
> ++	.consumer_supplies = am3517_crane_vdac_supplies,
> ++};
> ++
> ++static struct regulator_consumer_supply am3517_crane_vmmc_supplies[] = {
> ++	{
> ++		.supply = "vdda3p3v_usbphy",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vmmc = {
> ++	.constraints = {
> ++		.min_uV = 3300000,
> ++		.max_uV = 3300000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vmmc_supplies),
> ++	.consumer_supplies = am3517_crane_vmmc_supplies,
> ++};
> ++
> ++
> ++static struct regulator_consumer_supply am3517_crane_vpll_supplies[] = {
> ++	{
> ++		.supply = "vdds_dpll_mpu_usbhost",
> ++	},
> ++	{
> ++		.supply = "vdds_dpll_per_core",
> ++	},
> ++};
> ++
> ++static struct regulator_init_data am3517_crane_regulator_vpll = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL,
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies = ARRAY_SIZE(am3517_crane_vpll_supplies),
> ++	.consumer_supplies = am3517_crane_vpll_supplies,
> ++};
> ++
> ++static int am3517_crane_tps65910_config(struct tps65910_platform_data *pdata)
> ++{
> ++	u8 val 	= 0;
> ++	int i 	= 0;
> ++	int err = -1;
> ++
> ++
> ++	/* Configure TPS65910 for am3517_crane board needs */
> ++
> ++	/* Set sleep state active high */
> ++	val |= (TPS65910_DEV2_SLEEPSIG_POL);
> ++
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++			TPS65910_REG_DEVCTRL2);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_DEVCTRL2 reg\n");
> ++		return -EIO;
> ++	}
> ++
> ++	/* Mask ALL interrupts */
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, 0xFF,
> ++			TPS65910_REG_INT_MSK);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_INT_MSK reg\n");
> ++		return -EIO;
> ++	}
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, 0x03,
> ++			TPS65910_REG_INT_MSK2);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_INT_MSK2 reg\n");
> ++		return -EIO;
> ++	}
> ++
> ++	/* Set RTC regulator on during sleep */
> ++
> ++	val = TPS65910_VRTC_OFFMASK;
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++			TPS65910_REG_VRTC);
> ++
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_VRTC reg\n");
> ++		return -EIO;
> ++	}
> ++	/* Set RTC Power, disable Smart Reflex in DEVCTRL_REG */
> ++	val = 0;
> ++	val &= ~TPS65910_RTC_PWDNN;
> ++	val |= (TPS65910_CK32K_CTRL | TPS65910_SR_CTL_I2C_SEL);
> ++
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++			TPS65910_REG_DEVCTRL);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_DEVCTRL reg\n");
> ++		return -EIO;
> ++	}
> ++
> ++	/* Enable and set back-up battery charger control*/
> ++
> ++	tps65910_enable_bbch(TPS65910_BBSEL_2P52);
> ++
> ++	err = tps65910_i2c_read_u8(TPS65910_I2C_ID0, &val,
> ++			TPS65910_REG_VRTC);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to read  TPS65910_REG_VRTC reg\n");
> ++		return -EIO;
> ++	}
> ++	val = TPS65910_VRTC_OFFMASK;
> ++
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++			TPS65910_REG_VRTC);
> ++	if (err) {
> ++		printk(KERN_ERR "Unable to write TPS65910_REG_VRTC reg\n");
> ++		return -EIO;
> ++	}
> ++
> ++	/* Disable SmartReflex control */
> ++	val &= 0;
> ++	val &= ~TPS65910_RTC_PWDNN;
> ++	val |= (TPS65910_CK32K_CTRL | TPS65910_SR_CTL_I2C_SEL);
> ++
> ++	err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++			TPS65910_REG_DEVCTRL);
> ++	if (err) {
> ++		printk(KERN_ERR "Unabale to write TPS65910_REG_DEVCTRL reg\n");
> ++		return -EIO;
> ++	}
> ++
> ++	/* initilize all ISR work as NULL, specific driver will
> ++	 * assign function(s) later.
> ++	 */
> ++	for (i = 0; i < TPS65910_MAX_IRQS; i++)
> ++		pdata->handlers[i] = NULL;
> ++
> ++	return 0;
> ++}
> ++
> ++struct tps65910_platform_data am3517_crane_tps65910_data = {
> ++	.irq_num 	= (unsigned)TPS65910_HOST_IRQ,
> ++	.gpio  		= NULL,
> ++	.vio   		= &am3517_crane_regulator_vio,
> ++	.vdd1  		= &am3517_crane_regulator_vdd1,
> ++	.vdd2  		= &am3517_crane_regulator_vdd2,
> ++	.vdd3  		= NULL,
> ++	.vdig1		= NULL,
> ++	.vdig2		= NULL,
> ++	.vaux33		= NULL,
> ++	.vmmc		= &am3517_crane_regulator_vmmc,
> ++	.vaux1		= &am3517_crane_regulator_vaux1,
> ++	.vaux2		= &am3517_crane_regulator_vaux2,
> ++	.vdac		= &am3517_crane_regulator_vdac,
> ++	.vpll		= &am3517_crane_regulator_vpll,
> ++	.board_tps65910_config = am3517_crane_tps65910_config,
> ++};
> ++
> ++static struct i2c_board_info __initdata am3517crane_i2c1_boardinfo[] = {
> ++	{
> ++		I2C_BOARD_INFO("tps65910", TPS65910_I2C_ID0),
> ++		.flags          = I2C_CLIENT_WAKE,
> ++		.irq            = TPS65910_HOST_IRQ,
> ++		.platform_data  = &am3517_crane_tps65910_data,
> ++	},
> ++};
> ++
> ++
> ++static int __init am3517_crane_i2c_init(void)
> ++{
> ++	omap_register_i2c_bus(1, 400, am3517crane_i2c1_boardinfo,
> ++			ARRAY_SIZE(am3517crane_i2c1_boardinfo));
> ++	omap_register_i2c_bus(2, 400, NULL, 0);
> ++	omap_register_i2c_bus(3, 400, NULL, 0);
> ++
> ++	return 0;
> ++}
> ++
> ++/*
> ++ * HECC information
> ++ */
> ++static struct resource am3517_hecc_resources[] = {
> ++	{
> ++		.start  = AM35XX_IPSS_HECC_BASE,
> ++		.end    = AM35XX_IPSS_HECC_BASE + 0x3FFF,
> ++		.flags  = IORESOURCE_MEM,
> ++	},
> ++	{
> ++		.start  = INT_35XX_HECC0_IRQ,
> ++		.end    = INT_35XX_HECC0_IRQ,
> ++		.flags  = IORESOURCE_IRQ,
> ++	},
> ++};
> ++
> ++static struct platform_device am3517_hecc_device = {
> ++	.name           = "ti_hecc",
> ++	.id             = 1,
> ++	.num_resources  = ARRAY_SIZE(am3517_hecc_resources),
> ++	.resource       = am3517_hecc_resources,
> ++};
> ++
> ++static struct ti_hecc_platform_data am3517_crane_hecc_pdata = {
> ++	.scc_hecc_offset        = AM35XX_HECC_SCC_HECC_OFFSET,
> ++	.scc_ram_offset         = AM35XX_HECC_SCC_RAM_OFFSET,
> ++	.hecc_ram_offset        = AM35XX_HECC_RAM_OFFSET,
> ++	.mbx_offset            = AM35XX_HECC_MBOX_OFFSET,
> ++	.int_line               = AM35XX_HECC_INT_LINE,
> ++	.version                = AM35XX_HECC_VERSION,
> ++};
> ++
> ++static void am3517_crane_hecc_init(struct ti_hecc_platform_data *pdata)
> ++{
> ++	am3517_hecc_device.dev.platform_data = pdata;
> ++	platform_device_register(&am3517_hecc_device);
> ++}
> ++
> ++
> ++/*
> ++ * Board initialization
> ++ */
> ++static struct omap_board_config_kernel am3517_crane_config[] __initdata = {
> ++};
> ++
> ++static struct platform_device *am3517_crane_devices[] __initdata = {
> ++	&dm644x_ccdc_dev,
> ++	&am3517_crane_dss_device,
> ++};
> ++
> ++static void __init am3517_crane_init_irq(void)
> ++{
> ++	omap_board_config = am3517_crane_config;
> ++	omap_board_config_size = ARRAY_SIZE(am3517_crane_config);
> ++
> ++	omap2_init_common_hw(NULL, NULL, NULL, NULL, NULL);
> ++	omap_init_irq();
> ++	omap_gpio_init();
> ++}
> ++
> ++static struct ehci_hcd_omap_platform_data ehci_pdata __initdata = {
> ++	.port_mode[0] = EHCI_HCD_OMAP_MODE_PHY,
> ++	.port_mode[1] = EHCI_HCD_OMAP_MODE_UNKNOWN,
> ++	.port_mode[2] = EHCI_HCD_OMAP_MODE_UNKNOWN,
> ++
> ++	.phy_reset  = true,
> ++	.reset_gpio_port[0]  = 38,
> ++	.reset_gpio_port[1]  = -EINVAL,
> ++	.reset_gpio_port[2]  = -EINVAL
> ++};
> ++
> ++#ifdef CONFIG_OMAP_MUX
> ++static struct omap_board_mux board_mux[] __initdata = {
> ++	/* USB OTG DRVVBUS offset = 0x212 */
> ++	OMAP3_MUX(CHASSIS_DMAREQ3, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLDOWN),
> ++	OMAP3_MUX(MCBSP_CLKS, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP),
> ++	OMAP3_MUX(GPMC_NCS4, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLDOWN),
> ++	{ .reg_offset = OMAP_MUX_TERMINATOR },
> ++};
> ++#else
> ++#define board_mux       NULL
> ++#endif
> ++
> ++static struct am3517_hsmmc_info mmc[] = {
> ++	{
> ++		.mmc            = 1,
> ++		.wires          = 8,
> ++		.gpio_cd        = 41,
> ++		.gpio_wp        = 40,
> ++	},
> ++	{}      /* Terminator */
> ++};
> ++
> ++static void __init am3517_crane_init(void)
> ++{
> ++
> ++	am3517_crane_i2c_init();
> ++	omap3_mux_init(board_mux, OMAP_PACKAGE_CBB);
> ++	platform_add_devices(am3517_crane_devices,
> ++			ARRAY_SIZE(am3517_crane_devices));
> ++
> ++	omap_serial_init();
> ++	am3517crane_flash_init();
> ++	usb_musb_init();
> ++
> ++	/* Configure GPIO for EHCI port */
> ++	omap_mux_init_gpio(35, OMAP_PIN_OUTPUT);
> ++	gpio_request(35, "usb_ehci_enable");
> ++	gpio_direction_output(35, 1);
> ++	gpio_set_value(35, 1);
> ++	omap_mux_init_gpio(38, OMAP_PIN_OUTPUT);
> ++	usb_ehci_init(&ehci_pdata);
> ++
> ++	/* DSS */
> ++	am3517_crane_display_init();
> ++
> ++	/*Ethernet*/
> ++	am3517_crane_ethernet_init(&am3517_crane_emac_pdata);
> ++	am3517_crane_hecc_init(&am3517_crane_hecc_pdata);
> ++
> ++	/* MMC init function */
> ++	am3517_mmc_init(mmc);
> ++
> ++}
> ++
> ++static void __init am3517_crane_map_io(void)
> ++{
> ++	omap2_set_globals_343x();
> ++	omap2_map_common_io();
> ++}
> ++
> ++MACHINE_START(CRANEBOARD, "AM3517/05 CRANEBOARD")
> ++	.phys_io	= 0x48000000,
> ++	.io_pg_offst	= ((0xd8000000) >> 18) & 0xfffc,
> ++	.boot_params	= 0x80000100,
> ++	.map_io		= am3517_crane_map_io,
> ++	.init_irq	= am3517_crane_init_irq,
> ++	.init_machine	= am3517_crane_init,
> ++	.timer		= &omap_timer,
> ++MACHINE_END
> +diff --git a/arch/arm/mach-omap2/mmc-am3517crane.c b/arch/arm/mach-omap2/mmc-am3517crane.c
> +new file mode 100644
> +index 0000000..80ad8ae
> +--- /dev/null
> ++++ b/arch/arm/mach-omap2/mmc-am3517crane.c
> +@@ -0,0 +1,267 @@
> ++/*
> ++ * linux/arch/arm/mach-omap2/mmc-crane.c
> ++ *
> ++ * Copyright (C) 2010 Mistral Solutions Pvt Ltd <www.mistralsolutions.com>
> ++ * Author: Srinath.R <srinath at mistralsolutions.com>
> ++ *
> ++ * Based on linux/arch/arm/mach-omap2/mmc-am3517evm.c
> ++ *
> ++ * 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/err.h>
> ++#include <linux/io.h>
> ++#include <linux/module.h>
> ++#include <linux/platform_device.h>
> ++#include <linux/interrupt.h>
> ++#include <linux/delay.h>
> ++#include <linux/gpio.h>
> ++
> ++#include <mach/hardware.h>
> ++#include <plat/control.h>
> ++#include <plat/mmc.h>
> ++#include <plat/board.h>
> ++#include "mmc-am3517crane.h"
> ++
> ++#define LDO_CLR			0x00
> ++#define VSEL_S2_CLR		0x40
> ++
> ++#define VMMC1_DEV_GRP		0x27
> ++#define VMMC1_CLR		0x00
> ++#define VMMC1_315V		0x03
> ++#define VMMC1_300V		0x02
> ++#define VMMC1_285V		0x01
> ++#define VMMC1_185V		0x00
> ++#define VMMC1_DEDICATED		0x2A
> ++
> ++#define VMMC2_DEV_GRP		0x2B
> ++#define VMMC2_CLR		0x40
> ++#define VMMC2_315V		0x0c
> ++#define VMMC2_300V		0x0b
> ++#define VMMC2_285V		0x0a
> ++#define VMMC2_260V		0x08
> ++#define VMMC2_185V		0x06
> ++#define VMMC2_DEDICATED		0x2E
> ++
> ++#define VMMC_DEV_GRP_P1		0x20
> ++
> ++#define HSMMC_NAME_LEN	9
> ++
> ++#if defined(CONFIG_REGULATOR) || \
> ++	(defined(CONFIG_MMC_OMAP) || defined(CONFIG_MMC_OMAP_MODULE) || \
> ++	 defined(CONFIG_MMC_OMAP_HS) || defined(CONFIG_MMC_OMAP_HS_MODULE))
> ++
> ++/*
> ++ * MMC definitions
> ++ *
> ++ */
> ++static struct mmc_controller {
> ++	struct omap_mmc_platform_data	*mmc;
> ++	u8		vmmc_dev_grp;
> ++	u8		vmmc_dedicated;
> ++	char		name[HSMMC_NAME_LEN];
> ++} hsmmc[] = {
> ++	{
> ++		.vmmc_dev_grp		= VMMC1_DEV_GRP,
> ++		.vmmc_dedicated		= VMMC1_DEDICATED,
> ++	},
> ++	{
> ++		.vmmc_dev_grp		= VMMC2_DEV_GRP,
> ++		.vmmc_dedicated		= VMMC2_DEDICATED,
> ++	},
> ++};
> ++
> ++static int mmc_card_detect(int irq)
> ++{
> ++	unsigned i;
> ++
> ++	for (i = 0; i < ARRAY_SIZE(hsmmc); i++) {
> ++		struct omap_mmc_platform_data *mmc;
> ++
> ++		mmc = hsmmc[i].mmc;
> ++		if (!mmc)
> ++			continue;
> ++		if (irq != mmc->slots[0].card_detect_irq)
> ++			continue;
> ++
> ++		/* NOTE: assumes card detect signal is active-low */
> ++		return !gpio_get_value_cansleep(mmc->slots[0].switch_pin);
> ++	}
> ++	return -ENOSYS;
> ++}
> ++
> ++static int mmc_get_ro(struct device *dev, int slot)
> ++{
> ++	struct omap_mmc_platform_data *mmc = dev->platform_data;
> ++
> ++	/* NOTE: assumes write protect signal is active-high */
> ++	return gpio_get_value_cansleep(mmc->slots[0].gpio_wp);
> ++}
> ++
> ++/*
> ++ * MMC Slot Initialization.
> ++ */
> ++static int mmc_late_init(struct device *dev)
> ++{
> ++	struct omap_mmc_platform_data *mmc = dev->platform_data;
> ++	int ret = 0;
> ++	int i;
> ++
> ++	ret = gpio_request(mmc->slots[0].switch_pin, "mmc_cd");
> ++	if (ret)
> ++		goto done;
> ++	ret = gpio_direction_input(mmc->slots[0].switch_pin);
> ++	if (ret)
> ++		goto err;
> ++
> ++	for (i = 0; i < ARRAY_SIZE(hsmmc); i++) {
> ++		if (hsmmc[i].name == mmc->slots[0].name) {
> ++			hsmmc[i].mmc = mmc;
> ++			break;
> ++		}
> ++	}
> ++
> ++	return 0;
> ++
> ++err:
> ++	gpio_free(mmc->slots[0].switch_pin);
> ++done:
> ++	mmc->slots[0].card_detect_irq = 0;
> ++	mmc->slots[0].card_detect = NULL;
> ++
> ++	dev_err(dev, "err %d configuring card detect\n", ret);
> ++	return ret;
> ++}
> ++
> ++static void mmc_cleanup(struct device *dev)
> ++{
> ++	struct omap_mmc_platform_data *mmc = dev->platform_data;
> ++
> ++	gpio_free(mmc->slots[0].switch_pin);
> ++}
> ++
> ++#ifdef CONFIG_PM
> ++
> ++static int mmc_suspend(struct device *dev, int slot)
> ++{
> ++	struct omap_mmc_platform_data *mmc = dev->platform_data;
> ++
> ++	disable_irq(mmc->slots[0].card_detect_irq);
> ++	return 0;
> ++}
> ++
> ++static int mmc_resume(struct device *dev, int slot)
> ++{
> ++	struct omap_mmc_platform_data *mmc = dev->platform_data;
> ++
> ++	enable_irq(mmc->slots[0].card_detect_irq);
> ++	return 0;
> ++}
> ++
> ++#else
> ++#define mmc_suspend	NULL
> ++#define mmc_resume	NULL
> ++#endif
> ++
> ++/*
> ++ * the MMC power setting function
> ++ */
> ++
> ++static int mmc1_set_power(struct device *dev, int slot, int power_on,
> ++				int vdd)
> ++{
> ++	return 0;
> ++}
> ++
> ++static int mmc2_set_power(struct device *dev, int slot, int power_on, int vdd)
> ++{
> ++	return 0;
> ++}
> ++
> ++static struct omap_mmc_platform_data *hsmmc_data[OMAP34XX_NR_MMC] __initdata;
> ++
> ++void __init am3517_mmc_init(struct am3517_hsmmc_info *controllers)
> ++{
> ++	struct am3517_hsmmc_info *c;
> ++	int nr_hsmmc = ARRAY_SIZE(hsmmc_data);
> ++
> ++	for (c = controllers; c->mmc; c++) {
> ++		struct mmc_controller *mmc_control = hsmmc + c->mmc - 1;
> ++		struct omap_mmc_platform_data *mmc = hsmmc_data[c->mmc - 1];
> ++
> ++		if (!c->mmc || c->mmc > nr_hsmmc) {
> ++			pr_debug("MMC%d: no such controller\n", c->mmc);
> ++			continue;
> ++		}
> ++		if (mmc) {
> ++			pr_debug("MMC%d: already configured\n", c->mmc);
> ++			continue;
> ++		}
> ++
> ++		mmc = kzalloc(sizeof(struct omap_mmc_platform_data),
> ++					GFP_KERNEL);
> ++		if (!mmc) {
> ++			pr_err("Cannot allocate memory for mmc device!\n");
> ++			return;
> ++		}
> ++
> ++		sprintf(mmc_control->name, "mmc%islot%i", c->mmc, 1);
> ++		mmc->slots[0].name = mmc_control->name;
> ++		mmc->nr_slots = 1;
> ++		mmc->slots[0].ocr_mask = MMC_VDD_165_195 |
> ++					MMC_VDD_26_27 | MMC_VDD_27_28 |
> ++					MMC_VDD_29_30 |
> ++					MMC_VDD_30_31 | MMC_VDD_31_32;
> ++		mmc->slots[0].wires = c->wires;
> ++		mmc->slots[0].internal_clock = !c->ext_clock;
> ++		mmc->dma_mask = 0xffffffff;
> ++
> ++		if (1) {
> ++			mmc->init = mmc_late_init;
> ++			mmc->cleanup = mmc_cleanup;
> ++			mmc->suspend = mmc_suspend;
> ++			mmc->resume = mmc_resume;
> ++
> ++			mmc->slots[0].switch_pin = c->gpio_cd;
> ++			mmc->slots[0].card_detect_irq = gpio_to_irq(c->gpio_cd);
> ++			mmc->slots[0].card_detect = mmc_card_detect;
> ++		} else
> ++			mmc->slots[0].switch_pin = -EINVAL;
> ++
> ++		/* write protect normally uses an OMAP gpio */
> ++		if (gpio_is_valid(c->gpio_wp)) {
> ++			gpio_request(c->gpio_wp, "mmc_wp");
> ++			gpio_direction_input(c->gpio_wp);
> ++
> ++			mmc->slots[0].gpio_wp = c->gpio_wp;
> ++			mmc->slots[0].get_ro = mmc_get_ro;
> ++		} else
> ++			mmc->slots[0].gpio_wp = -EINVAL;
> ++
> ++		/* NOTE:  we assume OMAP's MMC1 and MMC2 use
> ++		 * the TWL4030's VMMC1 and VMMC2, respectively;
> ++		 * and that OMAP's MMC3 isn't used.
> ++		 */
> ++
> ++		switch (c->mmc) {
> ++		case 1:
> ++			mmc->slots[0].set_power = mmc1_set_power;
> ++			break;
> ++		case 2:
> ++			mmc->slots[0].set_power = mmc2_set_power;
> ++			break;
> ++		default:
> ++			pr_err("MMC%d configuration not supported!\n", c->mmc);
> ++			continue;
> ++		}
> ++		hsmmc_data[c->mmc - 1] = mmc;
> ++	}
> ++
> ++	omap2_init_mmc(hsmmc_data, OMAP34XX_NR_MMC);
> ++}
> ++#else
> ++inline void am3517_mmc_init(struct craneboard_hsmmc_info *info)
> ++{
> ++}
> ++#endif
> +diff --git a/arch/arm/mach-omap2/mmc-am3517crane.h b/arch/arm/mach-omap2/mmc-am3517crane.h
> +new file mode 100644
> +index 0000000..97fd872
> +--- /dev/null
> ++++ b/arch/arm/mach-omap2/mmc-am3517crane.h
> +@@ -0,0 +1,22 @@
> ++/*
> ++ * MMC definitions for craneboard AM3517/05
> ++ *
> ++ * 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.
> ++ */
> ++
> ++struct am3517_hsmmc_info {
> ++	u8	mmc;		/* controller 1/2/3 */
> ++	u8	wires;		/* 1/4/8 wires */
> ++	bool	transceiver;	/* MMC-2 option */
> ++	bool	ext_clock;	/* use external pin for input clock */
> ++	bool	cover_only;	/* No card detect - just cover switch */
> ++	int	gpio_cd;	/* or -EINVAL */
> ++	int	gpio_wp;	/* or -EINVAL */
> ++	char	*name;		/* or NULL for default */
> ++	struct device *dev;	/* returned: pointer to mmc adapter */
> ++	int	ocr_mask;	/* temporary HACK */
> ++};
> ++
> ++void am3517_mmc_init(struct am3517_hsmmc_info *);
> +diff --git a/arch/arm/mach-omap2/tps65910-pmic.c b/arch/arm/mach-omap2/tps65910-pmic.c
> +new file mode 100644
> +index 0000000..b17d662
> +--- /dev/null
> ++++ b/arch/arm/mach-omap2/tps65910-pmic.c
> +@@ -0,0 +1,195 @@
> ++/*
> ++ * tps65910-pmic.c
> ++ *
> ++ * Common regulator supplies and init data structs for TPS65910
> ++ * PMIC for AM35xx based EVMs. They can be used in various board-evm
> ++ * files for Am35xx based platforms using TPS65910.
> ++ *
> ++ * Copyright (C) 2010 Mistral Solutions Pvt Ltd <www.mistralsolutions.com>
> ++ *
> ++ * Based on arch/arm/mach-omap2/twl4030-pmic.c
> ++ *
> ++ * 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 version 2.
> ++ *
> ++ * This program is distributed "as is" WITHOUT ANY WARRANTY of any kind,
> ++ * whether express or implied; without even the implied warranty of
> ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> ++ * General Public License for more details.
> ++ */
> ++
> ++/* Power domain maping for TPS65910 and AM35XX
> ++
> ++	   1.8V
> ++	   VIO -----------> VDDS
> ++
> ++	   1.8V
> ++	   VAUX1 ---------> VDDS_SRAM_CORE_BG
> ++				|
> ++				-------> VDDS_SRAM_MPU
> ++				|
> ++				-------> VDDOSC
> ++
> ++	   3.3V
> ++	   VDD2 ----------> VDDSHV
> ++
> ++	   1.2V
> ++	   VDD1 ----------> VDD_CORE
> ++
> ++	   1.8V
> ++	   VPLL ----------> VDDS_DPLL_PRE_CORE
> ++				|
> ++				-------> VDDSPLL_MPU_USBHOST
> ++
> ++	   1.8V
> ++	   VDAC ----------> VDDA_DAC
> ++
> ++	   1.8V
> ++	   VAUX2 ----------> VDDA1P8V_USBPHY
> ++
> ++	   3.3V
> ++	   VMMC ----------> VDDA3P3V_USBPHY
> ++
> ++*/
> ++#include <linux/regulator/machine.h>
> ++
> ++/* VIO */
> ++struct regulator_consumer_supply tps65910_vio_supply = {
> ++	.supply = "vdds",
> ++};
> ++
> ++
> ++/* VAUX1 */
> ++struct regulator_consumer_supply tps65910_vaux1_supply[] = {
> ++	{
> ++		.supply = "vdds_sram_core_bg",
> ++	},
> ++	{
> ++		.supply = "vdds_sram_mpu",
> ++	},
> ++	{
> ++		.supply = "vddosc",
> ++	},
> ++};
> ++
> ++/* VPLL */
> ++struct regulator_consumer_supply tps65910_vpll_supply[] = {
> ++	{
> ++		.supply = "vdds_dpll_pre_core",
> ++	},
> ++	{
> ++		.supply = "vddspll_mpu_usbhost",
> ++	},
> ++
> ++};
> ++
> ++/* VDAC */
> ++struct regulator_consumer_supply tps65910_vdac_supply = {
> ++	.supply = "vdda_dac",
> ++};
> ++
> ++/* VAUX2 */
> ++struct regulator_consumer_supply tps65910_vaux2_supply = {
> ++	.supply = "vdda1p8v_usbphy",
> ++};
> ++
> ++
> ++/* VMMC */
> ++struct regulator_consumer_supply tps65910_vmmc_supply = {
> ++	.supply = "vdda3p3v_usbphy",
> ++};
> ++
> ++
> ++/* Regulator initialization data */
> ++
> ++/* VIO  LDO */
> ++struct regulator_init_data vio_data = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 1800000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vaux1_supply),
> ++	.consumer_supplies      = &tps65910_vaux1_supply,
> ++};
> ++
> ++
> ++
> ++/* VAUX1  LDO */
> ++struct regulator_init_data vaux1_data = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 2850000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = false,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vaux1_supply),
> ++	.consumer_supplies      = &tps65910_vaux1_supply,
> ++};
> ++
> ++/* VAUX2  LDO */
> ++struct regulator_init_data vaux2_data = {
> ++	.constraints = {
> ++		.min_uV = 3300000,
> ++		.max_uV = 3300000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = true,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vaux2_supply),
> ++	.consumer_supplies      = &tps65910_vaux2_supply,
> ++
> ++};
> ++
> ++/* VMMC  LDO */
> ++struct regulator_init_data vmmc_data = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 3300000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = false,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vmmc_supply),
> ++	.consumer_supplies      = &tps65910_vmmc_supply,
> ++
> ++};
> ++
> ++/* VPLL  LDO */
> ++struct regulator_init_data vpll_data = {
> ++	.constraints = {
> ++		.min_uV = 100000,
> ++		.max_uV = 2500000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = false,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vpll_supply),
> ++	.consumer_supplies      = &tps65910_vpll_supply,
> ++};
> ++
> ++/* VDAC  LDO */
> ++struct regulator_init_data vdac_data = {
> ++	.constraints = {
> ++		.min_uV = 1800000,
> ++		.max_uV = 2850000,
> ++		.valid_modes_mask = REGULATOR_MODE_NORMAL
> ++		.valid_ops_mask = REGULATOR_CHANGE_STATUS,
> ++		.always_on = true,
> ++		.apply_uV = false,
> ++	},
> ++	.num_consumer_supplies  = ARRAY_SIZE(tps65910_vdac_supply),
> ++	.consumer_supplies      = &tps65910_vdac_supply,
> ++
> ++};
> ++
> ++
> +diff --git a/arch/arm/tools/mach-types b/arch/arm/tools/mach-types
> +index 07b976d..2c9a874 100644
> +--- a/arch/arm/tools/mach-types
> ++++ b/arch/arm/tools/mach-types
> +@@ -2536,3 +2536,4 @@ c3ax03			MACH_C3AX03		C3AX03			2549
> + mxt_td60		MACH_MXT_TD60		MXT_TD60		2550
> + esyx			MACH_ESYX		ESYX			2551
> + bulldog			MACH_BULLDOG		BULLDOG			2553
> ++craneboard		MACH_CRANEBOARD		CRANEBOARD		2932
> +diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c
> +index bbea8a0..48273d7 100644
> +--- a/drivers/i2c/busses/i2c-omap.c
> ++++ b/drivers/i2c/busses/i2c-omap.c
> +@@ -801,7 +801,7 @@ complete:
> + 							"data to send\n");
> + 					break;
> + 				}
> +-
> ++#ifndef CONFIG_CRANEBOARD
> + 				/*
> + 				 * OMAP3430 Errata 1.153: When an XRDY/XDR
> + 				 * is hit, wait for XUDF before writing data
> +@@ -821,6 +821,7 @@ complete:
> + 							stat = omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG);
> + 						}
> + 				}
> ++#endif
> +
> + 				omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w);
> + 			}
> +diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig
> +index aefdd66..ddc3e38 100644
> +--- a/drivers/mfd/Kconfig
> ++++ b/drivers/mfd/Kconfig
> +@@ -129,6 +129,18 @@ config TWL4030_POWER
> + 	  and load scripts controling which resources are switched off/on
> + 	  or reset when a sleep, wakeup or warm reset event occurs.
> +
> ++config TPS65910_CORE
> ++	bool "Texas Instruments TPS65910 Support"
> ++	depends on I2C=y && GENERIC_HARDIRQS
> ++	help
> ++	  Say yes here if you have TPS65910 family chip on your board.
> ++	  This core driver provides register access and registers devices
> ++          for the various functions so that function-specific drivers can
> ++          bind to them.
> ++
> ++	  These multi-function chips are found on many AM35xx boards,
> ++          providing power management, RTC, GPIO features.
> ++
> + config TWL4030_CODEC
> + 	bool
> + 	depends on TWL4030_CORE
> +diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile
> +index ec9c4f2..44350e7 100644
> +--- a/drivers/mfd/Makefile
> ++++ b/drivers/mfd/Makefile
> +@@ -31,6 +31,8 @@ obj-$(CONFIG_TWL4030_POWER)    += twl4030-power.o
> + obj-$(CONFIG_TWL4030_CODEC)	+= twl4030-codec.o
> + obj-$(CONFIG_TWL4030_MADC)	+= twl4030-madc.o
> +
> ++obj-$(CONFIG_TPS65910_CORE)     += tps65910-core.o
> ++
> + obj-$(CONFIG_MFD_MC13783)	+= mc13783-core.o
> +
> + obj-$(CONFIG_MFD_CORE)		+= mfd-core.o
> +@@ -56,4 +58,4 @@ obj-$(CONFIG_AB3100_CORE)	+= ab3100-core.o
> + obj-$(CONFIG_AB3100_OTP)	+= ab3100-otp.o
> + obj-$(CONFIG_AB4500_CORE)	+= ab4500-core.o
> + obj-$(CONFIG_MFD_88PM8607)	+= 88pm8607.o
> +-obj-$(CONFIG_PMIC_ADP5520)	+= adp5520.o
> +\ No newline at end of file
> ++obj-$(CONFIG_PMIC_ADP5520)	+= adp5520.o
> +diff --git a/drivers/mfd/tps65910-core.c b/drivers/mfd/tps65910-core.c
> +new file mode 100644
> +index 0000000..32d4566
> +--- /dev/null
> ++++ b/drivers/mfd/tps65910-core.c
> +@@ -0,0 +1,741 @@
> ++/*
> ++ * tps65910-core.c -- Multifunction core driver for  TPS65910x chips
> ++ *
> ++ * Copyright (C) 2010 Mistral solutions Pvt Ltd <www.mistralsolutions.com>
> ++ *
> ++ * Based on twl-core.c
> ++ *
> ++ * 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/init.h>
> ++#include <linux/mutex.h>
> ++#include <linux/platform_device.h>
> ++#include <linux/clk.h>
> ++#include <linux/err.h>
> ++
> ++#include <linux/regulator/machine.h>
> ++
> ++#include <linux/i2c.h>
> ++#include <linux/i2c/tps65910.h>
> ++#include <plat/board.h>
> ++#include <linux/irq.h>
> ++#include <linux/interrupt.h>
> ++#include <linux/delay.h>
> ++
> ++#if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3)
> ++#include <plat/cpu.h>
> ++#endif
> ++
> ++#define DRIVER_NAME			"tps65910"
> ++
> ++#if defined(CONFIG_GPIO_TPS65910)
> ++#define tps65910_has_gpio()  		true
> ++#else
> ++#define tps65910_has_gpio()  		false
> ++#endif
> ++
> ++#if defined(CONFIG_REGULATOR_TPS65910)
> ++#define tps65910_has_regulator()     	true
> ++#else
> ++#define tps65910_has_regulator()     	false
> ++#endif
> ++
> ++#if defined(CONFIG_RTC_DRV_TPS65910)
> ++#define tps65910_has_rtc()   		true
> ++#else
> ++#define tps65910_has_rtc()   		false
> ++#endif
> ++
> ++#define TPS65910_GENERAL		0
> ++#define TPS65910_SMARTREFLEX		1
> ++
> ++
> ++struct tps65910_platform_data *the_tps65910;
> ++
> ++enum tps65910x_model {
> ++	TPS65910,   	/* TI processors OMAP3 family */
> ++	TPS659101,  	/* Samsung - S5PV210, S5PC1xx */
> ++	TPS659102,	/* Samsung - S3C64xx */
> ++	TPS659103,	/* Reserved */
> ++	TPS659104,	/* Reserved */
> ++	TPS659105,	/* TI processors - DM643x, DM644x */
> ++	TPS659106,	/* Reserved */
> ++	TPS659107,	/* Reserved */
> ++	TPS659108,	/* Reserved */
> ++	TPS659109,	/* Freescale - i.MX51 */
> ++
> ++};
> ++
> ++static bool inuse;
> ++static struct work_struct core_work;
> ++static struct mutex work_lock;
> ++
> ++/* Structure for each TPS65910 Slave */
> ++struct tps65910_client {
> ++	struct i2c_client *client;
> ++	u8 address;
> ++	/* max numb of i2c_msg required for read = 2 */
> ++	struct i2c_msg xfer_msg[2];
> ++	/* To lock access to xfer_msg */
> ++	struct mutex xfer_lock;
> ++};
> ++static struct tps65910_client tps65910_modules[TPS65910_NUM_SLAVES];
> ++
> ++/* bbch = Back-up battery charger control register */
> ++int tps65910_enable_bbch(u8 voltage)
> ++{
> ++
> ++	u8 val = 0;
> ++	int err;
> ++
> ++	if (voltage == TPS65910_BBSEL_3P0 || voltage == TPS65910_BBSEL_2P52 ||
> ++			voltage == TPS65910_BBSEL_3P15 ||
> ++			voltage == TPS65910_BBSEL_VBAT) {
> ++		val = (voltage | TPS65910_BBCHEN);
> ++		err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++				TPS65910_REG_BBCH);
> ++		if (err) {
> ++			printk(KERN_ERR "Unable write TPS65910_REG_BBCH reg\n");
> ++			return -EIO;
> ++		}
> ++	} else {
> ++		printk(KERN_ERR"Invalid argumnet for %s \n", __func__);
> ++		return -EINVAL;
> ++	}
> ++
> ++	return 0;
> ++}
> ++EXPORT_SYMBOL(tps65910_enable_bbch);
> ++
> ++int tps65910_disable_bbch(void)
> ++{
> ++
> ++	u8 val = 0;
> ++	int err;
> ++
> ++	err = tps65910_i2c_read_u8(TPS65910_I2C_ID0, &val, TPS65910_REG_BBCH);
> ++
> ++	if (!err) {
> ++		val &= ~TPS65910_BBCHEN;
> ++
> ++		err = tps65910_i2c_write_u8(TPS65910_I2C_ID0, val,
> ++				TPS65910_REG_BBCH);
> ++		if (err) {
> ++			printk(KERN_ERR "Unable write TPS65910_REG_BBCH \
> ++					reg\n");
> ++			return -EIO;
> ++		}
> ++	} else {
> ++		printk(KERN_ERR "Unable to read TPS65910_REG_BBCH reg\n");
> ++		return -EIO;
> ++	}
> ++	return 0;
> ++}
> ++EXPORT_SYMBOL(tps65910_disable_bbch);
> ++
> ++int tps65910_i2c_read(u8 slave_addr, u8 *value, u8 reg, unsigned num_bytes)
> ++{
> ++	u8 		val;
> ++	u32 		ret;
> ++	struct 		tps65910_client *tps65910;
> ++	struct i2c_msg *msg;
> ++
> ++	switch (slave_addr) {
> ++	case TPS65910_I2C_ID0:
> ++		tps65910 = &tps65910_modules[0];
> ++		tps65910->address = TPS65910_I2C_ID0;
> ++		break;
> ++	case TPS65910_I2C_ID1:
> ++		tps65910 = &tps65910_modules[1];
> ++		tps65910->address = TPS65910_I2C_ID1;
> ++		break;
> ++	default:
> ++		printk(KERN_ERR "Invalid Slave address for TPS65910\n");
> ++		return -ENODEV;
> ++	}
> ++	mutex_lock(&tps65910->xfer_lock);
> ++	/* [MSG1] fill the register address data */
> ++	msg = &tps65910->xfer_msg[0];
> ++	msg->addr = tps65910->address;
> ++	msg->len = 1;
> ++	msg->flags = 0;
> ++	val = reg;
> ++	msg->buf = &val;
> ++	/* [MSG2] fill the data rx buffer */
> ++	msg = &tps65910->xfer_msg[1];
> ++	msg->addr = tps65910->address;
> ++	msg->flags = I2C_M_RD;  /* Read the register value */
> ++	msg->len = num_bytes;   /* only n bytes */
> ++	msg->buf = value;
> ++
> ++	ret = i2c_transfer(tps65910->client->adapter, tps65910->xfer_msg, 2);
> ++	mutex_unlock(&tps65910->xfer_lock);
> ++
> ++	/* i2c_transfer returns number of messages transferred */
> ++	if (ret != 2) {
> ++		pr_err("%s: i2c_read failed to transfer all messages\n",
> ++				"TPS65910C");
> ++		return -EIO;
> ++	} else {
> ++		return 0;
> ++	}
> ++}
> ++EXPORT_SYMBOL(tps65910_i2c_read);
> ++
> ++
> ++int tps65910_i2c_write(u8 slave_addr, u8 *value, u8 reg, unsigned num_bytes)
> ++{
> ++	int ret;
> ++	struct tps65910_client *tps65910;
> ++	struct i2c_msg *msg;
> ++	u8 write_buf[66]; /* Max 65 Regs + offset*/
> ++
> ++	switch (slave_addr) {
> ++	case TPS65910_I2C_ID0:
> ++		tps65910 = &tps65910_modules[0];
> ++		tps65910->address = TPS65910_I2C_ID0;
> ++		break;
> ++	case TPS65910_I2C_ID1:
> ++		tps65910 = &tps65910_modules[1];
> ++		tps65910->address = TPS65910_I2C_ID1;
> ++		break;
> ++	default:
> ++		printk(KERN_ERR "Invalid Slave address for TPS65910\n");
> ++		return -ENODEV;
> ++	}
> ++
> ++	mutex_lock(&tps65910->xfer_lock);
> ++	/* [MSG1]: fill the register address data fill the data Tx buffer */
> ++	msg = &tps65910->xfer_msg[0];
> ++	msg->addr = tps65910->address;
> ++	msg->len = num_bytes + 1;
> ++	msg->flags = 0;
> ++	write_buf[0] = reg;
> ++	memcpy(&write_buf[1], value, num_bytes);
> ++	msg->buf = &write_buf[0];
> ++	ret = i2c_transfer(tps65910->client->adapter, tps65910->xfer_msg, 1);
> ++	mutex_unlock(&tps65910->xfer_lock);
> ++
> ++	/* i2c_transfer returns number of messages transferred */
> ++	if (ret != 1) {
> ++		pr_err("%s: i2c_write failed to transfer all messages\n",
> ++				__func__);
> ++		return -EIO;
> ++	} else {
> ++		return 0;
> ++	}
> ++}
> ++EXPORT_SYMBOL(tps65910_i2c_write);
> ++
> ++int tps65910_i2c_read_u8(u8 mod_no, u8 *value, u8 reg)
> ++{
> ++	struct tps65910_client *tps65910;
> ++
> ++	switch (mod_no) {
> ++	case TPS65910_I2C_ID0:
> ++		tps65910 = &tps65910_modules[0];
> ++		tps65910->address = TPS65910_I2C_ID0;
> ++		break;
> ++	case TPS65910_I2C_ID1:
> ++		tps65910 = &tps65910_modules[1];
> ++		tps65910->address = TPS65910_I2C_ID1;
> ++		break;
> ++	default:
> ++		printk(KERN_ERR "Invalid Slave address for TPS65910\n");
> ++		return -ENODEV;
> ++	}
> ++
> ++	(*value) = i2c_smbus_read_byte_data(tps65910->client, reg);
> ++	mdelay(10);
> ++	if (*value < 0)
> ++		return -EIO;
> ++	else
> ++		return 0;
> ++}
> ++EXPORT_SYMBOL(tps65910_i2c_read_u8);
> ++
> ++int tps65910_i2c_write_u8(u8 slave_addr, u8 value, u8 reg)
> ++{
> ++	int 			ret;
> ++	struct tps65910_client *tps65910;
> ++
> ++	switch (slave_addr) {
> ++	case TPS65910_I2C_ID0:
> ++		tps65910 = &tps65910_modules[0];
> ++		tps65910->address = TPS65910_I2C_ID0;
> ++		break;
> ++	case TPS65910_I2C_ID1:
> ++		tps65910 = &tps65910_modules[1];
> ++		tps65910->address = TPS65910_I2C_ID1;
> ++		break;
> ++	default:
> ++		printk(KERN_ERR "Invalid Slave address for TPS65910\n");
> ++		return -ENODEV;
> ++	}
> ++	ret = i2c_smbus_write_byte_data(tps65910->client, reg, value);
> ++	if (ret < 0)
> ++		return -EIO;
> ++	else
> ++		return 0;
> ++}
> ++EXPORT_SYMBOL(tps65910_i2c_write_u8);
> ++
> ++
> ++int tps65910_enable_irq(int irq)
> ++{
> ++	u8  mask = 0x00;
> ++
> ++	if (irq > 7) {
> ++		irq -= 8;
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0,
> ++				&mask, TPS65910_REG_INT_MSK2);
> ++		mask &= ~(1 << irq);
> ++		return tps65910_i2c_write_u8(TPS65910_I2C_ID0,
> ++				mask, TPS65910_REG_INT_MSK2);
> ++	} else {
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0,
> ++				&mask, TPS65910_REG_INT_MSK);
> ++		mask &= ~(1 << irq);
> ++		return tps65910_i2c_write_u8(TPS65910_I2C_ID0,
> ++				mask, TPS65910_REG_INT_MSK);
> ++	}
> ++}
> ++EXPORT_SYMBOL(tps65910_enable_irq);
> ++
> ++int tps65910_disable_irq(int irq)
> ++{
> ++	u8  mask = 0x00;
> ++
> ++	if (irq > 7) {
> ++		irq -= 8;
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0,
> ++				&mask, TPS65910_REG_INT_MSK2);
> ++		mask |= (1 << irq);
> ++		return tps65910_i2c_write_u8(TPS65910_I2C_ID0,
> ++				mask, TPS65910_REG_INT_MSK2);
> ++	} else {
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0,
> ++				&mask, TPS65910_REG_INT_MSK);
> ++		mask = (1 << irq);
> ++		return tps65910_i2c_write_u8(TPS65910_I2C_ID0,
> ++				mask, TPS65910_REG_INT_MSK);
> ++	}
> ++}
> ++EXPORT_SYMBOL(tps65910_disable_irq);
> ++
> ++int tps65910_add_irq_work(int irq,
> ++		void (*handler)(void *data))
> ++{
> ++	int ret = 0;
> ++	the_tps65910->handlers[irq] = handler;
> ++	ret = tps65910_enable_irq(irq);
> ++
> ++	return ret;
> ++}
> ++EXPORT_SYMBOL(tps65910_add_irq_work);
> ++
> ++int tps65910_remove_irq_work(int irq)
> ++{
> ++	int ret = 0;
> ++	ret = tps65910_disable_irq(irq);
> ++	the_tps65910->handlers[irq] = NULL;
> ++	return ret;
> ++}
> ++EXPORT_SYMBOL(tps65910_remove_irq_work);
> ++
> ++static void tps65910_core_work(struct work_struct *work)
> ++{
> ++	/* Read the status register and take action  */
> ++	u8	status = 0x00;
> ++	u8	status2 = 0x00;
> ++	u8 	mask = 0x00;
> ++	u8 	mask2 = 0x00;
> ++	u16 	isr = 0x00;
> ++	u16 	irq = 0;
> ++	void	(*handler)(void *data) = NULL;
> ++
> ++	mutex_lock(&work_lock);
> ++	while (1) {
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0, &status2,
> ++				TPS65910_REG_INT_STS2);
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0, &mask2,
> ++				TPS65910_REG_INT_MSK2);
> ++		status2 &= (~mask2);
> ++		isr = (status2 << 8);
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0, &status,
> ++				TPS65910_REG_INT_STS);
> ++		tps65910_i2c_read_u8(TPS65910_I2C_ID0, &mask,
> ++				TPS65910_REG_INT_MSK);
> ++		status &= ~(mask);
> ++		isr |= status;
> ++		if (!isr)
> ++			break;
> ++
> ++		while (isr) {
> ++			irq = fls(isr) - 1;
> ++			isr &= ~(1 << irq);
> ++			handler = the_tps65910->handlers[irq];
> ++			if (handler)
> ++				handler(the_tps65910);
> ++		}
> ++	}
> ++	enable_irq(the_tps65910->irq_num);
> ++	mutex_unlock(&work_lock);
> ++}
> ++
> ++
> ++static irqreturn_t tps65910_isr(int irq,  void *data)
> ++{
> ++
> ++#ifdef CONFIG_LOCKDEP
> ++	/* WORKAROUND for lockdep forcing IRQF_DISABLED on us, which
> ++	 * we don't want and can't tolerate.  Although it might be
> ++	 * friendlier not to borrow this thread context...
> ++	 */
> ++	local_irq_enable();
> ++#endif
> ++	disable_irq_nosync(irq);
> ++	(void) schedule_work(&core_work);
> ++	return IRQ_HANDLED;
> ++}
> ++
> ++
> ++static struct device *add_numbered_child(unsigned chip, const char *name,
> ++	int num, void *pdata, unsigned pdata_len, bool can_wakeup, int irq)
> ++{
> ++
> ++	struct platform_device  *pdev;
> ++	struct tps65910_client  *tps65910 = &tps65910_modules[chip];
> ++	int  status;
> ++
> ++	pdev = platform_device_alloc(name, num);
> ++	if (!pdev) {
> ++		dev_dbg(&tps65910->client->dev, "can't alloc dev\n");
> ++		status = -ENOMEM;
> ++		goto err;
> ++	}
> ++	device_init_wakeup(&pdev->dev, can_wakeup);
> ++	pdev->dev.parent = &tps65910->client->dev;
> ++
> ++	if (pdata) {
> ++		status = platform_device_add_data(pdev, pdata, pdata_len);
> ++		if (status < 0) {
> ++			dev_dbg(&pdev->dev, "can't add platform_data\n");
> ++			goto err;
> ++		}
> ++	}
> ++	status = platform_device_add(pdev);
> ++
> ++err:
> ++	if (status < 0) {
> ++		platform_device_put(pdev);
> ++		dev_err(&tps65910->client->dev, "can't add %s dev\n", name);
> ++		return ERR_PTR(status);
> ++	}
> ++	return &pdev->dev;
> ++
> ++}
> ++
> ++static inline struct device *add_child(unsigned chip, const char *name,
> ++		void *pdata, unsigned pdata_len,
> ++		bool can_wakeup, int irq)
> ++{
> ++	return add_numbered_child(chip, name, -1, pdata, pdata_len,
> ++			can_wakeup, irq);
> ++}
> ++	static
> ++struct device *add_regulator_linked(int num, struct regulator_init_data *pdata,
> ++		struct regulator_consumer_supply *consumers,
> ++		unsigned num_consumers)
> ++{
> ++	/* regulator framework demands init_data */
> ++	if (!pdata)
> ++		return NULL;
> ++
> ++	if (consumers) {
> ++		pdata->consumer_supplies = consumers;
> ++		pdata->num_consumer_supplies = num_consumers;
> ++	}
> ++	return add_numbered_child(TPS65910_GENERAL, "tps65910_regulator", num,
> ++			pdata, sizeof(*pdata), false, TPS65910_HOST_IRQ);
> ++}
> ++
> ++	static struct device *
> ++add_regulator(int num, struct regulator_init_data *pdata)
> ++{
> ++	return add_regulator_linked(num, pdata, NULL, 0);
> ++}
> ++
> ++	static int
> ++add_children(struct tps65910_platform_data *pdata, unsigned long features)
> ++{
> ++	int 		status;
> ++	struct device   *child;
> ++
> ++	struct platform_device  *pdev = NULL;
> ++
> ++	if (tps65910_has_gpio() && (pdata->gpio != NULL)) {
> ++
> ++		pdev = platform_device_alloc("tps65910_gpio", -1);
> ++		if (!pdev) {
> ++			status = -ENOMEM;
> ++			goto err;
> ++		}
> ++		pdev->dev.parent = &tps65910_modules[0].client->dev;
> ++		device_init_wakeup(&pdev->dev, 0);
> ++		if (pdata) {
> ++			status = platform_device_add_data(pdev, pdata,
> ++							sizeof(*pdata));
> ++			if (status < 0) {
> ++				dev_dbg(&pdev->dev,
> ++				"can't add platform_data\n");
> ++				goto err;
> ++			}
> ++		}
> ++	}
> ++	if (tps65910_has_rtc()) {
> ++		child = add_child(TPS65910_GENERAL, "tps65910_rtc",
> ++				NULL, 0, true, pdata->irq_num);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++	}
> ++
> ++	if (tps65910_has_regulator()) {
> ++
> ++		child = add_regulator(TPS65910_VIO, pdata->vio);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDD1, pdata->vdd1);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDD2, pdata->vdd2);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDD3, pdata->vdd3);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDIG1, pdata->vdig1);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDIG2, pdata->vdig2);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VAUX33, pdata->vaux33);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VMMC, pdata->vmmc);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VAUX1, pdata->vaux1);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VAUX2, pdata->vaux2);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VDAC, pdata->vdac);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++
> ++		child = add_regulator(TPS65910_VPLL, pdata->vpll);
> ++		if (IS_ERR(child))
> ++			return PTR_ERR(child);
> ++	}
> ++	return 0;
> ++
> ++err:
> ++	return -1;
> ++
> ++}
> ++
> ++static int tps65910_remove(struct i2c_client *client)
> ++{
> ++	unsigned i;
> ++
> ++	for (i = 0; i < TPS65910_NUM_SLAVES; i++) {
> ++
> ++		struct tps65910_client *tps65910 = &tps65910_modules[i];
> ++
> ++		if (tps65910->client && tps65910->client != client)
> ++			i2c_unregister_device(tps65910->client);
> ++
> ++		tps65910_modules[i].client = NULL;
> ++	}
> ++	inuse = false;
> ++	return 0;
> ++}
> ++
> ++static int __init
> ++tps65910_i2c_probe(struct i2c_client *client, const struct i2c_device_id *id)
> ++{
> ++	int	 status;
> ++	unsigned i;
> ++	struct 	 tps65910_platform_data	*pdata;
> ++
> ++	pdata = client->dev.platform_data;
> ++	the_tps65910 = pdata;
> ++
> ++	if (!pdata) {
> ++		dev_dbg(&client->dev, "no platform data?\n");
> ++		return -EINVAL;
> ++	}
> ++
> ++	if (i2c_check_functionality(client->adapter,
> ++				(I2C_FUNC_I2C | I2C_FUNC_SMBUS_BYTE)) == 0) {
> ++		dev_dbg(&client->dev, "can't talk I2C?\n");
> ++		return -EIO;
> ++	}
> ++
> ++	if (inuse) {
> ++		dev_dbg(&client->dev, "driver is already in use\n");
> ++		return -EBUSY;
> ++	}
> ++
> ++	for (i = 0; i < TPS65910_NUM_SLAVES; i++) {
> ++
> ++		struct tps65910_client  *tps65910 = &tps65910_modules[i];
> ++
> ++		tps65910->address = client->addr + i;
> ++
> ++		if (i == 0)
> ++			tps65910->client = client;
> ++		else {
> ++			tps65910->client = i2c_new_dummy(client->adapter,
> ++					tps65910->address);
> ++
> ++			if (!tps65910->client) {
> ++				dev_err(&client->dev,
> ++						"can't attach client %d\n", i);
> ++				status = -ENOMEM;
> ++				goto fail;
> ++			}
> ++		}
> ++		mutex_init(&tps65910->xfer_lock);
> ++	}
> ++
> ++	inuse = true;
> ++
> ++	if (pdata->board_tps65910_config != NULL)
> ++		pdata->board_tps65910_config(pdata);
> ++
> ++
> ++	if (pdata->irq_num) {
> ++		/* TPS65910 power ON interrupt(s) would have already been
> ++		 * occurred, so immediately after request_irq the control will
> ++		 * be transferred to tps65910_isr, if we do core_work
> ++		 * initialization after requesting IRQ, the system crashes
> ++		 * and does not boot; to avoid this we do core_work
> ++		 * initialization before requesting IRQ
> ++		 */
> ++		mutex_init(&work_lock);
> ++		INIT_WORK(&core_work, tps65910_core_work);
> ++
> ++		status = request_irq(pdata->irq_num, tps65910_isr,
> ++					IRQF_DISABLED, "tps65910", pdata);
> ++		if (status < 0) {
> ++			pr_err("tps65910: could not claim irq%d: %d\n",
> ++					pdata->irq_num,	status);
> ++			goto fail;
> ++		}
> ++	}
> ++
> ++	status = add_children(pdata, 0x00);
> ++	if (status < 0)
> ++		goto fail;
> ++
> ++	return 0;
> ++
> ++fail:
> ++	if (status < 0)
> ++		tps65910_remove(client);
> ++
> ++	return status;
> ++}
> ++
> ++
> ++static int tps65910_i2c_remove(struct i2c_client *client)
> ++{
> ++	unsigned i;
> ++
> ++	for (i = 0; i < TPS65910_NUM_SLAVES; i++) {
> ++
> ++		struct tps65910_client	*tps65910 = &tps65910_modules[i];
> ++
> ++		if (tps65910->client && tps65910->client != client)
> ++			i2c_unregister_device(tps65910->client);
> ++
> ++		tps65910_modules[i].client = NULL;
> ++	}
> ++	inuse = false;
> ++	return 0;
> ++}
> ++
> ++/* chip-specific feature flags, for i2c_device_id.driver_data */
> ++static const struct i2c_device_id tps65910_i2c_ids[] = {
> ++	{ "tps65910", TPS65910 },
> ++	{ "tps659101", TPS659101 },
> ++	{ "tps659102", TPS659102 },
> ++	{ "tps659103", TPS659103 },
> ++	{ "tps659104", TPS659104 },
> ++	{ "tps659105", TPS659105 },
> ++	{ "tps659106", TPS659106 },
> ++	{ "tps659107", TPS659107 },
> ++	{ "tps659108", TPS659108 },
> ++	{ "tps659109", TPS659109 },
> ++	{/* end of list */ },
> ++};
> ++MODULE_DEVICE_TABLE(i2c, tps65910_i2c_ids);
> ++
> ++/* One Client Driver ,3 Clients - Regulator, RTC , GPIO */
> ++static struct i2c_driver tps65910_i2c_driver = {
> ++	.driver.name    = DRIVER_NAME,
> ++	.id_table       = tps65910_i2c_ids,
> ++	.probe          = tps65910_i2c_probe,
> ++	.remove         = tps65910_i2c_remove,
> ++};
> ++
> ++static int __init tps65910_init(void)
> ++{
> ++	int res;
> ++
> ++	res = i2c_add_driver(&tps65910_i2c_driver);
> ++	if (res < 0) {
> ++		pr_err(DRIVER_NAME ": driver registration failed\n");
> ++		return res;
> ++	}
> ++
> ++	return 0;
> ++}
> ++subsys_initcall(tps65910_init);
> ++
> ++static void __exit tps65910_exit(void)
> ++{
> ++	i2c_del_driver(&tps65910_i2c_driver);
> ++}
> ++module_exit(tps65910_exit);
> ++
> ++MODULE_AUTHOR("Mistral Solutions Pvt Ltd");
> ++MODULE_DESCRIPTION("I2C Core interface for TPS65910");
> ++MODULE_LICENSE("GPL");
> +diff --git a/drivers/rtc/Kconfig b/drivers/rtc/Kconfig
> +index 71fbd6e..0ddf4c2 100644
> +--- a/drivers/rtc/Kconfig
> ++++ b/drivers/rtc/Kconfig
> +@@ -267,6 +267,14 @@ config RTC_DRV_TWL4030
> + 	  This driver can also be built as a module. If so, the module
> + 	  will be called rtc-twl.
> +
> ++config RTC_DRV_TPS65910
> ++	boolean "TI TPS65910"
> ++	depends on RTC_CLASS && TPS65910_CORE
> ++	help
> ++	  If you say yes here you get support for the RTC on the
> ++	  TPS65910 family chips, used mostly with OMAP3/AM35xx platforms.
> ++
> ++
> + config RTC_DRV_S35390A
> + 	tristate "Seiko Instruments S-35390A"
> + 	select BITREVERSE
> +diff --git a/drivers/rtc/Makefile b/drivers/rtc/Makefile
> +index 7da6efb..8fcfe49 100644
> +--- a/drivers/rtc/Makefile
> ++++ b/drivers/rtc/Makefile
> +@@ -81,6 +81,7 @@ obj-$(CONFIG_RTC_DRV_STMP)	+= rtc-stmp3xxx.o
> + obj-$(CONFIG_RTC_DRV_SUN4V)	+= rtc-sun4v.o
> + obj-$(CONFIG_RTC_DRV_TEST)	+= rtc-test.o
> + obj-$(CONFIG_RTC_DRV_TWL4030)	+= rtc-twl.o
> ++obj-$(CONFIG_RTC_DRV_TPS65910)	+= rtc-tps65910.o
> + obj-$(CONFIG_RTC_DRV_TX4939)	+= rtc-tx4939.o
> + obj-$(CONFIG_RTC_DRV_V3020)	+= rtc-v3020.o
> + obj-$(CONFIG_RTC_DRV_VR41XX)	+= rtc-vr41xx.o
> +diff --git a/drivers/rtc/rtc-tps65910.c b/drivers/rtc/rtc-tps65910.c
> +new file mode 100644
> +index 0000000..7e7ed4b
> +--- /dev/null
> ++++ b/drivers/rtc/rtc-tps65910.c
> +@@ -0,0 +1,657 @@
> ++/*
> ++ * rtc-tps65910.c -- TPS65910 Real Time Clock interface
> ++ *
> ++ * Copyright (C) 2010 Mistral Solutions Pvt Ltd. <www.mistralsolutions.com>
> ++ * Author: Umesh K <umeshk at mistralsolutions.com>
> ++ *
> ++ * Based on rtc-twl.c
> ++ *
> ++ * 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.
> ++ */
> ++
> ++#include <linux/kernel.h>
> ++#include <linux/errno.h>
> ++#include <linux/init.h>
> ++#include <linux/module.h>
> ++#include <linux/types.h>
> ++#include <linux/rtc.h>
> ++#include <linux/bcd.h>
> ++#include <linux/platform_device.h>
> ++#include <linux/interrupt.h>
> ++#include <linux/i2c/tps65910.h>
> ++#include <linux/gpio.h>
> ++#include <linux/delay.h>
> ++
> ++/* RTC Definitions */
> ++/* RTC_CTRL_REG bitfields */
> ++#define BIT_RTC_CTRL_REG_STOP_RTC_M		0x01
> ++#define BIT_RTC_CTRL_REG_ROUND_30S_M		0x02
> ++#define BIT_RTC_CTRL_REG_AUTO_COMP_M		0x04
> ++#define BIT_RTC_CTRL_REG_MODE_12_24_M		0x08
> ++#define BIT_RTC_CTRL_REG_TEST_MODE_M		0x10
> ++#define BIT_RTC_CTRL_REG_SET_32_COUNTER_M	0x20
> ++#define BIT_RTC_CTRL_REG_GET_TIME_M		0x40
> ++#define BIT_RTC_CTRL_REG_RTC_V_OPT_M		0x80
> ++
> ++/* RTC_STATUS_REG bitfields */
> ++#define BIT_RTC_STATUS_REG_RUN_M		0x02
> ++#define BIT_RTC_STATUS_REG_1S_EVENT_M		0x04
> ++#define BIT_RTC_STATUS_REG_1M_EVENT_M		0x08
> ++#define BIT_RTC_STATUS_REG_1H_EVENT_M		0x10
> ++#define BIT_RTC_STATUS_REG_1D_EVENT_M		0x20
> ++#define BIT_RTC_STATUS_REG_ALARM_M		0x40
> ++#define BIT_RTC_STATUS_REG_POWER_UP_M		0x80
> ++
> ++/* RTC_INTERRUPTS_REG bitfields */
> ++#define BIT_RTC_INTERRUPTS_REG_EVERY_M		0x03
> ++#define BIT_RTC_INTERRUPTS_REG_IT_TIMER_M	0x04
> ++#define BIT_RTC_INTERRUPTS_REG_IT_ALARM_M	0x08
> ++
> ++/* DEVCTRL bitfields */
> ++#define BIT_RTC_PWDN				0x40
> ++
> ++/* REG_SECONDS_REG through REG_YEARS_REG is how many registers? */
> ++#define ALL_TIME_REGS				6
> ++
> ++/*
> ++ * Supports 1 byte read from TPS65910 RTC register.
> ++ */
> ++static int tps65910_rtc_read_u8(u8 *data, u8 reg)
> ++{
> ++	int ret;
> ++
> ++	ret = tps65910_i2c_read_u8(TPS65910_I2C_ID0, data, reg);
> ++
> ++	if (ret < 0)
> ++		pr_err("tps65910_rtc: Could not read TPS65910"
> ++				"register %X - error %d\n", reg, ret);
> ++	return ret;
> ++}
> ++
> ++/*
> ++ * Supports 1 byte write to TPS65910 RTC registers.
> ++ */
> ++static int tps65910_rtc_write_u8(u8 data, u8 reg)
> ++{
> ++	int ret;
> ++
> ++	ret = tps65910_i2c_write_u8(TPS65910_I2C_ID0, data, reg);
> ++	if (ret < 0)
> ++		pr_err("tps65910_rtc: Could not write TPS65910"
> ++				"register %X - error %d\n", reg, ret);
> ++	return ret;
> ++}
> ++
> ++/*
> ++ * Cache the value for timer/alarm interrupts register; this is
> ++ * only changed by callers holding rtc ops lock (or resume).
> ++ */
> ++static unsigned char rtc_irq_bits;
> ++
> ++/*
> ++ * Enable 1/second update and/or alarm interrupts.
> ++ */
> ++static int set_rtc_irq_bit(unsigned char bit)
> ++{
> ++	unsigned char val;
> ++	int ret;
> ++
> ++	val = rtc_irq_bits | bit;
> ++	val |= bit;
> ++	ret = tps65910_rtc_write_u8(val, TPS65910_REG_RTC_INTERRUPTS);
> ++	if (ret == 0)
> ++		rtc_irq_bits = val;
> ++
> ++	return ret;
> ++}
> ++
> ++/*
> ++ * Disable update and/or alarm interrupts.
> ++ */
> ++static int mask_rtc_irq_bit(unsigned char bit)
> ++{
> ++	unsigned char val;
> ++	int ret;
> ++
> ++	val = rtc_irq_bits & ~bit;
> ++	ret = tps65910_rtc_write_u8(val, TPS65910_REG_RTC_INTERRUPTS);
> ++	if (ret == 0)
> ++		rtc_irq_bits = val;
> ++
> ++	return ret;
> ++}
> ++
> ++static int tps65910_rtc_alarm_irq_enable(struct device *dev, unsigned enabled)
> ++{
> ++	int ret;
> ++
> ++	if (enabled)
> ++		ret = set_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_ALARM_M);
> ++	else
> ++		ret = mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_ALARM_M);
> ++
> ++	return ret;
> ++}
> ++
> ++static int tps65910_rtc_update_irq_enable(struct device *dev, unsigned enabled)
> ++{
> ++	int ret;
> ++
> ++	if (enabled)
> ++		ret = set_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_TIMER_M);
> ++	else
> ++		ret = mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_TIMER_M);
> ++
> ++	return ret;
> ++}
> ++
> ++#if 1 /* Debugging periodic interrupts */
> ++/*
> ++ * We will just handle setting the frequency and make use the framework for
> ++ * reading the periodic interupts.
> ++ *
> ++ * @freq: Current periodic IRQ freq:
> ++ * bit 0: every second
> ++ * bit 1: every minute
> ++ * bit 2: every hour
> ++ * bit 3: every day
> ++ */
> ++
> ++static int tps65910_rtc_irq_set_freq(struct device *dev, int freq)
> ++{
> ++	struct rtc_device *rtc = dev_get_drvdata(dev);
> ++
> ++	if (freq < 0 || freq > 3)
> ++		return -EINVAL;
> ++
> ++	rtc->irq_freq = freq;
> ++	/* set rtc irq freq to user defined value */
> ++	set_rtc_irq_bit(freq);
> ++
> ++	return 0;
> ++}
> ++#endif
> ++
> ++/*
> ++ * Gets current TPS65910 RTC time and date parameters.
> ++ *
> ++ * The RTC's time/alarm representation is not what gmtime(3) requires
> ++ * Linux to use:
> ++ *
> ++ *  - Months are 1..12 vs Linux 0-11
> ++ *  - Years are 0..99 vs Linux 1900..N (we assume 21st century)
> ++ */
> ++static int tps65910_rtc_read_time(struct device *dev, struct rtc_time *tm)
> ++{
> ++	unsigned char rtc_data[ALL_TIME_REGS + 1];
> ++	int ret;
> ++	u8 save_control;
> ++
> ++	tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++	ret = tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++	if (ret < 0)
> ++		return ret;
> ++
> ++	save_control &= ~BIT_RTC_CTRL_REG_RTC_V_OPT_M;
> ++
> ++	ret = tps65910_rtc_write_u8(save_control, TPS65910_REG_RTC_CTRL);
> ++	if (ret < 0)
> ++		return ret;
> ++
> ++	ret = tps65910_rtc_read_u8(&rtc_data[0], TPS65910_REG_SECONDS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[1], TPS65910_REG_MINUTES);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[2], TPS65910_REG_HOURS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[3], TPS65910_REG_DAYS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[4], TPS65910_REG_MONTHS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[5], TPS65910_REG_YEARS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++
> ++	tm->tm_sec = bcd2bin(rtc_data[0]);
> ++	tm->tm_min = bcd2bin(rtc_data[1]);
> ++	tm->tm_hour = bcd2bin(rtc_data[2]);
> ++	tm->tm_mday = bcd2bin(rtc_data[3]);
> ++	tm->tm_mon = bcd2bin(rtc_data[4]) - 1;
> ++	tm->tm_year = bcd2bin(rtc_data[5]) + 100;
> ++
> ++	return ret;
> ++}
> ++
> ++static int tps65910_rtc_set_time(struct device *dev, struct rtc_time *tm)
> ++{
> ++	unsigned char save_control;
> ++	unsigned char rtc_data[ALL_TIME_REGS + 1];
> ++	int ret;
> ++
> ++	rtc_data[1] = bin2bcd(tm->tm_sec);
> ++	rtc_data[2] = bin2bcd(tm->tm_min);
> ++	rtc_data[3] = bin2bcd(tm->tm_hour);
> ++	rtc_data[4] = bin2bcd(tm->tm_mday);
> ++	rtc_data[5] = bin2bcd(tm->tm_mon + 1);
> ++	rtc_data[6] = bin2bcd(tm->tm_year - 100);
> ++
> ++	/*Dummy read*/
> ++	ret = tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++
> ++	/* Stop RTC while updating the TC registers */
> ++	ret = tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++	if (ret < 0)
> ++		goto out;
> ++
> ++	save_control &= ~BIT_RTC_CTRL_REG_STOP_RTC_M;
> ++
> ++	tps65910_rtc_write_u8(save_control, TPS65910_REG_RTC_CTRL);
> ++
> ++	/* update all the time registers in one shot */
> ++	ret = tps65910_rtc_write_u8(rtc_data[1], TPS65910_REG_SECONDS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(rtc_data[2], TPS65910_REG_MINUTES);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(rtc_data[3], TPS65910_REG_HOURS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(rtc_data[4], TPS65910_REG_DAYS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(rtc_data[5], TPS65910_REG_MONTHS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(rtc_data[6], TPS65910_REG_YEARS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++
> ++	/*Dummy read*/
> ++	ret = tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++
> ++	ret = tps65910_rtc_read_u8(&save_control, TPS65910_REG_RTC_CTRL);
> ++	if (ret < 0)
> ++		goto out;
> ++	/* Start back RTC */
> ++	save_control |= BIT_RTC_CTRL_REG_STOP_RTC_M;
> ++	ret = tps65910_rtc_write_u8(save_control, TPS65910_REG_RTC_CTRL);
> ++
> ++out:
> ++	return ret;
> ++}
> ++
> ++/*
> ++ * Gets current TPS65910 RTC alarm time.
> ++ */
> ++static int tps65910_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alm)
> ++{
> ++	unsigned char rtc_data[ALL_TIME_REGS + 1];
> ++	int ret;
> ++
> ++	ret = tps65910_rtc_read_u8(&rtc_data[0], TPS65910_REG_ALARM_SECONDS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[1], TPS65910_REG_ALARM_MINUTES);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[2], TPS65910_REG_ALARM_HOURS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[3], TPS65910_REG_ALARM_DAYS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[4], TPS65910_REG_ALARM_MONTHS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_read_u8(&rtc_data[5], TPS65910_REG_ALARM_YEARS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_read_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++
> ++	/* some of these fields may be wildcard/"match all" */
> ++	alm->time.tm_sec = bcd2bin(rtc_data[0]);
> ++	alm->time.tm_min = bcd2bin(rtc_data[1]);
> ++	alm->time.tm_hour = bcd2bin(rtc_data[2]);
> ++	alm->time.tm_mday = bcd2bin(rtc_data[3]);
> ++	alm->time.tm_mon = bcd2bin(rtc_data[4]) - 1;
> ++	alm->time.tm_year = bcd2bin(rtc_data[5]) + 100;
> ++
> ++	/* report cached alarm enable state */
> ++	if (rtc_irq_bits & BIT_RTC_INTERRUPTS_REG_IT_ALARM_M)
> ++		alm->enabled = 1;
> ++
> ++	return ret;
> ++}
> ++
> ++static int tps65910_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alm)
> ++{
> ++	unsigned char alarm_data[ALL_TIME_REGS + 1];
> ++	int ret;
> ++
> ++	ret = tps65910_rtc_alarm_irq_enable(dev, 0);
> ++	if (ret)
> ++		goto out;
> ++
> ++	alarm_data[1] = bin2bcd(alm->time.tm_sec);
> ++	alarm_data[2] = bin2bcd(alm->time.tm_min);
> ++	alarm_data[3] = bin2bcd(alm->time.tm_hour);
> ++	alarm_data[4] = bin2bcd(alm->time.tm_mday);
> ++	alarm_data[5] = bin2bcd(alm->time.tm_mon + 1);
> ++	alarm_data[6] = bin2bcd(alm->time.tm_year - 100);
> ++
> ++	/* update all the alarm registers in one shot */
> ++	ret = tps65910_rtc_write_u8(alarm_data[1], TPS65910_REG_ALARM_SECONDS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(alarm_data[2], TPS65910_REG_ALARM_MINUTES);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(alarm_data[3], TPS65910_REG_ALARM_HOURS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(alarm_data[4], TPS65910_REG_ALARM_DAYS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(alarm_data[5], TPS65910_REG_ALARM_MONTHS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++	ret = tps65910_rtc_write_u8(alarm_data[6], TPS65910_REG_ALARM_YEARS);
> ++	if (ret < 0) {
> ++		dev_err(dev, "rtc_write_time error %d\n", ret);
> ++		return ret;
> ++	}
> ++
> ++	if (alm->enabled)
> ++		ret = tps65910_rtc_alarm_irq_enable(dev, 1);
> ++out:
> ++	return ret;
> ++}
> ++
> ++
> ++struct work_struct rtc_wq;
> ++unsigned long rtc_events;
> ++struct rtc_device *global_rtc;
> ++
> ++void  rtc_work(void  *data)
> ++{
> ++
> ++	int res;
> ++	u8 rd_reg;
> ++	unsigned long events = 0;
> ++
> ++	res = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_INT_STS);
> ++
> ++	if (res < 0)
> ++		goto out;
> ++	/*
> ++	 * Figure out source of interrupt: ALARM or TIMER in RTC_STATUS_REG.
> ++	 * only one (ALARM or RTC) interrupt source may be enabled
> ++	 * at time, we also could check our results
> ++	 * by reading RTS_INTERRUPTS_REGISTER[IT_TIMER,IT_ALARM]
> ++	 */
> ++	if (rd_reg & TPS65910_RTC_ALARM_IT) {
> ++		res = tps65910_rtc_write_u8(rd_reg | TPS65910_RTC_ALARM_IT,
> ++				TPS65910_REG_INT_STS);
> ++		if (res < 0)
> ++			goto out;
> ++
> ++		/*Dummy read -- mandatory for status register*/
> ++		res = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++		mdelay(100);
> ++		res = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++		res = tps65910_rtc_write_u8(rd_reg, TPS65910_REG_RTC_STATUS);
> ++
> ++		rtc_events |= RTC_IRQF | RTC_AF;
> ++	} else if (rd_reg & TPS65910_RTC_PERIOD_IT) {
> ++		res = tps65910_rtc_write_u8(rd_reg | TPS65910_RTC_PERIOD_IT,
> ++				TPS65910_REG_INT_STS);
> ++		if (res < 0)
> ++			goto out;
> ++
> ++		/*Dummy read -- mandatory for status register*/
> ++		res = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++		mdelay(100);
> ++		res = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++		rd_reg &= 0xC3;
> ++		res = tps65910_rtc_write_u8(rd_reg, TPS65910_REG_RTC_STATUS);
> ++		rtc_events |= RTC_IRQF | RTC_UF;
> ++	}
> ++out:
> ++	/* Notify RTC core on event */
> ++	events = rtc_events;
> ++	rtc_update_irq(global_rtc, 1, events);
> ++}
> ++
> ++static struct rtc_class_ops tps65910_rtc_ops = {
> ++	.read_time	= tps65910_rtc_read_time,
> ++	.set_time	= tps65910_rtc_set_time,
> ++	.read_alarm	= tps65910_rtc_read_alarm,
> ++	.set_alarm	= tps65910_rtc_set_alarm,
> ++	.alarm_irq_enable = tps65910_rtc_alarm_irq_enable,
> ++	.update_irq_enable = tps65910_rtc_update_irq_enable,
> ++	.irq_set_freq	= tps65910_rtc_irq_set_freq,
> ++};
> ++
> ++static int __devinit tps65910_rtc_probe(struct platform_device *pdev)
> ++{
> ++	struct rtc_device *rtc;
> ++	int ret = 0;
> ++	u8 rd_reg;
> ++
> ++	rtc = rtc_device_register(pdev->name,
> ++			&pdev->dev, &tps65910_rtc_ops, THIS_MODULE);
> ++
> ++	if (IS_ERR(rtc)) {
> ++		ret = PTR_ERR(rtc);
> ++		dev_err(&pdev->dev, "can't register TPS65910 RTC device,\
> ++					 err %ld\n", PTR_ERR(rtc));
> ++		goto out0;
> ++
> ++	}
> ++	printk(KERN_INFO "TPS65910 RTC device successfully registered\n");
> ++
> ++	platform_set_drvdata(pdev, rtc);
> ++
> ++	/* Take rtc out of reset */
> ++	tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_DEVCTRL);
> ++	rd_reg &= ~BIT_RTC_PWDN;
> ++	ret = tps65910_rtc_write_u8(rd_reg, TPS65910_REG_DEVCTRL);
> ++
> ++	/* Dummy read to ensure that the register gets updated.
> ++	 * Please refer tps65910 TRM table:25 for details
> ++	 */
> ++	tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++
> ++	ret = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_STATUS);
> ++	if (ret < 0) {
> ++		printk(KERN_ERR "TPS65910 RTC STATUS REG READ FAILED\n");
> ++		goto out1;
> ++	}
> ++
> ++	if (rd_reg & BIT_RTC_STATUS_REG_POWER_UP_M)
> ++		dev_warn(&pdev->dev, "Power up reset detected.\n");
> ++
> ++	if (rd_reg & BIT_RTC_STATUS_REG_ALARM_M)
> ++		dev_warn(&pdev->dev, "Pending Alarm interrupt detected.\n");
> ++
> ++	/* Clear RTC Power up reset and pending alarm interrupts */
> ++	ret = tps65910_rtc_write_u8(rd_reg, TPS65910_REG_RTC_STATUS);
> ++	if (ret < 0)
> ++		goto out1;
> ++	ret = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_INT_STS);
> ++	if (ret < 0) {
> ++		printk(KERN_ERR "TPS65910 RTC STATUS REG READ FAILED\n");
> ++		goto out1;
> ++	}
> ++
> ++	if (rd_reg & 0x40) {
> ++		printk(KERN_INFO "pending alarm interrupt!!! clearing!!!");
> ++		tps65910_rtc_write_u8(rd_reg, TPS65910_REG_INT_STS);
> ++	}
> ++
> ++	global_rtc = rtc;
> ++
> ++	/* Link RTC IRQ handler to TPS65910 Core */
> ++	tps65910_add_irq_work(TPS65910_RTC_ALARM_IRQ, rtc_work);
> ++	tps65910_add_irq_work(TPS65910_RTC_PERIOD_IRQ, rtc_work);
> ++
> ++	/* Check RTC module status, Enable if it is off */
> ++	ret = tps65910_rtc_read_u8(&rd_reg, TPS65910_REG_RTC_CTRL);
> ++	if (ret < 0)
> ++		goto out1;
> ++
> ++	if (!(rd_reg & BIT_RTC_CTRL_REG_STOP_RTC_M)) {
> ++		dev_info(&pdev->dev, "Enabling TPS65910-RTC.\n");
> ++		rd_reg |= BIT_RTC_CTRL_REG_STOP_RTC_M;
> ++		ret = tps65910_rtc_write_u8(rd_reg, TPS65910_REG_RTC_CTRL);
> ++		if (ret < 0)
> ++			goto out1;
> ++	}
> ++
> ++	/* init cached IRQ enable bits */
> ++	ret = tps65910_rtc_read_u8(&rtc_irq_bits, TPS65910_REG_RTC_INTERRUPTS);
> ++	if (ret < 0)
> ++		goto out1;
> ++
> ++	tps65910_rtc_write_u8(0x3F, TPS65910_REG_INT_MSK);
> ++	return ret;
> ++
> ++out1:
> ++	rtc_device_unregister(rtc);
> ++out0:
> ++	return ret;
> ++}
> ++
> ++/*
> ++ * Disable all TPS65910 RTC module interrupts.
> ++ * Sets status flag to free.
> ++ */
> ++static int __devexit tps65910_rtc_remove(struct platform_device *pdev)
> ++{
> ++	/* leave rtc running, but disable irqs */
> ++	struct rtc_device *rtc = platform_get_drvdata(pdev);
> ++	int irq = platform_get_irq(pdev, 0);
> ++
> ++	mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_ALARM_M);
> ++	mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_TIMER_M);
> ++
> ++
> ++	free_irq(irq, rtc);
> ++
> ++	rtc_device_unregister(rtc);
> ++	platform_set_drvdata(pdev, NULL);
> ++	return 0;
> ++}
> ++
> ++static void tps65910_rtc_shutdown(struct platform_device *pdev)
> ++{
> ++	/* mask timer interrupts, but leave alarm interrupts on to enable
> ++	 * power-on when alarm is triggered
> ++	 */
> ++	mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_TIMER_M);
> ++}
> ++
> ++#ifdef CONFIG_PM
> ++
> ++static unsigned char irqstat;
> ++
> ++	static
> ++int tps65910_rtc_suspend(struct platform_device *pdev, pm_message_t state)
> ++{
> ++	irqstat = rtc_irq_bits;
> ++	mask_rtc_irq_bit(BIT_RTC_INTERRUPTS_REG_IT_TIMER_M);
> ++	return 0;
> ++}
> ++
> ++static int tps65910_rtc_resume(struct platform_device *pdev)
> ++{
> ++	set_rtc_irq_bit(irqstat);
> ++	return 0;
> ++}
> ++
> ++#else
> ++#define tps65910_rtc_suspend NULL
> ++#define tps65910_rtc_resume  NULL
> ++#endif
> ++
> ++
> ++static struct platform_driver tps65910rtc_driver = {
> ++	.probe		= tps65910_rtc_probe,
> ++	.remove		= __devexit_p(tps65910_rtc_remove),
> ++	.shutdown	= tps65910_rtc_shutdown,
> ++	.suspend	= tps65910_rtc_suspend,
> ++	.resume		= tps65910_rtc_resume,
> ++	.driver		= {
> ++		.owner	= THIS_MODULE,
> ++		.name	= "tps65910_rtc",
> ++	},
> ++};
> ++static int __init tps65910_rtc_init(void)
> ++{
> ++	return platform_driver_register(&tps65910rtc_driver);
> ++}
> ++module_init(tps65910_rtc_init);
> ++
> ++static void __exit tps65910_rtc_exit(void)
> ++{
> ++	platform_driver_unregister(&tps65910rtc_driver);
> ++}
> ++module_exit(tps65910_rtc_exit);
> ++
> ++MODULE_ALIAS("platform:tps65910_rtc");
> ++MODULE_AUTHOR("Umesh K  <umeshk at mistralsolutions.com");
> ++MODULE_LICENSE("GPL");
> +diff --git a/drivers/usb/host/ehci-hub.c b/drivers/usb/host/ehci-hub.c
> +index c80105b..1d9cf0c 100644
> +--- a/drivers/usb/host/ehci-hub.c
> ++++ b/drivers/usb/host/ehci-hub.c
> +@@ -468,7 +468,8 @@ static int check_reset_complete (
> + 			index + 1);
> +
> + 		// what happens if HCS_N_CC(params) == 0 ?
> +-#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM)
> ++#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM) && \
> ++    !defined(CONFIG_MACH_CRANEBOARD)
> + 		port_status |= PORT_OWNER;
> + #endif
> + 		port_status &= ~PORT_RWC_BITS;
> +@@ -927,7 +928,8 @@ static int ehci_hub_control (
> + 				ehci_dbg (ehci,
> + 					"port %d low speed --> companion\n",
> + 					wIndex + 1);
> +-#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM)
> ++#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM) && \
> ++    !defined(CONFIG_MACH_CRANEBOARD)
> + 				temp |= PORT_OWNER;
> + #endif
> + 			} else {
> +@@ -978,7 +980,8 @@ error_exit:
> +
> + static void ehci_relinquish_port(struct usb_hcd *hcd, int portnum)
> + {
> +-#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM)
> ++#if !defined(CONFIG_MACH_OMAP3EVM) && !defined(CONFIG_MACH_OMAP3517EVM) && \
> ++    !defined(CONFIG_MACH_CRANEBOARD)
> + 	struct ehci_hcd		*ehci = hcd_to_ehci(hcd);
> +
> + 	if (ehci_is_TDI(ehci))
> +diff --git a/drivers/usb/musb/Kconfig b/drivers/usb/musb/Kconfig
> +index dd1edfd..5ac688d 100644
> +--- a/drivers/usb/musb/Kconfig
> ++++ b/drivers/usb/musb/Kconfig
> +@@ -10,7 +10,7 @@ comment "Enable Host or Gadget support to see Inventra options"
> + config USB_MUSB_HDRC
> + 	depends on (USB || USB_GADGET)
> + 	depends on (ARM || (BF54x && !BF544) || (BF52x && !BF522 && !BF523))
> +-	select NOP_USB_XCEIV if (ARCH_DAVINCI || MACH_OMAP3EVM || BLACKFIN || MACH_OMAP3517EVM)
> ++	select NOP_USB_XCEIV if (ARCH_DAVINCI || MACH_OMAP3EVM || BLACKFIN || MACH_OMAP3517EVM || MACH_CRANEBOARD)
> + 	select TWL4030_USB if MACH_OMAP_3430SDP
> + 	select USB_OTG_UTILS
> + 	tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)'
> +@@ -152,7 +152,7 @@ config MUSB_PIO_ONLY
> +
> + config USB_INVENTRA_DMA
> + 	bool
> +-	depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY && !MACH_OMAP3517EVM
> ++	depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY && !MACH_OMAP3517EVM && !MACH_CRANEBOARD
> + 	default ARCH_OMAP2430 || ARCH_OMAP34XX || BLACKFIN
> + 	help
> + 	  Enable DMA transfers using Mentor's engine.
> +@@ -182,7 +182,7 @@ config USB_TI_CPPI_DMA
> + config USB_TI_CPPI41_DMA
> + 	bool
> + 	depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY
> +-	default ARCH_DAVINCI_DA830 || MACH_OMAP3517EVM
> ++	default ARCH_DAVINCI_DA830 || MACH_OMAP3517EVM || MACH_CRANEBOARD
> + 	select CPPI41
> + 	help
> + 	 Enable DMA transfers when TI CPPI 4.1 DMA is available.
> +diff --git a/drivers/usb/musb/Makefile b/drivers/usb/musb/Makefile
> +index 01de383..daf3415 100644
> +--- a/drivers/usb/musb/Makefile
> ++++ b/drivers/usb/musb/Makefile
> +@@ -19,7 +19,8 @@ ifeq ($(CONFIG_ARCH_OMAP2430),y)
> + endif
> +
> + ifeq ($(CONFIG_ARCH_OMAP3430),y)
> +-   ifeq ($(CONFIG_MACH_OMAP3517EVM),y)
> ++
> ++   ifeq ($(CONFIG_MACH_CRANEBOARD),y)
> + 	musb_hdrc-objs  += am3517.o
> +    else
> + 	musb_hdrc-objs	+= omap2430.o
> +diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c
> +index a448fa6..9988553 100644
> +--- a/drivers/usb/musb/musb_core.c
> ++++ b/drivers/usb/musb/musb_core.c
> +@@ -1019,7 +1019,7 @@ static void musb_shutdown(struct platform_device *pdev)
> +  */
> + #if defined(CONFIG_USB_TUSB6010) || \
> + 	defined(CONFIG_ARCH_OMAP2430) || defined(CONFIG_ARCH_OMAP34XX) || \
> +-	defined(CONFIG_MACH_OMAP3517EVM)
> ++	defined(CONFIG_MACH_OMAP3517EVM) ||  defined(CONFIG_MACH_CRANEBOARD)
> + static ushort __initdata fifo_mode = 4;
> + #else
> + static ushort __initdata fifo_mode = 2;
> +diff --git a/drivers/usb/musb/musb_core.h b/drivers/usb/musb/musb_core.h
> +index 0b19d0b..d7850c7 100644
> +--- a/drivers/usb/musb/musb_core.h
> ++++ b/drivers/usb/musb/musb_core.h
> +@@ -380,7 +380,7 @@ struct musb {
> + 	void __iomem		*sync_va;
> + #endif
> +
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + /* Backup registers required for the workaround of AM3517 bytewise
> +  * read issue. FADDR, POWER, INTRTXE, INTRRXE and INTRUSBE register
> +  * read would actually clear the interrupt registers and would cause
> +diff --git a/drivers/usb/musb/musb_gadget.c b/drivers/usb/musb/musb_gadget.c
> +index b9ef9f3..d0d1cee 100644
> +--- a/drivers/usb/musb/musb_gadget.c
> ++++ b/drivers/usb/musb/musb_gadget.c
> +@@ -2001,7 +2001,7 @@ __acquires(musb->lock)
> +
> +
> + 	/* what speed did we negotiate? */
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 	musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 	power = musb_readb(mbase, MUSB_POWER);
> +diff --git a/drivers/usb/musb/musb_gadget_ep0.c b/drivers/usb/musb/musb_gadget_ep0.c
> +index 7a9dc1e..bcc754d 100644
> +--- a/drivers/usb/musb/musb_gadget_ep0.c
> ++++ b/drivers/usb/musb/musb_gadget_ep0.c
> +@@ -770,7 +770,7 @@ setup:
> + 				printk(KERN_NOTICE "%s: peripheral reset "
> + 						"irq lost!\n",
> + 						musb_driver_name);
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 				musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 				power = musb_readb(mbase, MUSB_POWER);
> +diff --git a/drivers/usb/musb/musb_io.h b/drivers/usb/musb/musb_io.h
> +index 0969d88..e578061 100644
> +--- a/drivers/usb/musb/musb_io.h
> ++++ b/drivers/usb/musb/musb_io.h
> +@@ -56,7 +56,8 @@ static inline void writesb(const void __iomem *addr, const void *buf, int len)
> +
> + #endif
> +
> +-#if !defined(CONFIG_BLACKFIN) && !defined(CONFIG_MACH_OMAP3517EVM)
> ++#if !defined(CONFIG_BLACKFIN) && !defined(CONFIG_MACH_OMAP3517EVM) && \
> ++    !defined(CONFIG_MACH_CRANEBOARD)
> +
> + /* NOTE:  these offsets are all in bytes */
> +
> +@@ -136,7 +137,7 @@ static inline void musb_writew(void __iomem *addr, unsigned offset, u16 data)
> + static inline void musb_writel(void __iomem *addr, unsigned offset, u32 data)
> + 	{ bfin_write16(addr + offset, (u16) data); }
> +
> +-#elif defined(CONFIG_MACH_OMAP3517EVM)
> ++#elif (defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD))
> +
> + /* AM3517 has a limitation on read operation. Only 32 bit read is
> +  * allowed and thus 8bit and 16bit read has to be handled differently
> +diff --git a/drivers/usb/musb/musb_virthub.c b/drivers/usb/musb/musb_virthub.c
> +index 0200a62..c1570b6 100644
> +--- a/drivers/usb/musb/musb_virthub.c
> ++++ b/drivers/usb/musb/musb_virthub.c
> +@@ -68,12 +68,12 @@ static void musb_port_suspend(struct musb *musb, bool do_suspend)
> + 		musb_writeb(mbase, MUSB_POWER, power);
> +
> + 		/* Needed for OPT A tests */
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 		musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 		power = musb_readb(mbase, MUSB_POWER);
> + 		while (power & MUSB_POWER_SUSPENDM) {
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 			musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 			power = musb_readb(mbase, MUSB_POWER);
> +@@ -135,7 +135,7 @@ static void musb_port_reset(struct musb *musb, bool do_reset)
> + 	/* NOTE:  caller guarantees it will turn off the reset when
> + 	 * the appropriate amount of time has passed
> + 	 */
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 	musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 	power = musb_readb(mbase, MUSB_POWER);
> +@@ -171,7 +171,7 @@ static void musb_port_reset(struct musb *musb, bool do_reset)
> +
> + 		musb->ignore_disconnect = false;
> +
> +-#ifdef CONFIG_MACH_OMAP3517EVM
> ++#if defined(CONFIG_MACH_OMAP3517EVM) || defined(CONFIG_MACH_CRANEBOARD)
> + 		musb->read_mask &= ~AM3517_READ_ISSUE_POWER;
> + #endif
> + 		power = musb_readb(mbase, MUSB_POWER);
> +diff --git a/drivers/video/omap2/displays/panel-generic.c b/drivers/video/omap2/displays/panel-generic.c
> +index eb48d1a..e6d1f59 100644
> +--- a/drivers/video/omap2/displays/panel-generic.c
> ++++ b/drivers/video/omap2/displays/panel-generic.c
> +@@ -26,7 +26,11 @@ static struct omap_video_timings generic_panel_timings = {
> + 	/* 640 x 480 @ 60 Hz  Reduced blanking VESA CVT 0.31M3-R */
> + 	.x_res		= 640,
> + 	.y_res		= 480,
> +-	.pixel_clock	= 23500,
> ++#ifdef CONFIG_MACH_CRANEBOARD
> ++        .pixel_clock	= 24000,
> ++#else
> ++	.pixel_clock    = 23500,
> ++#endif
> + 	.hfp		= 48,
> + 	.hsw		= 32,
> + 	.hbp		= 80,
> +@@ -37,7 +41,12 @@ static struct omap_video_timings generic_panel_timings = {
> +
> + static int generic_panel_probe(struct omap_dss_device *dssdev)
> + {
> ++#ifdef CONFIG_MACH_CRANEBOARD
> ++	dssdev->panel.config = (OMAP_DSS_LCD_TFT | OMAP_DSS_LCD_IVS |
> ++				OMAP_DSS_LCD_IHS | OMAP_DSS_LCD_IPC);
> ++#else
> + 	dssdev->panel.config = OMAP_DSS_LCD_TFT;
> ++#endif
> + 	dssdev->panel.timings = generic_panel_timings;
> +
> + 	return 0;
> +diff --git a/drivers/video/omap2/dss/venc.c b/drivers/video/omap2/dss/venc.c
> +index 53fa54e..fbfc24b 100644
> +--- a/drivers/video/omap2/dss/venc.c
> ++++ b/drivers/video/omap2/dss/venc.c
> +@@ -297,7 +297,9 @@ static struct {
> + 	void __iomem *base;
> + 	struct mutex venc_lock;
> + 	u32 wss_data;
> ++#ifndef CONFIG_MACH_CRANEBOARD
> + 	struct regulator *vdda_dac_reg;
> ++#endif
> + } venc;
> +
> + static inline void venc_write_reg(int idx, u32 val)
> +@@ -525,13 +527,14 @@ int venc_init(struct platform_device *pdev)
> + 		return -ENOMEM;
> + 	}
> +
> ++#ifndef CONFIG_MACH_CRANEBOARD
> + 	venc.vdda_dac_reg = regulator_get(&pdev->dev, "vdda_dac");
> + 	if (IS_ERR(venc.vdda_dac_reg)) {
> + 		iounmap(venc.base);
> + 		DSSERR("can't get VDDA_DAC regulator\n");
> + 		return PTR_ERR(venc.vdda_dac_reg);
> + 	}
> +-
> ++#endif
> + 	venc_enable_clocks(1);
> +
> + 	rev_id = (u8)(venc_read_reg(VENC_REV_ID) & 0xff);
> +@@ -545,9 +548,9 @@ int venc_init(struct platform_device *pdev)
> + void venc_exit(void)
> + {
> + 	omap_dss_unregister_driver(&venc_driver);
> +-
> ++#ifndef CONFIG_MACH_CRANEBOARD
> + 	regulator_put(venc.vdda_dac_reg);
> +-
> ++#endif
> + 	iounmap(venc.base);
> + }
> +
> +@@ -598,8 +601,9 @@ static int venc_power_on(struct omap_dss_device *dssdev)
> + 	dispc_set_digit_size(dssdev->panel.timings.x_res,
> + 			dssdev->panel.timings.y_res/2);
> +
> ++#ifndef CONFIG_MACH_CRANEBOARD
> + 	regulator_enable(venc.vdda_dac_reg);
> +-
> ++#endif
> + 	if (dssdev->platform_enable)
> + 		dssdev->platform_enable(dssdev);
> +
> +@@ -626,8 +630,9 @@ static void venc_power_off(struct omap_dss_device *dssdev)
> + 	if (dssdev->platform_disable)
> + 		dssdev->platform_disable(dssdev);
> +
> ++#ifndef CONFIG_MACH_CRANEBOARD
> + 	regulator_disable(venc.vdda_dac_reg);
> +-
> ++#endif
> + #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL
> + 	dsi_pll_uninit();
> + 	dss_clk_disable(DSS_CLK_FCK2);
> +diff --git a/include/linux/i2c/tps65910.h b/include/linux/i2c/tps65910.h
> +new file mode 100644
> +index 0000000..1362de4
> +--- /dev/null
> ++++ b/include/linux/i2c/tps65910.h
> +@@ -0,0 +1,278 @@
> ++/* linux/i2c/tps65910.h
> ++ *
> ++ *  TPS65910 Power Management Device Definitions.
> ++ *
> ++ * Based on include/linux/i2c/twl.h
> ++ *
> ++ * Copyright (C) 2010 Mistral Solutions Pvt Ltd <www.mistralsolutions.com>
> ++ *
> ++ * 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 SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
> ++ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
> ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
> ++ * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
> ++ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
> ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
> ++ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
> ++ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
> ++ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
> ++ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
> ++ *
> ++ * 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.,
> ++ * 675 Mass Ave, Cambridge, MA 02139, USA.
> ++ */
> ++
> ++#ifndef __LINUX_I2C_TPS65910_H
> ++#define __LINUX_I2C_TPS65910_H
> ++
> ++#define TPS65910_NUM_SLAVES	2
> ++/* I2C Slave Address 7-bit */
> ++#define	TPS65910_I2C_ID0	0x2D /* general-purpose */
> ++#define	TPS65910_I2C_ID1	0x12 /* Smart Reflex */
> ++
> ++/* TPS65910 to host IRQ */
> ++#define TPS65910_HOST_IRQ 	INT_34XX_SYS_NIRQ
> ++
> ++/* TPS65910 MAX GPIOs */
> ++#define TPS65910_GPIO_MAX	1
> ++
> ++/*
> ++ * ----------------------------------------------------------------------------
> ++ * Registers, all 8 bits
> ++ * ----------------------------------------------------------------------------
> ++ */
> ++#define	TPS65910_REG_SECONDS		0x00
> ++#define TPS65910_REG_MINUTES		0x01
> ++#define TPS65910_REG_HOURS		0x02
> ++#define TPS65910_REG_DAYS		0x03
> ++#define TPS65910_REG_MONTHS		0x04
> ++#define TPS65910_REG_YEARS		0x05
> ++#define TPS65910_REG_WEEKS		0x06
> ++#define TPS65910_REG_ALARM_SECONDS	0x08
> ++#define TPS65910_REG_ALARM_MINUTES	0x09
> ++#define TPS65910_REG_ALARM_HOURS	0x0A
> ++#define TPS65910_REG_ALARM_DAYS		0x0B
> ++#define TPS65910_REG_ALARM_MONTHS	0x0C
> ++#define TPS65910_REG_ALARM_YEARS	0x0D
> ++
> ++#define TPS65910_REG_RTC_CTRL		0x10
> ++#define TPS65910_REG_RTC_STATUS		0x11
> ++#define TPS65910_REG_RTC_INTERRUPTS	0x12
> ++#define TPS65910_REG_RTC_COMP_LSB	0x13
> ++#define TPS65910_REG_RTC_COMP_MSB	0x14
> ++#define TPS65910_REG_RTC_RES_PROG	0x15
> ++#define TPS65910_REG_RTC_RESET_STATUS	0x16
> ++#define TPS65910_REG_BCK1		0x17
> ++#define TPS65910_REG_BCK2		0x18
> ++#define TPS65910_REG_BCK3		0x19
> ++#define TPS65910_REG_BCK4		0x1A
> ++#define TPS65910_REG_BCK5		0x1B
> ++#define TPS65910_REG_PUADEN		0x1C
> ++#define TPS65910_REG_REF		0x1D
> ++#define TPS65910_REG_VRTC		0x1E
> ++
> ++#define TPS65910_REG_VIO		0x20
> ++#define TPS65910_REG_VDD1		0x21
> ++#define TPS65910_REG_VDD1_OP		0x22
> ++#define TPS65910_REG_VDD1_SR		0x23
> ++#define TPS65910_REG_VDD2		0x24
> ++#define TPS65910_REG_VDD2_OP		0x25
> ++#define TPS65910_REG_VDD2_SR		0x26
> ++#define TPS65910_REG_VDD3		0x27
> ++
> ++#define TPS65910_REG_VDIG1		0x30
> ++#define TPS65910_REG_VDIG2		0x31
> ++#define TPS65910_REG_VAUX1		0x32
> ++#define TPS65910_REG_VAUX2		0x33
> ++#define TPS65910_REG_VAUX33		0x34
> ++#define TPS65910_REG_VMMC		0x35
> ++#define TPS65910_REG_VPLL		0x36
> ++#define TPS65910_REG_VDAC		0x37
> ++#define TPS65910_REG_THERM		0x38
> ++#define TPS65910_REG_BBCH		0x39
> ++
> ++#define TPS65910_REG_DCDCCTRL		0x3E
> ++#define TPS65910_REG_DEVCTRL		0x3F
> ++#define TPS65910_REG_DEVCTRL2		0x40
> ++#define TPS65910_REG_SLEEP_KEEP_LDO_ON	0x41
> ++#define TPS65910_REG_SLEEP_KEEP_RES_ON	0x42
> ++#define TPS65910_REG_SLEEP_SET_LDO_OFF	0x43
> ++#define TPS65910_REG_SLEEP_SET_RES_OFF	0x44
> ++#define TPS65910_REG_EN1_LDO_ASS	0x45
> ++#define TPS65910_REG_EN1_SMPS_ASS	0x46
> ++#define TPS65910_REG_EN2_LDO_ASS	0x47
> ++#define TPS65910_REG_EN2_SMPS_ASS	0x48
> ++#define TPS65910_REG_EN3_LDO_ASS	0x49
> ++#define TPS65910_REG_SPARE		0x4A
> ++
> ++#define TPS65910_REG_INT_STS		0x50
> ++#define TPS65910_REG_INT_MSK		0x51
> ++#define TPS65910_REG_INT_STS2		0x52
> ++#define TPS65910_REG_INT_MSK2		0x53
> ++#define TPS65910_REG_INT_STS3		0x54
> ++#define TPS65910_REG_INT_MSK3		0x55
> ++
> ++#define TPS65910_REG_GPIO0		0x60
> ++
> ++#define TPS65910_REG_JTAGVERNUM		0x80
> ++
> ++/* TPS65910 GPIO Specific flags */
> ++#define TPS65910_GPIO_INT_FALLING	0
> ++#define TPS65910_GPIO_INT_RISING	1
> ++
> ++#define TPS65910_DEBOUNCE_91_5_MS	0
> ++#define TPS65910_DEBOUNCE_150_MS	1
> ++
> ++#define TPS65910_GPIO_PUDIS		(1 << 3)
> ++#define TPS65910_GPIO_CFG_OUTPUT	(1 << 2)
> ++
> ++
> ++
> ++/* TPS65910 Interrupt events */
> ++
> ++/* RTC Driver */
> ++#define TPS65910_RTC_ALARM_IT		0x80
> ++#define TPS65910_RTC_PERIOD_IT		0x40
> ++
> ++/*Core Driver */
> ++#define TPS65910_HOT_DIE_IT		0x20
> ++#define TPS65910_PWRHOLD_IT		0x10
> ++#define TPS65910_PWRON_LP_IT		0x08
> ++#define TPS65910_PWRON_IT		0x04
> ++#define TPS65910_VMBHI_IT		0x02
> ++#define TPS65910_VMBGCH_IT		0x01
> ++
> ++/* GPIO driver */
> ++#define TPS65910_GPIO_F_IT		0x02
> ++#define TPS65910_GPIO_R_IT		0x01
> ++
> ++
> ++#define TPS65910_VRTC_OFFMASK		(1<<3)
> ++
> ++/* Back-up battery charger control */
> ++#define TPS65910_BBCHEN			0x01
> ++
> ++/* Back-up battery charger voltage */
> ++#define TPS65910_BBSEL_3P0		0x00
> ++#define TPS65910_BBSEL_2P52		0x02
> ++#define TPS65910_BBSEL_3P15		0x04
> ++#define TPS65910_BBSEL_VBAT		0x06
> ++
> ++/* DEVCTRL_REG flags */
> ++#define TPS65910_RTC_PWDNN		0x40
> ++#define TPS65910_CK32K_CTRL		0x20
> ++#define TPS65910_SR_CTL_I2C_SEL 	0x10
> ++#define TPS65910_DEV_OFF_RST		0x08
> ++#define TPS65910_DEV_ON			0x04
> ++#define TPS65910_DEV_SLP		0x02
> ++#define TPS65910_DEV_OFF		0x01
> ++
> ++/* DEVCTRL2_REG flags */
> ++#define TPS65910_DEV2_TSLOT_LENGTH	0x30
> ++#define TPS65910_DEV2_SLEEPSIG_POL	0x08
> ++#define TPS65910_DEV2_PWON_LP_OFF	0x04
> ++#define TPS65910_DEV2_PWON_LP_RST	0x02
> ++#define TPS65910_DEV2_IT_POL		0x01
> ++
> ++/* TPS65910 SMPS/LDO's */
> ++#define TPS65910_VIO			0
> ++#define TPS65910_VDD1			1
> ++#define TPS65910_VDD2			2
> ++#define TPS65910_VDD3			3
> ++/* LDOs */
> ++#define TPS65910_VDIG1			4
> ++#define TPS65910_VDIG2			5
> ++#define TPS65910_VAUX33			6
> ++#define TPS65910_VMMC			7
> ++#define TPS65910_VAUX1			8
> ++#define TPS65910_VAUX2			9
> ++#define TPS65910_VDAC			10
> ++#define TPS65910_VPLL			11
> ++/* Internal LDO */
> ++#define TPS65910_VRTC			12
> ++
> ++/* Number of step-down/up converters available */
> ++#define TPS65910_NUM_DCDC		4
> ++
> ++/* Number of LDO voltage regulators  available */
> ++#define TPS65910_NUM_LDO		9
> ++
> ++/* Number of total regulators available */
> ++#define TPS65910_NUM_REGULATOR  (TPS65910_NUM_DCDC + TPS65910_NUM_LDO)
> ++
> ++
> ++/* Regulator Supply state */
> ++#define SUPPLY_STATE_FLAG		0x03
> ++/* OFF States */
> ++#define TPS65910_REG_OFF_00		0x00
> ++#define TPS65910_REG_OFF_10		0x02
> ++/* OHP - on High Power */
> ++#define TPS65910_REG_OHP		0x01
> ++/* OLP - on Low Power */
> ++#define TPS65910_REG_OLP		0x03
> ++
> ++#define TPS65910_MAX_IRQS		10
> ++#define TPS65910_VMBDCH_IRQ     	0
> ++#define TPS65910_VMBHI_IRQ      	1
> ++#define TPS65910_PWRON_IRQ      	2
> ++#define TPS65910_PWRON_LP_IRQ   	3
> ++#define TPS65910_PWRHOLD_IRQ    	4
> ++#define TPS65910_HOTDIE_IRQ     	5
> ++#define TPS65910_RTC_ALARM_IRQ  	6
> ++#define TPS65910_RTC_PERIOD_IRQ 	7
> ++#define TPS65910_GPIO0_R_IRQ    	8
> ++#define TPS65910_GPIO0_F_IRQ    	9
> ++
> ++/* TPS65910 has 1 GPIO  */
> ++struct tps65910_gpio {
> ++	u8      debounce;
> ++	u8      pullup_pulldown;
> ++	u8 	gpio_config;  /* Input or output */
> ++	u8 	gpio_val;    /* Output value */
> ++	int (*gpio_setup)(struct tps65910_gpio *pdata);
> ++	int (*gpio_taredown)(struct tps65910_gpio *pdata);
> ++};
> ++
> ++struct tps65910_platform_data {
> ++
> ++	unsigned irq_num;  /* TPS65910 to Host IRQ Number */
> ++	struct tps65910_gpio	*gpio;
> ++
> ++	/* plaform specific data to be initialised in board file */
> ++	struct regulator_init_data *vio;
> ++	struct regulator_init_data *vdd1;
> ++	struct regulator_init_data *vdd2;
> ++	struct regulator_init_data *vdd3;
> ++	struct regulator_init_data *vdig1;
> ++	struct regulator_init_data *vdig2;
> ++	struct regulator_init_data *vaux33;
> ++	struct regulator_init_data *vmmc;
> ++	struct regulator_init_data *vaux1;
> ++	struct regulator_init_data *vaux2;
> ++	struct regulator_init_data *vdac;
> ++	struct regulator_init_data *vpll;
> ++
> ++	void  (*handlers[TPS65910_MAX_IRQS]) (void  *data);
> ++	/* Configure TP65910 to board specific usage*/
> ++	int (*board_tps65910_config)(struct tps65910_platform_data *pdata);
> ++};
> ++
> ++int tps65910_enable_bbch(u8 voltage);
> ++int tps65910_disable_bbch(void);
> ++
> ++int tps65910_remove_irq_work(int irq);
> ++int tps65910_add_irq_work(int irq, void (*handler)(void *data));
> ++
> ++int tps65910_i2c_write_u8(u8 slave_addr, u8 val, u8 reg);
> ++int tps65910_i2c_read_u8(u8 slave_addr, u8 *val, u8 reg);
> ++
> ++int tps65910_i2c_write(u8 slave_addr, u8 *value, u8 reg, unsigned num_bytes);
> ++int tps65910_i2c_read(u8 slave_addr, u8 *value, u8 reg, unsigned num_bytes);
> ++
> ++#endif /*  __LINUX_I2C_TPS65910_H */
> ++
> +--
> +1.7.0.4
> +
> diff --git a/recipes/linux/linux-omap-psp-2.6.32/am3517-crane/defconfig b/recipes/linux/linux-omap-psp-2.6.32/am3517-crane/defconfig
> new file mode 100644
> index 0000000..7af351e
> --- /dev/null
> +++ b/recipes/linux/linux-omap-psp-2.6.32/am3517-crane/defconfig
> @@ -0,0 +1,1769 @@
> +#
> +# Automatically generated make config: don't edit
> +# Linux kernel version: 2.6.32
> +# Fri Sep  3 09:45:07 2010
> +#
> +CONFIG_ARM=y
> +CONFIG_SYS_SUPPORTS_APM_EMULATION=y
> +CONFIG_GENERIC_GPIO=y
> +CONFIG_GENERIC_TIME=y
> +CONFIG_GENERIC_CLOCKEVENTS=y
> +CONFIG_GENERIC_HARDIRQS=y
> +CONFIG_STACKTRACE_SUPPORT=y
> +CONFIG_HAVE_LATENCYTOP_SUPPORT=y
> +CONFIG_LOCKDEP_SUPPORT=y
> +CONFIG_TRACE_IRQFLAGS_SUPPORT=y
> +CONFIG_HARDIRQS_SW_RESEND=y
> +CONFIG_GENERIC_IRQ_PROBE=y
> +CONFIG_RWSEM_GENERIC_SPINLOCK=y
> +CONFIG_ARCH_HAS_CPUFREQ=y
> +CONFIG_GENERIC_HWEIGHT=y
> +CONFIG_GENERIC_CALIBRATE_DELAY=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
> +#
> +CONFIG_EXPERIMENTAL=y
> +CONFIG_BROKEN_ON_SMP=y
> +CONFIG_INIT_ENV_ARG_LIMIT=32
> +CONFIG_LOCALVERSION=""
> +# CONFIG_LOCALVERSION_AUTO is not set
> +CONFIG_SWAP=y
> +CONFIG_SYSVIPC=y
> +CONFIG_SYSVIPC_SYSCTL=y
> +# CONFIG_POSIX_MQUEUE is not set
> +CONFIG_BSD_PROCESS_ACCT=y
> +# CONFIG_BSD_PROCESS_ACCT_V3 is not set
> +# CONFIG_TASKSTATS is not set
> +# CONFIG_AUDIT is not set
> +
> +#
> +# RCU Subsystem
> +#
> +CONFIG_TREE_RCU=y
> +# CONFIG_TREE_PREEMPT_RCU is not set
> +# CONFIG_TINY_RCU is not set
> +# CONFIG_RCU_TRACE is not set
> +CONFIG_RCU_FANOUT=32
> +# CONFIG_RCU_FANOUT_EXACT is not set
> +# CONFIG_TREE_RCU_TRACE is not set
> +CONFIG_IKCONFIG=y
> +CONFIG_IKCONFIG_PROC=y
> +CONFIG_LOG_BUF_SHIFT=14
> +CONFIG_GROUP_SCHED=y
> +CONFIG_FAIR_GROUP_SCHED=y
> +# CONFIG_RT_GROUP_SCHED is not set
> +CONFIG_USER_SCHED=y
> +# CONFIG_CGROUP_SCHED is not set
> +# CONFIG_CGROUPS is not set
> +CONFIG_SYSFS_DEPRECATED=y
> +CONFIG_SYSFS_DEPRECATED_V2=y
> +# CONFIG_RELAY is not set
> +# CONFIG_NAMESPACES is not set
> +CONFIG_BLK_DEV_INITRD=y
> +CONFIG_INITRAMFS_SOURCE=""
> +CONFIG_RD_GZIP=y
> +# CONFIG_RD_BZIP2 is not set
> +# CONFIG_RD_LZMA is not set
> +CONFIG_CC_OPTIMIZE_FOR_SIZE=y
> +CONFIG_SYSCTL=y
> +CONFIG_ANON_INODES=y
> +CONFIG_EMBEDDED=y
> +CONFIG_UID16=y
> +# CONFIG_SYSCTL_SYSCALL is not set
> +CONFIG_KALLSYMS=y
> +# CONFIG_KALLSYMS_ALL is not set
> +CONFIG_KALLSYMS_EXTRA_PASS=y
> +CONFIG_HOTPLUG=y
> +CONFIG_PRINTK=y
> +CONFIG_BUG=y
> +CONFIG_ELF_CORE=y
> +CONFIG_BASE_FULL=y
> +CONFIG_FUTEX=y
> +CONFIG_EPOLL=y
> +CONFIG_SIGNALFD=y
> +CONFIG_TIMERFD=y
> +CONFIG_EVENTFD=y
> +CONFIG_SHMEM=y
> +CONFIG_AIO=y
> +
> +#
> +# Kernel Performance Events And Counters
> +#
> +CONFIG_VM_EVENT_COUNTERS=y
> +CONFIG_COMPAT_BRK=y
> +CONFIG_SLAB=y
> +# CONFIG_SLUB is not set
> +# CONFIG_SLOB is not set
> +# CONFIG_PROFILING is not set
> +CONFIG_HAVE_OPROFILE=y
> +# CONFIG_KPROBES is not set
> +CONFIG_HAVE_KPROBES=y
> +CONFIG_HAVE_KRETPROBES=y
> +CONFIG_HAVE_CLK=y
> +
> +#
> +# GCOV-based kernel profiling
> +#
> +# CONFIG_SLOW_WORK is not set
> +CONFIG_HAVE_GENERIC_DMA_COHERENT=y
> +CONFIG_SLABINFO=y
> +CONFIG_RT_MUTEXES=y
> +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_MODVERSIONS=y
> +CONFIG_MODULE_SRCVERSION_ALL=y
> +CONFIG_BLOCK=y
> +CONFIG_LBDAF=y
> +# CONFIG_BLK_DEV_BSG is not set
> +# CONFIG_BLK_DEV_INTEGRITY is not set
> +
> +#
> +# IO Schedulers
> +#
> +CONFIG_IOSCHED_NOOP=y
> +CONFIG_IOSCHED_DEADLINE=y
> +CONFIG_IOSCHED_CFQ=y
> +# CONFIG_DEFAULT_DEADLINE is not set
> +CONFIG_DEFAULT_CFQ=y
> +# CONFIG_DEFAULT_NOOP is not set
> +CONFIG_DEFAULT_IOSCHED="cfq"
> +# CONFIG_INLINE_SPIN_TRYLOCK is not set
> +# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set
> +# CONFIG_INLINE_SPIN_LOCK is not set
> +# CONFIG_INLINE_SPIN_LOCK_BH is not set
> +# CONFIG_INLINE_SPIN_LOCK_IRQ is not set
> +# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set
> +CONFIG_INLINE_SPIN_UNLOCK=y
> +# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
> +CONFIG_INLINE_SPIN_UNLOCK_IRQ=y
> +# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set
> +# CONFIG_INLINE_READ_TRYLOCK is not set
> +# CONFIG_INLINE_READ_LOCK is not set
> +# CONFIG_INLINE_READ_LOCK_BH is not set
> +# CONFIG_INLINE_READ_LOCK_IRQ is not set
> +# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set
> +CONFIG_INLINE_READ_UNLOCK=y
> +# CONFIG_INLINE_READ_UNLOCK_BH is not set
> +CONFIG_INLINE_READ_UNLOCK_IRQ=y
> +# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set
> +# CONFIG_INLINE_WRITE_TRYLOCK is not set
> +# CONFIG_INLINE_WRITE_LOCK is not set
> +# CONFIG_INLINE_WRITE_LOCK_BH is not set
> +# CONFIG_INLINE_WRITE_LOCK_IRQ is not set
> +# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set
> +CONFIG_INLINE_WRITE_UNLOCK=y
> +# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
> +CONFIG_INLINE_WRITE_UNLOCK_IRQ=y
> +# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set
> +# CONFIG_MUTEX_SPIN_ON_OWNER is not set
> +CONFIG_FREEZER=y
> +
> +#
> +# System Type
> +#
> +CONFIG_MMU=y
> +# CONFIG_ARCH_AAEC2000 is not set
> +# CONFIG_ARCH_INTEGRATOR is not set
> +# CONFIG_ARCH_REALVIEW is not set
> +# 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_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_NOMADIK is not set
> +# CONFIG_ARCH_IOP13XX is not set
> +# CONFIG_ARCH_IOP32X is not set
> +# CONFIG_ARCH_IOP33X is not set
> +# CONFIG_ARCH_IXP23XX is not set
> +# CONFIG_ARCH_IXP2000 is not set
> +# CONFIG_ARCH_IXP4XX is not set
> +# CONFIG_ARCH_L7200 is not set
> +# CONFIG_ARCH_DOVE is not set
> +# CONFIG_ARCH_KIRKWOOD is not set
> +# CONFIG_ARCH_LOKI is not set
> +# CONFIG_ARCH_MV78XX0 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 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_S5PC1XX 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=y
> +# CONFIG_ARCH_BCMRING is not set
> +# CONFIG_ARCH_U8500 is not set
> +
> +#
> +# TI OMAP Implementations
> +#
> +CONFIG_ARCH_OMAP_OTG=y
> +# CONFIG_ARCH_OMAP1 is not set
> +# CONFIG_ARCH_OMAP2 is not set
> +CONFIG_ARCH_OMAP3=y
> +# CONFIG_ARCH_OMAP4 is not set
> +
> +#
> +# OMAP Feature Selections
> +#
> +CONFIG_OMAP_RESET_CLOCKS=y
> +CONFIG_OMAP_MUX=y
> +# CONFIG_OMAP_MUX_DEBUG is not set
> +CONFIG_OMAP_MUX_WARNINGS=y
> +CONFIG_OMAP_MCBSP=y
> +# CONFIG_OMAP_MBOX_FWK is not set
> +# CONFIG_OMAP_MPU_TIMER is not set
> +CONFIG_OMAP_32K_TIMER=y
> +# CONFIG_OMAP3_L2_AUX_SECURE_SAVE_RESTORE is not set
> +CONFIG_OMAP_32K_TIMER_HZ=128
> +CONFIG_OMAP_DM_TIMER=y
> +# CONFIG_OMAP_LL_DEBUG_UART1 is not set
> +# CONFIG_OMAP_LL_DEBUG_UART2 is not set
> +CONFIG_OMAP_LL_DEBUG_UART3=y
> +# CONFIG_OMAP_LL_DEBUG_NONE is not set
> +# CONFIG_OMAP_PM_NONE is not set
> +CONFIG_OMAP_PM_NOOP=y
> +# CONFIG_OMAP_PM_SRF is not set
> +CONFIG_ARCH_OMAP34XX=y
> +CONFIG_ARCH_OMAP3430=y
> +CONFIG_OMAP_PACKAGE_CBB=y
> +
> +#
> +# OMAP Board Type
> +#
> +# CONFIG_MACH_OMAP3_BEAGLE is not set
> +# CONFIG_MACH_OMAP_LDP is not set
> +# CONFIG_MACH_OVERO is not set
> +# CONFIG_MACH_OMAP3EVM is not set
> +# CONFIG_MACH_OMAP3517EVM is not set
> +CONFIG_MACH_CRANEBOARD=y
> +# CONFIG_MACH_OMAP3_PANDORA is not set
> +# CONFIG_MACH_OMAP3_TOUCHBOOK is not set
> +# CONFIG_MACH_OMAP_3430SDP is not set
> +# CONFIG_MACH_NOKIA_RX51 is not set
> +# CONFIG_MACH_OMAP_ZOOM2 is not set
> +# CONFIG_MACH_OMAP_ZOOM3 is not set
> +# CONFIG_MACH_CM_T35 is not set
> +# CONFIG_MACH_IGEP0020 is not set
> +# CONFIG_MACH_OMAP_3630SDP is not set
> +# CONFIG_OMAP3_EMU is not set
> +# CONFIG_OMAP3_SDRC_AC_TIMING is not set
> +
> +#
> +# Processor Type
> +#
> +CONFIG_CPU_32=y
> +CONFIG_CPU_32v6K=y
> +CONFIG_CPU_V7=y
> +CONFIG_CPU_32v7=y
> +CONFIG_CPU_ABRT_EV7=y
> +CONFIG_CPU_PABRT_V7=y
> +CONFIG_CPU_CACHE_V7=y
> +CONFIG_CPU_CACHE_VIPT=y
> +CONFIG_CPU_COPY_V6=y
> +CONFIG_CPU_TLB_V7=y
> +CONFIG_CPU_HAS_ASID=y
> +CONFIG_CPU_CP15=y
> +CONFIG_CPU_CP15_MMU=y
> +
> +#
> +# Processor Features
> +#
> +CONFIG_ARM_THUMB=y
> +# CONFIG_ARM_THUMBEE is not set
> +# CONFIG_CPU_ICACHE_DISABLE is not set
> +# CONFIG_CPU_DCACHE_DISABLE is not set
> +# CONFIG_CPU_BPREDICT_DISABLE is not set
> +CONFIG_HAS_TLS_REG=y
> +CONFIG_ARM_L1_CACHE_SHIFT=6
> +CONFIG_ARM_ERRATA_430973=y
> +CONFIG_ARM_ERRATA_458693=y
> +CONFIG_ARM_ERRATA_460075=y
> +CONFIG_COMMON_CLKDEV=y
> +
> +#
> +# Bus support
> +#
> +# CONFIG_PCI_SYSCALL is not set
> +# CONFIG_ARCH_SUPPORTS_MSI is not set
> +# CONFIG_PCCARD is not set
> +
> +#
> +# Kernel Features
> +#
> +CONFIG_TICK_ONESHOT=y
> +CONFIG_NO_HZ=y
> +CONFIG_HIGH_RES_TIMERS=y
> +CONFIG_GENERIC_CLOCKEVENTS_BUILD=y
> +CONFIG_VMSPLIT_3G=y
> +# CONFIG_VMSPLIT_2G is not set
> +# CONFIG_VMSPLIT_1G is not set
> +CONFIG_PAGE_OFFSET=0xC0000000
> +CONFIG_PREEMPT_NONE=y
> +# CONFIG_PREEMPT_VOLUNTARY is not set
> +# CONFIG_PREEMPT is not set
> +CONFIG_HZ=128
> +# CONFIG_THUMB2_KERNEL is not set
> +CONFIG_AEABI=y
> +CONFIG_OABI_COMPAT=y
> +CONFIG_ARCH_HAS_HOLES_MEMORYMODEL=y
> +# CONFIG_ARCH_SPARSEMEM_DEFAULT is not set
> +# CONFIG_ARCH_SELECT_MEMORY_MODEL is not set
> +# CONFIG_HIGHMEM is not set
> +CONFIG_SELECT_MEMORY_MODEL=y
> +CONFIG_FLATMEM_MANUAL=y
> +# CONFIG_DISCONTIGMEM_MANUAL is not set
> +# CONFIG_SPARSEMEM_MANUAL is not set
> +CONFIG_FLATMEM=y
> +CONFIG_FLAT_NODE_MEM_MAP=y
> +CONFIG_PAGEFLAGS_EXTENDED=y
> +CONFIG_SPLIT_PTLOCK_CPUS=4
> +# CONFIG_PHYS_ADDR_T_64BIT is not set
> +CONFIG_ZONE_DMA_FLAG=0
> +CONFIG_VIRT_TO_BUS=y
> +# CONFIG_KSM is not set
> +CONFIG_DEFAULT_MMAP_MIN_ADDR=4096
> +# CONFIG_LEDS is not set
> +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/nfs nfsroot=192.168.0.1:/home/user/buildroot ip=192.168.0.2:192.168.0.1:192.168.0.1:255.255.255.0:tgt:eth0:off rw console=ttyS2,115200n8"
> +# CONFIG_XIP_KERNEL is not set
> +# CONFIG_KEXEC is not set
> +
> +#
> +# CPU Power Management
> +#
> +# CONFIG_CPU_FREQ is not set
> +# CONFIG_CPU_IDLE is not set
> +
> +#
> +# Floating point emulation
> +#
> +
> +#
> +# At least one emulation must be selected
> +#
> +CONFIG_FPE_NWFPE=y
> +# CONFIG_FPE_NWFPE_XP is not set
> +# CONFIG_FPE_FASTFPE is not set
> +CONFIG_VFP=y
> +CONFIG_VFPv3=y
> +CONFIG_NEON=y
> +
> +#
> +# Userspace binary formats
> +#
> +CONFIG_BINFMT_ELF=y
> +# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
> +CONFIG_HAVE_AOUT=y
> +# CONFIG_BINFMT_AOUT is not set
> +CONFIG_BINFMT_MISC=y
> +
> +#
> +# Power management options
> +#
> +CONFIG_PM=y
> +CONFIG_PM_DEBUG=y
> +# CONFIG_PM_VERBOSE is not set
> +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 is not set
> +# CONFIG_PM_RUNTIME is not set
> +CONFIG_ARCH_SUSPEND_POSSIBLE=y
> +CONFIG_NET=y
> +
> +#
> +# Networking options
> +#
> +CONFIG_PACKET=y
> +# CONFIG_PACKET_MMAP is not set
> +CONFIG_UNIX=y
> +CONFIG_XFRM=y
> +# CONFIG_XFRM_USER is not set
> +# CONFIG_XFRM_SUB_POLICY is not set
> +# CONFIG_XFRM_MIGRATE is not set
> +# CONFIG_XFRM_STATISTICS is not set
> +CONFIG_NET_KEY=y
> +# CONFIG_NET_KEY_MIGRATE is not set
> +CONFIG_INET=y
> +# CONFIG_IP_MULTICAST is not set
> +# CONFIG_IP_ADVANCED_ROUTER is not set
> +CONFIG_IP_FIB_HASH=y
> +CONFIG_IP_PNP=y
> +CONFIG_IP_PNP_DHCP=y
> +CONFIG_IP_PNP_BOOTP=y
> +CONFIG_IP_PNP_RARP=y
> +# CONFIG_NET_IPIP is not set
> +# CONFIG_NET_IPGRE is not set
> +# CONFIG_ARPD is not set
> +# CONFIG_SYN_COOKIES is not set
> +# CONFIG_INET_AH is not set
> +# CONFIG_INET_ESP is not set
> +# CONFIG_INET_IPCOMP is not set
> +# CONFIG_INET_XFRM_TUNNEL is not set
> +# CONFIG_INET_TUNNEL is not set
> +CONFIG_INET_XFRM_MODE_TRANSPORT=y
> +CONFIG_INET_XFRM_MODE_TUNNEL=y
> +CONFIG_INET_XFRM_MODE_BEET=y
> +# CONFIG_INET_LRO is not set
> +CONFIG_INET_DIAG=y
> +CONFIG_INET_TCP_DIAG=y
> +# CONFIG_TCP_CONG_ADVANCED is not set
> +CONFIG_TCP_CONG_CUBIC=y
> +CONFIG_DEFAULT_TCP_CONG="cubic"
> +# CONFIG_TCP_MD5SIG is not set
> +# CONFIG_IPV6 is not set
> +# CONFIG_NETWORK_SECMARK is not set
> +# CONFIG_NETFILTER is not set
> +# CONFIG_IP_DCCP is not set
> +# CONFIG_IP_SCTP is not set
> +# CONFIG_RDS is not set
> +# CONFIG_TIPC is not set
> +# CONFIG_ATM is not set
> +# CONFIG_BRIDGE is not set
> +# CONFIG_NET_DSA is not set
> +# CONFIG_VLAN_8021Q is not set
> +# CONFIG_DECNET is not set
> +# CONFIG_LLC2 is not set
> +# CONFIG_IPX is not set
> +# CONFIG_ATALK is not set
> +# CONFIG_X25 is not set
> +# CONFIG_LAPB is not set
> +# 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
> +
> +#
> +# Network testing
> +#
> +# CONFIG_NET_PKTGEN is not set
> +# CONFIG_HAMRADIO is not set
> +CONFIG_CAN=y
> +CONFIG_CAN_RAW=y
> +CONFIG_CAN_BCM=y
> +
> +#
> +# CAN Device Drivers
> +#
> +CONFIG_CAN_VCAN=y
> +CONFIG_CAN_DEV=y
> +CONFIG_CAN_CALC_BITTIMING=y
> +CONFIG_CAN_TI_HECC=y
> +# CONFIG_CAN_SJA1000 is not set
> +
> +#
> +# CAN USB interfaces
> +#
> +# CONFIG_CAN_EMS_USB is not set
> +CONFIG_CAN_DEBUG_DEVICES=y
> +# CONFIG_IRDA is not set
> +# CONFIG_BT is not set
> +# CONFIG_AF_RXRPC is not set
> +CONFIG_WIRELESS=y
> +# CONFIG_CFG80211 is not set
> +# CONFIG_LIB80211 is not set
> +
> +#
> +# CFG80211 needs to be enabled for MAC80211
> +#
> +# CONFIG_WIMAX is not set
> +# CONFIG_RFKILL is not set
> +# CONFIG_NET_9P is not set
> +
> +#
> +# Device Drivers
> +#
> +
> +#
> +# Generic Driver Options
> +#
> +CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
> +# CONFIG_DEVTMPFS is not set
> +CONFIG_STANDALONE=y
> +CONFIG_PREVENT_FIRMWARE_BUILD=y
> +# CONFIG_FW_LOADER is not set
> +# CONFIG_DEBUG_DRIVER is not set
> +# CONFIG_DEBUG_DEVRES is not set
> +# CONFIG_SYS_HYPERVISOR is not set
> +# CONFIG_CONNECTOR is not set
> +CONFIG_MTD=y
> +# CONFIG_MTD_DEBUG is not set
> +# CONFIG_MTD_TESTS is not set
> +CONFIG_MTD_CONCAT=y
> +CONFIG_MTD_PARTITIONS=y
> +# CONFIG_MTD_REDBOOT_PARTS is not set
> +CONFIG_MTD_CMDLINE_PARTS=y
> +# CONFIG_MTD_AFS_PARTS is not set
> +# CONFIG_MTD_AR7_PARTS is not set
> +
> +#
> +# User Modules And Translation Layers
> +#
> +CONFIG_MTD_CHAR=y
> +CONFIG_MTD_BLKDEVS=y
> +CONFIG_MTD_BLOCK=y
> +# CONFIG_FTL is not set
> +# CONFIG_NFTL is not set
> +# CONFIG_INFTL is not set
> +# CONFIG_RFD_FTL is not set
> +# CONFIG_SSFDC is not set
> +# CONFIG_MTD_OOPS is not set
> +
> +#
> +# RAM/ROM/Flash chip drivers
> +#
> +# CONFIG_MTD_CFI is not set
> +# CONFIG_MTD_JEDECPROBE is not set
> +CONFIG_MTD_MAP_BANK_WIDTH_1=y
> +CONFIG_MTD_MAP_BANK_WIDTH_2=y
> +CONFIG_MTD_MAP_BANK_WIDTH_4=y
> +# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
> +# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
> +# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
> +CONFIG_MTD_CFI_I1=y
> +CONFIG_MTD_CFI_I2=y
> +# CONFIG_MTD_CFI_I4 is not set
> +# CONFIG_MTD_CFI_I8 is not set
> +# CONFIG_MTD_RAM is not set
> +# CONFIG_MTD_ROM is not set
> +# CONFIG_MTD_ABSENT is not set
> +
> +#
> +# Mapping drivers for chip access
> +#
> +# CONFIG_MTD_COMPLEX_MAPPINGS is not set
> +# CONFIG_MTD_PLATRAM is not set
> +
> +#
> +# Self-contained MTD device drivers
> +#
> +# CONFIG_MTD_SLRAM is not set
> +# CONFIG_MTD_PHRAM is not set
> +# CONFIG_MTD_MTDRAM is not set
> +# CONFIG_MTD_BLOCK2MTD is not set
> +
> +#
> +# Disk-On-Chip Device Drivers
> +#
> +# CONFIG_MTD_DOC2000 is not set
> +# CONFIG_MTD_DOC2001 is not set
> +# CONFIG_MTD_DOC2001PLUS is not set
> +CONFIG_MTD_NAND=y
> +# CONFIG_MTD_NAND_VERIFY_WRITE is not set
> +# CONFIG_MTD_NAND_ECC_SMC is not set
> +# CONFIG_MTD_NAND_MUSEUM_IDS is not set
> +# CONFIG_MTD_NAND_GPIO is not set
> +CONFIG_MTD_NAND_OMAP2=y
> +# CONFIG_MTD_NAND_OMAP_PREFETCH is not set
> +CONFIG_MTD_NAND_IDS=y
> +# CONFIG_MTD_NAND_DISKONCHIP is not set
> +# CONFIG_MTD_NAND_NANDSIM is not set
> +# CONFIG_MTD_NAND_PLATFORM is not set
> +# CONFIG_MTD_ALAUDA is not set
> +# CONFIG_MTD_ONENAND is not set
> +
> +#
> +# LPDDR flash memory drivers
> +#
> +# CONFIG_MTD_LPDDR is not set
> +
> +#
> +# UBI - Unsorted block images
> +#
> +# CONFIG_MTD_UBI is not set
> +# CONFIG_PARPORT is not set
> +CONFIG_BLK_DEV=y
> +# CONFIG_BLK_DEV_COW_COMMON is not set
> +CONFIG_BLK_DEV_LOOP=y
> +# CONFIG_BLK_DEV_CRYPTOLOOP is not set
> +
> +#
> +# DRBD disabled because PROC_FS, INET or CONNECTOR not selected
> +#
> +# CONFIG_BLK_DEV_NBD is not set
> +# CONFIG_BLK_DEV_UB is not set
> +CONFIG_BLK_DEV_RAM=y
> +CONFIG_BLK_DEV_RAM_COUNT=16
> +CONFIG_BLK_DEV_RAM_SIZE=32768
> +# 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
> +
> +#
> +# SCSI device support
> +#
> +# CONFIG_RAID_ATTRS is not set
> +CONFIG_SCSI=y
> +CONFIG_SCSI_DMA=y
> +# CONFIG_SCSI_TGT is not set
> +# CONFIG_SCSI_NETLINK is not set
> +CONFIG_SCSI_PROC_FS=y
> +
> +#
> +# SCSI support type (disk, tape, CD-ROM)
> +#
> +CONFIG_BLK_DEV_SD=y
> +# CONFIG_CHR_DEV_ST is not set
> +# CONFIG_CHR_DEV_OSST is not set
> +# CONFIG_BLK_DEV_SR is not set
> +# CONFIG_CHR_DEV_SG is not set
> +# CONFIG_CHR_DEV_SCH is not set
> +# CONFIG_SCSI_MULTI_LUN is not set
> +# CONFIG_SCSI_CONSTANTS is not set
> +# CONFIG_SCSI_LOGGING is not set
> +# CONFIG_SCSI_SCAN_ASYNC is not set
> +CONFIG_SCSI_WAIT_SCAN=m
> +
> +#
> +# SCSI Transports
> +#
> +# CONFIG_SCSI_SPI_ATTRS is not set
> +# CONFIG_SCSI_FC_ATTRS is not set
> +# CONFIG_SCSI_ISCSI_ATTRS is not set
> +# CONFIG_SCSI_SAS_LIBSAS is not set
> +# CONFIG_SCSI_SRP_ATTRS is not set
> +CONFIG_SCSI_LOWLEVEL=y
> +# CONFIG_ISCSI_TCP is not set
> +# CONFIG_LIBFC is not set
> +# CONFIG_LIBFCOE is not set
> +# CONFIG_SCSI_DEBUG is not set
> +# CONFIG_SCSI_DH is not set
> +# CONFIG_SCSI_OSD_INITIATOR is not set
> +# CONFIG_ATA is not set
> +# CONFIG_MD is not set
> +CONFIG_NETDEVICES=y
> +# CONFIG_DUMMY is not set
> +# CONFIG_BONDING is not set
> +# CONFIG_MACVLAN is not set
> +# CONFIG_EQUALIZER is not set
> +# CONFIG_TUN is not set
> +# CONFIG_VETH is not set
> +CONFIG_PHYLIB=y
> +
> +#
> +# MII PHY device drivers
> +#
> +# CONFIG_MARVELL_PHY is not set
> +# CONFIG_DAVICOM_PHY is not set
> +# CONFIG_QSEMI_PHY is not set
> +# CONFIG_LXT_PHY is not set
> +# CONFIG_CICADA_PHY is not set
> +# CONFIG_VITESSE_PHY is not set
> +# CONFIG_SMSC_PHY is not set
> +# CONFIG_BROADCOM_PHY is not set
> +# CONFIG_ICPLUS_PHY is not set
> +# CONFIG_REALTEK_PHY is not set
> +# CONFIG_NATIONAL_PHY is not set
> +# CONFIG_STE10XP is not set
> +# CONFIG_LSI_ET1011C_PHY is not set
> +# CONFIG_FIXED_PHY is not set
> +# CONFIG_MDIO_BITBANG is not set
> +CONFIG_NET_ETHERNET=y
> +CONFIG_MII=y
> +# CONFIG_AX88796 is not set
> +# CONFIG_SMC91X is not set
> +CONFIG_TI_DAVINCI_EMAC=y
> +# CONFIG_DM9000 is not set
> +# CONFIG_ETHOC is not set
> +# CONFIG_SMC911X is not set
> +# CONFIG_SMSC911X is not set
> +# CONFIG_DNET is not set
> +# CONFIG_IBM_NEW_EMAC_ZMII is not set
> +# CONFIG_IBM_NEW_EMAC_RGMII is not set
> +# CONFIG_IBM_NEW_EMAC_TAH is not set
> +# CONFIG_IBM_NEW_EMAC_EMAC4 is not set
> +# CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set
> +# 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_MLL is not set
> +CONFIG_NETDEV_1000=y
> +CONFIG_NETDEV_10000=y
> +CONFIG_WLAN=y
> +# CONFIG_USB_ZD1201 is not set
> +# CONFIG_HOSTAP is not set
> +
> +#
> +# Enable WiMAX (Networking options) to see the WiMAX drivers
> +#
> +
> +#
> +# USB Network Adapters
> +#
> +# CONFIG_USB_CATC is not set
> +# CONFIG_USB_KAWETH is not set
> +# CONFIG_USB_PEGASUS is not set
> +# CONFIG_USB_RTL8150 is not set
> +CONFIG_USB_USBNET=y
> +# CONFIG_USB_NET_AX8817X is not set
> +CONFIG_USB_NET_CDCETHER=y
> +# CONFIG_USB_NET_CDC_EEM is not set
> +CONFIG_USB_NET_DM9601=y
> +# CONFIG_USB_NET_SMSC95XX is not set
> +# CONFIG_USB_NET_GL620A is not set
> +# CONFIG_USB_NET_NET1080 is not set
> +# CONFIG_USB_NET_PLUSB is not set
> +# CONFIG_USB_NET_MCS7830 is not set
> +# CONFIG_USB_NET_RNDIS_HOST is not set
> +# CONFIG_USB_NET_CDC_SUBSET is not set
> +# CONFIG_USB_NET_ZAURUS is not set
> +# CONFIG_USB_NET_INT51X1 is not set
> +# CONFIG_WAN is not set
> +# CONFIG_PPP is not set
> +# CONFIG_SLIP is not set
> +# CONFIG_NETCONSOLE is not set
> +# CONFIG_NETPOLL is not set
> +# CONFIG_NET_POLL_CONTROLLER is not set
> +# CONFIG_ISDN is not set
> +# CONFIG_PHONE is not set
> +
> +#
> +# Input device support
> +#
> +CONFIG_INPUT=y
> +# CONFIG_INPUT_FF_MEMLESS is not set
> +# CONFIG_INPUT_POLLDEV is not set
> +# CONFIG_INPUT_SPARSEKMAP is not set
> +
> +#
> +# Userland interfaces
> +#
> +# CONFIG_INPUT_MOUSEDEV is not set
> +# CONFIG_INPUT_JOYDEV is not set
> +CONFIG_INPUT_EVDEV=y
> +# CONFIG_INPUT_EVBUG is not set
> +
> +#
> +# Input Device Drivers
> +#
> +# CONFIG_INPUT_KEYBOARD is not set
> +# CONFIG_INPUT_MOUSE is not set
> +# CONFIG_INPUT_JOYSTICK is not set
> +# CONFIG_INPUT_TABLET is not set
> +# CONFIG_INPUT_TOUCHSCREEN is not set
> +# CONFIG_INPUT_MISC is not set
> +
> +#
> +# Hardware I/O ports
> +#
> +CONFIG_SERIO=y
> +CONFIG_SERIO_SERPORT=y
> +CONFIG_SERIO_LIBPS2=y
> +# CONFIG_SERIO_RAW is not set
> +# CONFIG_SERIO_ALTERA_PS2 is not set
> +# CONFIG_GAMEPORT is not set
> +
> +#
> +# Character devices
> +#
> +CONFIG_VT=y
> +CONFIG_CONSOLE_TRANSLATIONS=y
> +CONFIG_VT_CONSOLE=y
> +CONFIG_HW_CONSOLE=y
> +# CONFIG_VT_HW_CONSOLE_BINDING is not set
> +CONFIG_DEVKMEM=y
> +# CONFIG_SERIAL_NONSTANDARD is not set
> +
> +#
> +# Serial drivers
> +#
> +CONFIG_SERIAL_8250=y
> +CONFIG_SERIAL_8250_CONSOLE=y
> +CONFIG_SERIAL_8250_NR_UARTS=32
> +CONFIG_SERIAL_8250_RUNTIME_UARTS=4
> +CONFIG_SERIAL_8250_EXTENDED=y
> +CONFIG_SERIAL_8250_MANY_PORTS=y
> +CONFIG_SERIAL_8250_SHARE_IRQ=y
> +CONFIG_SERIAL_8250_DETECT_IRQ=y
> +CONFIG_SERIAL_8250_RSA=y
> +
> +#
> +# Non-8250 serial port support
> +#
> +CONFIG_SERIAL_CORE=y
> +CONFIG_SERIAL_CORE_CONSOLE=y
> +CONFIG_UNIX98_PTYS=y
> +# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set
> +# CONFIG_LEGACY_PTYS is not set
> +# CONFIG_IPMI_HANDLER is not set
> +CONFIG_HW_RANDOM=y
> +# CONFIG_HW_RANDOM_TIMERIOMEM is not set
> +# CONFIG_R3964 is not set
> +# CONFIG_RAW_DRIVER is not set
> +# CONFIG_TCG_TPM is not set
> +CONFIG_I2C=y
> +CONFIG_I2C_BOARDINFO=y
> +CONFIG_I2C_COMPAT=y
> +# CONFIG_I2C_CHARDEV is not set
> +CONFIG_I2C_HELPER_AUTO=y
> +
> +#
> +# I2C Hardware Bus support
> +#
> +
> +#
> +# 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_OMAP=y
> +# CONFIG_I2C_SIMTEC is not set
> +
> +#
> +# External I2C/SMBus adapter drivers
> +#
> +# CONFIG_I2C_PARPORT_LIGHT is not set
> +# CONFIG_I2C_TAOS_EVM is not set
> +# CONFIG_I2C_TINY_USB is not set
> +
> +#
> +# Other I2C/SMBus bus drivers
> +#
> +# CONFIG_I2C_PCA_PLATFORM is not set
> +# CONFIG_I2C_STUB is not set
> +
> +#
> +# Miscellaneous I2C Chip support
> +#
> +# 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
> +
> +#
> +# PPS support
> +#
> +# CONFIG_PPS is not set
> +CONFIG_ARCH_REQUIRE_GPIOLIB=y
> +CONFIG_GPIOLIB=y
> +# CONFIG_DEBUG_GPIO is not set
> +CONFIG_GPIO_SYSFS=y
> +
> +#
> +# Memory mapped GPIO expanders:
> +#
> +
> +#
> +# I2C GPIO expanders:
> +#
> +# CONFIG_GPIO_MAX732X is not set
> +# CONFIG_GPIO_PCA953X is not set
> +# CONFIG_GPIO_PCF857X is not set
> +# CONFIG_GPIO_TPS65910 is not set
> +
> +#
> +# PCI GPIO expanders:
> +#
> +
> +#
> +# SPI GPIO expanders:
> +#
> +
> +#
> +# AC97 GPIO expanders:
> +#
> +# CONFIG_W1 is not set
> +# CONFIG_POWER_SUPPLY is not set
> +# CONFIG_HWMON is not set
> +# CONFIG_THERMAL is not set
> +CONFIG_WATCHDOG=y
> +CONFIG_WATCHDOG_NOWAYOUT=y
> +
> +#
> +# Watchdog Device Drivers
> +#
> +# CONFIG_SOFT_WATCHDOG is not set
> +CONFIG_OMAP_WATCHDOG=y
> +
> +#
> +# USB-based Watchdog Cards
> +#
> +# CONFIG_USBPCWATCHDOG is not set
> +CONFIG_SSB_POSSIBLE=y
> +
> +#
> +# Sonics Silicon Backplane
> +#
> +# CONFIG_SSB is not set
> +
> +#
> +# Multifunction device drivers
> +#
> +# CONFIG_MFD_CORE is not set
> +# CONFIG_MFD_SM501 is not set
> +# CONFIG_MFD_ASIC3 is not set
> +# CONFIG_HTC_EGPIO is not set
> +# CONFIG_HTC_PASIC3 is not set
> +# CONFIG_TPS65010 is not set
> +# CONFIG_TWL4030_CORE is not set
> +CONFIG_TPS65910_CORE=y
> +# 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_ADP5520 is not set
> +# CONFIG_MFD_WM8400 is not set
> +# CONFIG_MFD_WM831X is not set
> +# CONFIG_MFD_WM8350_I2C is not set
> +# CONFIG_MFD_PCF50633 is not set
> +# CONFIG_AB3100_CORE is not set
> +# CONFIG_MFD_88PM8607 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_TPS65910 is not set
> +# CONFIG_REGULATOR_LP3971 is not set
> +# CONFIG_REGULATOR_TPS65023 is not set
> +# CONFIG_REGULATOR_TPS6507X is not set
> +CONFIG_MEDIA_SUPPORT=y
> +
> +#
> +# Multimedia core support
> +#
> +CONFIG_VIDEO_DEV=y
> +CONFIG_VIDEO_V4L2_COMMON=y
> +CONFIG_VIDEO_ALLOW_V4L1=y
> +CONFIG_VIDEO_V4L1_COMPAT=y
> +# CONFIG_DVB_CORE is not set
> +CONFIG_VIDEO_MEDIA=y
> +
> +#
> +# Multimedia drivers
> +#
> +# CONFIG_MEDIA_ATTACH is not set
> +CONFIG_MEDIA_TUNER=y
> +# CONFIG_MEDIA_TUNER_CUSTOMISE is not set
> +CONFIG_MEDIA_TUNER_SIMPLE=y
> +CONFIG_MEDIA_TUNER_TDA8290=y
> +CONFIG_MEDIA_TUNER_TDA9887=y
> +CONFIG_MEDIA_TUNER_TEA5761=y
> +CONFIG_MEDIA_TUNER_TEA5767=y
> +CONFIG_MEDIA_TUNER_MT20XX=y
> +CONFIG_MEDIA_TUNER_XC2028=y
> +CONFIG_MEDIA_TUNER_XC5000=y
> +CONFIG_MEDIA_TUNER_MC44S803=y
> +CONFIG_VIDEO_V4L2=y
> +CONFIG_VIDEO_V4L1=y
> +# CONFIG_VIDEO_CAPTURE_DRIVERS is not set
> +# CONFIG_RADIO_ADAPTERS is not set
> +# CONFIG_DAB is not set
> +
> +#
> +# Graphics support
> +#
> +# CONFIG_VGASTATE is not set
> +# CONFIG_VIDEO_OUTPUT_CONTROL is not set
> +CONFIG_FB=y
> +# CONFIG_FIRMWARE_EDID is not set
> +# CONFIG_FB_DDC is not set
> +# CONFIG_FB_BOOT_VESA_SUPPORT is not set
> +CONFIG_FB_CFB_FILLRECT=y
> +CONFIG_FB_CFB_COPYAREA=y
> +CONFIG_FB_CFB_IMAGEBLIT=y
> +# CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set
> +# CONFIG_FB_SYS_FILLRECT is not set
> +# CONFIG_FB_SYS_COPYAREA is not set
> +# CONFIG_FB_SYS_IMAGEBLIT is not set
> +# CONFIG_FB_FOREIGN_ENDIAN is not set
> +# CONFIG_FB_SYS_FOPS is not set
> +# CONFIG_FB_SVGALIB is not set
> +# CONFIG_FB_MACMODES is not set
> +# CONFIG_FB_BACKLIGHT is not set
> +# CONFIG_FB_MODE_HELPERS is not set
> +# CONFIG_FB_TILEBLITTING is not set
> +
> +#
> +# Frame buffer hardware drivers
> +#
> +# CONFIG_FB_S1D13XXX is not set
> +# CONFIG_FB_VIRTUAL is not set
> +# CONFIG_FB_METRONOME is not set
> +# CONFIG_FB_MB862XX is not set
> +# CONFIG_FB_BROADSHEET is not set
> +# CONFIG_FB_OMAP_BOOTLOADER_INIT is not set
> +CONFIG_OMAP2_VRAM=y
> +CONFIG_OMAP2_VRFB=y
> +CONFIG_OMAP2_DSS=y
> +CONFIG_OMAP2_VRAM_SIZE=4
> +# CONFIG_OMAP2_DSS_DEBUG_SUPPORT is not set
> +# CONFIG_OMAP2_DSS_RFBI is not set
> +CONFIG_OMAP2_DSS_VENC=y
> +# CONFIG_OMAP2_VENC_OUT_TYPE_SVIDEO is not set
> +CONFIG_OMAP2_VENC_OUT_TYPE_COMPOSITE=y
> +# CONFIG_OMAP2_DSS_SDI is not set
> +# CONFIG_OMAP2_DSS_DSI is not set
> +# CONFIG_OMAP2_DSS_FAKE_VSYNC is not set
> +CONFIG_OMAP2_DSS_MIN_FCK_PER_PCK=1
> +CONFIG_FB_OMAP2=y
> +# CONFIG_FB_OMAP2_DEBUG_SUPPORT is not set
> +# CONFIG_FB_OMAP2_FORCE_AUTO_UPDATE is not set
> +CONFIG_FB_OMAP2_NUM_FBS=1
> +
> +#
> +# OMAP2/3 Display Device Drivers
> +#
> +CONFIG_PANEL_GENERIC=y
> +# CONFIG_PANEL_SHARP_LS037V7DW01 is not set
> +# CONFIG_PANEL_SHARP_LQ043T1DG01 is not set
> +# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
> +
> +#
> +# Display device support
> +#
> +# CONFIG_DISPLAY_SUPPORT is not set
> +
> +#
> +# Console display driver support
> +#
> +# CONFIG_VGA_CONSOLE is not set
> +CONFIG_DUMMY_CONSOLE=y
> +# CONFIG_FRAMEBUFFER_CONSOLE is not set
> +CONFIG_LOGO=y
> +CONFIG_LOGO_LINUX_MONO=y
> +CONFIG_LOGO_LINUX_VGA16=y
> +CONFIG_LOGO_LINUX_CLUT224=y
> +# CONFIG_SOUND is not set
> +CONFIG_HID_SUPPORT=y
> +CONFIG_HID=y
> +# CONFIG_HIDRAW is not set
> +
> +#
> +# USB Input Devices
> +#
> +CONFIG_USB_HID=y
> +# CONFIG_HID_PID is not set
> +# CONFIG_USB_HIDDEV is not set
> +
> +#
> +# Special HID drivers
> +#
> +# 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_TWINHAN 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_ZEROPLUS is not set
> +CONFIG_USB_SUPPORT=y
> +CONFIG_USB_ARCH_HAS_HCD=y
> +CONFIG_USB_ARCH_HAS_OHCI=y
> +CONFIG_USB_ARCH_HAS_EHCI=y
> +CONFIG_USB=y
> +# CONFIG_USB_DEBUG is not set
> +CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
> +
> +#
> +# Miscellaneous USB options
> +#
> +CONFIG_USB_DEVICEFS=y
> +CONFIG_USB_DEVICE_CLASS=y
> +# CONFIG_USB_DYNAMIC_MINORS is not set
> +CONFIG_USB_SUSPEND=y
> +CONFIG_USB_OTG=y
> +# CONFIG_USB_OTG_WHITELIST is not set
> +# CONFIG_USB_OTG_BLACKLIST_HUB is not set
> +# CONFIG_USB_MON is not set
> +# CONFIG_USB_WUSB is not set
> +# CONFIG_USB_WUSB_CBAF is not set
> +
> +#
> +# USB Host Controller Drivers
> +#
> +# CONFIG_USB_C67X00_HCD is not set
> +CONFIG_USB_EHCI_HCD=y
> +# CONFIG_USB_EHCI_ROOT_HUB_TT is not set
> +CONFIG_USB_EHCI_TT_NEWSCHED=y
> +# CONFIG_USB_OXU210HP_HCD is not set
> +# CONFIG_USB_ISP116X_HCD is not set
> +# CONFIG_USB_ISP1760_HCD is not set
> +# CONFIG_USB_ISP1362_HCD is not set
> +# CONFIG_USB_OHCI_HCD is not set
> +# CONFIG_USB_SL811_HCD is not set
> +# CONFIG_USB_R8A66597_HCD is not set
> +# CONFIG_USB_HWA_HCD is not set
> +CONFIG_USB_MUSB_HDRC=y
> +CONFIG_USB_MUSB_SOC=y
> +
> +#
> +# OMAP 343x high speed USB support
> +#
> +# CONFIG_USB_MUSB_HOST is not set
> +# CONFIG_USB_MUSB_PERIPHERAL is not set
> +CONFIG_USB_MUSB_OTG=y
> +CONFIG_USB_GADGET_MUSB_HDRC=y
> +CONFIG_USB_MUSB_HDRC_HCD=y
> +# CONFIG_MUSB_PIO_ONLY is not set
> +# CONFIG_USB_TI_CPPI_DMA is not set
> +CONFIG_USB_TI_CPPI41_DMA=y
> +CONFIG_USB_MUSB_DEBUG=y
> +
> +#
> +# USB Device Class drivers
> +#
> +# CONFIG_USB_ACM is not set
> +# CONFIG_USB_PRINTER is not set
> +# CONFIG_USB_WDM is not set
> +# CONFIG_USB_TMC is not set
> +
> +#
> +# NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may
> +#
> +
> +#
> +# also be needed; see USB_STORAGE Help for more info
> +#
> +CONFIG_USB_STORAGE=y
> +# CONFIG_USB_STORAGE_DEBUG is not set
> +# CONFIG_USB_STORAGE_DATAFAB is not set
> +# CONFIG_USB_STORAGE_FREECOM is not set
> +# CONFIG_USB_STORAGE_ISD200 is not set
> +# CONFIG_USB_STORAGE_USBAT is not set
> +# CONFIG_USB_STORAGE_SDDR09 is not set
> +# CONFIG_USB_STORAGE_SDDR55 is not set
> +# CONFIG_USB_STORAGE_JUMPSHOT is not set
> +# CONFIG_USB_STORAGE_ALAUDA is not set
> +# CONFIG_USB_STORAGE_ONETOUCH is not set
> +# CONFIG_USB_STORAGE_KARMA is not set
> +# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set
> +# CONFIG_USB_LIBUSUAL is not set
> +
> +#
> +# USB Imaging devices
> +#
> +# CONFIG_USB_MDC800 is not set
> +# CONFIG_USB_MICROTEK is not set
> +
> +#
> +# USB port drivers
> +#
> +# CONFIG_USB_SERIAL is not set
> +
> +#
> +# USB Miscellaneous drivers
> +#
> +# CONFIG_USB_EMI62 is not set
> +# CONFIG_USB_EMI26 is not set
> +# CONFIG_USB_ADUTUX is not set
> +# CONFIG_USB_SEVSEG is not set
> +# CONFIG_USB_RIO500 is not set
> +# CONFIG_USB_LEGOTOWER is not set
> +# CONFIG_USB_LCD is not set
> +# CONFIG_USB_BERRY_CHARGE is not set
> +# CONFIG_USB_LED is not set
> +# CONFIG_USB_CYPRESS_CY7C63 is not set
> +# CONFIG_USB_CYTHERM is not set
> +# CONFIG_USB_IDMOUSE is not set
> +# CONFIG_USB_FTDI_ELAN is not set
> +# CONFIG_USB_APPLEDISPLAY is not set
> +# CONFIG_USB_SISUSBVGA is not set
> +# CONFIG_USB_LD is not set
> +# CONFIG_USB_TRANCEVIBRATOR is not set
> +# CONFIG_USB_IOWARRIOR is not set
> +CONFIG_USB_TEST=y
> +# CONFIG_USB_ISIGHTFW is not set
> +# CONFIG_USB_VST is not set
> +CONFIG_USB_GADGET=y
> +# CONFIG_USB_GADGET_DEBUG is not set
> +# CONFIG_USB_GADGET_DEBUG_FILES is not set
> +CONFIG_USB_GADGET_VBUS_DRAW=2
> +CONFIG_USB_GADGET_SELECTED=y
> +# CONFIG_USB_GADGET_AT91 is not set
> +# CONFIG_USB_GADGET_ATMEL_USBA is not set
> +# CONFIG_USB_GADGET_FSL_USB2 is not set
> +# CONFIG_USB_GADGET_LH7A40X is not set
> +# CONFIG_USB_GADGET_OMAP is not set
> +# CONFIG_USB_GADGET_PXA25X is not set
> +# CONFIG_USB_GADGET_R8A66597 is not set
> +# CONFIG_USB_GADGET_PXA27X is not set
> +# CONFIG_USB_GADGET_S3C_HSOTG is not set
> +# CONFIG_USB_GADGET_IMX is not set
> +# CONFIG_USB_GADGET_S3C2410 is not set
> +# CONFIG_USB_GADGET_M66592 is not set
> +# CONFIG_USB_GADGET_AMD5536UDC is not set
> +# CONFIG_USB_GADGET_FSL_QE is not set
> +# CONFIG_USB_GADGET_CI13XXX is not set
> +# CONFIG_USB_GADGET_NET2280 is not set
> +# CONFIG_USB_GADGET_GOKU is not set
> +# CONFIG_USB_GADGET_LANGWELL is not set
> +# CONFIG_USB_GADGET_DUMMY_HCD is not set
> +CONFIG_USB_GADGET_DUALSPEED=y
> +# CONFIG_USB_ZERO is not set
> +# CONFIG_USB_AUDIO is not set
> +CONFIG_USB_ETH=y
> +CONFIG_USB_ETH_RNDIS=y
> +# CONFIG_USB_ETH_EEM is not set
> +# CONFIG_USB_GADGETFS is not set
> +# CONFIG_USB_FILE_STORAGE is not set
> +# CONFIG_USB_MASS_STORAGE is not set
> +# CONFIG_USB_G_SERIAL is not set
> +# CONFIG_USB_MIDI_GADGET is not set
> +# CONFIG_USB_G_PRINTER is not set
> +# CONFIG_USB_CDC_COMPOSITE is not set
> +# CONFIG_USB_G_MULTI is not set
> +
> +#
> +# OTG and related infrastructure
> +#
> +CONFIG_USB_OTG_UTILS=y
> +# CONFIG_USB_GPIO_VBUS is not set
> +# CONFIG_ISP1301_OMAP is not set
> +# CONFIG_USB_ULPI is not set
> +CONFIG_NOP_USB_XCEIV=y
> +CONFIG_MMC=y
> +# CONFIG_MMC_DEBUG is not set
> +# CONFIG_MMC_UNSAFE_RESUME is not set
> +
> +#
> +# MMC/SD/SDIO Card Drivers
> +#
> +CONFIG_MMC_BLOCK=y
> +CONFIG_MMC_BLOCK_BOUNCE=y
> +# CONFIG_SDIO_UART is not set
> +# CONFIG_MMC_TEST is not set
> +
> +#
> +# MMC/SD/SDIO Host Controller Drivers
> +#
> +# CONFIG_MMC_SDHCI is not set
> +# CONFIG_MMC_OMAP is not set
> +CONFIG_MMC_OMAP_HS=y
> +# CONFIG_MMC_AT91 is not set
> +# CONFIG_MMC_ATMELMCI is not set
> +# CONFIG_MEMSTICK is not set
> +# CONFIG_NEW_LEDS is not set
> +# CONFIG_ACCESSIBILITY is not set
> +CONFIG_RTC_LIB=y
> +CONFIG_RTC_CLASS=y
> +CONFIG_RTC_HCTOSYS=y
> +CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
> +# CONFIG_RTC_DEBUG is not set
> +
> +#
> +# RTC interfaces
> +#
> +CONFIG_RTC_INTF_SYSFS=y
> +CONFIG_RTC_INTF_PROC=y
> +CONFIG_RTC_INTF_DEV=y
> +# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
> +# CONFIG_RTC_DRV_TEST is not set
> +
> +#
> +# I2C RTC drivers
> +#
> +# CONFIG_RTC_DRV_DS1307 is not set
> +# CONFIG_RTC_DRV_DS1374 is not set
> +# CONFIG_RTC_DRV_DS1672 is not set
> +# CONFIG_RTC_DRV_MAX6900 is not set
> +# CONFIG_RTC_DRV_RS5C372 is not set
> +# CONFIG_RTC_DRV_ISL1208 is not set
> +# CONFIG_RTC_DRV_X1205 is not set
> +# CONFIG_RTC_DRV_PCF8563 is not set
> +# CONFIG_RTC_DRV_PCF8583 is not set
> +# CONFIG_RTC_DRV_M41T80 is not set
> +CONFIG_RTC_DRV_TPS65910=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
> +#
> +
> +#
> +# Platform RTC drivers
> +#
> +# CONFIG_RTC_DRV_CMOS is not set
> +# CONFIG_RTC_DRV_DS1286 is not set
> +# CONFIG_RTC_DRV_DS1511 is not set
> +# CONFIG_RTC_DRV_DS1553 is not set
> +# CONFIG_RTC_DRV_DS1742 is not set
> +# CONFIG_RTC_DRV_STK17TA8 is not set
> +# CONFIG_RTC_DRV_M48T86 is not set
> +# CONFIG_RTC_DRV_M48T35 is not set
> +# CONFIG_RTC_DRV_M48T59 is not set
> +# CONFIG_RTC_DRV_MSM6242 is not set
> +# CONFIG_RTC_DRV_BQ4802 is not set
> +# CONFIG_RTC_DRV_RP5C01 is not set
> +# CONFIG_RTC_DRV_V3020 is not set
> +
> +#
> +# on-CPU RTC drivers
> +#
> +# CONFIG_DMADEVICES is not set
> +# CONFIG_AUXDISPLAY is not set
> +# CONFIG_UIO is not set
> +
> +#
> +# TI VLYNQ
> +#
> +# CONFIG_STAGING is not set
> +
> +#
> +# CBUS support
> +#
> +# CONFIG_CBUS is not set
> +
> +#
> +# File systems
> +#
> +CONFIG_FS_JOURNAL_INFO=y
> +CONFIG_EXT2_FS=y
> +# CONFIG_EXT2_FS_XATTR is not set
> +# CONFIG_EXT2_FS_XIP is not set
> +CONFIG_EXT3_FS=y
> +# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
> +# CONFIG_EXT3_FS_XATTR is not set
> +# CONFIG_EXT4_FS is not set
> +CONFIG_JBD=y
> +# CONFIG_REISERFS_FS is not set
> +# CONFIG_JFS_FS is not set
> +# CONFIG_FS_POSIX_ACL is not set
> +# 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_NILFS2_FS is not set
> +CONFIG_FILE_LOCKING=y
> +CONFIG_FSNOTIFY=y
> +CONFIG_DNOTIFY=y
> +CONFIG_INOTIFY=y
> +CONFIG_INOTIFY_USER=y
> +CONFIG_QUOTA=y
> +# CONFIG_QUOTA_NETLINK_INTERFACE is not set
> +CONFIG_PRINT_QUOTA_WARNING=y
> +CONFIG_QUOTA_TREE=y
> +# CONFIG_QFMT_V1 is not set
> +CONFIG_QFMT_V2=y
> +CONFIG_QUOTACTL=y
> +# CONFIG_AUTOFS_FS is not set
> +# CONFIG_AUTOFS4_FS is not set
> +# CONFIG_FUSE_FS is not set
> +
> +#
> +# Caches
> +#
> +# CONFIG_FSCACHE is not set
> +
> +#
> +# CD-ROM/DVD Filesystems
> +#
> +# CONFIG_ISO9660_FS is not set
> +# CONFIG_UDF_FS is not set
> +
> +#
> +# DOS/FAT/NT Filesystems
> +#
> +CONFIG_FAT_FS=y
> +CONFIG_MSDOS_FS=y
> +CONFIG_VFAT_FS=y
> +CONFIG_FAT_DEFAULT_CODEPAGE=437
> +CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1"
> +# CONFIG_NTFS_FS is not set
> +
> +#
> +# Pseudo filesystems
> +#
> +CONFIG_PROC_FS=y
> +CONFIG_PROC_SYSCTL=y
> +CONFIG_PROC_PAGE_MONITOR=y
> +CONFIG_SYSFS=y
> +CONFIG_TMPFS=y
> +# CONFIG_TMPFS_POSIX_ACL is not set
> +# CONFIG_HUGETLB_PAGE is not set
> +# CONFIG_CONFIGFS_FS is not set
> +CONFIG_MISC_FILESYSTEMS=y
> +# CONFIG_ADFS_FS is not set
> +# CONFIG_AFFS_FS is not set
> +# CONFIG_HFS_FS is not set
> +# CONFIG_HFSPLUS_FS is not set
> +# CONFIG_BEFS_FS is not set
> +# CONFIG_BFS_FS is not set
> +# CONFIG_EFS_FS is not set
> +CONFIG_JFFS2_FS=y
> +CONFIG_JFFS2_FS_DEBUG=0
> +CONFIG_JFFS2_FS_WRITEBUFFER=y
> +# CONFIG_JFFS2_FS_WBUF_VERIFY is not set
> +# CONFIG_JFFS2_SUMMARY is not set
> +# CONFIG_JFFS2_FS_XATTR is not set
> +CONFIG_JFFS2_COMPRESSION_OPTIONS=y
> +CONFIG_JFFS2_ZLIB=y
> +# CONFIG_JFFS2_LZO is not set
> +CONFIG_JFFS2_RTIME=y
> +# CONFIG_JFFS2_RUBIN is not set
> +# CONFIG_JFFS2_CMODE_NONE is not set
> +CONFIG_JFFS2_CMODE_PRIORITY=y
> +# CONFIG_JFFS2_CMODE_SIZE is not set
> +# CONFIG_JFFS2_CMODE_FAVOURLZO is not set
> +# CONFIG_CRAMFS is not set
> +# CONFIG_SQUASHFS is not set
> +# CONFIG_VXFS_FS is not set
> +# CONFIG_MINIX_FS is not set
> +# CONFIG_OMFS_FS is not set
> +# CONFIG_HPFS_FS is not set
> +# CONFIG_QNX4FS_FS is not set
> +# CONFIG_ROMFS_FS is not set
> +# CONFIG_SYSV_FS is not set
> +# CONFIG_UFS_FS is not set
> +CONFIG_NETWORK_FILESYSTEMS=y
> +CONFIG_NFS_FS=y
> +CONFIG_NFS_V3=y
> +# CONFIG_NFS_V3_ACL is not set
> +CONFIG_NFS_V4=y
> +# CONFIG_NFS_V4_1 is not set
> +CONFIG_ROOT_NFS=y
> +# CONFIG_NFSD is not set
> +CONFIG_LOCKD=y
> +CONFIG_LOCKD_V4=y
> +CONFIG_NFS_COMMON=y
> +CONFIG_SUNRPC=y
> +CONFIG_SUNRPC_GSS=y
> +CONFIG_RPCSEC_GSS_KRB5=y
> +# CONFIG_RPCSEC_GSS_SPKM3 is not set
> +# CONFIG_SMB_FS is not set
> +# CONFIG_CIFS is not set
> +# CONFIG_NCP_FS is not set
> +# CONFIG_CODA_FS is not set
> +# CONFIG_AFS_FS is not set
> +
> +#
> +# Partition Types
> +#
> +CONFIG_PARTITION_ADVANCED=y
> +# CONFIG_ACORN_PARTITION is not set
> +# CONFIG_OSF_PARTITION is not set
> +# CONFIG_AMIGA_PARTITION is not set
> +# CONFIG_ATARI_PARTITION is not set
> +# CONFIG_MAC_PARTITION is not set
> +CONFIG_MSDOS_PARTITION=y
> +# CONFIG_BSD_DISKLABEL is not set
> +# CONFIG_MINIX_SUBPARTITION is not set
> +# CONFIG_SOLARIS_X86_PARTITION is not set
> +# CONFIG_UNIXWARE_DISKLABEL is not set
> +# CONFIG_LDM_PARTITION is not set
> +# CONFIG_SGI_PARTITION is not set
> +# CONFIG_ULTRIX_PARTITION is not set
> +# CONFIG_SUN_PARTITION is not set
> +# CONFIG_KARMA_PARTITION is not set
> +# CONFIG_EFI_PARTITION is not set
> +# CONFIG_SYSV68_PARTITION is not set
> +CONFIG_NLS=y
> +CONFIG_NLS_DEFAULT="iso8859-1"
> +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
> +# CONFIG_NLS_CODEPAGE_852 is not set
> +# CONFIG_NLS_CODEPAGE_855 is not set
> +# CONFIG_NLS_CODEPAGE_857 is not set
> +# CONFIG_NLS_CODEPAGE_860 is not set
> +# CONFIG_NLS_CODEPAGE_861 is not set
> +# CONFIG_NLS_CODEPAGE_862 is not set
> +# CONFIG_NLS_CODEPAGE_863 is not set
> +# CONFIG_NLS_CODEPAGE_864 is not set
> +# CONFIG_NLS_CODEPAGE_865 is not set
> +# CONFIG_NLS_CODEPAGE_866 is not set
> +# CONFIG_NLS_CODEPAGE_869 is not set
> +# CONFIG_NLS_CODEPAGE_936 is not set
> +# CONFIG_NLS_CODEPAGE_950 is not set
> +# CONFIG_NLS_CODEPAGE_932 is not set
> +# CONFIG_NLS_CODEPAGE_949 is not set
> +# CONFIG_NLS_CODEPAGE_874 is not set
> +# CONFIG_NLS_ISO8859_8 is not set
> +# CONFIG_NLS_CODEPAGE_1250 is not set
> +# CONFIG_NLS_CODEPAGE_1251 is not set
> +# CONFIG_NLS_ASCII is not set
> +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
> +# CONFIG_NLS_ISO8859_5 is not set
> +# CONFIG_NLS_ISO8859_6 is not set
> +# CONFIG_NLS_ISO8859_7 is not set
> +# CONFIG_NLS_ISO8859_9 is not set
> +# CONFIG_NLS_ISO8859_13 is not set
> +# CONFIG_NLS_ISO8859_14 is not set
> +# CONFIG_NLS_ISO8859_15 is not set
> +# CONFIG_NLS_KOI8_R is not set
> +# CONFIG_NLS_KOI8_U is not set
> +# CONFIG_NLS_UTF8 is not set
> +# CONFIG_DLM is not set
> +
> +#
> +# Kernel hacking
> +#
> +# CONFIG_PRINTK_TIME is not set
> +CONFIG_ENABLE_WARN_DEPRECATED=y
> +CONFIG_ENABLE_MUST_CHECK=y
> +CONFIG_FRAME_WARN=1024
> +CONFIG_MAGIC_SYSRQ=y
> +# CONFIG_STRIP_ASM_SYMS is not set
> +# CONFIG_UNUSED_SYMBOLS is not set
> +# CONFIG_DEBUG_FS is not set
> +# CONFIG_HEADERS_CHECK is not set
> +CONFIG_DEBUG_KERNEL=y
> +# CONFIG_DEBUG_SHIRQ is not set
> +CONFIG_DETECT_SOFTLOCKUP=y
> +# CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set
> +CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0
> +CONFIG_DETECT_HUNG_TASK=y
> +# CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set
> +CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0
> +# CONFIG_SCHED_DEBUG is not set
> +# CONFIG_SCHEDSTATS is not set
> +# CONFIG_TIMER_STATS is not set
> +# CONFIG_DEBUG_OBJECTS is not set
> +# CONFIG_DEBUG_SLAB 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
> +CONFIG_DEBUG_MUTEXES=y
> +# CONFIG_DEBUG_LOCK_ALLOC is not set
> +# CONFIG_PROVE_LOCKING is not set
> +# CONFIG_LOCK_STAT is not set
> +# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
> +# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
> +# CONFIG_DEBUG_KOBJECT is not set
> +# CONFIG_DEBUG_BUGVERBOSE is not set
> +CONFIG_DEBUG_INFO=y
> +# CONFIG_DEBUG_VM is not set
> +# CONFIG_DEBUG_WRITECOUNT is not set
> +# 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
> +# CONFIG_DEBUG_CREDENTIALS is not set
> +# CONFIG_BOOT_PRINTK_DELAY is not set
> +# CONFIG_RCU_TORTURE_TEST is not set
> +# CONFIG_RCU_CPU_STALL_DETECTOR is not set
> +# CONFIG_BACKTRACE_SELF_TEST is not set
> +# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
> +# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
> +# CONFIG_FAULT_INJECTION is not set
> +# CONFIG_LATENCYTOP is not set
> +# CONFIG_SYSCTL_SYSCALL_CHECK is not set
> +# CONFIG_PAGE_POISONING is not set
> +CONFIG_HAVE_FUNCTION_TRACER=y
> +CONFIG_TRACING_SUPPORT=y
> +CONFIG_FTRACE=y
> +# CONFIG_FUNCTION_TRACER is not set
> +# CONFIG_IRQSOFF_TRACER is not set
> +# CONFIG_SCHED_TRACER is not set
> +# CONFIG_ENABLE_DEFAULT_TRACERS is not set
> +# CONFIG_BOOT_TRACER 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
> +# CONFIG_BLK_DEV_IO_TRACE is not set
> +# CONFIG_SAMPLES is not set
> +CONFIG_HAVE_ARCH_KGDB=y
> +# CONFIG_KGDB is not set
> +CONFIG_ARM_UNWIND=y
> +# CONFIG_DEBUG_USER is not set
> +# CONFIG_DEBUG_ERRORS is not set
> +# CONFIG_DEBUG_STACK_USAGE is not set
> +CONFIG_DEBUG_LL=y
> +# CONFIG_EARLY_PRINTK is not set
> +# CONFIG_DEBUG_ICEDCC is not set
> +# CONFIG_OC_ETM is not set
> +
> +#
> +# Security options
> +#
> +# CONFIG_KEYS is not set
> +# CONFIG_SECURITY is not set
> +# CONFIG_SECURITYFS is not set
> +# CONFIG_DEFAULT_SECURITY_SELINUX is not set
> +# CONFIG_DEFAULT_SECURITY_SMACK is not set
> +# CONFIG_DEFAULT_SECURITY_TOMOYO is not set
> +CONFIG_DEFAULT_SECURITY_DAC=y
> +CONFIG_DEFAULT_SECURITY=""
> +CONFIG_CRYPTO=y
> +
> +#
> +# Crypto core or helper
> +#
> +CONFIG_CRYPTO_ALGAPI=y
> +CONFIG_CRYPTO_ALGAPI2=y
> +CONFIG_CRYPTO_AEAD2=y
> +CONFIG_CRYPTO_BLKCIPHER=y
> +CONFIG_CRYPTO_BLKCIPHER2=y
> +CONFIG_CRYPTO_HASH=y
> +CONFIG_CRYPTO_HASH2=y
> +CONFIG_CRYPTO_RNG2=y
> +CONFIG_CRYPTO_PCOMP=y
> +CONFIG_CRYPTO_MANAGER=y
> +CONFIG_CRYPTO_MANAGER2=y
> +# CONFIG_CRYPTO_GF128MUL is not set
> +# CONFIG_CRYPTO_NULL is not set
> +CONFIG_CRYPTO_WORKQUEUE=y
> +# CONFIG_CRYPTO_CRYPTD is not set
> +# CONFIG_CRYPTO_AUTHENC is not set
> +# CONFIG_CRYPTO_TEST is not set
> +
> +#
> +# Authenticated Encryption with Associated Data
> +#
> +# CONFIG_CRYPTO_CCM is not set
> +# CONFIG_CRYPTO_GCM is not set
> +# CONFIG_CRYPTO_SEQIV is not set
> +
> +#
> +# Block modes
> +#
> +CONFIG_CRYPTO_CBC=y
> +# CONFIG_CRYPTO_CTR is not set
> +# CONFIG_CRYPTO_CTS is not set
> +CONFIG_CRYPTO_ECB=m
> +# CONFIG_CRYPTO_LRW is not set
> +CONFIG_CRYPTO_PCBC=m
> +# CONFIG_CRYPTO_XTS is not set
> +
> +#
> +# Hash modes
> +#
> +# CONFIG_CRYPTO_HMAC is not set
> +# CONFIG_CRYPTO_XCBC is not set
> +# CONFIG_CRYPTO_VMAC is not set
> +
> +#
> +# Digest
> +#
> +CONFIG_CRYPTO_CRC32C=y
> +# CONFIG_CRYPTO_GHASH is not set
> +# CONFIG_CRYPTO_MD4 is not set
> +CONFIG_CRYPTO_MD5=y
> +# CONFIG_CRYPTO_MICHAEL_MIC is not set
> +# CONFIG_CRYPTO_RMD128 is not set
> +# CONFIG_CRYPTO_RMD160 is not set
> +# CONFIG_CRYPTO_RMD256 is not set
> +# CONFIG_CRYPTO_RMD320 is not set
> +# CONFIG_CRYPTO_SHA1 is not set
> +# CONFIG_CRYPTO_SHA256 is not set
> +# CONFIG_CRYPTO_SHA512 is not set
> +# CONFIG_CRYPTO_TGR192 is not set
> +# CONFIG_CRYPTO_WP512 is not set
> +
> +#
> +# Ciphers
> +#
> +# CONFIG_CRYPTO_AES is not set
> +# CONFIG_CRYPTO_ANUBIS is not set
> +# CONFIG_CRYPTO_ARC4 is not set
> +# CONFIG_CRYPTO_BLOWFISH is not set
> +# CONFIG_CRYPTO_CAMELLIA is not set
> +# CONFIG_CRYPTO_CAST5 is not set
> +# CONFIG_CRYPTO_CAST6 is not set
> +CONFIG_CRYPTO_DES=y
> +# CONFIG_CRYPTO_FCRYPT is not set
> +# CONFIG_CRYPTO_KHAZAD is not set
> +# CONFIG_CRYPTO_SALSA20 is not set
> +# CONFIG_CRYPTO_SEED is not set
> +# CONFIG_CRYPTO_SERPENT is not set
> +# CONFIG_CRYPTO_TEA is not set
> +# CONFIG_CRYPTO_TWOFISH is not set
> +
> +#
> +# Compression
> +#
> +# CONFIG_CRYPTO_DEFLATE is not set
> +# CONFIG_CRYPTO_ZLIB is not set
> +# CONFIG_CRYPTO_LZO is not set
> +
> +#
> +# Random Number Generation
> +#
> +# CONFIG_CRYPTO_ANSI_CPRNG is not set
> +CONFIG_CRYPTO_HW=y
> +# CONFIG_BINARY_PRINTF is not set
> +
> +#
> +# Library routines
> +#
> +CONFIG_BITREVERSE=y
> +CONFIG_GENERIC_FIND_LAST_BIT=y
> +CONFIG_CRC_CCITT=y
> +# CONFIG_CRC16 is not set
> +# CONFIG_CRC_T10DIF is not set
> +# CONFIG_CRC_ITU_T is not set
> +CONFIG_CRC32=y
> +# CONFIG_CRC7 is not set
> +CONFIG_LIBCRC32C=y
> +CONFIG_ZLIB_INFLATE=y
> +CONFIG_ZLIB_DEFLATE=y
> +CONFIG_DECOMPRESS_GZIP=y
> +CONFIG_HAS_IOMEM=y
> +CONFIG_HAS_IOPORT=y
> +CONFIG_HAS_DMA=y
> +CONFIG_NLATTR=y
> diff --git a/recipes/linux/linux-omap-psp_2.6.32.bb b/recipes/linux/linux-omap-psp_2.6.32.bb
> index 7d0118d..1f59594 100644
> --- a/recipes/linux/linux-omap-psp_2.6.32.bb
> +++ b/recipes/linux/linux-omap-psp_2.6.32.bb
> @@ -3,7 +3,8 @@ require multi-kernel.inc
>  DESCRIPTION = "Linux kernel for OMAP processors"
>  KERNEL_IMAGETYPE = "uImage"
>  
> -COMPATIBLE_MACHINE = "beagleboard|omap3evm|am3517-evm|dm37x-evm|am37x-evm|omap3-touchbook|overo"
> +COMPATIBLE_MACHINE = "am3517-crane|beagleboard|omap3evm|am3517-evm| \
> +                           dm37x-evm|am37x-evm|omap3-touchbook|overo"
>  
>  # This is the v2.6.32_OMAPPSP_03.00.01.06 branch
>  SRCREV = "a6bad4464f985fdd3bed72e1b82dcbfc004d7869"
> @@ -13,6 +14,7 @@ MACHINE_KERNEL_PR_append = "+gitr${SRCREV}"
>  
>  SRC_URI = "git://arago-project.org/git/people/sriram/ti-psp-omap.git;protocol=git;branch=master \
>             file://0001-Revert-omap3-beagle-Fix-compile-time-errors.patch \
> +           file://0001-Added-support-for-AM3517-CraneBoard.patch \
>             file://0002-board-omap3touchbook-make-it-build-against-TI-linux-.patch \
>             file://0003-ARM-OMAP-add-support-for-TCT-Zippy-to-Beagle-board-f.patch \
>             file://0004-ARM-OMAP-Make-beagle-u-boot-partition-writable.patch \

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.5 (Darwin)

iD8DBQFM7+1XMkyGM64RGpERAsCjAKC0V7RhTMvBh/uGFjgtnXzsnm818wCfYFsN
T026MmIfPK06kqR+OciUJkQ=
=d16L
-----END PGP SIGNATURE-----





More information about the Openembedded-devel mailing list