diff --git a/.config b/.config
deleted file mode 100644
index 83e1515..0000000
--- a/.config
+++ /dev/null
@@ -1,2278 +0,0 @@
-#
-# Automatically generated make config: don't edit
-# Linux/arm 3.0.8 Kernel Configuration
-#
-CONFIG_ARM=y
-CONFIG_HAVE_PWM=y
-CONFIG_SYS_SUPPORTS_APM_EMULATION=y
-CONFIG_GENERIC_GPIO=y
-# CONFIG_ARCH_USES_GETTIMEOFFSET is not set
-CONFIG_GENERIC_CLOCKEVENTS=y
-CONFIG_KTIME_SCALAR=y
-CONFIG_HAVE_PROC_CPU=y
-CONFIG_NO_IOPORT=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_ARCH_HAS_CPU_IDLE_WAIT=y
-CONFIG_GENERIC_HWEIGHT=y
-CONFIG_GENERIC_CALIBRATE_DELAY=y
-CONFIG_NEED_DMA_MAP_STATE=y
-CONFIG_VECTORS_BASE=0xffff0000
-CONFIG_ARM_PATCH_PHYS_VIRT=y
-CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
-CONFIG_HAVE_IRQ_WORK=y
-
-#
-# General setup
-#
-CONFIG_EXPERIMENTAL=y
-CONFIG_BROKEN_ON_SMP=y
-CONFIG_INIT_ENV_ARG_LIMIT=32
-CONFIG_CROSS_COMPILE=""
-CONFIG_LOCALVERSION=""
-CONFIG_LOCALVERSION_AUTO=y
-CONFIG_HAVE_KERNEL_GZIP=y
-CONFIG_HAVE_KERNEL_LZMA=y
-CONFIG_HAVE_KERNEL_LZO=y
-CONFIG_KERNEL_GZIP=y
-# CONFIG_KERNEL_LZMA is not set
-# CONFIG_KERNEL_LZO is not set
-CONFIG_DEFAULT_HOSTNAME="(none)"
-# CONFIG_SWAP is not set
-CONFIG_SYSVIPC=y
-CONFIG_SYSVIPC_SYSCTL=y
-# CONFIG_POSIX_MQUEUE is not set
-# CONFIG_BSD_PROCESS_ACCT is not set
-# CONFIG_FHANDLE is not set
-# CONFIG_TASKSTATS is not set
-# CONFIG_AUDIT is not set
-CONFIG_HAVE_GENERIC_HARDIRQS=y
-
-#
-# IRQ subsystem
-#
-CONFIG_GENERIC_HARDIRQS=y
-CONFIG_HAVE_SPARSE_IRQ=y
-CONFIG_GENERIC_IRQ_SHOW=y
-CONFIG_GENERIC_IRQ_CHIP=y
-# CONFIG_SPARSE_IRQ is not set
-
-#
-# RCU Subsystem
-#
-CONFIG_TREE_PREEMPT_RCU=y
-# CONFIG_TINY_RCU is not set
-# CONFIG_TINY_PREEMPT_RCU is not set
-CONFIG_PREEMPT_RCU=y
-# 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_RCU_BOOST is not set
-# CONFIG_IKCONFIG is not set
-CONFIG_LOG_BUF_SHIFT=17
-CONFIG_CGROUPS=y
-CONFIG_CGROUP_DEBUG=y
-CONFIG_CGROUP_FREEZER=y
-# CONFIG_CGROUP_DEVICE is not set
-# CONFIG_CPUSETS is not set
-CONFIG_CGROUP_CPUACCT=y
-CONFIG_RESOURCE_COUNTERS=y
-# CONFIG_CGROUP_MEM_RES_CTLR is not set
-CONFIG_CGROUP_SCHED=y
-CONFIG_FAIR_GROUP_SCHED=y
-CONFIG_RT_GROUP_SCHED=y
-# CONFIG_BLK_CGROUP is not set
-# CONFIG_NAMESPACES is not set
-# CONFIG_SCHED_AUTOGROUP is not set
-# CONFIG_SYSFS_DEPRECATED is not set
-# CONFIG_RELAY is not set
-CONFIG_BLK_DEV_INITRD=y
-CONFIG_INITRAMFS_SOURCE=""
-CONFIG_RD_GZIP=y
-CONFIG_RD_BZIP2=y
-CONFIG_RD_LZMA=y
-CONFIG_RD_XZ=y
-CONFIG_RD_LZO=y
-# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set
-CONFIG_SYSCTL=y
-CONFIG_ANON_INODES=y
-CONFIG_PANIC_TIMEOUT=0
-CONFIG_EXPERT=y
-CONFIG_UID16=y
-CONFIG_SYSCTL_SYSCALL=y
-CONFIG_KALLSYMS=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_ASHMEM=y
-CONFIG_AIO=y
-CONFIG_EMBEDDED=y
-CONFIG_HAVE_PERF_EVENTS=y
-CONFIG_PERF_USE_VMALLOC=y
-
-#
-# Kernel Performance Events And Counters
-#
-# CONFIG_PERF_EVENTS is not set
-# CONFIG_PERF_COUNTERS is not set
-CONFIG_VM_EVENT_COUNTERS=y
-CONFIG_SLUB_DEBUG=y
-CONFIG_COMPAT_BRK=y
-# CONFIG_SLAB is not set
-CONFIG_SLUB=y
-# 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_REGS_AND_STACK_ACCESS_API=y
-CONFIG_HAVE_CLK=y
-CONFIG_HAVE_DMA_API_DEBUG=y
-
-#
-# GCOV-based kernel profiling
-#
-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 is not set
-# CONFIG_MODULE_SRCVERSION_ALL is not set
-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 is not set
-# CONFIG_INLINE_SPIN_UNLOCK_BH is not set
-# CONFIG_INLINE_SPIN_UNLOCK_IRQ is not set
-# 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 is not set
-# CONFIG_INLINE_READ_UNLOCK_BH is not set
-# CONFIG_INLINE_READ_UNLOCK_IRQ is not set
-# 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 is not set
-# CONFIG_INLINE_WRITE_UNLOCK_BH is not set
-# CONFIG_INLINE_WRITE_UNLOCK_IRQ is not set
-# 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_INTEGRATOR is not set
-# CONFIG_ARCH_REALVIEW is not set
-# CONFIG_ARCH_VERSATILE is not set
-# CONFIG_ARCH_VEXPRESS is not set
-# CONFIG_ARCH_AT91 is not set
-# CONFIG_ARCH_BCMRING is not set
-# CONFIG_ARCH_CLPS711X is not set
-# CONFIG_ARCH_CNS3XXX 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_MXS is not set
-# CONFIG_ARCH_NETX is not set
-# CONFIG_ARCH_H720X 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_DOVE is not set
-# CONFIG_ARCH_KIRKWOOD is not set
-# CONFIG_ARCH_LOKI is not set
-# CONFIG_ARCH_LPC32XX 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_W90X900 is not set
-# CONFIG_ARCH_NUC93X is not set
-# CONFIG_ARCH_TEGRA is not set
-# CONFIG_ARCH_PNX4008 is not set
-# CONFIG_ARCH_PXA is not set
-# CONFIG_ARCH_MSM is not set
-# CONFIG_ARCH_SHMOBILE 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_S5P64X0 is not set
-# CONFIG_ARCH_S5PC100 is not set
-CONFIG_ARCH_S5PV210=y
-# CONFIG_ARCH_EXYNOS4 is not set
-# CONFIG_ARCH_SHARK is not set
-# CONFIG_ARCH_TCC_926 is not set
-# CONFIG_ARCH_U300 is not set
-# CONFIG_ARCH_U8500 is not set
-# CONFIG_ARCH_NOMADIK is not set
-# CONFIG_ARCH_DAVINCI is not set
-# CONFIG_ARCH_OMAP is not set
-# CONFIG_PLAT_SPEAR is not set
-# CONFIG_ARCH_VT8500 is not set
-# CONFIG_GPIO_PCA953X is not set
-# CONFIG_KEYBOARD_GPIO_POLLED is not set
-CONFIG_PLAT_SAMSUNG=y
-
-#
-# Boot options
-#
-# CONFIG_S3C_BOOT_WATCHDOG is not set
-# CONFIG_S3C_BOOT_ERROR_RESET is not set
-CONFIG_S3C_BOOT_UART_FORCE_FIFO=y
-CONFIG_S3C_LOWLEVEL_UART_PORT=2
-CONFIG_SAMSUNG_CLKSRC=y
-CONFIG_SAMSUNG_IRQ_VIC_TIMER=y
-CONFIG_SAMSUNG_IRQ_UART=y
-CONFIG_SAMSUNG_GPIOLIB_4BIT=y
-CONFIG_S3C_GPIO_CFG_S3C24XX=y
-CONFIG_S3C_GPIO_CFG_S3C64XX=y
-CONFIG_S3C_GPIO_PULL_UPDOWN=y
-CONFIG_S5P_GPIO_DRVSTR=y
-CONFIG_SAMSUNG_GPIO_EXTRA=0
-CONFIG_S3C_GPIO_SPACE=0
-CONFIG_S3C_GPIO_TRACK=y
-# CONFIG_S3C_ADC is not set
-CONFIG_S3C_DEV_HSMMC=y
-CONFIG_S3C_DEV_HSMMC1=y
-CONFIG_S3C_DEV_HSMMC2=y
-CONFIG_S3C_DEV_HSMMC3=y
-CONFIG_S3C_DEV_I2C1=y
-CONFIG_S3C_DEV_I2C2=y
-CONFIG_S3C_DEV_FB=y
-CONFIG_S3C_DEV_WDT=y
-CONFIG_S3C_DEV_NAND=y
-CONFIG_S3C_DEV_RTC=y
-CONFIG_SAMSUNG_DEV_ADC=y
-CONFIG_S3C64XX_DEV_SPI=y
-CONFIG_SAMSUNG_DEV_TS=y
-CONFIG_SAMSUNG_DEV_PWM=y
-CONFIG_S3C24XX_PWM=y
-CONFIG_S3C_PL330_DMA=y
-
-#
-# Power management
-#
-# CONFIG_SAMSUNG_PM_DEBUG is not set
-# CONFIG_SAMSUNG_PM_CHECK is not set
-
-#
-# Power Domain
-#
-# CONFIG_SAMSUNG_PD is not set
-CONFIG_PLAT_S5P=y
-CONFIG_S5P_EXT_INT=y
-CONFIG_S5P_HRT=y
-
-#
-# System MMU
-#
-CONFIG_S5P_DEV_USB_EHCI=y
-CONFIG_S5P_DEV_USB_OHCI=y
-CONFIG_S5P_HIGH_RES_TIMERS=y
-CONFIG_HRT_RTC=y
-CONFIG_S5P_DEV_MFC=y
-CONFIG_S5P_SETUP_MFC=y
-CONFIG_S5P_DEV_USB_HSDEVICE=y
-CONFIG_CPU_S5PV210=y
-CONFIG_S5PV210_SETUP_I2C1=y
-CONFIG_S5PV210_SETUP_I2C2=y
-CONFIG_S5PV210_SETUP_IDE=y
-CONFIG_S5PV210_SETUP_FB_24BPP=y
-CONFIG_S5PV210_SETUP_SDHCI=y
-CONFIG_S5PV210_SETUP_SDHCI_GPIO=y
-CONFIG_S5PV210_SETUP_FIMC=y
-CONFIG_S5PV210_SETUP_USB_PHY=y
-CONFIG_S5PV210_POWER_DOMAIN=y
-
-#
-# S5PC110 Machines
-#
-# CONFIG_MACH_AQUILA is not set
-# CONFIG_MACH_GONI is not set
-# CONFIG_MACH_SMDKC110 is not set
-
-#
-# S5PV210 Machines
-#
-CONFIG_MACH_SMDKV210=y
-# CONFIG_MACH_TORBRECK is not set
-CONFIG_S5PV210_PM=y
-CONFIG_S5PV210_SETUP_FIMC0=y
-CONFIG_S5PV210_SETUP_FIMC1=y
-CONFIG_S5PV210_SETUP_FIMC2=y
-CONFIG_S5PV210_SETUP_CSIS=y
-
-#
-# Processor Type
-#
-CONFIG_CPU_V7=y
-CONFIG_CPU_32v6K=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_SWP_EMULATE 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_ARM_L1_CACHE_SHIFT_6=y
-CONFIG_ARM_L1_CACHE_SHIFT=6
-CONFIG_ARM_DMA_MEM_BUFFERABLE=y
-CONFIG_CPU_HAS_PMU=y
-# CONFIG_ARM_ERRATA_430973 is not set
-# CONFIG_ARM_ERRATA_458693 is not set
-# CONFIG_ARM_ERRATA_460075 is not set
-# CONFIG_ARM_ERRATA_743622 is not set
-# CONFIG_ARM_ERRATA_754322 is not set
-CONFIG_ARM_VIC=y
-CONFIG_ARM_VIC_NR=4
-CONFIG_PL330=y
-# CONFIG_FIQ_DEBUGGER is not set
-
-#
-# 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 is not set
-# CONFIG_PREEMPT_VOLUNTARY is not set
-CONFIG_PREEMPT=y
-CONFIG_HZ=200
-# CONFIG_THUMB2_KERNEL is not set
-CONFIG_AEABI=y
-CONFIG_OABI_COMPAT=y
-CONFIG_ARCH_HAS_HOLES_MEMORYMODEL=y
-CONFIG_ARCH_SPARSEMEM_ENABLE=y
-CONFIG_ARCH_SPARSEMEM_DEFAULT=y
-CONFIG_ARCH_SELECT_MEMORY_MODEL=y
-CONFIG_HAVE_ARCH_PFN_VALID=y
-# CONFIG_HIGHMEM is not set
-CONFIG_SELECT_MEMORY_MODEL=y
-CONFIG_SPARSEMEM_MANUAL=y
-CONFIG_SPARSEMEM=y
-CONFIG_HAVE_MEMORY_PRESENT=y
-CONFIG_SPARSEMEM_EXTREME=y
-CONFIG_HAVE_MEMBLOCK=y
-CONFIG_SPLIT_PTLOCK_CPUS=4
-# CONFIG_COMPACTION is not set
-# 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_NEED_PER_CPU_KM=y
-# CONFIG_CLEANCACHE is not set
-CONFIG_FORCE_MAX_ZONEORDER=11
-CONFIG_ALIGNMENT_TRAP=y
-# CONFIG_UACCESS_WITH_MEMCPY is not set
-# CONFIG_SECCOMP is not set
-# CONFIG_CC_STACKPROTECTOR is not set
-# CONFIG_DEPRECATED_PARAM_STRUCT is not set
-# CONFIG_ARM_FLUSH_CONSOLE_ON_RESTART is not set
-
-#
-# Boot options
-#
-# CONFIG_USE_OF is not set
-CONFIG_ZBOOT_ROM_TEXT=0
-CONFIG_ZBOOT_ROM_BSS=0x0
-# CONFIG_ZBOOT_ROM is not set
-CONFIG_CMDLINE="console=ttySAC2,115200 init=/init"
-CONFIG_CMDLINE_FROM_BOOTLOADER=y
-# CONFIG_CMDLINE_EXTEND is not set
-# CONFIG_CMDLINE_FORCE is not set
-# CONFIG_XIP_KERNEL is not set
-# CONFIG_KEXEC is not set
-# CONFIG_CRASH_DUMP is not set
-CONFIG_AUTO_ZRELADDR=y
-
-#
-# CPU Power Management
-#
-
-#
-# CPU Frequency scaling
-#
-# 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 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=y
-CONFIG_HAVE_AOUT=y
-# CONFIG_BINFMT_AOUT is not set
-CONFIG_BINFMT_MISC=y
-
-#
-# Power management options
-#
-CONFIG_SUSPEND=y
-CONFIG_SUSPEND_FREEZER=y
-CONFIG_HAS_WAKELOCK=y
-CONFIG_HAS_EARLYSUSPEND=y
-CONFIG_WAKELOCK=y
-CONFIG_WAKELOCK_STAT=y
-CONFIG_USER_WAKELOCK=y
-CONFIG_EARLYSUSPEND=y
-# CONFIG_NO_USER_SPACE_SCREEN_ACCESS_CONTROL is not set
-# CONFIG_CONSOLE_EARLYSUSPEND is not set
-CONFIG_FB_EARLYSUSPEND=y
-CONFIG_PM_SLEEP=y
-CONFIG_PM_RUNTIME=y
-CONFIG_PM=y
-# CONFIG_PM_DEBUG is not set
-# CONFIG_APM_EMULATION is not set
-CONFIG_PM_RUNTIME_CLK=y
-# CONFIG_SUSPEND_TIME is not set
-CONFIG_ARCH_SUSPEND_POSSIBLE=y
-CONFIG_NET=y
-
-#
-# Networking options
-#
-# CONFIG_PACKET is not set
-# CONFIG_UNIX is not set
-# CONFIG_NET_KEY is not set
-# CONFIG_INET is not set
-CONFIG_ANDROID_PARANOID_NETWORK=y
-CONFIG_NET_ACTIVITY_STATS=y
-# CONFIG_NETWORK_SECMARK is not set
-# CONFIG_NETWORK_PHY_TIMESTAMPING is not set
-# CONFIG_NETFILTER is not set
-# CONFIG_ATM is not set
-# CONFIG_BRIDGE 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_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
-# CONFIG_DNS_RESOLVER is not set
-# CONFIG_BATMAN_ADV is not set
-
-#
-# Network testing
-#
-# CONFIG_NET_PKTGEN is not set
-# CONFIG_HAMRADIO is not set
-# CONFIG_CAN is not set
-# CONFIG_IRDA is not set
-# CONFIG_BT 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_RFKILL_REGULATOR is not set
-# CONFIG_NET_9P is not set
-# CONFIG_CAIF is not set
-
-#
-# Device Drivers
-#
-
-#
-# Generic Driver Options
-#
-CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
-CONFIG_DEVTMPFS=y
-CONFIG_DEVTMPFS_MOUNT=y
-CONFIG_STANDALONE=y
-CONFIG_PREVENT_FIRMWARE_BUILD=y
-CONFIG_FW_LOADER=y
-CONFIG_FIRMWARE_IN_KERNEL=y
-CONFIG_EXTRA_FIRMWARE=""
-# CONFIG_SYS_HYPERVISOR is not set
-# CONFIG_CONNECTOR is not set
-CONFIG_MTD=y
-CONFIG_MTD_DEBUG=y
-CONFIG_MTD_DEBUG_VERBOSE=0
-# CONFIG_MTD_TESTS is not set
-# CONFIG_MTD_CONCAT is not set
-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 is not set
-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_SM_FTL 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_IDS=y
-CONFIG_MTD_NAND_ECC=y
-# CONFIG_MTD_NAND_ECC_SMC is not set
-CONFIG_MTD_NAND=y
-# CONFIG_MTD_NAND_VERIFY_WRITE is not set
-# CONFIG_MTD_NAND_ECC_BCH is not set
-# CONFIG_MTD_SM_COMMON is not set
-# CONFIG_MTD_NAND_MUSEUM_IDS is not set
-# CONFIG_MTD_NAND_GPIO is not set
-CONFIG_MTD_NAND_S3C=y
-CONFIG_MTD_NAND_S3C_DEBUG=y
-CONFIG_MTD_NAND_S3C_HWECC=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
-# 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=8192
-# 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_SENSORS_LIS3LV02D is not set
-CONFIG_MISC_DEVICES=y
-# CONFIG_AD525X_DPOT is not set
-CONFIG_ANDROID_PMEM=y
-
-#
-# Reserved memory configurations
-#
-CONFIG_ANDROID_PMEM_MEMSIZE_PMEM=8192
-CONFIG_ANDROID_PMEM_MEMSIZE_PMEM_GPU1=3072
-CONFIG_ANDROID_PMEM_MEMSIZE_PMEM_ADSP=6144
-# CONFIG_INTEL_MID_PTI is not set
-# CONFIG_ICS932S401 is not set
-# CONFIG_ENCLOSURE_SERVICES is not set
-# CONFIG_APDS9802ALS is not set
-# CONFIG_ISL29003 is not set
-# CONFIG_ISL29020 is not set
-# CONFIG_SENSORS_TSL2550 is not set
-# CONFIG_SENSORS_BH1780 is not set
-# CONFIG_SENSORS_BH1770 is not set
-# CONFIG_SENSORS_APDS990X is not set
-# CONFIG_HMC6352 is not set
-# CONFIG_SENSORS_AK8975 is not set
-# CONFIG_DS1682 is not set
-# CONFIG_UID_STAT is not set
-# CONFIG_BMP085 is not set
-# CONFIG_APANIC is not set
-# CONFIG_C2PORT is not set
-
-#
-# EEPROM support
-#
-# CONFIG_EEPROM_AT24 is not set
-# CONFIG_EEPROM_LEGACY is not set
-# CONFIG_EEPROM_MAX6875 is not set
-# CONFIG_EEPROM_93CX6 is not set
-# CONFIG_IWMC3200TOP is not set
-
-#
-# Texas Instruments shared transport line discipline
-#
-# CONFIG_TI_ST is not set
-# CONFIG_SENSORS_LIS3_I2C is not set
-CONFIG_HAVE_IDE=y
-# CONFIG_IDE is not set
-
-#
-# SCSI device support
-#
-CONFIG_SCSI_MOD=y
-# 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=y
-# CONFIG_CHR_DEV_SCH is not set
-CONFIG_SCSI_MULTI_LUN=y
-# 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_ATTRS is not set
-# CONFIG_SCSI_SAS_LIBSAS is not set
-# CONFIG_SCSI_SRP_ATTRS is not set
-CONFIG_SCSI_LOWLEVEL=y
-# CONFIG_ISCSI_BOOT_SYSFS 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_TARGET_CORE is not set
-# CONFIG_NETDEVICES 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=y
-CONFIG_INPUT_MOUSEDEV_PSAUX=y
-CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024
-CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768
-# CONFIG_INPUT_JOYDEV is not set
-CONFIG_INPUT_EVDEV=y
-# CONFIG_INPUT_EVBUG is not set
-# CONFIG_INPUT_KEYRESET is not set
-
-#
-# Input Device Drivers
-#
-CONFIG_INPUT_KEYBOARD=y
-# CONFIG_KEYBOARD_ADP5588 is not set
-# CONFIG_KEYBOARD_ADP5589 is not set
-CONFIG_KEYBOARD_ATKBD=y
-# CONFIG_KEYBOARD_QT1070 is not set
-# CONFIG_KEYBOARD_QT2160 is not set
-# CONFIG_KEYBOARD_LKKBD is not set
-CONFIG_KEYBOARD_GPIO=y
-# CONFIG_KEYBOARD_TCA6416 is not set
-# CONFIG_KEYBOARD_MATRIX is not set
-# CONFIG_KEYBOARD_LM8323 is not set
-# CONFIG_KEYBOARD_MAX7359 is not set
-# CONFIG_KEYBOARD_MCS is not set
-# CONFIG_KEYBOARD_MPR121 is not set
-# CONFIG_KEYBOARD_NEWTON is not set
-# CONFIG_KEYBOARD_OPENCORES is not set
-# CONFIG_KEYBOARD_STOWAWAY is not set
-# CONFIG_KEYBOARD_SUNKBD is not set
-# CONFIG_KEYBOARD_XTKBD is not set
-CONFIG_INPUT_MOUSE=y
-CONFIG_MOUSE_PS2=y
-CONFIG_MOUSE_PS2_ALPS=y
-CONFIG_MOUSE_PS2_LOGIPS2PP=y
-CONFIG_MOUSE_PS2_SYNAPTICS=y
-CONFIG_MOUSE_PS2_TRACKPOINT=y
-# CONFIG_MOUSE_PS2_ELANTECH is not set
-# CONFIG_MOUSE_PS2_SENTELIC is not set
-# CONFIG_MOUSE_PS2_TOUCHKIT is not set
-# CONFIG_MOUSE_SERIAL is not set
-# CONFIG_MOUSE_APPLETOUCH is not set
-# CONFIG_MOUSE_BCM5974 is not set
-# CONFIG_MOUSE_VSXXXAA is not set
-# CONFIG_MOUSE_GPIO is not set
-# CONFIG_MOUSE_SYNAPTICS_I2C is not set
-# CONFIG_INPUT_JOYSTICK is not set
-# CONFIG_INPUT_TABLET is not set
-CONFIG_INPUT_TOUCHSCREEN=y
-# CONFIG_TOUCHSCREEN_AD7879 is not set
-# CONFIG_TOUCHSCREEN_ATMEL_MXT is not set
-# CONFIG_TOUCHSCREEN_BU21013 is not set
-# CONFIG_TOUCHSCREEN_CY8CTMG110 is not set
-CONFIG_TOUCHSCREEN_FORLINX=y
-CONFIG_TOUCHSCREEN_FT5306=y
-# CONFIG_TOUCHSCREEN_DYNAPRO is not set
-# CONFIG_TOUCHSCREEN_HAMPSHIRE is not set
-# CONFIG_TOUCHSCREEN_EETI is not set
-# CONFIG_TOUCHSCREEN_EGALAX is not set
-# CONFIG_TOUCHSCREEN_FUJITSU is not set
-# CONFIG_TOUCHSCREEN_S3C2410 is not set
-# CONFIG_TOUCHSCREEN_GUNZE is not set
-# CONFIG_TOUCHSCREEN_ELO is not set
-# CONFIG_TOUCHSCREEN_WACOM_W8001 is not set
-# CONFIG_TOUCHSCREEN_MAX11801 is not set
-# CONFIG_TOUCHSCREEN_MCS5000 is not set
-# CONFIG_TOUCHSCREEN_MTOUCH is not set
-# CONFIG_TOUCHSCREEN_INEXIO is not set
-# CONFIG_TOUCHSCREEN_MK712 is not set
-# CONFIG_TOUCHSCREEN_PENMOUNT is not set
-# CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI is not set
-# CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set
-# CONFIG_TOUCHSCREEN_TOUCHWIN is not set
-# CONFIG_TOUCHSCREEN_WM97XX is not set
-# CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set
-# CONFIG_TOUCHSCREEN_TOUCHIT213 is not set
-# CONFIG_TOUCHSCREEN_TSC2007 is not set
-# CONFIG_TOUCHSCREEN_W90X900 is not set
-# CONFIG_TOUCHSCREEN_ST1232 is not set
-# CONFIG_TOUCHSCREEN_TPS6507X 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_SERIO_PS2MULT 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_UNIX98_PTYS=y
-# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set
-CONFIG_LEGACY_PTYS=y
-CONFIG_LEGACY_PTY_COUNT=256
-# CONFIG_SERIAL_NONSTANDARD is not set
-# CONFIG_N_GSM is not set
-# CONFIG_TRACE_SINK is not set
-CONFIG_DEVMEM=y
-CONFIG_DEVKMEM=y
-CONFIG_FL210_LEDS=y
-CONFIG_FL210_HELLO_MODULE=y
-# CONFIG_FL210_BUZZER is not set
-CONFIG_FL210_ADC=y
-CONFIG_FL210_TEM=y
-
-#
-# Serial drivers
-#
-# CONFIG_SERIAL_8250 is not set
-
-#
-# Non-8250 serial port support
-#
-CONFIG_SERIAL_SAMSUNG=y
-CONFIG_SERIAL_SAMSUNG_UARTS_4=y
-CONFIG_SERIAL_SAMSUNG_UARTS=4
-CONFIG_SERIAL_SAMSUNG_CONSOLE=y
-CONFIG_SERIAL_S5PV210=y
-CONFIG_SERIAL_CORE=y
-CONFIG_SERIAL_CORE_CONSOLE=y
-# CONFIG_SERIAL_TIMBERDALE is not set
-# CONFIG_SERIAL_ALTERA_JTAGUART is not set
-# CONFIG_SERIAL_ALTERA_UART is not set
-# CONFIG_SERIAL_XILINX_PS_UART is not set
-# CONFIG_TTY_PRINTK is not set
-# CONFIG_HVC_DCC 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_DCC_TTY is not set
-# CONFIG_RAMOOPS is not set
-CONFIG_S3C_MEM=y
-CONFIG_I2C=y
-CONFIG_I2C_BOARDINFO=y
-CONFIG_I2C_COMPAT=y
-CONFIG_I2C_CHARDEV=y
-# CONFIG_I2C_MUX is not set
-CONFIG_I2C_HELPER_AUTO=y
-CONFIG_I2C_ALGOBIT=y
-
-#
-# I2C Hardware Bus support
-#
-
-#
-# I2C system bus drivers (mostly embedded / system-on-chip)
-#
-# CONFIG_I2C_DESIGNWARE is not set
-CONFIG_I2C_GPIO=y
-# CONFIG_I2C_OCORES is not set
-# CONFIG_I2C_PCA_PLATFORM is not set
-# CONFIG_I2C_PXA_PCI is not set
-CONFIG_HAVE_S3C2410_I2C=y
-CONFIG_I2C_S3C2410=y
-# CONFIG_I2C_SIMTEC is not set
-# CONFIG_I2C_XILINX is not set
-
-#
-# External I2C/SMBus adapter drivers
-#
-# CONFIG_I2C_DIOLAN_U2C is not set
-# 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_STUB 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_SPI is not set
-
-#
-# PPS support
-#
-# CONFIG_PPS is not set
-
-#
-# PPS generators support
-#
-
-#
-# PTP clock support
-#
-
-#
-# Enable Device Drivers -> PPS to see the PTP clock options.
-#
-CONFIG_ARCH_REQUIRE_GPIOLIB=y
-CONFIG_GPIOLIB=y
-# CONFIG_GPIO_SYSFS is not set
-
-#
-# Memory mapped GPIO drivers:
-#
-# CONFIG_GPIO_BASIC_MMIO is not set
-# CONFIG_GPIO_IT8761E is not set
-CONFIG_GPIO_PLAT_SAMSUNG=y
-CONFIG_GPIO_S5PV210=y
-
-#
-# I2C GPIO expanders:
-#
-# CONFIG_GPIO_MAX7300 is not set
-# CONFIG_GPIO_MAX732X is not set
-# CONFIG_GPIO_PCF857X is not set
-# CONFIG_GPIO_SX150X is not set
-# CONFIG_GPIO_ADP5588 is not set
-
-#
-# PCI GPIO expanders:
-#
-
-#
-# SPI GPIO expanders:
-#
-
-#
-# AC97 GPIO expanders:
-#
-
-#
-# MODULbus GPIO expanders:
-#
-# CONFIG_W1 is not set
-CONFIG_POWER_SUPPLY=y
-# CONFIG_POWER_SUPPLY_DEBUG is not set
-# CONFIG_PDA_POWER is not set
-# CONFIG_TEST_POWER is not set
-# CONFIG_BATTERY_DS2780 is not set
-# CONFIG_BATTERY_DS2782 is not set
-# CONFIG_BATTERY_BQ20Z75 is not set
-# CONFIG_BATTERY_BQ27x00 is not set
-# CONFIG_BATTERY_MAX17040 is not set
-# CONFIG_BATTERY_MAX17042 is not set
-CONFIG_BATTERY_S3C=y
-# CONFIG_CHARGER_MAX8903 is not set
-# CONFIG_CHARGER_GPIO is not set
-# CONFIG_HWMON is not set
-# CONFIG_THERMAL is not set
-CONFIG_WATCHDOG=y
-# CONFIG_WATCHDOG_NOWAYOUT is not set
-
-#
-# Watchdog Device Drivers
-#
-# CONFIG_SOFT_WATCHDOG is not set
-CONFIG_HAVE_S3C2410_WATCHDOG=y
-CONFIG_S3C2410_WATCHDOG=y
-# CONFIG_MAX63XX_WATCHDOG is not set
-
-#
-# USB-based Watchdog Cards
-#
-# CONFIG_USBPCWATCHDOG is not set
-CONFIG_SSB_POSSIBLE=y
-
-#
-# Sonics Silicon Backplane
-#
-# CONFIG_SSB is not set
-CONFIG_BCMA_POSSIBLE=y
-
-#
-# Broadcom specific AMBA
-#
-# CONFIG_BCMA is not set
-CONFIG_MFD_SUPPORT=y
-# CONFIG_MFD_CORE is not set
-# CONFIG_MFD_88PM860X 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_HTC_I2CPLD is not set
-# CONFIG_UCB1400_CORE is not set
-# CONFIG_TPS6105X is not set
-# CONFIG_TPS65010 is not set
-# CONFIG_TPS6507X is not set
-# CONFIG_MFD_TPS6586X is not set
-# CONFIG_TWL4030_CORE is not set
-# CONFIG_MFD_STMPE is not set
-# CONFIG_MFD_TC3589X is not set
-# CONFIG_MFD_TMIO is not set
-# CONFIG_MFD_T7L66XB is not set
-# CONFIG_MFD_TC6387XB is not set
-# CONFIG_MFD_TC6393XB is not set
-# CONFIG_PMIC_DA903X is not set
-# CONFIG_PMIC_ADP5520 is not set
-# CONFIG_MFD_MAX8698 is not set
-# CONFIG_MFD_MAX8925 is not set
-# CONFIG_MFD_MAX8997 is not set
-# CONFIG_MFD_MAX8998 is not set
-# CONFIG_MFD_WM8400 is not set
-# CONFIG_MFD_WM831X_I2C is not set
-# CONFIG_MFD_WM8350_I2C is not set
-# CONFIG_MFD_WM8994 is not set
-# CONFIG_MFD_PCF50633 is not set
-# CONFIG_ABX500_CORE is not set
-# CONFIG_MFD_WL1273_CORE is not set
-# CONFIG_MFD_TPS65910 is not set
-CONFIG_REGULATOR=y
-CONFIG_REGULATOR_DEBUG=y
-# CONFIG_REGULATOR_DUMMY 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_MAX8649 is not set
-# CONFIG_REGULATOR_MAX8660 is not set
-# CONFIG_REGULATOR_MAX8952 is not set
-# CONFIG_REGULATOR_LP3971 is not set
-# CONFIG_REGULATOR_LP3972 is not set
-# CONFIG_REGULATOR_TPS65023 is not set
-# CONFIG_REGULATOR_TPS6507X is not set
-# CONFIG_REGULATOR_ISL6271A is not set
-# CONFIG_REGULATOR_AD5398 is not set
-CONFIG_MEDIA_SUPPORT=y
-
-#
-# Multimedia core support
-#
-# CONFIG_MEDIA_CONTROLLER is not set
-CONFIG_VIDEO_DEV=y
-CONFIG_VIDEO_V4L2_COMMON=y
-CONFIG_VIDEO_MEDIA=y
-
-#
-# Multimedia drivers
-#
-CONFIG_RC_CORE=y
-CONFIG_LIRC=y
-CONFIG_RC_MAP=y
-CONFIG_IR_NEC_DECODER=y
-CONFIG_IR_RC5_DECODER=y
-CONFIG_IR_RC6_DECODER=y
-CONFIG_IR_JVC_DECODER=y
-CONFIG_IR_SONY_DECODER=y
-CONFIG_IR_RC5_SZ_DECODER=y
-CONFIG_IR_LIRC_CODEC=y
-# CONFIG_IR_IMON is not set
-# CONFIG_IR_MCEUSB is not set
-# CONFIG_IR_REDRAT3 is not set
-# CONFIG_IR_STREAMZAP is not set
-# CONFIG_RC_LOOPBACK is not set
-# CONFIG_MEDIA_ATTACH is not set
-CONFIG_MEDIA_TUNER=y
-CONFIG_MEDIA_TUNER_CUSTOMISE=y
-
-#
-# Customize TV tuners
-#
-# CONFIG_MEDIA_TUNER_SIMPLE is not set
-# CONFIG_MEDIA_TUNER_TDA8290 is not set
-# CONFIG_MEDIA_TUNER_TDA827X is not set
-# CONFIG_MEDIA_TUNER_TDA18271 is not set
-# CONFIG_MEDIA_TUNER_TDA9887 is not set
-# CONFIG_MEDIA_TUNER_TEA5761 is not set
-# CONFIG_MEDIA_TUNER_TEA5767 is not set
-# CONFIG_MEDIA_TUNER_MT20XX is not set
-# CONFIG_MEDIA_TUNER_MT2060 is not set
-# CONFIG_MEDIA_TUNER_MT2266 is not set
-# CONFIG_MEDIA_TUNER_MT2131 is not set
-# CONFIG_MEDIA_TUNER_QT1010 is not set
-# CONFIG_MEDIA_TUNER_XC2028 is not set
-# CONFIG_MEDIA_TUNER_XC5000 is not set
-# CONFIG_MEDIA_TUNER_MXL5005S is not set
-# CONFIG_MEDIA_TUNER_MXL5007T is not set
-# CONFIG_MEDIA_TUNER_MC44S803 is not set
-# CONFIG_MEDIA_TUNER_MAX2165 is not set
-# CONFIG_MEDIA_TUNER_TDA18218 is not set
-# CONFIG_MEDIA_TUNER_TDA18212 is not set
-CONFIG_VIDEO_V4L2=y
-CONFIG_VIDEOBUF_GEN=y
-CONFIG_VIDEOBUF2_CORE=y
-CONFIG_VIDEO_CAPTURE_DRIVERS=y
-# CONFIG_VIDEO_ADV_DEBUG is not set
-CONFIG_VIDEO_FIXED_MINOR_RANGES=y
-# CONFIG_VIDEO_HELPER_CHIPS_AUTO is not set
-CONFIG_VIDEO_IR_I2C=y
-
-#
-# Encoders, decoders, sensors and other helper chips
-#
-
-#
-# Audio decoders, processors and mixers
-#
-# CONFIG_VIDEO_TVAUDIO is not set
-# CONFIG_VIDEO_TDA7432 is not set
-# CONFIG_VIDEO_TDA9840 is not set
-# CONFIG_VIDEO_TEA6415C is not set
-# CONFIG_VIDEO_TEA6420 is not set
-# CONFIG_VIDEO_MSP3400 is not set
-# CONFIG_VIDEO_CS5345 is not set
-# CONFIG_VIDEO_CS53L32A is not set
-# CONFIG_VIDEO_TLV320AIC23B is not set
-# CONFIG_VIDEO_WM8775 is not set
-# CONFIG_VIDEO_WM8739 is not set
-# CONFIG_VIDEO_VP27SMPX is not set
-
-#
-# RDS decoders
-#
-# CONFIG_VIDEO_SAA6588 is not set
-
-#
-# Video decoders
-#
-# CONFIG_VIDEO_ADV7180 is not set
-# CONFIG_VIDEO_BT819 is not set
-# CONFIG_VIDEO_BT856 is not set
-# CONFIG_VIDEO_BT866 is not set
-# CONFIG_VIDEO_KS0127 is not set
-# CONFIG_VIDEO_SAA7110 is not set
-# CONFIG_VIDEO_SAA711X is not set
-# CONFIG_VIDEO_SAA7191 is not set
-# CONFIG_VIDEO_TVP514X is not set
-# CONFIG_VIDEO_TVP5150 is not set
-# CONFIG_VIDEO_TVP7002 is not set
-# CONFIG_VIDEO_VPX3220 is not set
-
-#
-# Video and audio decoders
-#
-# CONFIG_VIDEO_SAA717X is not set
-# CONFIG_VIDEO_CX25840 is not set
-
-#
-# MPEG video encoders
-#
-# CONFIG_VIDEO_CX2341X is not set
-
-#
-# Video encoders
-#
-# CONFIG_VIDEO_SAA7127 is not set
-# CONFIG_VIDEO_SAA7185 is not set
-# CONFIG_VIDEO_ADV7170 is not set
-# CONFIG_VIDEO_ADV7175 is not set
-# CONFIG_VIDEO_ADV7343 is not set
-# CONFIG_VIDEO_AK881X is not set
-
-#
-# Camera sensor devices
-#
-# CONFIG_VIDEO_OV7670 is not set
-# CONFIG_VIDEO_MT9V011 is not set
-# CONFIG_VIDEO_TCM825X is not set
-
-#
-# Video improvement chips
-#
-# CONFIG_VIDEO_UPD64031A is not set
-# CONFIG_VIDEO_UPD64083 is not set
-
-#
-# Miscelaneous helper chips
-#
-# CONFIG_VIDEO_THS7303 is not set
-# CONFIG_VIDEO_M52790 is not set
-# CONFIG_VIDEO_CPIA2 is not set
-# CONFIG_VIDEO_SR030PC30 is not set
-# CONFIG_VIDEO_NOON010PC30 is not set
-CONFIG_SOC_CAMERA=y
-# CONFIG_SOC_CAMERA_IMX074 is not set
-# CONFIG_SOC_CAMERA_MT9M001 is not set
-# CONFIG_SOC_CAMERA_MT9M111 is not set
-# CONFIG_SOC_CAMERA_MT9T031 is not set
-# CONFIG_SOC_CAMERA_MT9T112 is not set
-# CONFIG_SOC_CAMERA_MT9V022 is not set
-# CONFIG_SOC_CAMERA_RJ54N1 is not set
-# CONFIG_SOC_CAMERA_TW9910 is not set
-# CONFIG_SOC_CAMERA_PLATFORM is not set
-# CONFIG_SOC_CAMERA_OV2640 is not set
-# CONFIG_SOC_CAMERA_OV6650 is not set
-# CONFIG_SOC_CAMERA_OV772X is not set
-CONFIG_SOC_CAMERA_OV9640=y
-# CONFIG_SOC_CAMERA_OV9740 is not set
-# CONFIG_VIDEO_SH_MOBILE_CSI2 is not set
-# CONFIG_VIDEO_SH_MOBILE_CEU is not set
-# CONFIG_VIDEO_SAMSUNG_S5P_FIMC is not set
-CONFIG_V4L_USB_DRIVERS=y
-CONFIG_USB_VIDEO_CLASS=y
-CONFIG_USB_VIDEO_CLASS_INPUT_EVDEV=y
-CONFIG_USB_GSPCA=y
-# CONFIG_USB_M5602 is not set
-# CONFIG_USB_STV06XX is not set
-# CONFIG_USB_GL860 is not set
-# CONFIG_USB_GSPCA_BENQ is not set
-# CONFIG_USB_GSPCA_CONEX is not set
-# CONFIG_USB_GSPCA_CPIA1 is not set
-# CONFIG_USB_GSPCA_ETOMS is not set
-# CONFIG_USB_GSPCA_FINEPIX is not set
-# CONFIG_USB_GSPCA_JEILINJ is not set
-# CONFIG_USB_GSPCA_KINECT is not set
-# CONFIG_USB_GSPCA_KONICA is not set
-# CONFIG_USB_GSPCA_MARS is not set
-# CONFIG_USB_GSPCA_MR97310A is not set
-# CONFIG_USB_GSPCA_NW80X is not set
-# CONFIG_USB_GSPCA_OV519 is not set
-# CONFIG_USB_GSPCA_OV534 is not set
-# CONFIG_USB_GSPCA_OV534_9 is not set
-# CONFIG_USB_GSPCA_PAC207 is not set
-# CONFIG_USB_GSPCA_PAC7302 is not set
-# CONFIG_USB_GSPCA_PAC7311 is not set
-# CONFIG_USB_GSPCA_SN9C2028 is not set
-# CONFIG_USB_GSPCA_SN9C20X is not set
-# CONFIG_USB_GSPCA_SONIXB is not set
-# CONFIG_USB_GSPCA_SONIXJ is not set
-# CONFIG_USB_GSPCA_SPCA500 is not set
-# CONFIG_USB_GSPCA_SPCA501 is not set
-# CONFIG_USB_GSPCA_SPCA505 is not set
-# CONFIG_USB_GSPCA_SPCA506 is not set
-# CONFIG_USB_GSPCA_SPCA508 is not set
-# CONFIG_USB_GSPCA_SPCA561 is not set
-# CONFIG_USB_GSPCA_SPCA1528 is not set
-# CONFIG_USB_GSPCA_SQ905 is not set
-# CONFIG_USB_GSPCA_SQ905C is not set
-# CONFIG_USB_GSPCA_SQ930X is not set
-# CONFIG_USB_GSPCA_STK014 is not set
-# CONFIG_USB_GSPCA_STV0680 is not set
-# CONFIG_USB_GSPCA_SUNPLUS is not set
-# CONFIG_USB_GSPCA_T613 is not set
-# CONFIG_USB_GSPCA_TV8532 is not set
-# CONFIG_USB_GSPCA_VC032X is not set
-# CONFIG_USB_GSPCA_VICAM is not set
-# CONFIG_USB_GSPCA_XIRLINK_CIT is not set
-# CONFIG_USB_GSPCA_ZC3XX is not set
-# CONFIG_VIDEO_PVRUSB2 is not set
-# CONFIG_VIDEO_HDPVR is not set
-# CONFIG_VIDEO_EM28XX is not set
-# CONFIG_VIDEO_CX231XX is not set
-# CONFIG_VIDEO_USBVISION is not set
-# CONFIG_USB_ET61X251 is not set
-# CONFIG_USB_SN9C102 is not set
-# CONFIG_USB_PWC is not set
-# CONFIG_USB_ZR364XX is not set
-# CONFIG_USB_STKWEBCAM is not set
-# CONFIG_USB_S2255 is not set
-# CONFIG_VIDEO_S5K4BA is not set
-# CONFIG_VIDEO_S5KA3DFX is not set
-# CONFIG_VIDEO_S5K4ECGX is not set
-CONFIG_VIDEO_SAMSUNG=y
-CONFIG_VIDEO_SAMSUNG_V4L2=y
-CONFIG_VIDEO_FIMC=y
-CONFIG_VIDEO_FIMC_RANGE_NARROW=y
-# CONFIG_VIDEO_FIMC_RANGE_WIDE is not set
-# CONFIG_VIDEO_FIMC_DEBUG is not set
-# CONFIG_VIDEO_FIMC_MIPI is not set
-CONFIG_VIDEO_MFC50=y
-CONFIG_VIDEO_MFC_MAX_INSTANCE=4
-# CONFIG_VIDEO_MFC50_DEBUG is not set
-CONFIG_VIDEO_G2D=y
-# CONFIG_VIDEO_G2D_DEBUG is not set
-CONFIG_VIDEO_JPEG_V2=y
-# CONFIG_VIDEO_JPEG_DEBUG is not set
-CONFIG_VIDEO_TV20=y
-CONFIG_HDMI_CEC=y
-CONFIG_HDMI_HPD=y
-# CONFIG_TV_FB is not set
-# CONFIG_V4L_MEM2MEM_DRIVERS is not set
-CONFIG_RADIO_ADAPTERS=y
-# CONFIG_I2C_SI4713 is not set
-# CONFIG_RADIO_SI4713 is not set
-# CONFIG_USB_DSBR is not set
-# CONFIG_RADIO_SI470X is not set
-# CONFIG_USB_MR800 is not set
-# CONFIG_RADIO_TEA5764 is not set
-# CONFIG_RADIO_SAA7706H is not set
-# CONFIG_RADIO_TEF6862 is not set
-# CONFIG_RADIO_WL1273 is not set
-
-#
-# Texas Instruments WL128x FM driver (ST based)
-#
-
-#
-# Graphics support
-#
-# CONFIG_DRM is not set
-# CONFIG_ION is not set
-CONFIG_PVR_SGX=y
-CONFIG_PVR_BUILD_RELEASE=y
-# CONFIG_PVR_BUILD_DEBUG is not set
-CONFIG_PVR_NEED_PVR_DPF=y
-CONFIG_PVR_NEED_PVR_ASSERT=y
-CONFIG_PVR_PERCONTEXT_PB=y
-CONFIG_PVR_ACTIVE_POWER_MANAGEMENT=y
-CONFIG_PVR_ACTIVE_POWER_LATENCY_MS=100
-CONFIG_PVR_SGX_LOW_LATENCY_SCHEDULING=y
-CONFIG_PVR_USSE_EDM_STATUS_DEBUG=y
-CONFIG_PVR_DUMP_MK_TRACE=y
-# CONFIG_PVR_PDUMP is not set
-# 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_WMT_GE_ROPS 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_S3C=y
-# CONFIG_FB_S3C_SPLASH_SCREEN is not set
-CONFIG_FB_S3C_LCD_INIT=y
-# CONFIG_FB_S3C_DEBUG is not set
-# CONFIG_FB_S3C_TRACE_UNDERRUN is not set
-CONFIG_FB_S3C_DEFAULT_WINDOW=2
-CONFIG_FB_S3C_NR_BUFFERS=2
-CONFIG_FB_S3C_NUM_OVLY_WIN=1
-CONFIG_FB_S3C_NUM_BUF_OVLY_WIN=3
-# CONFIG_FB_S3C_VIRTUAL is not set
-# CONFIG_FB_S3C_LB070WV6 is not set
-CONFIG_FB_S3C_LTE480WV=y
-# CONFIG_FB_S3C_101WA01S is not set
-# CONFIG_FB_S3C_TL2796 is not set
-# CONFIG_FB_S3C_HT101HD1 is not set
-# CONFIG_FB_S3C_NT35580 is not set
-# CONFIG_FB_S3C_LVDS is not set
-# CONFIG_FB_S3C_AMS701KA is not set
-# CONFIG_FB_S3C_MDNIE is not set
-# CONFIG_FB_S3C_CMC623 is not set
-# CONFIG_FB_S1D13XXX is not set
-# CONFIG_FB_S3C_DEBUG_REGWRITE is not set
-# CONFIG_FB_UDL is not set
-# CONFIG_FB_VIRTUAL is not set
-# CONFIG_FB_METRONOME is not set
-# CONFIG_FB_BROADSHEET is not set
-CONFIG_BACKLIGHT_LCD_SUPPORT=y
-CONFIG_LCD_CLASS_DEVICE=y
-# CONFIG_LCD_PLATFORM is not set
-CONFIG_BACKLIGHT_CLASS_DEVICE=y
-CONFIG_BACKLIGHT_GENERIC=y
-CONFIG_BACKLIGHT_PWM=y
-# CONFIG_BACKLIGHT_ADP8860 is not set
-# CONFIG_BACKLIGHT_ADP8870 is not set
-
-#
-# Display device support
-#
-# CONFIG_DISPLAY_SUPPORT is not set
-
-#
-# Console display driver support
-#
-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=y
-# CONFIG_SOUND_OSS_CORE is not set
-CONFIG_SND=y
-CONFIG_SND_TIMER=y
-CONFIG_SND_PCM=y
-CONFIG_SND_JACK=y
-# CONFIG_SND_SEQUENCER is not set
-# CONFIG_SND_MIXER_OSS is not set
-# CONFIG_SND_PCM_OSS is not set
-# CONFIG_SND_HRTIMER is not set
-# CONFIG_SND_DYNAMIC_MINORS is not set
-CONFIG_SND_SUPPORT_OLD_API=y
-CONFIG_SND_VERBOSE_PROCFS=y
-CONFIG_SND_VERBOSE_PRINTK=y
-CONFIG_SND_DEBUG=y
-CONFIG_SND_DEBUG_VERBOSE=y
-CONFIG_SND_PCM_XRUN_DEBUG=y
-# CONFIG_SND_RAWMIDI_SEQ is not set
-# CONFIG_SND_OPL3_LIB_SEQ is not set
-# CONFIG_SND_OPL4_LIB_SEQ is not set
-# CONFIG_SND_SBAWE_SEQ is not set
-# CONFIG_SND_EMU10K1_SEQ is not set
-CONFIG_SND_DRIVERS=y
-# CONFIG_SND_DUMMY is not set
-# CONFIG_SND_ALOOP is not set
-# CONFIG_SND_MTPAV is not set
-# CONFIG_SND_SERIAL_U16550 is not set
-# CONFIG_SND_MPU401 is not set
-CONFIG_SND_ARM=y
-CONFIG_SND_USB=y
-# CONFIG_SND_USB_AUDIO is not set
-# CONFIG_SND_USB_UA101 is not set
-# CONFIG_SND_USB_CAIAQ is not set
-# CONFIG_SND_USB_6FIRE is not set
-CONFIG_SND_SOC=y
-# CONFIG_SND_SOC_CACHE_LZO is not set
-CONFIG_SND_SOC_AC97_BUS=y
-CONFIG_SND_SOC_SAMSUNG=y
-CONFIG_SND_SAMSUNG_AC97=y
-# CONFIG_SND_SOC_SAMSUNG_SMDK_WM8580 is not set
-# CONFIG_SND_SOC_SAMSUNG_SMDK_WM8960 is not set
-CONFIG_SND_SOC_SAMSUNG_SMDK_WM9713=y
-# CONFIG_SND_SOC_SAMSUNG_SMDK_SPDIF is not set
-# CONFIG_SND_SOC_SMDK_WM8580_PCM is not set
-CONFIG_SND_SOC_I2C_AND_SPI=y
-# CONFIG_SND_SOC_ALL_CODECS is not set
-CONFIG_SND_SOC_WM9713=y
-# CONFIG_SOUND_PRIME is not set
-CONFIG_AC97_BUS=y
-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_ACRUX 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_PRODIKEYS is not set
-# CONFIG_HID_CYPRESS is not set
-# CONFIG_HID_DRAGONRISE is not set
-# CONFIG_HID_EMS_FF is not set
-# CONFIG_HID_EZKEY is not set
-# CONFIG_HID_KEYTOUCH is not set
-# CONFIG_HID_KYE is not set
-# CONFIG_HID_UCLOGIC is not set
-# CONFIG_HID_WALTOP is not set
-# CONFIG_HID_GYRATION is not set
-# CONFIG_HID_TWINHAN is not set
-# CONFIG_HID_KENSINGTON is not set
-# CONFIG_HID_LCPOWER is not set
-# CONFIG_HID_LOGITECH is not set
-# CONFIG_HID_MICROSOFT is not set
-# CONFIG_HID_MONTEREY is not set
-# CONFIG_HID_MULTITOUCH is not set
-# CONFIG_HID_NTRIG is not set
-# CONFIG_HID_ORTEK is not set
-# CONFIG_HID_PANTHERLORD is not set
-# CONFIG_HID_PETALYNX is not set
-# CONFIG_HID_PICOLCD is not set
-# CONFIG_HID_QUANTA is not set
-# CONFIG_HID_ROCCAT is not set
-# CONFIG_HID_ROCCAT_ARVO is not set
-# CONFIG_HID_ROCCAT_KONE is not set
-# CONFIG_HID_ROCCAT_KONEPLUS is not set
-# CONFIG_HID_ROCCAT_KOVAPLUS is not set
-# CONFIG_HID_ROCCAT_PYRA 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_HID_ZYDACRON 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 is not set
-
-#
-# Miscellaneous USB options
-#
-# CONFIG_USB_DEVICEFS is not set
-CONFIG_USB_DEVICE_CLASS=y
-# CONFIG_USB_DYNAMIC_MINORS is not set
-# CONFIG_USB_SUSPEND is not set
-# 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_EHCI_S5P=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=y
-CONFIG_USB_OHCI_S5P=y
-# CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set
-# CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set
-CONFIG_USB_OHCI_LITTLE_ENDIAN=y
-# 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 is not set
-
-#
-# 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_REALTEK 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_STORAGE_ENE_UB6250 is not set
-# CONFIG_USB_UAS 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_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 is not set
-# CONFIG_USB_ISIGHTFW is not set
-# CONFIG_USB_YUREX is not set
-CONFIG_USB_GADGET=y
-# CONFIG_USB_GADGET_DEBUG_FILES is not set
-CONFIG_USB_GADGET_VBUS_DRAW=2
-CONFIG_USB_GADGET_SELECTED=y
-# CONFIG_USB_GADGET_FUSB300 is not set
-# CONFIG_USB_GADGET_R8A66597 is not set
-CONFIG_USB_GADGET_S3C_OTGD=y
-# CONFIG_USB_GADGET_PXA_U2O is not set
-# CONFIG_USB_GADGET_M66592 is not set
-# CONFIG_USB_GADGET_DUMMY_HCD is not set
-
-#
-# NOTE: S3C OTG device role enables the controller driver below
-#
-CONFIG_USB_S3C_OTGD=y
-CONFIG_USB_GADGET_S3C_OTGD_DMA_MODE=y
-# CONFIG_USB_GADGET_S3C_OTGD_SLAVE_MODE is not set
-CONFIG_USB_GADGET_DUALSPEED=y
-# CONFIG_USB_ZERO is not set
-# CONFIG_USB_AUDIO is not set
-# CONFIG_USB_ETH is not set
-# CONFIG_USB_G_NCM is not set
-# CONFIG_USB_GADGETFS is not set
-# CONFIG_USB_FUNCTIONFS 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_G_ANDROID=y
-CONFIG_USB_ANDROID_RNDIS_DWORD_ALIGNED=y
-# CONFIG_USB_CDC_COMPOSITE is not set
-# CONFIG_USB_G_MULTI is not set
-# CONFIG_USB_G_HID is not set
-# CONFIG_USB_G_DBGP is not set
-# CONFIG_USB_G_WEBCAM is not set
-
-#
-# OTG and related infrastructure
-#
-# CONFIG_USB_OTG_WAKELOCK is not set
-# CONFIG_USB_GPIO_VBUS is not set
-# CONFIG_USB_ULPI is not set
-# CONFIG_NOP_USB_XCEIV is not set
-CONFIG_MMC=y
-# CONFIG_MMC_DEBUG is not set
-CONFIG_MMC_UNSAFE_RESUME=y
-# CONFIG_MMC_CLKGATE is not set
-# CONFIG_MMC_EMBEDDED_SDIO is not set
-# CONFIG_MMC_PARANOID_SD_INIT is not set
-
-#
-# MMC/SD/SDIO Card Drivers
-#
-CONFIG_MMC_BLOCK=y
-CONFIG_MMC_BLOCK_MINORS=8
-CONFIG_MMC_BLOCK_BOUNCE=y
-# CONFIG_MMC_BLOCK_DEFERRED_RESUME is not set
-# CONFIG_SDIO_UART is not set
-# CONFIG_MMC_TEST is not set
-
-#
-# MMC/SD/SDIO Host Controller Drivers
-#
-CONFIG_MMC_SDHCI=y
-CONFIG_MMC_SDHCI_PLTFM=y
-CONFIG_MMC_SDHCI_S3C=y
-CONFIG_MMC_SDHCI_S3C_DMA=y
-# CONFIG_MMC_DW is not set
-# CONFIG_MMC_VUB300 is not set
-# CONFIG_MMC_USHC is not set
-# CONFIG_MEMSTICK is not set
-CONFIG_NEW_LEDS=y
-CONFIG_LEDS_CLASS=y
-
-#
-# LED drivers
-#
-# CONFIG_LEDS_LM3530 is not set
-# CONFIG_LEDS_PCA9532 is not set
-CONFIG_LEDS_GPIO=y
-CONFIG_LEDS_GPIO_PLATFORM=y
-# CONFIG_LEDS_LP3944 is not set
-# CONFIG_LEDS_LP5521 is not set
-# CONFIG_LEDS_LP5523 is not set
-# CONFIG_LEDS_PCA955X is not set
-# CONFIG_LEDS_PWM is not set
-# CONFIG_LEDS_REGULATOR is not set
-# CONFIG_LEDS_BD2802 is not set
-# CONFIG_LEDS_LT3593 is not set
-CONFIG_LEDS_TRIGGERS=y
-
-#
-# LED Triggers
-#
-CONFIG_LEDS_TRIGGER_TIMER=y
-CONFIG_LEDS_TRIGGER_HEARTBEAT=y
-CONFIG_LEDS_TRIGGER_BACKLIGHT=y
-CONFIG_LEDS_TRIGGER_GPIO=y
-CONFIG_LEDS_TRIGGER_DEFAULT_ON=y
-CONFIG_LEDS_TRIGGER_SLEEP=y
-
-#
-# iptables trigger is under Netfilter config (LED target)
-#
-# CONFIG_NFC_DEVICES is not set
-CONFIG_SWITCH=m
-# CONFIG_SWITCH_GPIO 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_INTF_ALARM=y
-CONFIG_RTC_INTF_ALARM_DEV=y
-# 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_DS3232 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_ISL12022 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_BQ32K is not set
-# 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
-# CONFIG_RTC_DRV_EM3027 is not set
-# CONFIG_RTC_DRV_RV3029C2 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_HAVE_S3C_RTC=y
-CONFIG_RTC_DRV_S3C=y
-# CONFIG_DMADEVICES is not set
-# CONFIG_AUXDISPLAY is not set
-# CONFIG_UIO is not set
-CONFIG_STAGING=y
-# CONFIG_VIDEO_TM6000 is not set
-# CONFIG_USBIP_CORE is not set
-# CONFIG_ECHO is not set
-# CONFIG_BRCMUTIL is not set
-# CONFIG_ASUS_OLED is not set
-# CONFIG_TRANZPORT is not set
-
-#
-# Android
-#
-CONFIG_ANDROID=y
-CONFIG_ANDROID_BINDER_IPC=y
-CONFIG_ANDROID_LOGGER=y
-CONFIG_ANDROID_RAM_CONSOLE=y
-CONFIG_ANDROID_RAM_CONSOLE_ENABLE_VERBOSE=y
-# CONFIG_ANDROID_RAM_CONSOLE_ERROR_CORRECTION is not set
-# CONFIG_ANDROID_RAM_CONSOLE_EARLY_INIT is not set
-CONFIG_ANDROID_TIMED_OUTPUT=y
-# CONFIG_ANDROID_TIMED_GPIO is not set
-CONFIG_ANDROID_LOW_MEMORY_KILLER=y
-# CONFIG_POHMELFS is not set
-# CONFIG_LINE6_USB is not set
-# CONFIG_IIO is not set
-# CONFIG_XVMALLOC is not set
-# CONFIG_ZRAM is not set
-# CONFIG_FB_SM7XX is not set
-# CONFIG_LIRC_STAGING is not set
-# CONFIG_EASYCAP is not set
-CONFIG_MACH_NO_WESTBRIDGE=y
-# CONFIG_USB_ENESTORAGE is not set
-# CONFIG_BCM_WIMAX is not set
-# CONFIG_FT1000 is not set
-
-#
-# Speakup console speech
-#
-# CONFIG_SPEAKUP is not set
-# CONFIG_TOUCHSCREEN_CLEARPAD_TM1217 is not set
-# CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set
-
-#
-# Altera FPGA firmware download module
-#
-# CONFIG_ALTERA_STAPL is not set
-
-#
-# File systems
-#
-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=y
-CONFIG_EXT3_FS_XATTR=y
-# CONFIG_EXT3_FS_POSIX_ACL is not set
-# CONFIG_EXT3_FS_SECURITY is not set
-CONFIG_EXT4_FS=y
-CONFIG_EXT4_FS_XATTR=y
-# CONFIG_EXT4_FS_POSIX_ACL is not set
-# CONFIG_EXT4_FS_SECURITY is not set
-# CONFIG_EXT4_DEBUG is not set
-CONFIG_JBD=y
-CONFIG_JBD2=y
-CONFIG_FS_MBCACHE=y
-# CONFIG_REISERFS_FS is not set
-# CONFIG_JFS_FS is not set
-# CONFIG_XFS_FS is not set
-# CONFIG_GFS2_FS is not set
-# CONFIG_BTRFS_FS is not set
-# CONFIG_NILFS2_FS is not set
-CONFIG_FS_POSIX_ACL=y
-CONFIG_FILE_LOCKING=y
-CONFIG_FSNOTIFY=y
-CONFIG_DNOTIFY=y
-CONFIG_INOTIFY_USER=y
-# CONFIG_FANOTIFY is not set
-# CONFIG_QUOTA is not set
-# CONFIG_QUOTACTL is not set
-# CONFIG_AUTOFS4_FS is not set
-# CONFIG_FUSE_FS is not set
-CONFIG_GENERIC_ACL=y
-
-#
-# 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=y
-CONFIG_TMPFS_XATTR=y
-# 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_ECRYPT_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_YAFFS_FS is not set
-# CONFIG_JFFS2_FS is not set
-# CONFIG_LOGFS is not set
-CONFIG_CRAMFS=y
-# 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=y
-CONFIG_ROMFS_BACKED_BY_BLOCK=y
-# CONFIG_ROMFS_BACKED_BY_MTD is not set
-# CONFIG_ROMFS_BACKED_BY_BOTH is not set
-CONFIG_ROMFS_ON_BLOCK=y
-# CONFIG_PSTORE is not set
-# CONFIG_SYSV_FS is not set
-# CONFIG_UFS_FS is not set
-CONFIG_NETWORK_FILESYSTEMS=y
-
-#
-# 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=y
-# CONFIG_MINIX_SUBPARTITION is not set
-CONFIG_SOLARIS_X86_PARTITION=y
-# 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=y
-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
-
-#
-# Kernel hacking
-#
-# CONFIG_PRINTK_TIME is not set
-CONFIG_DEFAULT_MESSAGE_LOGLEVEL=1
-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_SECTION_MISMATCH is not set
-# CONFIG_DEBUG_KERNEL is not set
-# CONFIG_HARDLOCKUP_DETECTOR is not set
-# CONFIG_SLUB_DEBUG_ON is not set
-# CONFIG_SLUB_STATS is not set
-# CONFIG_SPARSE_RCU_POINTER is not set
-CONFIG_STACKTRACE=y
-CONFIG_DEBUG_BUGVERBOSE=y
-CONFIG_DEBUG_MEMORY_INIT=y
-CONFIG_RCU_CPU_STALL_TIMEOUT=60
-CONFIG_RCU_CPU_STALL_VERBOSE=y
-CONFIG_SYSCTL_SYSCALL_CHECK=y
-CONFIG_HAVE_FUNCTION_TRACER=y
-CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
-CONFIG_HAVE_DYNAMIC_FTRACE=y
-CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
-CONFIG_HAVE_C_RECORDMCOUNT=y
-CONFIG_TRACING_SUPPORT=y
-CONFIG_FTRACE=y
-# CONFIG_FUNCTION_TRACER is not set
-# CONFIG_IRQSOFF_TRACER is not set
-# CONFIG_PREEMPT_TRACER is not set
-# CONFIG_SCHED_TRACER is not set
-# CONFIG_ENABLE_DEFAULT_TRACERS 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_BLK_DEV_IO_TRACE is not set
-# CONFIG_DMA_API_DEBUG is not set
-# CONFIG_ATOMIC64_SELFTEST is not set
-# CONFIG_SAMPLES is not set
-CONFIG_HAVE_ARCH_KGDB=y
-# CONFIG_TEST_KSTRTOX is not set
-# CONFIG_STRICT_DEVMEM is not set
-CONFIG_ARM_UNWIND=y
-CONFIG_DEBUG_USER=y
-# CONFIG_OC_ETM is not set
-CONFIG_DEBUG_S3C_UART=2
-
-#
-# Security options
-#
-CONFIG_KEYS=y
-# CONFIG_KEYS_DEBUG_PROC_KEYS is not set
-# CONFIG_SECURITY_DMESG_RESTRICT is not set
-# CONFIG_SECURITY is not set
-# CONFIG_SECURITYFS is not set
-CONFIG_DEFAULT_SECURITY_DAC=y
-CONFIG_DEFAULT_SECURITY=""
-CONFIG_CRYPTO=y
-
-#
-# Crypto core or helper
-#
-# CONFIG_CRYPTO_FIPS is not set
-CONFIG_CRYPTO_ALGAPI=y
-CONFIG_CRYPTO_ALGAPI2=y
-CONFIG_CRYPTO_RNG=y
-CONFIG_CRYPTO_RNG2=y
-# CONFIG_CRYPTO_MANAGER is not set
-# CONFIG_CRYPTO_MANAGER2 is not set
-# CONFIG_CRYPTO_GF128MUL is not set
-# CONFIG_CRYPTO_NULL is not set
-# 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 is not set
-# CONFIG_CRYPTO_CTR is not set
-# CONFIG_CRYPTO_CTS is not set
-# CONFIG_CRYPTO_ECB is not set
-# CONFIG_CRYPTO_LRW is not set
-# CONFIG_CRYPTO_PCBC is not set
-# 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 is not set
-# CONFIG_CRYPTO_GHASH is not set
-# CONFIG_CRYPTO_MD4 is not set
-# CONFIG_CRYPTO_MD5 is not set
-# 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=y
-# CONFIG_CRYPTO_ANUBIS is not set
-CONFIG_CRYPTO_ARC4=y
-# 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 is not set
-# 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=y
-# CONFIG_CRYPTO_USER_API_HASH is not set
-# CONFIG_CRYPTO_USER_API_SKCIPHER is not set
-CONFIG_CRYPTO_HW=y
-# CONFIG_CRYPTO_DEV_S5P is not set
-# CONFIG_BINARY_PRINTF is not set
-
-#
-# Library routines
-#
-CONFIG_BITREVERSE=y
-CONFIG_CRC_CCITT=y
-CONFIG_CRC16=y
-# CONFIG_CRC_T10DIF is not set
-# CONFIG_CRC_ITU_T is not set
-CONFIG_CRC32=y
-# CONFIG_CRC7 is not set
-# CONFIG_LIBCRC32C is not set
-CONFIG_ZLIB_INFLATE=y
-CONFIG_LZO_DECOMPRESS=y
-CONFIG_XZ_DEC=y
-CONFIG_XZ_DEC_X86=y
-CONFIG_XZ_DEC_POWERPC=y
-CONFIG_XZ_DEC_IA64=y
-CONFIG_XZ_DEC_ARM=y
-CONFIG_XZ_DEC_ARMTHUMB=y
-CONFIG_XZ_DEC_SPARC=y
-CONFIG_XZ_DEC_BCJ=y
-# CONFIG_XZ_DEC_TEST is not set
-CONFIG_DECOMPRESS_GZIP=y
-CONFIG_DECOMPRESS_BZIP2=y
-CONFIG_DECOMPRESS_LZMA=y
-CONFIG_DECOMPRESS_XZ=y
-CONFIG_DECOMPRESS_LZO=y
-CONFIG_HAS_IOMEM=y
-CONFIG_HAS_DMA=y
-CONFIG_NLATTR=y
-CONFIG_AVERAGE=y
diff --git a/arch/arm/mach-s5pv210/Kconfig b/arch/arm/mach-s5pv210/Kconfig
index 17e6de6..601f11a 100644
--- a/arch/arm/mach-s5pv210/Kconfig
+++ b/arch/arm/mach-s5pv210/Kconfig
@@ -8,10 +8,9 @@
# Configuration options for the S5PV210/S5PC110
if ARCH_S5PV210
-# jhk add s3c_dev_nand
+
config CPU_S5PV210
bool
-
select S3C_PL330_DMA
select S5P_EXT_INT
select S5P_HRT
@@ -157,7 +156,6 @@ config MACH_SMDKV210
select HAVE_PWM
select SAMSUNG_DEV_PWM
select SAMSUNG_DEV_TS
-
select S3C_DEV_NAND
select S5PV210_SETUP_FB_24BPP
select S5PV210_SETUP_I2C1
select S5PV210_SETUP_I2C2
diff --git a/arch/arm/mach-s5pv210/clock.c b/arch/arm/mach-s5pv210/clock.c
index fda0758..173f28b 100644
--- a/arch/arm/mach-s5pv210/clock.c
+++ b/arch/arm/mach-s5pv210/clock.c
@@ -409,13 +409,6 @@ static struct clk init_clocks_off[] = {
.enable
= s5pv210_clk_ip1_ctrl,
.ctrlbit
= (1<<16),
}, {
-
.name
= "nand",
-
.id
= -1,
-
.parent
= &clk_hclk_psys.clk,
-
.enable
= s5pv210_clk_ip1_ctrl,
-
.ctrlbit
= ((1 << 28) | (1 << 24)),
-
.dev
= &s3c_device_nand.dev,
-
}, {
.name
= "usbhost",
.id
= -1,
.parent
= &clk_hclk_psys.clk,
diff --git a/arch/arm/mach-s5pv210/include/mach/map.h b/arch/arm/mach-s5pv210/include/mach/map.h
index 189a3d3..83e08d7 100755
--- a/arch/arm/mach-s5pv210/include/mach/map.h
+++ b/arch/arm/mach-s5pv210/include/mach/map.h
@@ -29,11 +29,7 @@
#define S5PC110_PA_ONENAND
0xB0000000
#define S5PC110_PA_ONENAND_DMA
0xB0600000
-/* NAND //jhk*/
-#define S5PV210_PA_NAND
(0xB0E00000)
-#define S5P_PA_NAND
S5PV210_PA_NAND
-#define S5PV210_SZ_NAND
SZ_1M
-#define S5P_SZ_NAND
S5PV210_SZ_NAND
+
#define S5PV210_PA_CHIPID
0xE0000000
#define S5PV210_PA_SYSCON
0xE0100000
diff --git a/arch/arm/mach-s5pv210/mach-smdkv210.c b/arch/arm/mach-s5pv210/mach-smdkv210.c
index e9b26fb..bc39222 100755
--- a/arch/arm/mach-s5pv210/mach-smdkv210.c
+++ b/arch/arm/mach-s5pv210/mach-smdkv210.c
@@ -1204,9 +1204,6 @@ static struct platform_device *mango210_devices[] __initdata = {
//#ifdef CONFIG_SND_S3C_SOC_PCM
&s5pv210_device_pcm0,
//#endif
-#if defined CONFIG_MTD_NAND_S3C
-
&s3c_device_nand, //jhk
-#endif
&s3c_device_rtc,
&s3c_device_ts,
&s3c_device_wdt,
@@ -1647,9 +1644,6 @@ static void __init mango210_map_io(void)
#ifndef CONFIG_S5P_HIGH_RES_TIMERS
s5p_set_timer_source(S5P_PWM2, S5P_PWM4);
#endif
-#ifdef CONFIG_MTD_NAND_S3C
-
s3c_device_nand.name = "s5pv210-nand";
-#endif
s5p_reserve_bootmem(s5pv210_media_devs,
ARRAY_SIZE(s5pv210_media_devs), S5P_RANGE_MFC);
}
diff --git a/arch/arm/plat-s5p/devs.c b/arch/arm/plat-s5p/devs.c
index 6e9875f..e06f5ac 100755
--- a/arch/arm/plat-s5p/devs.c
+++ b/arch/arm/plat-s5p/devs.c
@@ -85,21 +85,6 @@ static int __init ethaddr_setup(char *line)
}
__setup("ethaddr=", ethaddr_setup);
#endif
-/* NAND Controller by jhk */
-static struct resource s3c_nand_resource[] = {
-
[0] = {
-
.start
= S5P_PA_NAND,
-
.end
= S5P_PA_NAND + S5P_SZ_NAND - 1,
-
.flags
= IORESOURCE_MEM,
-
}
-};
-
-struct platform_device s3c_device_nand = {
-
.name
= "s5pv210-nand",
-
.id
= -1,
-
.num_resources
= ARRAY_SIZE(s3c_nand_resource),
-
.resource
= s3c_nand_resource,
-};
#if defined(CONFIG_VIDEO_FIMC) || defined(CONFIG_CPU_FREQ) /* TODO: use existing dev */
static struct resource s3c_fimc0_resource[] = {
[0] = {
diff --git a/arch/arm/plat-s5p/include/plat/regs-nand.h b/arch/arm/plat-s5p/include/plat/regs-nand.h
deleted file mode 100644
index 2db2923..0000000
--- a/arch/arm/plat-s5p/include/plat/regs-nand.h
+++ /dev/null
@@ -1,87 +0,0 @@
-/* arch/arm/plat-s5p/include/plat/regs-nand.h
- *
- * Copyright (c) 2010 Samsung Electronics Co., Ltd.
- *
http://www.samsung.com/
- *
- * Register definition file for Samsung NAND driver
- *
- * 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.
-*/
-
-#ifndef __ASM_ARM_REGS_S5P_NAND
-#define __ASM_ARM_REGS_S5P_NAND
-
-
-#define S5P_NFREG(x) (x)
-
-/* for s3c_nand.c */
-#define S3C_NFCONF
S5P_NFREG(0x00)
-#define S3C_NFCONT
S5P_NFREG(0x04)
-#define S3C_NFCMMD
S5P_NFREG(0x08)
-#define S3C_NFADDR
S5P_NFREG(0x0c)
-#define S3C_NFDATA8
S5P_NFREG(0x10)
-#define S3C_NFDATA
S5P_NFREG(0x10)
-#define S3C_NFMECCDATA0
S5P_NFREG(0x14)
-#define S3C_NFMECCDATA1
S5P_NFREG(0x18)
-#define S3C_NFSECCDATA
S5P_NFREG(0x1c)
-#define S3C_NFSBLK
S5P_NFREG(0x20)
-#define S3C_NFEBLK
S5P_NFREG(0x24)
-#define S3C_NFSTAT
S5P_NFREG(0x28)
-#define S3C_NFMECCERR0
S5P_NFREG(0x2c)
-#define S3C_NFMECCERR1
S5P_NFREG(0x30)
-#define S3C_NFMECC0
S5P_NFREG(0x34)
-#define S3C_NFMECC1
S5P_NFREG(0x38)
-#define S3C_NFSECC
S5P_NFREG(0x3c)
-#define S3C_NFMLCBITPT
S5P_NFREG(0x40)
-#define S3C_NF8ECCERR0
S5P_NFREG(0x44)
-#define S3C_NF8ECCERR1
S5P_NFREG(0x48)
-#define S3C_NF8ECCERR2
S5P_NFREG(0x4C)
-#define S3C_NFM8ECC0
S5P_NFREG(0x50)
-#define S3C_NFM8ECC1
S5P_NFREG(0x54)
-#define S3C_NFM8ECC2
S5P_NFREG(0x58)
-#define S3C_NFM8ECC3
S5P_NFREG(0x5C)
-#define S3C_NFMLC8BITPT0
S5P_NFREG(0x60)
-#define S3C_NFMLC8BITPT1
S5P_NFREG(0x64)
-
-#define S3C_NFCONF_NANDBOOT
(1<<31)
-#define S3C_NFCONF_ECCCLKCON
(1<<30)
-#define S3C_NFCONF_ECC_MLC
(1<<24)
-#define S3C_NFCONF_ECC_1BIT
(0<<23)
-#define S3C_NFCONF_ECC_4BIT
(2<<23)
-#define S3C_NFCONF_ECC_8BIT
(1<<23)
-#define S3C_NFCONF_TACLS(x)
((x)<<12)
-#define S3C_NFCONF_TWRPH0(x)
((x)<<8)
-#define S3C_NFCONF_TWRPH1(x)
((x)<<4)
-#define S3C_NFCONF_ADVFLASH
(1<<3)
-#define S3C_NFCONF_PAGESIZE
(1<<2)
-#define S3C_NFCONF_ADDRCYCLE
(1<<1)
-#define S3C_NFCONF_BUSWIDTH
(1<<0)
-
-#define S3C_NFCONT_ECC_ENC
(1<<18)
-#define S3C_NFCONT_LOCKTGHT
(1<<17)
-#define S3C_NFCONT_LOCKSOFT
(1<<16)
-#define S3C_NFCONT_MECCLOCK
(1<<7)
-#define S3C_NFCONT_SECCLOCK
(1<<6)
-#define S3C_NFCONT_INITMECC
(1<<5)
-#define S3C_NFCONT_INITSECC
(1<<4)
-#define S3C_NFCONT_nFCE1
(1<<2)
-#define S3C_NFCONT_nFCE0
(1<<1)
-#define S3C_NFCONT_INITECC
(S3C_NFCONT_INITSECC | S3C_NFCONT_INITMECC)
-
-#define S3C_NFSTAT_ECCENCDONE
(1<<7)
-#define S3C_NFSTAT_ECCDECDONE
(1<<6)
-#define S3C_NFSTAT_ILEGL_ACC
(1<<5)
-#define S3C_NFSTAT_RnB_CHANGE
(1<<4)
-#define S3C_NFSTAT_nFCE1
(1<<3)
-#define S3C_NFSTAT_nFCE0
(1<<2)
-#define S3C_NFSTAT_Res1
(1<<1)
-#define S3C_NFSTAT_READY
(1<<0)
-#define S3C_NFSTAT_CLEAR
((1<<7) |(1<<6) |(1<<5) |(1<<4))
-#define S3C_NFSTAT_BUSY
(1<<0)
-
-#define S3C_NFECCERR0_ECCBUSY
(1<<31)
-
-#endif /* __ASM_ARM_REGS_S5P_NAND */
-
diff --git a/arch/arm/plat-samsung/dev-nand.c b/arch/arm/plat-samsung/dev-nand.c
index 3163289..6927ae8 100644
--- a/arch/arm/plat-samsung/dev-nand.c
+++ b/arch/arm/plat-samsung/dev-nand.c
@@ -16,10 +16,7 @@
#include <mach/map.h>
#include <plat/devs.h>
#include <plat/nand.h>
-/* NAND //jhk*/
-#define S3C_PA_NAND (0x70200000)
-/*
static struct resource s3c_nand_resource[] = {
[0] = {
.start = S3C_PA_NAND,
@@ -29,15 +26,14 @@ static struct resource s3c_nand_resource[] = {
};
struct platform_device s3c_device_nand = {
-//
.name
= "s3c2410-nand",
-
.name
= "s5pv210-nand",
+
.name
= "s3c2410-nand",
.id
= -1,
.num_resources
= ARRAY_SIZE(s3c_nand_resource),
.resource
= s3c_nand_resource,
};
EXPORT_SYMBOL(s3c_device_nand);
-*/
+
/**
* s3c_nand_copy_set() - copy nand set data
* @set: The new structure, directly copied from the old.
diff --git a/arch/arm/plat-samsung/include/plat/nand.h b/arch/arm/plat-samsung/include/plat/nand.h
index e99d2e1..b64115f 100644
--- a/arch/arm/plat-samsung/include/plat/nand.h
+++ b/arch/arm/plat-samsung/include/plat/nand.h
@@ -65,9 +65,3 @@ struct s3c2410_platform_nand {
* it with the s3c_device_nand. This allows @nand to be __initdata.
*/
extern void s3c_nand_set_platdata(struct s3c2410_platform_nand *nand);
-//jhk
-struct s3c_nand_mtd_info {
-
uint chip_nr;
-
uint mtd_part_nr;
-
struct mtd_partition *partition;
-};
diff --git a/arch/arm/plat-samsung/include/plat/regs-nand.h b/arch/arm/plat-samsung/include/plat/regs-nand.h
index 3180718..238efea 100644
--- a/arch/arm/plat-samsung/include/plat/regs-nand.h
+++ b/arch/arm/plat-samsung/include/plat/regs-nand.h
@@ -119,73 +119,5 @@
-
-
-/* for s3c_nand.c */
-#define S3C_NFCONF
S3C2410_NFREG(0x00)
-#define S3C_NFCONT
S3C2410_NFREG(0x04)
-#define S3C_NFCMMD
S3C2410_NFREG(0x08)
-#define S3C_NFADDR
S3C2410_NFREG(0x0c)
-#define S3C_NFDATA8
S3C2410_NFREG(0x10)
-#define S3C_NFDATA
S3C2410_NFREG(0x10)
-#define S3C_NFMECCDATA0
S3C2410_NFREG(0x14)
-#define S3C_NFMECCDATA1
S3C2410_NFREG(0x18)
-#define S3C_NFSECCDATA
S3C2410_NFREG(0x1c)
-#define S3C_NFSBLK
S3C2410_NFREG(0x20)
-#define S3C_NFEBLK
S3C2410_NFREG(0x24)
-#define S3C_NFSTAT
S3C2410_NFREG(0x28)
-#define S3C_NFMECCERR0
S3C2410_NFREG(0x2c)
-#define S3C_NFMECCERR1
S3C2410_NFREG(0x30)
-#define S3C_NFMECC0
S3C2410_NFREG(0x34)
-#define S3C_NFMECC1
S3C2410_NFREG(0x38)
-#define S3C_NFSECC
S3C2410_NFREG(0x3c)
-#define S3C_NFMLCBITPT
S3C2410_NFREG(0x40)
-
-#define S3C_NF8ECCERR0
S3C2410_NFREG(0x44)
-#define S3C_NF8ECCERR1
S3C2410_NFREG(0x48)
-#define S3C_NF8ECCERR2
S3C2410_NFREG(0x4c)
-
-
-#define S3C_NFM8ECC0
S3C2410_NFREG(0x50)
-#define S3C_NFM8ECC1
S3C2410_NFREG(0x54)
-#define S3C_NFM8ECC2
S3C2410_NFREG(0x58)
-#define S3C_NFM8ECC3
S3C2410_NFREG(0x5c)
-
-#define S3C_NFMLC8BITPT0
S3C2410_NFREG(0x60)
-#define S3C_NFMLC8BITPT1
S3C2410_NFREG(0x64)
-
-#define S3C_NFCONF_NANDBOOT
(1<<31)
-#define S3C_NFCONF_ECCCLKCON
(1<<30)
-#define S3C_NFCONF_ECC_MLC
(1<<24)
-#define S3C_NFCONF_ECC_1BIT
(0<<23)
-#define S3C_NFCONF_ECC_4BIT
(2<<23)
-#define S3C_NFCONF_ECC_8BIT
(1<<23)
-#define S3C_NFCONF_TACLS(x)
((x)<<12)
-#define S3C_NFCONF_TWRPH0(x)
((x)<<8)
-#define S3C_NFCONF_TWRPH1(x)
((x)<<4)
-#define S3C_NFCONF_ADVFLASH
(1<<3)
-#define S3C_NFCONF_PAGESIZE
(1<<2)
-#define S3C_NFCONF_ADDRCYCLE
(1<<1)
-#define S3C_NFCONF_BUSWIDTH
(1<<0)
-
-#define S3C_NFCONT_ECC_ENC
(1<<18)
-#define S3C_NFCONT_LOCKTGHT
(1<<17)
-#define S3C_NFCONT_LOCKSOFT
(1<<16)
-#define S3C_NFCONT_MECCLOCK
(1<<7)
-#define S3C_NFCONT_SECCLOCK
(1<<6)
-#define S3C_NFCONT_INITMECC
(1<<5)
-#define S3C_NFCONT_INITSECC
(1<<4)
-#define S3C_NFCONT_nFCE1
(1<<2)
-#define S3C_NFCONT_nFCE0
(1<<1)
-#define S3C_NFCONT_INITECC
(S3C_NFCONT_INITSECC | S3C_NFCONT_INITMECC)
-
-#define S3C_NFSTAT_ECCENCDONE
(1<<7)
-#define S3C_NFSTAT_ECCDECDONE
(1<<6)
-#define S3C_NFSTAT_BUSY
(1<<0)
-
-#define S3C_NFECCERR0_ECCBUSY
(1<<31)
-
-
-
#endif /* __ASM_ARM_REGS_NAND */
diff --git a/drivers/mtd/Kconfig b/drivers/mtd/Kconfig
index ceba591..4be8373 100644
--- a/drivers/mtd/Kconfig
+++ b/drivers/mtd/Kconfig
@@ -33,26 +33,6 @@ config MTD_TESTS
should normally be compiled as kernel modules. The modules perform
various checks and verifications when loaded.
-config MTD_CONCAT
-
tristate "MTD concatenating support"
-
help
-
Support for concatenating several MTD devices into a single
-
(virtual) one. This allows you to have -for example- a JFFS(2)
-
file system spanning multiple physical flash chips. If unsure,
-
say 'Y'.
-
-config MTD_PARTITIONS
-
bool "MTD partitioning support"
-
help
-
If you have a device which needs to divide its flash chip(s) up
-
into multiple 'partitions', each of which appears to the user as
-
a separate MTD device, you require this option to be enabled. If
-
unsure, say 'Y'.
-
-
Note, however, that you don't need this option for the DiskOnChip
-
devices. Partitioning on NFTL 'devices' is a different - that's the
-
'normal' form of partitioning used on a block device.
-
config MTD_REDBOOT_PARTS
tristate "RedBoot partition table parsing"
---help---
diff --git a/drivers/mtd/mtdpart.c b/drivers/mtd/mtdpart.c
index 386f6d7..630be3e 100644
--- a/drivers/mtd/mtdpart.c
+++ b/drivers/mtd/mtdpart.c
@@ -672,7 +672,6 @@ int add_mtd_partitions(struct mtd_info *master,
return 0;
}
-EXPORT_SYMBOL(add_mtd_partitions);//jhk
static DEFINE_SPINLOCK(part_parser_lock);
static LIST_HEAD(part_parsers);
diff --git a/drivers/mtd/nand/Kconfig b/drivers/mtd/nand/Kconfig
index 225d8de..43173a3 100644
--- a/drivers/mtd/nand/Kconfig
+++ b/drivers/mtd/nand/Kconfig
@@ -240,34 +240,6 @@ config MTD_NAND_S3C2410_HWECC
incorrect ECC generation, and if using these, the default of
software ECC is preferable.
-config MTD_NAND_S3C
-
tristate "NAND support for Samsung S3C"
-
depends on (ARCH_S3C64XX || ARCH_S5P64XX || ARCH_S5PC1XX||ARCH_S5PV210) && MTD_NAND
-
help
-
This enables the NAND flash controller on the S3C
-
-
No board specific support is done by this driver, each board
-
must advertise a platform_device for the driver to attach.
-
-config MTD_NAND_S3C_DEBUG
-
bool "S3C NAND driver debug"
-
depends on MTD_NAND_S3C
-
help
-
Enable debugging of the S3C NAND driver
-
-config MTD_NAND_S3C_HWECC
-
bool "S3C NAND Hardware ECC"
-
depends on MTD_NAND_S3C
-
help
-
Enable the use of the S3C's internal ECC generator when
-
using NAND. Early versions of the chip have had problems with
-
incorrect ECC generation, and if using these, the default of
-
software ECC is preferable.
-
-
If you lay down a device with the hardware ECC, then you will
-
currently not be able to switch to software, as there is no
-
implementation for ECC method used by the S3C
-
config MTD_NAND_NDFC
tristate "NDFC NanD Flash Controller"
depends on 4xx
diff --git a/drivers/mtd/nand/Makefile b/drivers/mtd/nand/Makefile
index ec2f82a..5745d83 100644
--- a/drivers/mtd/nand/Makefile
+++ b/drivers/mtd/nand/Makefile
@@ -18,7 +18,6 @@ obj-$(CONFIG_MTD_NAND_AU1550)
+= au1550nd.o
obj-$(CONFIG_MTD_NAND_BF5XX)
+= bf5xx_nand.o
obj-$(CONFIG_MTD_NAND_PPCHAMELEONEVB)
+= ppchameleonevb.o
obj-$(CONFIG_MTD_NAND_S3C2410)
+= s3c2410.o
-obj-$(CONFIG_MTD_NAND_S3C)
+= s3c_nand.o
obj-$(CONFIG_MTD_NAND_DAVINCI)
+= davinci_nand.o
obj-$(CONFIG_MTD_NAND_DISKONCHIP)
+= diskonchip.o
obj-$(CONFIG_MTD_NAND_FSMC)
+= fsmc_nand.o
diff --git a/drivers/mtd/nand/s3c_nand.c b/drivers/mtd/nand/s3c_nand.c
deleted file mode 100644
index 964bdc9..0000000
--- a/drivers/mtd/nand/s3c_nand.c
+++ /dev/null
@@ -1,1268 +0,0 @@
-/* linux/drivers/mtd/nand/s3c_nand.c
- *
- * Copyright (c) 2009 Samsung Electronics Co., Ltd.
- *
http://www.samsung.com/
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
-*/
-
-#include <linux/module.h>
-#include <linux/delay.h>
-#include <linux/types.h>
-#include <linux/init.h>
-#include <linux/kernel.h>
-#include <linux/string.h>
-#include <linux/ioport.h>
-#include <linux/platform_device.h>
-#include <linux/delay.h>
-#include <linux/err.h>
-#include <linux/clk.h>
-#include <linux/jiffies.h>
-#include <linux/sched.h>
-#include <linux/slab.h>
-#include <linux/io.h>
-
-#include <linux/mtd/mtd.h>
-#include <linux/mtd/nand.h>
-#include <linux/mtd/nand_ecc.h>
-#include <linux/mtd/partitions.h>
-
-#include <plat/regs-nand.h>
-#include <plat/nand.h>
-
-#ifdef CONFIG_MTD_CMDLINE_PARTS
-static const char *part_probes[] = { "cmdlinepart", NULL };
-#endif
-
-#if defined(CONFIG_ARCH_S5PV210)
-struct mtd_partition s3c_partition_info[] = {
-#if 0
-
{
-
.name
= "misc",
-
.offset
= (768*SZ_1K), /* for bootloader */
-
.size
= (256*SZ_1K),
-
.mask_flags
= MTD_CAP_NANDFLASH,
-
},
-
{
-
.name
= "recovery",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (5*SZ_1M),
-
},
-
{
-
.name
= "kernel",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (5*SZ_1M),
-
},
-
{
-
.name
= "ramdisk",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (3*SZ_1M),
-
},
-
{
-
.name
= "system",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (110*SZ_1M),
-
},
-
{
-
.name
= "cache",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (80*SZ_1M),
-
},
-
{
-
.name
= "userdata",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= MTDPART_SIZ_FULL,
-
}
-#endif
-
{
-
.name
= "misc",
-
.offset
= (768*SZ_1K), /* for bootloader */
-
.size
= (256*SZ_1K),
-
.mask_flags
= MTD_CAP_NANDFLASH,
-
},
-
{
-
.name
= "recovery",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (5*SZ_1M),
-
//.mask_flags
= MTD_CAP_NANDFLASH,
-
},
-
{
-
.name
= "kernel",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (5*SZ_1M),
-
},
-
{
-
.name
= "ramdisk",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (5*SZ_1M),
-
},
-
{
-
.name
= "system",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (110*SZ_1M),
-
},
-
{
-
.name
= "cache",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= (20*SZ_1M),
-
},
-
{
-
.name
= "userdata",
-
.offset
= MTDPART_OFS_APPEND,
-
.size
= MTDPART_SIZ_FULL,
-
}
-};
-
-struct s3c_nand_mtd_info s3c_nand_mtd_part_info = {
-
.chip_nr = 1,
-
.mtd_part_nr = ARRAY_SIZE(s3c_partition_info),
-
.partition = s3c_partition_info,
-};
-#endif
-
-enum s3c_cpu_type {
-
TYPE_S3C2450,
/* including s3c2416 */
-
TYPE_S3C6400,
-
TYPE_S3C6410,
/* including s3c6430/31 */
-
TYPE_S5P6440,
-
TYPE_S5PC100,
-
TYPE_S5PC110,
-
TYPE_S5PV210,
-};
-
-struct s3c_nand_info {
-
/* mtd info */
-
struct nand_hw_control
controller;
-
struct s3c_nand_mtd_info
*mtds;
-
struct s3c2410_platform_nand
*platform;
-
-
/* device info */
-
struct device
*device;
-
struct resource
*area;
-
struct clk
*clk;
-
void __iomem
*regs;
-
void __iomem
*sel_reg;
-
int
sel_bit;
-
int
mtd_count;
-
-
enum s3c_cpu_type
cpu_type;
-};
-static struct s3c_nand_info s3c_nand;
-
-static struct mtd_info *s3c_mtd;
-
-/* Nand flash definition values */
-#define S3C_NAND_TYPE_UNKNOWN
0x0
-#define S3C_NAND_TYPE_SLC
0x1
-#define S3C_NAND_TYPE_MLC
0x2
-
-/* when Hz=200, jiffies interval 1/200=5mS,
- * waiting for 80mS 80/5 = 16 */
-#define S3C_NAND_WAIT_TIME_MS
(80)
-#define S3C_NAND_WAIT_INTERVAL
(S3C_NAND_WAIT_TIME_MS * HZ / 1000)
-
-/* Nand flash global values */
-int cur_ecc_mode;
-int nand_type = S3C_NAND_TYPE_UNKNOWN;
-
-#if defined(CONFIG_MTD_NAND_S3C_HWECC)
-/* Nand flash oob definition for SLC 512b page size */
-static struct nand_ecclayout s3c_nand_oob_16 = {
-
.eccbytes = 4,
-
.eccpos = {
-
1, 2, 3, 4
-
},
-
.oobfree = {
-
{
-
.offset = 6,
-
.length = 10
-
}
-
}
-};
-
-/* Nand flash oob definition for SLC 2k page size */
-static struct nand_ecclayout s3c_nand_oob_64 = {
-
.eccbytes = 16,
-
.eccpos = {
-
40, 41, 42, 43, 44, 45, 46, 47,
-
48, 49, 50, 51, 52, 53, 54, 55
-
},
-
.oobfree = {
-
{
-
.offset = 2,
-
.length = 38
-
}
-
}
-};
-
-/* Nand flash oob definition for MLC 2k page size */
-static struct nand_ecclayout s3c_nand_oob_mlc_64 = {
-
.eccbytes = 32,
-
.eccpos = {
-
32, 33, 34, 35, 36, 37, 38, 39,
-
40, 41, 42, 43, 44, 45, 46, 47,
-
48, 49, 50, 51, 52, 53, 54, 55,
-
56, 57, 58, 59, 60, 61, 62, 63
-
},
-
.oobfree = {
-
{
-
.offset = 2,
-
.length = 28
-
}
-
}
-};
-
-/* Nand flash oob definition for 4Kb page size with 8_bit ECC */
-static struct nand_ecclayout s3c_nand_oob_128 = {
-
.eccbytes = 104,
-
.eccpos = {
-
24, 25, 26, 27, 28, 29, 30, 31,
-
32, 33, 34, 35, 36, 37, 38, 39,
-
40, 41, 42, 43, 44, 45, 46, 47,
-
48, 49, 50, 51, 52, 53, 54, 55,
-
56, 57, 58, 59, 60, 61, 62, 63,
-
64, 65, 66, 67, 68, 69, 70, 71,
-
72, 73, 74, 75, 76, 77, 78, 79,
-
80, 81, 82, 83, 84, 85, 86, 87,
-
88, 89, 90, 91, 92, 93, 94, 95,
-
96, 97, 98, 99, 100, 101, 102, 103,
-
104, 105, 106, 107, 108, 109, 110, 111,
-
112, 113, 114, 115, 116, 117, 118, 119,
-
120, 121, 122, 123, 124, 125, 126, 127},
-
.oobfree = {
-
{
-
.offset = 2,
-
.length = 22
-
}
-
}
-};
-#endif
-
-#if defined(CONFIG_MTD_NAND_S3C_DEBUG)
-/*
- * Function to print out oob buffer for debugging
- */
-void print_oob(const char *header, struct mtd_info *mtd)
-{
-
int i;
-
struct nand_chip *chip = mtd->priv;
-
-
printk(KERN_INFO "%s:\t", header);
-
-
for (i = 0; i < 64; i++)
-
printk(KERN_INFO "%02x ", chip->oob_poi[i]);
-
-
printk(KERN_INFO "\n");
-}
-EXPORT_SYMBOL(print_oob);
-#endif
-
-/*
- * Hardware specific access to control-lines function
- */
-static void s3c_nand_hwcontrol(struct mtd_info *mtd, int dat, unsigned int ctrl)
-{
-
unsigned int cur;
-
void __iomem *regs = s3c_nand.regs;
-
-
if (ctrl & NAND_CTRL_CHANGE) {
-
if (ctrl & NAND_NCE) {
-
if (dat != NAND_CMD_NONE) {
-
cur = readl(regs + S3C_NFCONT);
-
cur &= ~S3C_NFCONT_nFCE0;
-
writel(cur, regs + S3C_NFCONT);
-
}
-
} else {
-
cur = readl(regs + S3C_NFCONT);
-
cur |= S3C_NFCONT_nFCE0;
-
writel(cur, regs + S3C_NFCONT);
-
}
-
}
-
-
if (dat != NAND_CMD_NONE) {
-
if (ctrl & NAND_CLE)
-
writeb(dat, regs + S3C_NFCMMD);
-
else if (ctrl & NAND_ALE)
-
writeb(dat, regs + S3C_NFADDR);
-
}
-}
-
-/*
- * Function for checking device ready pin
- */
-static int s3c_nand_device_ready(struct mtd_info *mtd)
-{
-
void __iomem *regs = s3c_nand.regs;
-
-
/* it's to check the RnB nand signal bit and
-
* return to device ready condition in nand_base.c
-
*/
-
return readl(regs + S3C_NFSTAT) & S3C_NFSTAT_READY;
-}
-
-/*
- * We don't use a bad block table
- */
-static int s3c_nand_scan_bbt(struct mtd_info *mtdinfo)
-{
-
return 0;
-}
-
-#if defined(CONFIG_MTD_NAND_S3C_HWECC)
-
-/*
- * Function for checking ECCEncDone in NFSTAT
- */
-static void s3c_nand_wait_enc(void)
-{
-
void __iomem *regs = s3c_nand.regs;
-
unsigned long timeo = jiffies;
-
-
timeo += S3C_NAND_WAIT_INTERVAL;
-
-
/* Apply this short delay always to ensure that we do wait tWB in
-
* any case on any machine. */
-
while (time_before(jiffies, timeo)) {
-
if (readl(regs + S3C_NFSTAT) & S3C_NFSTAT_ECCENCDONE)
-
break;
-
cond_resched();
-
}
-}
-
-/*
- * Function for checking ECCDecDone in NFSTAT
- */
-static void s3c_nand_wait_dec(void)
-{
-
void __iomem *regs = s3c_nand.regs;
-
unsigned long timeo = jiffies;
-
-
timeo += S3C_NAND_WAIT_INTERVAL;
-
-
/* Apply this short delay always to ensure that we do wait tWB in
-
* any case on any machine. */
-
while (time_before(jiffies, timeo)) {
-
if (readl(regs + S3C_NFSTAT) & S3C_NFSTAT_ECCDECDONE)
-
break;
-
cond_resched();
-
}
-}
-
-/*
- * Function for checking ECC Busy
- */
-static void s3c_nand_wait_ecc_busy(void)
-{
-
void __iomem *regs = s3c_nand.regs;
-
unsigned long timeo = jiffies;
-
-
timeo += S3C_NAND_WAIT_INTERVAL;
-
-
/* Apply this short delay always to ensure that we do wait tWB in
-
* any case on any machine. */
-
while (time_before(jiffies, timeo)) {
-
if (!(readl(regs + S3C_NFMECCERR0) & S3C_NFECCERR0_ECCBUSY))
-
break;
-
cond_resched();
-
}
-}
-
-/*
- * This function is called before encoding ecc codes to ready ecc engine.
- */
-static void s3c_nand_enable_hwecc(struct mtd_info *mtd, int mode)
-{
-
u_long nfcont;
-
u_long nfconf;
-
void __iomem *regs = s3c_nand.regs;
-
-
cur_ecc_mode = mode;
-
-
nfconf = readl(regs + S3C_NFCONF);
-
-
if (s3c_nand.cpu_type == TYPE_S3C6400) {
-
if (nand_type == S3C_NAND_TYPE_SLC)
-
nfconf &= ~S3C_NFCONF_ECC_MLC;
/* SLC */
-
else
-
nfconf |= S3C_NFCONF_ECC_MLC;
/* MLC */
-
} else {
-
nfconf &= ~(0x3 << 23);
-
-
if (nand_type == S3C_NAND_TYPE_SLC)
-
nfconf |= S3C_NFCONF_ECC_1BIT;
-
else
-
nfconf |= S3C_NFCONF_ECC_4BIT;
-
}
-
-
writel(nfconf, regs + S3C_NFCONF);
-
-
/* Init main ECC & unlock */
-
nfcont = readl(regs + S3C_NFCONT);
-
nfcont |= S3C_NFCONT_INITMECC;
-
nfcont &= ~S3C_NFCONT_MECCLOCK;
-
-
if (nand_type == S3C_NAND_TYPE_MLC) {
-
if (mode == NAND_ECC_WRITE)
-
nfcont |= S3C_NFCONT_ECC_ENC;
-
else if (mode == NAND_ECC_READ)
-
nfcont &= ~S3C_NFCONT_ECC_ENC;
-
}
-
-
writel(nfcont, regs + S3C_NFCONT);
-}
-
-/*
- * This function is called immediately after encoding ecc codes.
- * This function returns encoded ecc codes.
- */
-static int s3c_nand_calculate_ecc(struct mtd_info *mtd,
-
const u_char *dat, u_char *ecc_code)
-{
-
u_long nfcont, nfmecc0, nfmecc1;
-
void __iomem *regs = s3c_nand.regs;
-
-
/* Lock */
-
nfcont = readl(regs + S3C_NFCONT);
-
nfcont |= S3C_NFCONT_MECCLOCK;
-
writel(nfcont, regs + S3C_NFCONT);
-
-
if (nand_type == S3C_NAND_TYPE_SLC) {
-
nfmecc0 = readl(regs + S3C_NFMECC0);
-
-
ecc_code[0] = nfmecc0 & 0xff;
-
ecc_code[1] = (nfmecc0 >> 8) & 0xff;
-
ecc_code[2] = (nfmecc0 >> 16) & 0xff;
-
ecc_code[3] = (nfmecc0 >> 24) & 0xff;
-
} else {
-
if (cur_ecc_mode == NAND_ECC_READ)
-
s3c_nand_wait_dec();
-
else {
-
s3c_nand_wait_enc();
-
-
nfmecc0 = readl(regs + S3C_NFMECC0);
-
nfmecc1 = readl(regs + S3C_NFMECC1);
-
-
ecc_code[0] = nfmecc0 & 0xff;
-
ecc_code[1] = (nfmecc0 >> 8) & 0xff;
-
ecc_code[2] = (nfmecc0 >> 16) & 0xff;
-
ecc_code[3] = (nfmecc0 >> 24) & 0xff;
-
ecc_code[4] = nfmecc1 & 0xff;
-
ecc_code[5] = (nfmecc1 >> 8) & 0xff;
-
ecc_code[6] = (nfmecc1 >> 16) & 0xff;
-
ecc_code[7] = (nfmecc1 >> 24) & 0xff;
-
}
-
}
-
-
return 0;
-}
-
-/*
- * This function determines whether read data is good or not.
- * If SLC, must write ecc codes to controller before reading status bit.
- * If MLC, status bit is already set, so only reading is needed.
- * If status bit is good, return 0.
- * If correctable errors occured, do that.
- * If uncorrectable errors occured, return -1.
- */
-static int s3c_nand_correct_data(struct mtd_info *mtd, u_char *dat,
-
u_char *read_ecc, u_char *calc_ecc)
-{
-
int ret = -1;
-
u_long nfestat0, nfestat1, nfmeccdata0, nfmeccdata1, nfmlcbitpt;
-
u_char err_type;
-
void __iomem *regs = s3c_nand.regs;
-
-
if (!dat) {
-
printk(KERN_ERR "No page data\n");
-
return ret;
-
}
-
-
if (nand_type == S3C_NAND_TYPE_SLC) {
-
/* SLC: Write ECC data to compare */
-
nfmeccdata0 = (read_ecc[1] << 16) | read_ecc[0];
-
nfmeccdata1 = (read_ecc[3] << 16) | read_ecc[2];
-
writel(nfmeccdata0, regs + S3C_NFMECCDATA0);
-
writel(nfmeccdata1, regs + S3C_NFMECCDATA1);
-
-
/* Read ECC status */
-
nfestat0 = readl(regs + S3C_NFMECCERR0);
-
err_type = nfestat0 & 0x3;
-
-
switch (err_type) {
-
case 0: /* No error */
-
ret = 0;
-
break;
-
-
case 1: /* 1 bit error (Correctable)
-
(nfestat0 >> 7) & 0x7ff
:error byte number
-
(nfestat0 >> 4) & 0x7
:error bit number */
-
printk(KERN_INFO "s3c-nand: 1 bit error detected at byte %ld, correcting from "
-
"0x%02x ", (nfestat0 >> 7) & 0x7ff, dat[(nfestat0 >> 7) & 0x7ff]);
-
dat[(nfestat0 >> 7) & 0x7ff] ^= (1 << ((nfestat0 >> 4) & 0x7));
-
printk("to 0x%02x...OK\n", dat[(nfestat0 >> 7) & 0x7ff]);
-
ret = 1;
-
break;
-
-
case 2: /* Multiple error */
-
case 3: /* ECC area error */
-
printk(KERN_INFO "s3c-nand: ECC uncorrectable error detected\n");
-
ret = -1;
-
break;
-
}
-
} else {
-
/* MLC: */
-
s3c_nand_wait_ecc_busy();
-
-
nfestat0 = readl(regs + S3C_NFMECCERR0);
-
nfestat1 = readl(regs + S3C_NFMECCERR1);
-
nfmlcbitpt = readl(regs + S3C_NFMLCBITPT);
-
-
err_type = (nfestat0 >> 26) & 0x7;
-
-
/* No error, If free page (all 0xff) */
-
if ((nfestat0 >> 29) & 0x1) {
-
err_type = 0;
-
} else {
-
/* No error, If all 0xff from 17th byte in oob (in case of JFFS2 format) */
-
if (dat) {
-
if (dat[17] == 0xff && dat[26] == 0xff && dat[35] == 0xff && dat[44] == 0xff && dat[54] == 0xff)
-
err_type = 0;
-
}
-
}
-
-
switch (err_type) {
-
case 5: /* Uncorrectable */
-
printk(KERN_INFO "s3c-nand: ECC uncorrectable error detected\n");
-
ret = -1;
-
break;
-
-
case 4: /* 4 bit error (Correctable) */
-
dat[(nfestat1 >> 16) & 0x3ff] ^= ((nfmlcbitpt >> 24) & 0xff);
-
-
case 3: /* 3 bit error (Correctable) */
-
dat[nfestat1 & 0x3ff] ^= ((nfmlcbitpt >> 16) & 0xff);
-
-
case 2: /* 2 bit error (Correctable) */
-
dat[(nfestat0 >> 16) & 0x3ff] ^= ((nfmlcbitpt >> 8) & 0xff);
-
-
case 1: /* 1 bit error (Correctable) */
-
printk(KERN_INFO "s3c-nand: %d bit(s) error detected, corrected successfully\n", err_type);
-
dat[nfestat0 & 0x3ff] ^= (nfmlcbitpt & 0xff);
-
ret = err_type;
-
break;
-
-
case 0: /* No error */
-
ret = 0;
-
break;
-
}
-
}
-
-
return ret;
-}
-
-static int s3c_nand_write_oob_1bit(struct mtd_info *mtd, struct nand_chip *chip,
-
int page)
-{
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
int status = 0;
-
int eccbytes = chip->ecc.bytes;
-
int secc_start = mtd->oobsize - eccbytes;
-
int i;
-
-
chip->cmdfunc(mtd, NAND_CMD_SEQIN, mtd->writesize, page);
-
-
/* spare area */
-
chip->ecc.hwctl(mtd, NAND_ECC_WRITE);
-
chip->write_buf(mtd, chip->oob_poi, secc_start);
-
chip->ecc.calculate(mtd, 0, &ecc_calc[chip->ecc.total]);
-
-
for (i = 0; i < eccbytes; i++)
-
chip->oob_poi[secc_start + i] = ecc_calc[chip->ecc.total + i];
-
-
chip->write_buf(mtd, chip->oob_poi + secc_start, eccbytes);
-
-
/* Send command to program the OOB data */
-
chip->cmdfunc(mtd, NAND_CMD_PAGEPROG, -1, -1);
-
-
status = chip->waitfunc(mtd, chip);
-
-
return status & NAND_STATUS_FAIL ? -EIO : 0;
-}
-
-static int s3c_nand_read_oob_1bit(struct mtd_info *mtd, struct nand_chip *chip,
-
int page, int sndcmd)
-{
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
int eccbytes = chip->ecc.bytes;
-
int secc_start = mtd->oobsize - eccbytes;
-
-
if (sndcmd) {
-
chip->cmdfunc(mtd, NAND_CMD_READOOB, 0, page);
-
sndcmd = 0;
-
}
-
-
chip->ecc.hwctl(mtd, NAND_ECC_READ);
-
chip->read_buf(mtd, chip->oob_poi, secc_start);
-
chip->ecc.calculate(mtd, 0, &ecc_calc[chip->ecc.total]);
-
chip->read_buf(mtd, chip->oob_poi + secc_start, eccbytes);
-
-
return sndcmd;
-}
-
-static void s3c_nand_write_page_1bit(struct mtd_info *mtd, struct nand_chip *chip,
-
const uint8_t *buf)
-{
-
int i, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
int secc_start = mtd->oobsize - eccbytes;
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
const uint8_t *p = buf;
-
-
uint32_t *eccpos = chip->ecc.layout->eccpos;
-
-
/* main area */
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->ecc.hwctl(mtd, NAND_ECC_WRITE);
-
chip->write_buf(mtd, p, eccsize);
-
chip->ecc.calculate(mtd, p, &ecc_calc[i]);
-
}
-
-
for (i = 0; i < chip->ecc.total; i++)
-
chip->oob_poi[eccpos[i]] = ecc_calc[i];
-
-
/* spare area */
-
chip->ecc.hwctl(mtd, NAND_ECC_WRITE);
-
chip->write_buf(mtd, chip->oob_poi, secc_start);
-
chip->ecc.calculate(mtd, p, &ecc_calc[chip->ecc.total]);
-
-
for (i = 0; i < eccbytes; i++)
-
chip->oob_poi[secc_start + i] = ecc_calc[chip->ecc.total + i];
-
-
chip->write_buf(mtd, chip->oob_poi + secc_start, eccbytes);
-}
-
-static int s3c_nand_read_page_1bit(struct mtd_info *mtd, struct nand_chip *chip,
-
uint8_t *buf)
-{
-
int i, stat, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
int secc_start = mtd->oobsize - eccbytes;
-
int col = 0;
-
uint8_t *p = buf;
-
uint32_t *mecc_pos = chip->ecc.layout->eccpos;
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
-
col = mtd->writesize;
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
-
/* spare area */
-
chip->ecc.hwctl(mtd, NAND_ECC_READ);
-
chip->read_buf(mtd, chip->oob_poi, secc_start);
-
chip->ecc.calculate(mtd, p, &ecc_calc[chip->ecc.total]);
-
chip->read_buf(mtd, chip->oob_poi + secc_start, eccbytes);
-
-
col = 0;
-
-
/* main area */
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
chip->ecc.hwctl(mtd, NAND_ECC_READ);
-
chip->read_buf(mtd, p, eccsize);
-
chip->ecc.calculate(mtd, p, &ecc_calc[i]);
-
-
stat = chip->ecc.correct(mtd, p, chip->oob_poi + mecc_pos[0] +
-
((chip->ecc.steps - eccsteps) * eccbytes), 0);
-
if (stat == -1)
-
mtd->ecc_stats.failed++;
-
-
col = eccsize * (chip->ecc.steps + 1 - eccsteps);
-
}
-
-
return 0;
-}
-
-/*
- * Hardware specific page read function for MLC.
- */
-static int s3c_nand_read_page_4bit(struct mtd_info *mtd, struct nand_chip *chip,
-
uint8_t *buf)
-{
-
int i, stat, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
int col = 0;
-
uint8_t *p = buf;
-
uint32_t *mecc_pos = chip->ecc.layout->eccpos;
-
-
/* Step1: read whole oob */
-
col = mtd->writesize;
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
chip->read_buf(mtd, chip->oob_poi, mtd->oobsize);
-
-
col = 0;
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
chip->ecc.hwctl(mtd, NAND_ECC_READ);
-
chip->read_buf(mtd, p, eccsize);
-
chip->write_buf(mtd, chip->oob_poi + mecc_pos[0] +
-
((chip->ecc.steps - eccsteps) * eccbytes), eccbytes);
-
chip->ecc.calculate(mtd, 0, 0);
-
stat = chip->ecc.correct(mtd, p, 0, 0);
-
-
if (stat == -1)
-
mtd->ecc_stats.failed++;
-
-
col = eccsize * (chip->ecc.steps + 1 - eccsteps);
-
}
-
-
return 0;
-}
-
-/*
- * Hardware specific page write function for MLC.
- */
-static void s3c_nand_write_page_4bit(struct mtd_info *mtd, struct nand_chip *chip,
-
const uint8_t *buf)
-{
-
int i, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
const uint8_t *p = buf;
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
uint32_t *mecc_pos = chip->ecc.layout->eccpos;
-
-
/* Step1: write main data and encode mecc */
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->ecc.hwctl(mtd, NAND_ECC_WRITE);
-
chip->write_buf(mtd, p, eccsize);
-
chip->ecc.calculate(mtd, p, &ecc_calc[i]);
-
}
-
-
/* Step2: save encoded mecc */
-
for (i = 0; i < chip->ecc.total; i++)
-
chip->oob_poi[mecc_pos[i]] = ecc_calc[i];
-
-
chip->write_buf(mtd, chip->oob_poi, mtd->oobsize);
-}
-
-
-static void s3c_nand_wait_ecc_busy_8bit(void)
-{
-
void __iomem *regs = s3c_nand.regs;
-
unsigned int timeout;
-
-
/* Wait max 100ms */
-
timeout = 1000;
-
while (readl(regs + S3C_NF8ECCERR0) & S3C_NFECCERR0_ECCBUSY) {
-
if (timeout == 0) {
-
printk(KERN_ERR "s3c_nand : wait_ecc_busy err.\n");
-
break;
-
}
-
-
timeout--;
-
udelay(100);
-
}
-}
-
-void s3c_nand_enable_hwecc_8bit(struct mtd_info *mtd, int mode)
-{
-
u_long nfcont, nfconf;
-
void __iomem *regs = s3c_nand.regs;
-
-
cur_ecc_mode = mode;
-
-
/* 8 bit selection */
-
nfconf = readl(regs + S3C_NFCONF);
-
-
nfconf &= ~(0x3 << 23);
-
nfconf |= (0x1 << 23);
-
-
writel(nfconf, (regs + S3C_NFCONF));
-
-
/* Initialize & unlock */
-
nfcont = readl(regs + S3C_NFCONT);
-
nfcont |= S3C_NFCONT_INITECC;
-
nfcont &= ~S3C_NFCONT_MECCLOCK;
-
-
if (mode == NAND_ECC_WRITE)
-
nfcont |= S3C_NFCONT_ECC_ENC;
-
else if (mode == NAND_ECC_READ)
-
nfcont &= ~S3C_NFCONT_ECC_ENC;
-
-
writel(nfcont, (regs + S3C_NFCONT));
-}
-
-int s3c_nand_calculate_ecc_8bit(struct mtd_info *mtd, const u_char *dat, u_char *ecc_code)
-{
-
u_long nfcont, nfm8ecc0, nfm8ecc1, nfm8ecc2, nfm8ecc3;
-
void __iomem *regs = s3c_nand.regs;
-
-
/* Lock */
-
nfcont = readl(regs + S3C_NFCONT);
-
nfcont |= S3C_NFCONT_MECCLOCK;
-
writel(nfcont, (regs + S3C_NFCONT));
-
-
if (cur_ecc_mode == NAND_ECC_READ)
-
s3c_nand_wait_dec();
-
else {
-
s3c_nand_wait_enc();
-
-
nfm8ecc0 = readl(regs + S3C_NFM8ECC0);
-
nfm8ecc1 = readl(regs + S3C_NFM8ECC1);
-
nfm8ecc2 = readl(regs + S3C_NFM8ECC2);
-
nfm8ecc3 = readl(regs + S3C_NFM8ECC3);
-
-
ecc_code[0] = nfm8ecc0 & 0xff;
-
ecc_code[1] = (nfm8ecc0 >> 8) & 0xff;
-
ecc_code[2] = (nfm8ecc0 >> 16) & 0xff;
-
ecc_code[3] = (nfm8ecc0 >> 24) & 0xff;
-
ecc_code[4] = nfm8ecc1 & 0xff;
-
ecc_code[5] = (nfm8ecc1 >> 8) & 0xff;
-
ecc_code[6] = (nfm8ecc1 >> 16) & 0xff;
-
ecc_code[7] = (nfm8ecc1 >> 24) & 0xff;
-
ecc_code[8] = nfm8ecc2 & 0xff;
-
ecc_code[9] = (nfm8ecc2 >> 8) & 0xff;
-
ecc_code[10] = (nfm8ecc2 >> 16) & 0xff;
-
ecc_code[11] = (nfm8ecc2 >> 24) & 0xff;
-
ecc_code[12] = nfm8ecc3 & 0xff;
-
}
-
-
return 0;
-}
-
-int s3c_nand_correct_data_8bit(struct mtd_info *mtd, u_char *dat, u_char *read_ecc, u_char *calc_ecc)
-{
-
int ret = -1;
-
u_long nf8eccerr0, nf8eccerr1, nf8eccerr2, nfmlc8bitpt0, nfmlc8bitpt1;
-
u_char err_type;
-
void __iomem *regs = s3c_nand.regs;
-
-
s3c_nand_wait_ecc_busy_8bit();
-
-
nf8eccerr0 = readl(regs + S3C_NF8ECCERR0);
-
nf8eccerr1 = readl(regs + S3C_NF8ECCERR1);
-
nf8eccerr2 = readl(regs + S3C_NF8ECCERR2);
-
nfmlc8bitpt0 = readl(regs + S3C_NFMLC8BITPT0);
-
nfmlc8bitpt1 = readl(regs + S3C_NFMLC8BITPT1);
-
-
err_type = (nf8eccerr0 >> 25) & 0xf;
-
-
/*
-
* No error, If free page (all 0xff)
-
* While testing, it was found that NFECCERR0[29] bit is set even if
-
* the page contents were not zero. So this code is commented
-
*/
-
switch (err_type) {
-
case 9: /* Uncorrectable */
-
printk(KERN_INFO "s3c-nand: ECC uncorrectable error detected\n");
-
ret = -1;
-
break;
-
-
case 8: /* 8 bit error (Correctable) */
-
dat[(nf8eccerr2 >> 22) & 0x3ff] ^= ((nfmlc8bitpt1 >> 24) & 0xff);
-
-
case 7: /* 7 bit error (Correctable) */
-
dat[(nf8eccerr2 >> 11) & 0x3ff] ^= ((nfmlc8bitpt1 >> 16) & 0xff);
-
-
case 6: /* 6 bit error (Correctable) */
-
dat[nf8eccerr2 & 0x3ff] ^= ((nfmlc8bitpt1 >> 8) & 0xff);
-
-
case 5: /* 5 bit error (Correctable) */
-
dat[(nf8eccerr1 >> 22) & 0x3ff] ^= (nfmlc8bitpt1 & 0xff);
-
-
case 4: /* 4 bit error (Correctable) */
-
dat[(nf8eccerr1 >> 11) & 0x3ff] ^= ((nfmlc8bitpt0 >> 24) & 0xff);
-
-
case 3: /* 3 bit error (Correctable) */
-
dat[nf8eccerr1 & 0x3ff] ^= ((nfmlc8bitpt0 >> 16) & 0xff);
-
-
case 2: /* 2 bit error (Correctable) */
-
dat[(nf8eccerr0 >> 15) & 0x3ff] ^= ((nfmlc8bitpt0 >> 8) & 0xff);
-
-
case 1: /* 1 bit error (Correctable) */
-
printk(KERN_INFO "s3c-nand: %d bit(s) error detected, corrected successfully\n", err_type);
-
dat[nf8eccerr0 & 0x3ff] ^= (nfmlc8bitpt0 & 0xff);
-
ret = err_type;
-
break;
-
-
case 0: /* No error */
-
ret = 0;
-
break;
-
}
-
-
return ret;
-}
-
-void s3c_nand_write_page_8bit(struct mtd_info *mtd, struct nand_chip *chip,
-
const uint8_t *buf)
-{
-
int i, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
const uint8_t *p = buf;
-
int badoffs = mtd->writesize == 512 ? NAND_SMALL_BADBLOCK_POS : NAND_LARGE_BADBLOCK_POS;
-
uint8_t *ecc_calc = chip->buffers->ecccalc;
-
uint32_t *mecc_pos = chip->ecc.layout->eccpos;
-
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->ecc.hwctl(mtd, NAND_ECC_WRITE);
-
chip->write_buf(mtd, p, eccsize);
-
chip->ecc.calculate(mtd, p, &ecc_calc[i]);
-
}
-
-
chip->oob_poi[badoffs] = 0xff;
-
for (i = 0; i < chip->ecc.total; i++)
-
chip->oob_poi[mecc_pos[i]] = ecc_calc[i];
-
-
chip->write_buf(mtd, chip->oob_poi, mtd->oobsize);
-}
-
-int s3c_nand_read_page_8bit(struct mtd_info *mtd, struct nand_chip *chip,
-
uint8_t *buf)
-{
-
int i, stat, eccsize = chip->ecc.size;
-
int eccbytes = chip->ecc.bytes;
-
int eccsteps = chip->ecc.steps;
-
int col = 0;
-
uint8_t *p = buf;
-
uint32_t *mecc_pos = chip->ecc.layout->eccpos;
-
-
/* Step1: read whole oob */
-
col = mtd->writesize;
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
chip->read_buf(mtd, chip->oob_poi, mtd->oobsize);
-
-
col = 0;
-
for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
-
chip->cmdfunc(mtd, NAND_CMD_RNDOUT, col, -1);
-
s3c_nand_enable_hwecc_8bit(mtd, NAND_ECC_READ);
-
chip->read_buf(mtd, p, eccsize);
-
chip->write_buf(mtd, chip->oob_poi + mecc_pos[0] + ((chip->ecc.steps - eccsteps) * eccbytes), eccbytes);
-
chip->ecc.calculate(mtd, 0, 0);
-
stat = chip->ecc.correct(mtd, p, NULL, NULL);
-
-
if (stat == -1)
-
mtd->ecc_stats.failed++;
-
-
col = eccsize * ((mtd->writesize / eccsize) + 1 - eccsteps);
-
}
-
-
return 0;
-}
-
-int s3c_nand_read_oob_8bit(struct mtd_info *mtd, struct nand_chip *chip,
-
int page, int sndcmd)
-{
-
int eccbytes = chip->ecc.bytes;
-
int secc_start = mtd->oobsize - eccbytes;
-
-
if (sndcmd) {
-
chip->cmdfunc(mtd, NAND_CMD_READOOB, 0, page);
-
sndcmd = 0;
-
}
-
-
chip->read_buf(mtd, chip->oob_poi, secc_start);
-
return sndcmd;
-}
-
-int s3c_nand_write_oob_8bit(struct mtd_info *mtd, struct nand_chip *chip, int page)
-{
-
int status = 0;
-
int eccbytes = chip->ecc.bytes;
-
int secc_start = mtd->oobsize - eccbytes;
-
-
chip->cmdfunc(mtd, NAND_CMD_SEQIN, mtd->writesize, page);
-
-
chip->write_buf(mtd, chip->oob_poi, secc_start);
-
chip->cmdfunc(mtd, NAND_CMD_PAGEPROG, -1, -1);
-
status = chip->waitfunc(mtd, chip);
-
-
return status & NAND_STATUS_FAIL ? -EIO : 0;
-}
-#endif
-
-/* s3c_nand_probe
- *
- * called by device layer when it finds a device matching
- * one our driver can handled. This code checks to see if
- * it can allocate all necessary resources then calls the
- * nand layer to look for devices
- */
-static int s3c_nand_probe(struct platform_device *pdev, enum s3c_cpu_type cpu_type)
-{
-#if defined(CONFIG_ARCH_S5PV210)
-
struct s3c_nand_mtd_info *plat_info = &s3c_nand_mtd_part_info;
-#else
-
struct s3c_nand_mtd_info *plat_info = pdev->dev.platform_data;
-#endif
-
struct mtd_partition *partition_info = (struct mtd_partition *)plat_info->partition;
-
struct nand_chip *nand;
-
struct resource *res;
-
int err = 0;
-
int ret = 0;
-
int i, size;
-#ifdef CONFIG_MTD_PARTITIONS
-
struct mtd_partition *partitions = NULL;
-
int num_partitions = 0;
-#endif
-
-#if defined(CONFIG_MTD_NAND_S3C_HWECC)
-
struct nand_flash_dev *type = NULL;
-
u_char tmp;
-
int j;
-#endif
-
-
/* get the clock source and enable it */
-
s3c_nand.clk = clk_get(&pdev->dev, "nand");
-
if (IS_ERR(s3c_nand.clk)) {
-
dev_err(&pdev->dev, "failed to get clock");
-
err = -ENOENT;
-
goto exit_error;
-
}
-
-
clk_enable(s3c_nand.clk);
-
-
/* allocate and map the resource */
-
-
/* currently we assume we have the one resource */
-
res = pdev->resource;
-
size = res->end - res->start + 1;
-
-
s3c_nand.area = request_mem_region(res->start, size, pdev->name);
-
-
if (s3c_nand.area == NULL) {
-
dev_err(&pdev->dev, "cannot reserve register region\n");
-
err = -ENOENT;
-
goto exit_error;
-
}
-
-
s3c_nand.cpu_type = cpu_type;
-
s3c_nand.device = &pdev->dev;
-
s3c_nand.regs = ioremap(res->start, size);
-
-
if (s3c_nand.regs == NULL) {
-
dev_err(&pdev->dev, "cannot reserve register region\n");
-
err = -EIO;
-
goto exit_error;
-
}
-
-
/* allocate memory for MTD device structure and private data */
-
s3c_mtd = kmalloc(sizeof(struct mtd_info) + sizeof(struct nand_chip), GFP_KERNEL);
-
-
if (!s3c_mtd) {
-
printk(KERN_ERR "Unable to allocate NAND MTD dev structure.\n");
-
return -ENOMEM;
-
}
-
-
/* Get pointer to private data */
-
nand = (struct nand_chip *) (&s3c_mtd[1]);
-
-
/* Initialize structures */
-
memset((char *) s3c_mtd, 0, sizeof(struct mtd_info));
-
memset((char *) nand, 0, sizeof(struct nand_chip));
-
-
/* Link the private data with the MTD structure */
-
s3c_mtd->priv = nand;
-
-
for (i = 0; i < plat_info->chip_nr; i++) {
-
nand->IO_ADDR_R
= (char *)(s3c_nand.regs + S3C_NFDATA);
-
nand->IO_ADDR_W
= (char *)(s3c_nand.regs + S3C_NFDATA);
-
nand->cmd_ctrl
= s3c_nand_hwcontrol;
-
nand->dev_ready
= s3c_nand_device_ready;
-
nand->scan_bbt
= s3c_nand_scan_bbt;
-
nand->options
= 0;
-
-#if defined(CONFIG_MTD_NAND_S3C_HWECC)
-
nand->ecc.mode
= NAND_ECC_HW;
-
nand->ecc.hwctl
= s3c_nand_enable_hwecc;
-
nand->ecc.calculate
= s3c_nand_calculate_ecc;
-
nand->ecc.correct
= s3c_nand_correct_data;
-
-
s3c_nand_hwcontrol(0, NAND_CMD_READID, NAND_NCE | NAND_CLE | NAND_CTRL_CHANGE);
-
s3c_nand_hwcontrol(0, 0x00, NAND_CTRL_CHANGE | NAND_NCE | NAND_ALE);
-
s3c_nand_hwcontrol(0, 0x00, NAND_NCE | NAND_ALE);
-
s3c_nand_hwcontrol(0, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
-
s3c_nand_device_ready(0);
-
-
tmp = readb(nand->IO_ADDR_R); /* Maf. ID */
-
tmp = readb(nand->IO_ADDR_R); /* Device ID */
-
-
for (j = 0; nand_flash_ids[j].name != NULL; j++) {
-
if (tmp == nand_flash_ids[j].id) {
-
type = &nand_flash_ids[j];
-
break;
-
}
-
}
-
-
if (!type) {
-
printk(KERN_ERR "Unknown NAND Device.\n");
-
goto exit_error;
-
}
-
-
nand->cellinfo = readb(nand->IO_ADDR_R);
/* the 3rd byte */
-
tmp = readb(nand->IO_ADDR_R);
/* the 4th byte */
-
if (!type->pagesize) {
-
if (((nand->cellinfo >> 2) & 0x3) == 0) {
-
nand_type = S3C_NAND_TYPE_SLC;
-
nand->ecc.size = 512;
-
nand->ecc.bytes
= 4;
-
-
/* For 4KB Page 8_bit ECC */
-
if ((1024 << (tmp & 3)) == 4096) {
-
/* Page size is 4Kbytes */
-
nand->ecc.read_page = s3c_nand_read_page_8bit;
-
nand->ecc.write_page = s3c_nand_write_page_8bit;
-
nand->ecc.read_oob = s3c_nand_read_oob_8bit;
-
nand->ecc.write_oob = s3c_nand_write_oob_8bit;
-
nand->ecc.layout = &s3c_nand_oob_128;
-
nand->ecc.hwctl = s3c_nand_enable_hwecc_8bit;
-
nand->ecc.calculate = s3c_nand_calculate_ecc_8bit;
-
nand->ecc.correct = s3c_nand_correct_data_8bit;
-
nand->ecc.size = 512;
-
nand->ecc.bytes = 13;
-
nand->options |= NAND_NO_SUBPAGE_WRITE;
-
} else {
-
if ((1024 << (tmp & 0x3)) > 512) {
-
nand->ecc.read_page = s3c_nand_read_page_1bit;
-
nand->ecc.write_page = s3c_nand_write_page_1bit;
-
nand->ecc.read_oob = s3c_nand_read_oob_1bit;
-
nand->ecc.write_oob = s3c_nand_write_oob_1bit;
-
nand->ecc.layout = &s3c_nand_oob_64;
-
} else {
-
nand->ecc.layout = &s3c_nand_oob_16;
-
}
-
}
-
} else {
-
nand_type = S3C_NAND_TYPE_MLC;
-
nand->options |= NAND_NO_SUBPAGE_WRITE;
/* NOP = 1 if MLC */
-
-
if ((1024 << (tmp & 3)) == 4096) {
-
/* Page size is 4Kbytes */
-
nand->ecc.read_page = s3c_nand_read_page_8bit;
-
nand->ecc.write_page = s3c_nand_write_page_8bit;
-
nand->ecc.read_oob = s3c_nand_read_oob_8bit;
-
nand->ecc.write_oob = s3c_nand_write_oob_8bit;
-
nand->ecc.layout = &s3c_nand_oob_128;
-
nand->ecc.hwctl = s3c_nand_enable_hwecc_8bit;
-
nand->ecc.calculate = s3c_nand_calculate_ecc_8bit;
-
nand->ecc.correct = s3c_nand_correct_data_8bit;
-
nand->ecc.size = 512;
-
nand->ecc.bytes = 13;
-
nand->options |= NAND_NO_SUBPAGE_WRITE;
-
} else {
-
nand->ecc.read_page = s3c_nand_read_page_4bit;
-
nand->ecc.write_page = s3c_nand_write_page_4bit;
-
nand->ecc.size = 512;
-
nand->ecc.bytes = 8; /* really 7 bytes */
-
nand->ecc.layout = &s3c_nand_oob_mlc_64;
-
}
-
}
-
} else {
-
nand_type = S3C_NAND_TYPE_SLC;
-
nand->ecc.size = 512;
-
nand->cellinfo = 0;
-
nand->ecc.bytes = 4;
-
nand->ecc.layout = &s3c_nand_oob_16;
-
}
-
-
printk(KERN_INFO "S3C NAND Driver is using hardware ECC.\n");
-#else
-
nand->ecc.mode = NAND_ECC_SOFT;
-
printk(KERN_INFO "S3C NAND Driver is using software ECC.\n");
-#endif
-
if (nand_scan(s3c_mtd, 1)) {
-
ret = -ENXIO;
-
goto exit_error;
-
}
-
-
s3c_mtd->name = dev_name(&pdev->dev);
-
s3c_mtd->owner = THIS_MODULE;
-
-
/* Register the partitions */
-#ifdef CONFIG_MTD_CMDLINE_PARTS
-
num_partitions = parse_mtd_partitions(s3c_mtd, part_probes, &partitions, 0);
-#endif
-
if (num_partitions <= 0) {
-
/* default partition table */
-
num_partitions = plat_info->mtd_part_nr;
-
partitions = partition_info;
-
}
-
-
add_mtd_partitions(s3c_mtd, partitions, num_partitions);
-
}
-
-
pr_debug("initialized ok\n");
-
return 0;
-
-exit_error:
-
kfree(s3c_mtd);
-
-
return ret;
-}
-
-static int s5pv210_nand_probe(struct platform_device *dev)
-{
-
return s3c_nand_probe(dev, TYPE_S5PV210);
-}
-
-/* PM Support */
-#if defined(CONFIG_PM)
-static int s3c_nand_suspend(struct platform_device *dev, pm_message_t pm)
-{
-
clk_disable(s3c_nand.clk);
-
return 0;
-}
-
-static int s3c_nand_resume(struct platform_device *dev)
-{
-
clk_enable(s3c_nand.clk);
-
return 0;
-}
-
-#else
-#define s3c_nand_suspend NULL
-#define s3c_nand_resume NULL
-#endif
-
-/* device management functions */
-static int s3c_nand_remove(struct platform_device *dev)
-{
-
platform_set_drvdata(dev, NULL);
-
-
return 0;
-}
-
-static struct platform_driver s5pv210_nand_driver = {
-
.probe = s5pv210_nand_probe,
-
.remove = s3c_nand_remove,
-
.suspend = s3c_nand_suspend,
-
.resume = s3c_nand_resume,
-
.driver = {
-
.name = "s5pv210-nand",
-
.owner = THIS_MODULE,
-
},
-};
-
-static int __init s3c_nand_init(void)
-{
-
printk(KERN_INFO "S3C NAND Driver, (c) 2008 Samsung Electronics\n");
-
-
return platform_driver_register(&s5pv210_nand_driver);
-}
-
-static void __exit s3c_nand_exit(void)
-{
-
platform_driver_unregister(&s5pv210_nand_driver);
-}
-
-module_init(s3c_nand_init);
-module_exit(s3c_nand_exit);
-
-MODULE_LICENSE("GPL");
-MODULE_AUTHOR("Jinsung Yang <
[email protected]>");
-MODULE_DESCRIPTION("S3C MTD NAND driver");
-
diff --git a/include/linux/mtd/partitions.h b/include/linux/mtd/partitions.h
index 6a0dc17..3a6f037 100644
--- a/include/linux/mtd/partitions.h
+++ b/include/linux/mtd/partitions.h
@@ -49,9 +49,6 @@ struct mtd_partition {
struct mtd_info;
-int add_mtd_partitions(struct mtd_info *, const struct mtd_partition *, int);//jhk
-int del_mtd_partitions(struct mtd_info *);//jhk
-
/*
* Functions dealing with the various ways of partitioning the space
*/