mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-13 08:20:07 +00:00
614683faf8
SVN-Revision: 13613
2765 lines
66 KiB
Diff
2765 lines
66 KiB
Diff
From 3f12f6b0b863453038bc4b7435b5bab06be30f45 Mon Sep 17 00:00:00 2001
|
|
From: Andy Green <andy@openmoko.com>
|
|
Date: Tue, 18 Nov 2008 12:11:13 +0000
|
|
Subject: [PATCH] fix-missing-new-files-glofiish.patch
|
|
|
|
Add in uncommitted local files after Harald's patch
|
|
|
|
Reported-by: Stefan Schmidt <stefan@openmoko.org>
|
|
Signed-off-by: Andy Green <andy@openmoko.com>
|
|
---
|
|
arch/arm/configs/glofiish_defconfig | 1728 +++++++++++++++++++++++++++++++
|
|
arch/arm/mach-s3c2440/mach-glofiish.c | 620 +++++++++++
|
|
drivers/input/keyboard/m800kbd.c | 330 ++++++
|
|
include/asm-arm/arch-s3c2410/glofiish.h | 39 +
|
|
4 files changed, 2717 insertions(+), 0 deletions(-)
|
|
create mode 100644 arch/arm/configs/glofiish_defconfig
|
|
create mode 100644 arch/arm/mach-s3c2440/mach-glofiish.c
|
|
create mode 100644 drivers/input/keyboard/m800kbd.c
|
|
create mode 100644 include/asm-arm/arch-s3c2410/glofiish.h
|
|
|
|
diff --git a/arch/arm/configs/glofiish_defconfig b/arch/arm/configs/glofiish_defconfig
|
|
new file mode 100644
|
|
index 0000000..808d61f
|
|
--- /dev/null
|
|
+++ b/arch/arm/configs/glofiish_defconfig
|
|
@@ -0,0 +1,1728 @@
|
|
+#
|
|
+# Automatically generated make config: don't edit
|
|
+# Linux kernel version: 2.6.24
|
|
+# Wed Nov 12 00:27:24 2008
|
|
+#
|
|
+CONFIG_ARM=y
|
|
+CONFIG_SYS_SUPPORTS_APM_EMULATION=y
|
|
+CONFIG_GENERIC_GPIO=y
|
|
+# CONFIG_GENERIC_TIME is not set
|
|
+# CONFIG_GENERIC_CLOCKEVENTS is not set
|
|
+CONFIG_MMU=y
|
|
+CONFIG_NO_IOPORT=y
|
|
+CONFIG_GENERIC_HARDIRQS=y
|
|
+CONFIG_STACKTRACE_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_ILOG2_U32 is not set
|
|
+# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
|
+CONFIG_GENERIC_HWEIGHT=y
|
|
+CONFIG_GENERIC_CALIBRATE_DELAY=y
|
|
+CONFIG_ZONE_DMA=y
|
|
+CONFIG_VECTORS_BASE=0xffff0000
|
|
+CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
|
|
+
|
|
+#
|
|
+# General setup
|
|
+#
|
|
+CONFIG_EXPERIMENTAL=y
|
|
+CONFIG_BROKEN_ON_SMP=y
|
|
+CONFIG_LOCK_KERNEL=y
|
|
+CONFIG_INIT_ENV_ARG_LIMIT=32
|
|
+CONFIG_LOCALVERSION=""
|
|
+# CONFIG_LOCALVERSION_AUTO is not set
|
|
+CONFIG_SWAP=y
|
|
+CONFIG_SYSVIPC=y
|
|
+CONFIG_SYSVIPC_SYSCTL=y
|
|
+# CONFIG_POSIX_MQUEUE is not set
|
|
+# CONFIG_BSD_PROCESS_ACCT is not set
|
|
+# CONFIG_TASKSTATS is not set
|
|
+# CONFIG_USER_NS is not set
|
|
+# CONFIG_PID_NS is not set
|
|
+# CONFIG_AUDIT is not set
|
|
+# CONFIG_IKCONFIG is not set
|
|
+CONFIG_LOG_BUF_SHIFT=14
|
|
+# CONFIG_CGROUPS is not set
|
|
+# CONFIG_FAIR_GROUP_SCHED is not set
|
|
+# CONFIG_SYSFS_DEPRECATED is not set
|
|
+# CONFIG_RELAY is not set
|
|
+CONFIG_BLK_DEV_INITRD=y
|
|
+CONFIG_INITRAMFS_SOURCE=""
|
|
+CONFIG_CC_OPTIMIZE_FOR_SIZE=y
|
|
+CONFIG_SYSCTL=y
|
|
+# CONFIG_EMBEDDED is not set
|
|
+CONFIG_UID16=y
|
|
+CONFIG_SYSCTL_SYSCALL=y
|
|
+CONFIG_KALLSYMS=y
|
|
+# CONFIG_KALLSYMS_ALL is not set
|
|
+# CONFIG_KALLSYMS_EXTRA_PASS is not set
|
|
+CONFIG_HOTPLUG=y
|
|
+CONFIG_PRINTK=y
|
|
+CONFIG_BUG=y
|
|
+CONFIG_ELF_CORE=y
|
|
+CONFIG_BASE_FULL=y
|
|
+CONFIG_FUTEX=y
|
|
+CONFIG_ANON_INODES=y
|
|
+CONFIG_EPOLL=y
|
|
+CONFIG_SIGNALFD=y
|
|
+CONFIG_EVENTFD=y
|
|
+CONFIG_SHMEM=y
|
|
+CONFIG_VM_EVENT_COUNTERS=y
|
|
+CONFIG_SLAB=y
|
|
+# CONFIG_SLUB is not set
|
|
+# CONFIG_SLOB is not set
|
|
+CONFIG_SLABINFO=y
|
|
+CONFIG_RT_MUTEXES=y
|
|
+# CONFIG_TINY_SHMEM is not set
|
|
+CONFIG_BASE_SMALL=0
|
|
+CONFIG_MODULES=y
|
|
+CONFIG_MODULE_UNLOAD=y
|
|
+CONFIG_MODULE_FORCE_UNLOAD=y
|
|
+# CONFIG_MODVERSIONS is not set
|
|
+# CONFIG_MODULE_SRCVERSION_ALL is not set
|
|
+CONFIG_KMOD=y
|
|
+CONFIG_BLOCK=y
|
|
+# CONFIG_LBD is not set
|
|
+# CONFIG_BLK_DEV_IO_TRACE is not set
|
|
+# CONFIG_LSF is not set
|
|
+# CONFIG_BLK_DEV_BSG is not set
|
|
+
|
|
+#
|
|
+# IO Schedulers
|
|
+#
|
|
+CONFIG_IOSCHED_NOOP=y
|
|
+CONFIG_IOSCHED_AS=m
|
|
+CONFIG_IOSCHED_DEADLINE=y
|
|
+CONFIG_IOSCHED_CFQ=m
|
|
+# CONFIG_DEFAULT_AS is not set
|
|
+CONFIG_DEFAULT_DEADLINE=y
|
|
+# CONFIG_DEFAULT_CFQ is not set
|
|
+# CONFIG_DEFAULT_NOOP is not set
|
|
+CONFIG_DEFAULT_IOSCHED="deadline"
|
|
+
|
|
+#
|
|
+# System Type
|
|
+#
|
|
+# CONFIG_ARCH_AAEC2000 is not set
|
|
+# CONFIG_ARCH_INTEGRATOR is not set
|
|
+# CONFIG_ARCH_REALVIEW is not set
|
|
+# CONFIG_ARCH_VERSATILE is not set
|
|
+# CONFIG_ARCH_AT91 is not set
|
|
+# CONFIG_ARCH_CLPS7500 is not set
|
|
+# CONFIG_ARCH_CLPS711X is not set
|
|
+# CONFIG_ARCH_CO285 is not set
|
|
+# CONFIG_ARCH_EBSA110 is not set
|
|
+# CONFIG_ARCH_EP93XX is not set
|
|
+# CONFIG_ARCH_FOOTBRIDGE is not set
|
|
+# CONFIG_ARCH_NETX is not set
|
|
+# CONFIG_ARCH_H720X is not set
|
|
+# CONFIG_ARCH_IMX is not set
|
|
+# CONFIG_ARCH_IOP13XX is not set
|
|
+# CONFIG_ARCH_IOP32X is not set
|
|
+# CONFIG_ARCH_IOP33X is not set
|
|
+# CONFIG_ARCH_IXP23XX is not set
|
|
+# CONFIG_ARCH_IXP2000 is not set
|
|
+# CONFIG_ARCH_IXP4XX is not set
|
|
+# CONFIG_ARCH_L7200 is not set
|
|
+# CONFIG_ARCH_KS8695 is not set
|
|
+# CONFIG_ARCH_NS9XXX is not set
|
|
+# CONFIG_ARCH_MXC is not set
|
|
+# CONFIG_ARCH_PNX4008 is not set
|
|
+# CONFIG_ARCH_PXA is not set
|
|
+# CONFIG_ARCH_RPC is not set
|
|
+# CONFIG_ARCH_SA1100 is not set
|
|
+CONFIG_ARCH_S3C2410=y
|
|
+# CONFIG_ARCH_SHARK is not set
|
|
+# CONFIG_ARCH_LH7A40X is not set
|
|
+# CONFIG_ARCH_DAVINCI is not set
|
|
+# CONFIG_ARCH_OMAP is not set
|
|
+CONFIG_PLAT_S3C24XX=y
|
|
+CONFIG_CPU_S3C244X=y
|
|
+CONFIG_S3C2410_DMA=y
|
|
+# CONFIG_S3C2410_DMA_DEBUG is not set
|
|
+CONFIG_MACH_SMDK=y
|
|
+CONFIG_PLAT_S3C=y
|
|
+CONFIG_CPU_LLSERIAL_S3C2410=y
|
|
+CONFIG_CPU_LLSERIAL_S3C2440=y
|
|
+
|
|
+#
|
|
+# Boot options
|
|
+#
|
|
+# CONFIG_S3C_BOOT_WATCHDOG is not set
|
|
+# CONFIG_S3C_BOOT_ERROR_RESET is not set
|
|
+
|
|
+#
|
|
+# Power management
|
|
+#
|
|
+# CONFIG_S3C2410_PM_CHECK is not set
|
|
+CONFIG_S3C_LOWLEVEL_UART_PORT=2
|
|
+
|
|
+#
|
|
+# S3C2400 Machines
|
|
+#
|
|
+CONFIG_CPU_S3C2410=y
|
|
+CONFIG_CPU_S3C2410_DMA=y
|
|
+CONFIG_S3C2410_PM=y
|
|
+CONFIG_S3C2410_GPIO=y
|
|
+CONFIG_S3C2410_CLOCK=y
|
|
+CONFIG_S3C2410_PWM=y
|
|
+
|
|
+#
|
|
+# S3C2410 Machines
|
|
+#
|
|
+# CONFIG_ARCH_SMDK2410 is not set
|
|
+# CONFIG_ARCH_H1940 is not set
|
|
+# CONFIG_MACH_N30 is not set
|
|
+# CONFIG_ARCH_BAST is not set
|
|
+# CONFIG_MACH_OTOM is not set
|
|
+# CONFIG_MACH_AML_M5900 is not set
|
|
+# CONFIG_MACH_VR1000 is not set
|
|
+CONFIG_MACH_QT2410=y
|
|
+# CONFIG_MACH_NEO1973_GTA01 is not set
|
|
+
|
|
+#
|
|
+# S3C2412 Machines
|
|
+#
|
|
+# CONFIG_MACH_SMDK2413 is not set
|
|
+# CONFIG_MACH_SMDK2412 is not set
|
|
+# CONFIG_MACH_VSTMS is not set
|
|
+CONFIG_CPU_S3C2440=y
|
|
+CONFIG_S3C2440_DMA=y
|
|
+# CONFIG_S3C2440_C_FIQ is not set
|
|
+
|
|
+#
|
|
+# S3C2440 Machines
|
|
+#
|
|
+# CONFIG_MACH_ANUBIS is not set
|
|
+# CONFIG_MACH_OSIRIS is not set
|
|
+# CONFIG_MACH_RX3715 is not set
|
|
+CONFIG_ARCH_S3C2440=y
|
|
+# CONFIG_MACH_NEXCODER_2440 is not set
|
|
+CONFIG_SMDK2440_CPU2440=y
|
|
+# CONFIG_MACH_HXD8 is not set
|
|
+# CONFIG_MACH_NEO1973_GTA02 is not set
|
|
+CONFIG_MACH_M800=y
|
|
+CONFIG_CPU_S3C2442=y
|
|
+
|
|
+#
|
|
+# S3C2442 Machines
|
|
+#
|
|
+CONFIG_SMDK2440_CPU2442=y
|
|
+
|
|
+#
|
|
+# S3C2443 Machines
|
|
+#
|
|
+# CONFIG_MACH_SMDK2443 is not set
|
|
+
|
|
+#
|
|
+# Processor Type
|
|
+#
|
|
+CONFIG_CPU_32=y
|
|
+CONFIG_CPU_ARM920T=y
|
|
+CONFIG_CPU_32v4T=y
|
|
+CONFIG_CPU_ABRT_EV4T=y
|
|
+CONFIG_CPU_CACHE_V4WT=y
|
|
+CONFIG_CPU_CACHE_VIVT=y
|
|
+CONFIG_CPU_COPY_V4WB=y
|
|
+CONFIG_CPU_TLB_V4WBI=y
|
|
+CONFIG_CPU_CP15=y
|
|
+CONFIG_CPU_CP15_MMU=y
|
|
+
|
|
+#
|
|
+# Processor Features
|
|
+#
|
|
+CONFIG_ARM_THUMB=y
|
|
+# CONFIG_CPU_ICACHE_DISABLE is not set
|
|
+# CONFIG_CPU_DCACHE_DISABLE is not set
|
|
+# CONFIG_CPU_DCACHE_WRITETHROUGH is not set
|
|
+# CONFIG_OUTER_CACHE 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 is not set
|
|
+CONFIG_PREEMPT=y
|
|
+CONFIG_NO_IDLE_HZ=y
|
|
+CONFIG_HZ=200
|
|
+CONFIG_AEABI=y
|
|
+CONFIG_OABI_COMPAT=y
|
|
+# CONFIG_ARCH_DISCONTIGMEM_ENABLE is not set
|
|
+CONFIG_SELECT_MEMORY_MODEL=y
|
|
+CONFIG_FLATMEM_MANUAL=y
|
|
+# CONFIG_DISCONTIGMEM_MANUAL is not set
|
|
+# CONFIG_SPARSEMEM_MANUAL is not set
|
|
+CONFIG_FLATMEM=y
|
|
+CONFIG_FLAT_NODE_MEM_MAP=y
|
|
+# CONFIG_SPARSEMEM_STATIC is not set
|
|
+# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set
|
|
+CONFIG_SPLIT_PTLOCK_CPUS=4096
|
|
+# CONFIG_RESOURCES_64BIT is not set
|
|
+CONFIG_ZONE_DMA_FLAG=1
|
|
+CONFIG_BOUNCE=y
|
|
+CONFIG_VIRT_TO_BUS=y
|
|
+CONFIG_ALIGNMENT_TRAP=y
|
|
+
|
|
+#
|
|
+# Boot options
|
|
+#
|
|
+CONFIG_ZBOOT_ROM_TEXT=0x0
|
|
+CONFIG_ZBOOT_ROM_BSS=0x0
|
|
+CONFIG_CMDLINE="root=/dev/mmcblk0p1 rootdelay=5"
|
|
+# CONFIG_XIP_KERNEL is not set
|
|
+CONFIG_KEXEC=y
|
|
+CONFIG_ATAGS_PROC=y
|
|
+
|
|
+#
|
|
+# Floating point emulation
|
|
+#
|
|
+
|
|
+#
|
|
+# At least one emulation must be selected
|
|
+#
|
|
+CONFIG_FPE_NWFPE=y
|
|
+# CONFIG_FPE_NWFPE_XP is not set
|
|
+# CONFIG_FPE_FASTFPE is not set
|
|
+
|
|
+#
|
|
+# Userspace binary formats
|
|
+#
|
|
+CONFIG_BINFMT_ELF=y
|
|
+# CONFIG_BINFMT_AOUT is not set
|
|
+# CONFIG_BINFMT_MISC is not set
|
|
+
|
|
+#
|
|
+# Power management options
|
|
+#
|
|
+CONFIG_PM=y
|
|
+CONFIG_PM_LEGACY=y
|
|
+CONFIG_PM_DEBUG=y
|
|
+# CONFIG_PM_VERBOSE is not set
|
|
+CONFIG_PM_SLEEP=y
|
|
+CONFIG_SUSPEND_UP_POSSIBLE=y
|
|
+CONFIG_SUSPEND=y
|
|
+CONFIG_APM_EMULATION=y
|
|
+
|
|
+#
|
|
+# Networking
|
|
+#
|
|
+CONFIG_NET=y
|
|
+
|
|
+#
|
|
+# Networking options
|
|
+#
|
|
+CONFIG_PACKET=y
|
|
+CONFIG_PACKET_MMAP=y
|
|
+CONFIG_UNIX=y
|
|
+CONFIG_XFRM=y
|
|
+# CONFIG_XFRM_USER is not set
|
|
+# CONFIG_XFRM_SUB_POLICY is not set
|
|
+CONFIG_XFRM_MIGRATE=y
|
|
+CONFIG_NET_KEY=m
|
|
+CONFIG_NET_KEY_MIGRATE=y
|
|
+CONFIG_INET=y
|
|
+CONFIG_IP_MULTICAST=y
|
|
+CONFIG_IP_ADVANCED_ROUTER=y
|
|
+CONFIG_ASK_IP_FIB_HASH=y
|
|
+# CONFIG_IP_FIB_TRIE is not set
|
|
+CONFIG_IP_FIB_HASH=y
|
|
+CONFIG_IP_MULTIPLE_TABLES=y
|
|
+# CONFIG_IP_ROUTE_MULTIPATH is not set
|
|
+# CONFIG_IP_ROUTE_VERBOSE is not set
|
|
+CONFIG_IP_PNP=y
|
|
+CONFIG_IP_PNP_DHCP=y
|
|
+# CONFIG_IP_PNP_BOOTP is not set
|
|
+# CONFIG_IP_PNP_RARP is not set
|
|
+CONFIG_NET_IPIP=m
|
|
+CONFIG_NET_IPGRE=m
|
|
+# CONFIG_NET_IPGRE_BROADCAST is not set
|
|
+# CONFIG_IP_MROUTE is not set
|
|
+# CONFIG_ARPD is not set
|
|
+CONFIG_SYN_COOKIES=y
|
|
+CONFIG_INET_AH=m
|
|
+CONFIG_INET_ESP=m
|
|
+CONFIG_INET_IPCOMP=m
|
|
+CONFIG_INET_XFRM_TUNNEL=m
|
|
+CONFIG_INET_TUNNEL=m
|
|
+CONFIG_INET_XFRM_MODE_TRANSPORT=m
|
|
+CONFIG_INET_XFRM_MODE_TUNNEL=m
|
|
+CONFIG_INET_XFRM_MODE_BEET=m
|
|
+# CONFIG_INET_LRO is not set
|
|
+CONFIG_INET_DIAG=y
|
|
+CONFIG_INET_TCP_DIAG=y
|
|
+# CONFIG_TCP_CONG_ADVANCED is not set
|
|
+CONFIG_TCP_CONG_CUBIC=y
|
|
+CONFIG_DEFAULT_TCP_CONG="cubic"
|
|
+CONFIG_TCP_MD5SIG=y
|
|
+# CONFIG_IP_VS is not set
|
|
+CONFIG_IPV6=m
|
|
+# CONFIG_IPV6_PRIVACY is not set
|
|
+# CONFIG_IPV6_ROUTER_PREF is not set
|
|
+# CONFIG_IPV6_OPTIMISTIC_DAD is not set
|
|
+CONFIG_INET6_AH=m
|
|
+CONFIG_INET6_ESP=m
|
|
+CONFIG_INET6_IPCOMP=m
|
|
+# CONFIG_IPV6_MIP6 is not set
|
|
+CONFIG_INET6_XFRM_TUNNEL=m
|
|
+CONFIG_INET6_TUNNEL=m
|
|
+CONFIG_INET6_XFRM_MODE_TRANSPORT=m
|
|
+CONFIG_INET6_XFRM_MODE_TUNNEL=m
|
|
+CONFIG_INET6_XFRM_MODE_BEET=m
|
|
+# CONFIG_INET6_XFRM_MODE_ROUTEOPTIMIZATION is not set
|
|
+CONFIG_IPV6_SIT=m
|
|
+CONFIG_IPV6_TUNNEL=m
|
|
+# CONFIG_IPV6_MULTIPLE_TABLES is not set
|
|
+# CONFIG_NETWORK_SECMARK is not set
|
|
+CONFIG_NETFILTER=y
|
|
+# CONFIG_NETFILTER_DEBUG is not set
|
|
+
|
|
+#
|
|
+# Core Netfilter Configuration
|
|
+#
|
|
+CONFIG_NETFILTER_NETLINK=m
|
|
+CONFIG_NETFILTER_NETLINK_QUEUE=m
|
|
+CONFIG_NETFILTER_NETLINK_LOG=m
|
|
+CONFIG_NF_CONNTRACK_ENABLED=m
|
|
+CONFIG_NF_CONNTRACK=m
|
|
+CONFIG_NF_CT_ACCT=y
|
|
+CONFIG_NF_CONNTRACK_MARK=y
|
|
+CONFIG_NF_CONNTRACK_EVENTS=y
|
|
+CONFIG_NF_CT_PROTO_GRE=m
|
|
+CONFIG_NF_CT_PROTO_SCTP=m
|
|
+# CONFIG_NF_CT_PROTO_UDPLITE is not set
|
|
+# CONFIG_NF_CONNTRACK_AMANDA is not set
|
|
+CONFIG_NF_CONNTRACK_FTP=m
|
|
+CONFIG_NF_CONNTRACK_H323=m
|
|
+CONFIG_NF_CONNTRACK_IRC=m
|
|
+CONFIG_NF_CONNTRACK_NETBIOS_NS=m
|
|
+CONFIG_NF_CONNTRACK_PPTP=m
|
|
+CONFIG_NF_CONNTRACK_SANE=m
|
|
+CONFIG_NF_CONNTRACK_SIP=m
|
|
+CONFIG_NF_CONNTRACK_TFTP=m
|
|
+CONFIG_NF_CT_NETLINK=m
|
|
+CONFIG_NETFILTER_XTABLES=m
|
|
+CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m
|
|
+CONFIG_NETFILTER_XT_TARGET_CONNMARK=m
|
|
+CONFIG_NETFILTER_XT_TARGET_DSCP=m
|
|
+CONFIG_NETFILTER_XT_TARGET_MARK=m
|
|
+CONFIG_NETFILTER_XT_TARGET_NFQUEUE=m
|
|
+CONFIG_NETFILTER_XT_TARGET_NFLOG=m
|
|
+CONFIG_NETFILTER_XT_TARGET_TCPMSS=m
|
|
+# CONFIG_NETFILTER_XT_MATCH_COMMENT is not set
|
|
+CONFIG_NETFILTER_XT_MATCH_CONNBYTES=m
|
|
+# CONFIG_NETFILTER_XT_MATCH_CONNLIMIT is not set
|
|
+CONFIG_NETFILTER_XT_MATCH_CONNMARK=m
|
|
+CONFIG_NETFILTER_XT_MATCH_CONNTRACK=m
|
|
+CONFIG_NETFILTER_XT_MATCH_DCCP=m
|
|
+CONFIG_NETFILTER_XT_MATCH_DSCP=m
|
|
+CONFIG_NETFILTER_XT_MATCH_ESP=m
|
|
+CONFIG_NETFILTER_XT_MATCH_HELPER=m
|
|
+CONFIG_NETFILTER_XT_MATCH_LENGTH=m
|
|
+CONFIG_NETFILTER_XT_MATCH_LIMIT=m
|
|
+CONFIG_NETFILTER_XT_MATCH_MAC=m
|
|
+CONFIG_NETFILTER_XT_MATCH_MARK=m
|
|
+CONFIG_NETFILTER_XT_MATCH_POLICY=m
|
|
+CONFIG_NETFILTER_XT_MATCH_MULTIPORT=m
|
|
+CONFIG_NETFILTER_XT_MATCH_PKTTYPE=m
|
|
+CONFIG_NETFILTER_XT_MATCH_QUOTA=m
|
|
+CONFIG_NETFILTER_XT_MATCH_REALM=m
|
|
+CONFIG_NETFILTER_XT_MATCH_SCTP=m
|
|
+CONFIG_NETFILTER_XT_MATCH_STATE=m
|
|
+CONFIG_NETFILTER_XT_MATCH_STATISTIC=m
|
|
+CONFIG_NETFILTER_XT_MATCH_STRING=m
|
|
+CONFIG_NETFILTER_XT_MATCH_TCPMSS=m
|
|
+# CONFIG_NETFILTER_XT_MATCH_TIME is not set
|
|
+# CONFIG_NETFILTER_XT_MATCH_U32 is not set
|
|
+CONFIG_NETFILTER_XT_MATCH_HASHLIMIT=m
|
|
+
|
|
+#
|
|
+# IP: Netfilter Configuration
|
|
+#
|
|
+CONFIG_NF_CONNTRACK_IPV4=m
|
|
+CONFIG_NF_CONNTRACK_PROC_COMPAT=y
|
|
+# CONFIG_IP_NF_QUEUE is not set
|
|
+CONFIG_IP_NF_IPTABLES=m
|
|
+CONFIG_IP_NF_MATCH_IPRANGE=m
|
|
+CONFIG_IP_NF_MATCH_TOS=m
|
|
+# CONFIG_IP_NF_MATCH_RECENT is not set
|
|
+CONFIG_IP_NF_MATCH_ECN=m
|
|
+CONFIG_IP_NF_MATCH_AH=m
|
|
+CONFIG_IP_NF_MATCH_TTL=m
|
|
+CONFIG_IP_NF_MATCH_OWNER=m
|
|
+CONFIG_IP_NF_MATCH_ADDRTYPE=m
|
|
+CONFIG_IP_NF_FILTER=m
|
|
+CONFIG_IP_NF_TARGET_REJECT=m
|
|
+CONFIG_IP_NF_TARGET_LOG=m
|
|
+CONFIG_IP_NF_TARGET_ULOG=m
|
|
+CONFIG_NF_NAT=m
|
|
+CONFIG_NF_NAT_NEEDED=y
|
|
+CONFIG_IP_NF_TARGET_MASQUERADE=m
|
|
+CONFIG_IP_NF_TARGET_REDIRECT=m
|
|
+CONFIG_IP_NF_TARGET_NETMAP=m
|
|
+CONFIG_IP_NF_TARGET_SAME=m
|
|
+CONFIG_NF_NAT_SNMP_BASIC=m
|
|
+CONFIG_NF_NAT_PROTO_GRE=m
|
|
+CONFIG_NF_NAT_FTP=m
|
|
+CONFIG_NF_NAT_IRC=m
|
|
+CONFIG_NF_NAT_TFTP=m
|
|
+# CONFIG_NF_NAT_AMANDA is not set
|
|
+CONFIG_NF_NAT_PPTP=m
|
|
+CONFIG_NF_NAT_H323=m
|
|
+CONFIG_NF_NAT_SIP=m
|
|
+CONFIG_IP_NF_MANGLE=m
|
|
+CONFIG_IP_NF_TARGET_TOS=m
|
|
+CONFIG_IP_NF_TARGET_ECN=m
|
|
+CONFIG_IP_NF_TARGET_TTL=m
|
|
+CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
|
+# CONFIG_IP_NF_RAW is not set
|
|
+# CONFIG_IP_NF_ARPTABLES is not set
|
|
+
|
|
+#
|
|
+# IPv6: Netfilter Configuration (EXPERIMENTAL)
|
|
+#
|
|
+CONFIG_NF_CONNTRACK_IPV6=m
|
|
+# CONFIG_IP6_NF_QUEUE is not set
|
|
+CONFIG_IP6_NF_IPTABLES=m
|
|
+CONFIG_IP6_NF_MATCH_RT=m
|
|
+CONFIG_IP6_NF_MATCH_OPTS=m
|
|
+CONFIG_IP6_NF_MATCH_FRAG=m
|
|
+CONFIG_IP6_NF_MATCH_HL=m
|
|
+CONFIG_IP6_NF_MATCH_OWNER=m
|
|
+CONFIG_IP6_NF_MATCH_IPV6HEADER=m
|
|
+CONFIG_IP6_NF_MATCH_AH=m
|
|
+CONFIG_IP6_NF_MATCH_MH=m
|
|
+CONFIG_IP6_NF_MATCH_EUI64=m
|
|
+CONFIG_IP6_NF_FILTER=m
|
|
+CONFIG_IP6_NF_TARGET_LOG=m
|
|
+CONFIG_IP6_NF_TARGET_REJECT=m
|
|
+CONFIG_IP6_NF_MANGLE=m
|
|
+CONFIG_IP6_NF_TARGET_HL=m
|
|
+# CONFIG_IP6_NF_RAW is not set
|
|
+# CONFIG_IP_DCCP is not set
|
|
+# CONFIG_IP_SCTP is not set
|
|
+# CONFIG_TIPC 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_ECONET is not set
|
|
+# CONFIG_WAN_ROUTER is not set
|
|
+CONFIG_NET_SCHED=y
|
|
+
|
|
+#
|
|
+# Queueing/Scheduling
|
|
+#
|
|
+CONFIG_NET_SCH_CBQ=m
|
|
+CONFIG_NET_SCH_HTB=m
|
|
+CONFIG_NET_SCH_HFSC=m
|
|
+CONFIG_NET_SCH_PRIO=m
|
|
+# CONFIG_NET_SCH_RR is not set
|
|
+CONFIG_NET_SCH_RED=m
|
|
+CONFIG_NET_SCH_SFQ=m
|
|
+CONFIG_NET_SCH_TEQL=m
|
|
+CONFIG_NET_SCH_TBF=m
|
|
+CONFIG_NET_SCH_GRED=m
|
|
+CONFIG_NET_SCH_DSMARK=m
|
|
+CONFIG_NET_SCH_NETEM=m
|
|
+CONFIG_NET_SCH_INGRESS=m
|
|
+
|
|
+#
|
|
+# Classification
|
|
+#
|
|
+CONFIG_NET_CLS=y
|
|
+CONFIG_NET_CLS_BASIC=m
|
|
+CONFIG_NET_CLS_TCINDEX=m
|
|
+CONFIG_NET_CLS_ROUTE4=m
|
|
+CONFIG_NET_CLS_ROUTE=y
|
|
+CONFIG_NET_CLS_FW=m
|
|
+CONFIG_NET_CLS_U32=m
|
|
+CONFIG_CLS_U32_PERF=y
|
|
+CONFIG_CLS_U32_MARK=y
|
|
+CONFIG_NET_CLS_RSVP=m
|
|
+CONFIG_NET_CLS_RSVP6=m
|
|
+# CONFIG_NET_EMATCH is not set
|
|
+# CONFIG_NET_CLS_ACT is not set
|
|
+# CONFIG_NET_CLS_POLICE is not set
|
|
+# CONFIG_NET_CLS_IND is not set
|
|
+CONFIG_NET_SCH_FIFO=y
|
|
+
|
|
+#
|
|
+# Network testing
|
|
+#
|
|
+# CONFIG_NET_PKTGEN is not set
|
|
+# CONFIG_HAMRADIO is not set
|
|
+# CONFIG_IRDA is not set
|
|
+CONFIG_BT=m
|
|
+CONFIG_BT_L2CAP=m
|
|
+CONFIG_BT_SCO=m
|
|
+CONFIG_BT_RFCOMM=m
|
|
+CONFIG_BT_RFCOMM_TTY=y
|
|
+CONFIG_BT_BNEP=m
|
|
+CONFIG_BT_BNEP_MC_FILTER=y
|
|
+CONFIG_BT_BNEP_PROTO_FILTER=y
|
|
+CONFIG_BT_HIDP=m
|
|
+
|
|
+#
|
|
+# Bluetooth device drivers
|
|
+#
|
|
+CONFIG_BT_HCIUSB=m
|
|
+CONFIG_BT_HCIUSB_SCO=y
|
|
+# CONFIG_BT_HCIBTSDIO is not set
|
|
+# CONFIG_BT_HCIUART is not set
|
|
+# CONFIG_BT_HCIBCM203X is not set
|
|
+# CONFIG_BT_HCIBPA10X is not set
|
|
+# CONFIG_BT_HCIBFUSB is not set
|
|
+# CONFIG_BT_HCIVHCI is not set
|
|
+# CONFIG_AF_RXRPC is not set
|
|
+CONFIG_FIB_RULES=y
|
|
+
|
|
+#
|
|
+# Wireless
|
|
+#
|
|
+# CONFIG_CFG80211 is not set
|
|
+CONFIG_WIRELESS_EXT=y
|
|
+# CONFIG_MAC80211 is not set
|
|
+# CONFIG_IEEE80211 is not set
|
|
+# CONFIG_RFKILL is not set
|
|
+# CONFIG_NET_9P is not set
|
|
+
|
|
+#
|
|
+# Device Drivers
|
|
+#
|
|
+
|
|
+#
|
|
+# Generic Driver Options
|
|
+#
|
|
+CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
|
+CONFIG_STANDALONE=y
|
|
+CONFIG_PREVENT_FIRMWARE_BUILD=y
|
|
+CONFIG_FW_LOADER=m
|
|
+# CONFIG_DEBUG_DRIVER is not set
|
|
+# CONFIG_DEBUG_DEVRES is not set
|
|
+# CONFIG_SYS_HYPERVISOR is not set
|
|
+CONFIG_CONNECTOR=m
|
|
+CONFIG_MTD=y
|
|
+# CONFIG_MTD_DEBUG 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
|
|
+
|
|
+#
|
|
+# User Modules And Translation Layers
|
|
+#
|
|
+CONFIG_MTD_CHAR=y
|
|
+CONFIG_MTD_BLKDEVS=y
|
|
+CONFIG_MTD_BLOCK=y
|
|
+# CONFIG_FTL is not set
|
|
+# CONFIG_NFTL is not set
|
|
+# CONFIG_INFTL is not set
|
|
+# CONFIG_RFD_FTL is not set
|
|
+# CONFIG_SSFDC is not set
|
|
+# CONFIG_MTD_OOPS is not set
|
|
+
|
|
+#
|
|
+# RAM/ROM/Flash chip drivers
|
|
+#
|
|
+CONFIG_MTD_CFI=y
|
|
+# CONFIG_MTD_JEDECPROBE is not set
|
|
+CONFIG_MTD_GEN_PROBE=y
|
|
+# CONFIG_MTD_CFI_ADV_OPTIONS 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_CFI_INTELEXT=y
|
|
+# CONFIG_MTD_CFI_AMDSTD is not set
|
|
+# CONFIG_MTD_CFI_STAA is not set
|
|
+CONFIG_MTD_CFI_UTIL=y
|
|
+# CONFIG_MTD_RAM is not set
|
|
+# CONFIG_MTD_ROM is not set
|
|
+CONFIG_MTD_ABSENT=y
|
|
+
|
|
+#
|
|
+# Mapping drivers for chip access
|
|
+#
|
|
+# CONFIG_MTD_COMPLEX_MAPPINGS is not set
|
|
+CONFIG_MTD_PHYSMAP=y
|
|
+CONFIG_MTD_PHYSMAP_START=0x8000000
|
|
+CONFIG_MTD_PHYSMAP_LEN=0
|
|
+CONFIG_MTD_PHYSMAP_BANKWIDTH=2
|
|
+# CONFIG_MTD_ARM_INTEGRATOR is not set
|
|
+# CONFIG_MTD_PLATRAM is not set
|
|
+
|
|
+#
|
|
+# Self-contained MTD device drivers
|
|
+#
|
|
+# CONFIG_MTD_DATAFLASH is not set
|
|
+# CONFIG_MTD_M25P80 is not set
|
|
+# CONFIG_MTD_SLRAM is not set
|
|
+# CONFIG_MTD_PHRAM is not set
|
|
+# CONFIG_MTD_MTDRAM is not set
|
|
+# CONFIG_MTD_BLOCK2MTD is not set
|
|
+
|
|
+#
|
|
+# Disk-On-Chip Device Drivers
|
|
+#
|
|
+# CONFIG_MTD_DOC2000 is not set
|
|
+# CONFIG_MTD_DOC2001 is not set
|
|
+# CONFIG_MTD_DOC2001PLUS is not set
|
|
+CONFIG_MTD_NAND=y
|
|
+CONFIG_MTD_NAND_VERIFY_WRITE=y
|
|
+# CONFIG_MTD_NAND_ECC_SMC is not set
|
|
+# CONFIG_MTD_NAND_MUSEUM_IDS is not set
|
|
+CONFIG_MTD_NAND_IDS=y
|
|
+CONFIG_MTD_NAND_S3C2410=y
|
|
+# CONFIG_MTD_NAND_S3C2410_DEBUG is not set
|
|
+CONFIG_MTD_NAND_S3C2410_HWECC=y
|
|
+# CONFIG_MTD_NAND_S3C2410_CLKSTOP is not set
|
|
+# 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
|
|
+
|
|
+#
|
|
+# UBI - Unsorted block images
|
|
+#
|
|
+# CONFIG_MTD_UBI is not set
|
|
+# CONFIG_PARPORT is not set
|
|
+CONFIG_BLK_DEV=y
|
|
+# CONFIG_BLK_DEV_COW_COMMON is not set
|
|
+CONFIG_BLK_DEV_LOOP=m
|
|
+# CONFIG_BLK_DEV_CRYPTOLOOP is not set
|
|
+# CONFIG_BLK_DEV_NBD is not set
|
|
+CONFIG_BLK_DEV_UB=m
|
|
+CONFIG_BLK_DEV_RAM=y
|
|
+CONFIG_BLK_DEV_RAM_COUNT=16
|
|
+CONFIG_BLK_DEV_RAM_SIZE=4096
|
|
+CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024
|
|
+# CONFIG_CDROM_PKTCDVD is not set
|
|
+# CONFIG_ATA_OVER_ETH is not set
|
|
+CONFIG_MISC_DEVICES=y
|
|
+# CONFIG_EEPROM_93CX6 is not set
|
|
+# CONFIG_IDE is not set
|
|
+
|
|
+
|
|
+#
|
|
+# SCSI device support
|
|
+#
|
|
+# CONFIG_RAID_ATTRS is not set
|
|
+CONFIG_SCSI=m
|
|
+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=m
|
|
+# CONFIG_CHR_DEV_ST is not set
|
|
+# CONFIG_CHR_DEV_OSST is not set
|
|
+CONFIG_BLK_DEV_SR=m
|
|
+# CONFIG_BLK_DEV_SR_VENDOR is not set
|
|
+CONFIG_CHR_DEV_SG=m
|
|
+# CONFIG_CHR_DEV_SCH is not set
|
|
+
|
|
+#
|
|
+# Some SCSI devices (e.g. CD jukebox) support multiple LUNs
|
|
+#
|
|
+# CONFIG_SCSI_MULTI_LUN is not set
|
|
+# CONFIG_SCSI_CONSTANTS is not set
|
|
+# CONFIG_SCSI_LOGGING is not set
|
|
+CONFIG_SCSI_SCAN_ASYNC=y
|
|
+CONFIG_SCSI_WAIT_SCAN=m
|
|
+
|
|
+#
|
|
+# SCSI Transports
|
|
+#
|
|
+# CONFIG_SCSI_SPI_ATTRS is not set
|
|
+# CONFIG_SCSI_FC_ATTRS is not set
|
|
+# CONFIG_SCSI_ISCSI_ATTRS is not set
|
|
+# CONFIG_SCSI_SAS_LIBSAS is not set
|
|
+# CONFIG_SCSI_SRP_ATTRS is not set
|
|
+CONFIG_SCSI_LOWLEVEL=y
|
|
+# CONFIG_ISCSI_TCP is not set
|
|
+# CONFIG_SCSI_DEBUG is not set
|
|
+# CONFIG_ATA is not set
|
|
+# CONFIG_MD is not set
|
|
+CONFIG_NETDEVICES=y
|
|
+# CONFIG_NETDEVICES_MULTIQUEUE is not set
|
|
+# CONFIG_DUMMY is not set
|
|
+# CONFIG_BONDING is not set
|
|
+# CONFIG_MACVLAN is not set
|
|
+# CONFIG_EQUALIZER is not set
|
|
+CONFIG_TUN=m
|
|
+# CONFIG_VETH is not set
|
|
+# CONFIG_PHYLIB is not set
|
|
+CONFIG_NET_ETHERNET=y
|
|
+CONFIG_MII=y
|
|
+# CONFIG_AX88796 is not set
|
|
+# CONFIG_SMC91X is not set
|
|
+# CONFIG_DM9000 is not set
|
|
+# CONFIG_IBM_NEW_EMAC_ZMII is not set
|
|
+# CONFIG_IBM_NEW_EMAC_RGMII is not set
|
|
+# CONFIG_IBM_NEW_EMAC_TAH is not set
|
|
+# CONFIG_IBM_NEW_EMAC_EMAC4 is not set
|
|
+CONFIG_NET_PCI=y
|
|
+# CONFIG_B44 is not set
|
|
+CONFIG_CS89x0=m
|
|
+# CONFIG_NETDEV_1000 is not set
|
|
+# CONFIG_NETDEV_10000 is not set
|
|
+
|
|
+#
|
|
+# Wireless LAN
|
|
+#
|
|
+# CONFIG_WLAN_PRE80211 is not set
|
|
+# CONFIG_WLAN_80211 is not set
|
|
+
|
|
+#
|
|
+# USB Network Adapters
|
|
+#
|
|
+CONFIG_USB_CATC=m
|
|
+CONFIG_USB_KAWETH=m
|
|
+CONFIG_USB_PEGASUS=m
|
|
+CONFIG_USB_RTL8150=m
|
|
+CONFIG_USB_USBNET=y
|
|
+CONFIG_USB_NET_AX8817X=m
|
|
+CONFIG_USB_NET_CDCETHER=m
|
|
+CONFIG_USB_NET_DM9601=m
|
|
+CONFIG_USB_NET_GL620A=m
|
|
+CONFIG_USB_NET_NET1080=m
|
|
+CONFIG_USB_NET_PLUSB=m
|
|
+CONFIG_USB_NET_MCS7830=m
|
|
+CONFIG_USB_NET_RNDIS_HOST=m
|
|
+CONFIG_USB_NET_CDC_SUBSET=m
|
|
+CONFIG_USB_ALI_M5632=y
|
|
+CONFIG_USB_AN2720=y
|
|
+CONFIG_USB_BELKIN=y
|
|
+CONFIG_USB_ARMLINUX=y
|
|
+CONFIG_USB_EPSON2888=y
|
|
+CONFIG_USB_KC2190=y
|
|
+CONFIG_USB_NET_ZAURUS=m
|
|
+# CONFIG_WAN is not set
|
|
+CONFIG_PPP=m
|
|
+CONFIG_PPP_MULTILINK=y
|
|
+CONFIG_PPP_FILTER=y
|
|
+CONFIG_PPP_ASYNC=m
|
|
+CONFIG_PPP_SYNC_TTY=m
|
|
+CONFIG_PPP_DEFLATE=m
|
|
+CONFIG_PPP_BSDCOMP=m
|
|
+CONFIG_PPP_MPPE=m
|
|
+# CONFIG_PPPOE is not set
|
|
+# CONFIG_PPPOL2TP is not set
|
|
+# CONFIG_SLIP is not set
|
|
+CONFIG_SLHC=m
|
|
+# CONFIG_SHAPER is not set
|
|
+# CONFIG_NETCONSOLE is not set
|
|
+# CONFIG_NETPOLL is not set
|
|
+# CONFIG_NET_POLL_CONTROLLER is not set
|
|
+# CONFIG_ISDN is not set
|
|
+
|
|
+#
|
|
+# Input device support
|
|
+#
|
|
+CONFIG_INPUT=y
|
|
+# CONFIG_INPUT_FF_MEMLESS is not set
|
|
+# CONFIG_INPUT_POLLDEV is not set
|
|
+
|
|
+#
|
|
+# Userland interfaces
|
|
+#
|
|
+CONFIG_INPUT_MOUSEDEV=y
|
|
+# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
|
|
+CONFIG_INPUT_MOUSEDEV_SCREEN_X=480
|
|
+CONFIG_INPUT_MOUSEDEV_SCREEN_Y=640
|
|
+# CONFIG_INPUT_JOYDEV is not set
|
|
+CONFIG_INPUT_EVDEV=y
|
|
+# CONFIG_INPUT_EVBUG is not set
|
|
+
|
|
+#
|
|
+# Input Device Drivers
|
|
+#
|
|
+CONFIG_INPUT_KEYBOARD=y
|
|
+# CONFIG_KEYBOARD_ATKBD is not set
|
|
+# CONFIG_KEYBOARD_SUNKBD is not set
|
|
+# CONFIG_KEYBOARD_LKKBD is not set
|
|
+# CONFIG_KEYBOARD_XTKBD is not set
|
|
+# CONFIG_KEYBOARD_NEWTON is not set
|
|
+CONFIG_KEYBOARD_STOWAWAY=m
|
|
+CONFIG_KEYBOARD_GPIO=m
|
|
+CONFIG_KEYBOARD_M800=y
|
|
+CONFIG_KEYBOARD_QT2410=y
|
|
+CONFIG_INPUT_MOUSE=y
|
|
+# CONFIG_MOUSE_PS2 is not set
|
|
+# CONFIG_MOUSE_SERIAL is not set
|
|
+# CONFIG_MOUSE_APPLETOUCH is not set
|
|
+# CONFIG_MOUSE_VSXXXAA is not set
|
|
+# CONFIG_MOUSE_GPIO is not set
|
|
+# CONFIG_INPUT_JOYSTICK is not set
|
|
+# CONFIG_INPUT_TABLET is not set
|
|
+CONFIG_INPUT_TOUCHSCREEN=y
|
|
+# CONFIG_TOUCHSCREEN_ADS7846 is not set
|
|
+# CONFIG_TOUCHSCREEN_FUJITSU is not set
|
|
+CONFIG_TOUCHSCREEN_S3C2410=y
|
|
+# CONFIG_TOUCHSCREEN_S3C2410_DEBUG is not set
|
|
+# CONFIG_TOUCHSCREEN_GUNZE is not set
|
|
+# CONFIG_TOUCHSCREEN_ELO is not set
|
|
+# CONFIG_TOUCHSCREEN_MTOUCH is not set
|
|
+# CONFIG_TOUCHSCREEN_MK712 is not set
|
|
+# CONFIG_TOUCHSCREEN_PENMOUNT is not set
|
|
+# CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set
|
|
+# CONFIG_TOUCHSCREEN_TOUCHWIN is not set
|
|
+# CONFIG_TOUCHSCREEN_UCB1400 is not set
|
|
+# CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set
|
|
+CONFIG_INPUT_MISC=y
|
|
+# CONFIG_INPUT_ATI_REMOTE is not set
|
|
+# CONFIG_INPUT_ATI_REMOTE2 is not set
|
|
+# CONFIG_INPUT_KEYSPAN_REMOTE is not set
|
|
+# CONFIG_INPUT_POWERMATE is not set
|
|
+# CONFIG_INPUT_YEALINK is not set
|
|
+CONFIG_INPUT_UINPUT=m
|
|
+CONFIG_INPUT_LIS302DL=y
|
|
+
|
|
+#
|
|
+# Hardware I/O ports
|
|
+#
|
|
+CONFIG_SERIO=y
|
|
+# CONFIG_SERIO_SERPORT is not set
|
|
+# CONFIG_SERIO_RAW is not set
|
|
+# CONFIG_GAMEPORT is not set
|
|
+
|
|
+#
|
|
+# Character devices
|
|
+#
|
|
+CONFIG_VT=y
|
|
+CONFIG_VT_CONSOLE=y
|
|
+CONFIG_NR_TTY_DEVICES=4
|
|
+CONFIG_HW_CONSOLE=y
|
|
+CONFIG_VT_HW_CONSOLE_BINDING=y
|
|
+# CONFIG_SERIAL_NONSTANDARD is not set
|
|
+
|
|
+#
|
|
+# Serial drivers
|
|
+#
|
|
+# CONFIG_SERIAL_8250 is not set
|
|
+
|
|
+#
|
|
+# Non-8250 serial port support
|
|
+#
|
|
+CONFIG_SERIAL_S3C2410=y
|
|
+CONFIG_SERIAL_S3C2410_CONSOLE=y
|
|
+CONFIG_SERIAL_CORE=y
|
|
+CONFIG_SERIAL_CORE_CONSOLE=y
|
|
+CONFIG_UNIX98_PTYS=y
|
|
+# CONFIG_LEGACY_PTYS is not set
|
|
+# CONFIG_IPMI_HANDLER is not set
|
|
+# CONFIG_HW_RANDOM is not set
|
|
+# CONFIG_NVRAM is not set
|
|
+# CONFIG_R3964 is not set
|
|
+# CONFIG_RAW_DRIVER is not set
|
|
+# CONFIG_TCG_TPM is not set
|
|
+CONFIG_I2C=y
|
|
+CONFIG_I2C_BOARDINFO=y
|
|
+CONFIG_I2C_CHARDEV=y
|
|
+
|
|
+#
|
|
+# I2C Algorithms
|
|
+#
|
|
+# CONFIG_I2C_ALGOBIT is not set
|
|
+# CONFIG_I2C_ALGOPCF is not set
|
|
+# CONFIG_I2C_ALGOPCA is not set
|
|
+
|
|
+#
|
|
+# I2C Hardware Bus support
|
|
+#
|
|
+# CONFIG_I2C_GPIO is not set
|
|
+# CONFIG_I2C_OCORES is not set
|
|
+# CONFIG_I2C_PARPORT_LIGHT is not set
|
|
+CONFIG_I2C_S3C2410=y
|
|
+# CONFIG_I2C_SIMTEC is not set
|
|
+# CONFIG_I2C_TAOS_EVM is not set
|
|
+# CONFIG_I2C_STUB is not set
|
|
+# CONFIG_I2C_TINY_USB is not set
|
|
+
|
|
+#
|
|
+# Miscellaneous I2C Chip support
|
|
+#
|
|
+# CONFIG_SENSORS_DS1337 is not set
|
|
+# CONFIG_SENSORS_DS1374 is not set
|
|
+# CONFIG_DS1682 is not set
|
|
+# CONFIG_SENSORS_EEPROM is not set
|
|
+CONFIG_SENSORS_PCF50606=y
|
|
+CONFIG_SENSORS_PCF50633=y
|
|
+# CONFIG_SENSORS_PCF8574 is not set
|
|
+# CONFIG_SENSORS_PCA9539 is not set
|
|
+# CONFIG_SENSORS_PCF8591 is not set
|
|
+# CONFIG_SENSORS_MAX6875 is not set
|
|
+# CONFIG_SENSORS_TSL2550 is not set
|
|
+CONFIG_SENSORS_TSL256X=m
|
|
+# CONFIG_PCA9632 is not set
|
|
+# CONFIG_I2C_DEBUG_CORE is not set
|
|
+# CONFIG_I2C_DEBUG_ALGO is not set
|
|
+# CONFIG_I2C_DEBUG_BUS is not set
|
|
+# CONFIG_I2C_DEBUG_CHIP is not set
|
|
+
|
|
+#
|
|
+# SPI support
|
|
+#
|
|
+CONFIG_SPI=y
|
|
+# CONFIG_SPI_DEBUG is not set
|
|
+CONFIG_SPI_MASTER=y
|
|
+
|
|
+#
|
|
+# SPI Master Controller Drivers
|
|
+#
|
|
+CONFIG_SPI_BITBANG=y
|
|
+CONFIG_SPI_S3C24XX=y
|
|
+CONFIG_SPI_S3C24XX_GPIO=y
|
|
+
|
|
+#
|
|
+# SPI Protocol Masters
|
|
+#
|
|
+# CONFIG_SPI_AT25 is not set
|
|
+# CONFIG_SPI_SPIDEV is not set
|
|
+# CONFIG_SPI_TLE62X0 is not set
|
|
+# CONFIG_W1 is not set
|
|
+CONFIG_POWER_SUPPLY=y
|
|
+# CONFIG_POWER_SUPPLY_DEBUG is not set
|
|
+# CONFIG_PDA_POWER is not set
|
|
+CONFIG_APM_POWER=y
|
|
+# CONFIG_BATTERY_DS2760 is not set
|
|
+CONFIG_BATTERY_BQ27000_HDQ=y
|
|
+# CONFIG_HWMON is not set
|
|
+CONFIG_WATCHDOG=y
|
|
+# CONFIG_WATCHDOG_NOWAYOUT is not set
|
|
+
|
|
+#
|
|
+# Watchdog Device Drivers
|
|
+#
|
|
+# CONFIG_SOFT_WATCHDOG is not set
|
|
+CONFIG_S3C2410_WATCHDOG=m
|
|
+
|
|
+#
|
|
+# USB-based Watchdog Cards
|
|
+#
|
|
+# CONFIG_USBPCWATCHDOG is not set
|
|
+
|
|
+#
|
|
+# Sonics Silicon Backplane
|
|
+#
|
|
+CONFIG_SSB_POSSIBLE=y
|
|
+# CONFIG_SSB is not set
|
|
+
|
|
+#
|
|
+# Multifunction device drivers
|
|
+#
|
|
+# CONFIG_MFD_SM501 is not set
|
|
+# CONFIG_MFD_GLAMO is not set
|
|
+
|
|
+#
|
|
+# Multimedia devices
|
|
+#
|
|
+# CONFIG_VIDEO_DEV is not set
|
|
+# CONFIG_DVB_CORE is not set
|
|
+# CONFIG_DAB is not set
|
|
+
|
|
+#
|
|
+# Graphics support
|
|
+#
|
|
+# CONFIG_VGASTATE is not set
|
|
+# CONFIG_VIDEO_OUTPUT_CONTROL is not set
|
|
+CONFIG_FB=y
|
|
+# CONFIG_FIRMWARE_EDID is not set
|
|
+# CONFIG_FB_DDC is not set
|
|
+CONFIG_FB_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_SYS_FOPS is not set
|
|
+CONFIG_FB_DEFERRED_IO=y
|
|
+# 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_UVESA is not set
|
|
+# CONFIG_FB_S1D13XXX is not set
|
|
+CONFIG_FB_S3C2410=y
|
|
+# CONFIG_FB_S3C2410_DEBUG is not set
|
|
+# CONFIG_FB_VIRTUAL is not set
|
|
+CONFIG_BACKLIGHT_LCD_SUPPORT=y
|
|
+CONFIG_LCD_CLASS_DEVICE=y
|
|
+# CONFIG_LCD_LTV350QV is not set
|
|
+CONFIG_BACKLIGHT_CLASS_DEVICE=y
|
|
+# CONFIG_BACKLIGHT_CORGI is not set
|
|
+
|
|
+#
|
|
+# Display device support
|
|
+#
|
|
+# CONFIG_DISPLAY_SUPPORT is not set
|
|
+CONFIG_DISPLAY_JBT6K74=y
|
|
+
|
|
+#
|
|
+# Console display driver support
|
|
+#
|
|
+# CONFIG_VGA_CONSOLE is not set
|
|
+CONFIG_DUMMY_CONSOLE=y
|
|
+CONFIG_FRAMEBUFFER_CONSOLE=y
|
|
+# CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY is not set
|
|
+# CONFIG_FRAMEBUFFER_CONSOLE_ROTATION is not set
|
|
+CONFIG_FONTS=y
|
|
+# CONFIG_FONT_8x8 is not set
|
|
+# CONFIG_FONT_8x16 is not set
|
|
+CONFIG_FONT_6x11=y
|
|
+# CONFIG_FONT_7x14 is not set
|
|
+# CONFIG_FONT_PEARL_8x8 is not set
|
|
+# CONFIG_FONT_ACORN_8x8 is not set
|
|
+# CONFIG_FONT_MINI_4x6 is not set
|
|
+# CONFIG_FONT_SUN8x16 is not set
|
|
+# CONFIG_FONT_SUN12x22 is not set
|
|
+# CONFIG_FONT_10x18 is not set
|
|
+# CONFIG_LOGO is not set
|
|
+
|
|
+#
|
|
+# Sound
|
|
+#
|
|
+CONFIG_SOUND=y
|
|
+
|
|
+#
|
|
+# Advanced Linux Sound Architecture
|
|
+#
|
|
+CONFIG_SND=m
|
|
+CONFIG_SND_TIMER=m
|
|
+CONFIG_SND_PCM=m
|
|
+CONFIG_SND_RAWMIDI=m
|
|
+# CONFIG_SND_SEQUENCER is not set
|
|
+CONFIG_SND_OSSEMUL=y
|
|
+CONFIG_SND_MIXER_OSS=m
|
|
+CONFIG_SND_PCM_OSS=m
|
|
+CONFIG_SND_PCM_OSS_PLUGINS=y
|
|
+# CONFIG_SND_DYNAMIC_MINORS is not set
|
|
+CONFIG_SND_SUPPORT_OLD_API=y
|
|
+CONFIG_SND_VERBOSE_PROCFS=y
|
|
+# CONFIG_SND_VERBOSE_PRINTK is not set
|
|
+# CONFIG_SND_DEBUG is not set
|
|
+
|
|
+#
|
|
+# Generic devices
|
|
+#
|
|
+# CONFIG_SND_DUMMY is not set
|
|
+# CONFIG_SND_MTPAV is not set
|
|
+# CONFIG_SND_SERIAL_U16550 is not set
|
|
+# CONFIG_SND_MPU401 is not set
|
|
+
|
|
+#
|
|
+# ALSA ARM devices
|
|
+#
|
|
+
|
|
+#
|
|
+# SPI devices
|
|
+#
|
|
+
|
|
+#
|
|
+# USB devices
|
|
+#
|
|
+# CONFIG_SND_USB_AUDIO is not set
|
|
+# CONFIG_SND_USB_CAIAQ is not set
|
|
+
|
|
+#
|
|
+# System on Chip audio support
|
|
+#
|
|
+CONFIG_SND_SOC=m
|
|
+CONFIG_SND_S3C24XX_SOC=m
|
|
+
|
|
+#
|
|
+# SoC Audio support for SuperH
|
|
+#
|
|
+
|
|
+#
|
|
+# Open Sound System
|
|
+#
|
|
+# CONFIG_SOUND_PRIME is not set
|
|
+CONFIG_HID_SUPPORT=y
|
|
+CONFIG_HID=y
|
|
+# CONFIG_HID_DEBUG is not set
|
|
+# CONFIG_HIDRAW is not set
|
|
+
|
|
+#
|
|
+# USB Input Devices
|
|
+#
|
|
+CONFIG_USB_HID=y
|
|
+# CONFIG_USB_HIDINPUT_POWERBOOK is not set
|
|
+# CONFIG_HID_FF is not set
|
|
+CONFIG_USB_HIDDEV=y
|
|
+CONFIG_USB_SUPPORT=y
|
|
+CONFIG_USB_ARCH_HAS_HCD=y
|
|
+CONFIG_USB_ARCH_HAS_OHCI=y
|
|
+# CONFIG_USB_ARCH_HAS_EHCI is not set
|
|
+CONFIG_USB=y
|
|
+# CONFIG_USB_DEBUG is not set
|
|
+
|
|
+#
|
|
+# Miscellaneous USB options
|
|
+#
|
|
+CONFIG_USB_DEVICEFS=y
|
|
+CONFIG_USB_DEVICE_CLASS=y
|
|
+# CONFIG_USB_DYNAMIC_MINORS is not set
|
|
+CONFIG_USB_SUSPEND=y
|
|
+# CONFIG_USB_PERSIST is not set
|
|
+# CONFIG_USB_OTG is not set
|
|
+
|
|
+#
|
|
+# USB Host Controller Drivers
|
|
+#
|
|
+# CONFIG_USB_ISP116X_HCD is not set
|
|
+CONFIG_USB_OHCI_HCD=m
|
|
+# 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
|
|
+
|
|
+#
|
|
+# USB Device Class drivers
|
|
+#
|
|
+CONFIG_USB_ACM=m
|
|
+CONFIG_USB_PRINTER=m
|
|
+
|
|
+#
|
|
+# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support'
|
|
+#
|
|
+
|
|
+#
|
|
+# may also be needed; see USB_STORAGE Help for more information
|
|
+#
|
|
+CONFIG_USB_STORAGE=m
|
|
+# CONFIG_USB_STORAGE_DEBUG is not set
|
|
+CONFIG_USB_STORAGE_DATAFAB=y
|
|
+CONFIG_USB_STORAGE_FREECOM=y
|
|
+# CONFIG_USB_STORAGE_ISD200 is not set
|
|
+CONFIG_USB_STORAGE_DPCM=y
|
|
+CONFIG_USB_STORAGE_USBAT=y
|
|
+CONFIG_USB_STORAGE_SDDR09=y
|
|
+CONFIG_USB_STORAGE_SDDR55=y
|
|
+CONFIG_USB_STORAGE_JUMPSHOT=y
|
|
+CONFIG_USB_STORAGE_ALAUDA=y
|
|
+CONFIG_USB_STORAGE_KARMA=y
|
|
+CONFIG_USB_LIBUSUAL=y
|
|
+
|
|
+#
|
|
+# USB Imaging devices
|
|
+#
|
|
+# CONFIG_USB_MDC800 is not set
|
|
+# CONFIG_USB_MICROTEK is not set
|
|
+CONFIG_USB_MON=y
|
|
+
|
|
+#
|
|
+# USB port drivers
|
|
+#
|
|
+
|
|
+#
|
|
+# USB Serial Converter support
|
|
+#
|
|
+CONFIG_USB_SERIAL=m
|
|
+CONFIG_USB_SERIAL_GENERIC=y
|
|
+CONFIG_USB_SERIAL_AIRCABLE=m
|
|
+CONFIG_USB_SERIAL_AIRPRIME=m
|
|
+CONFIG_USB_SERIAL_ARK3116=m
|
|
+CONFIG_USB_SERIAL_BELKIN=m
|
|
+# CONFIG_USB_SERIAL_CH341 is not set
|
|
+CONFIG_USB_SERIAL_WHITEHEAT=m
|
|
+CONFIG_USB_SERIAL_DIGI_ACCELEPORT=m
|
|
+CONFIG_USB_SERIAL_CP2101=m
|
|
+CONFIG_USB_SERIAL_CYPRESS_M8=m
|
|
+CONFIG_USB_SERIAL_EMPEG=m
|
|
+CONFIG_USB_SERIAL_FTDI_SIO=m
|
|
+CONFIG_USB_SERIAL_FUNSOFT=m
|
|
+CONFIG_USB_SERIAL_VISOR=m
|
|
+CONFIG_USB_SERIAL_IPAQ=m
|
|
+CONFIG_USB_SERIAL_IR=m
|
|
+CONFIG_USB_SERIAL_EDGEPORT=m
|
|
+CONFIG_USB_SERIAL_EDGEPORT_TI=m
|
|
+CONFIG_USB_SERIAL_GARMIN=m
|
|
+CONFIG_USB_SERIAL_IPW=m
|
|
+CONFIG_USB_SERIAL_KEYSPAN_PDA=m
|
|
+CONFIG_USB_SERIAL_KEYSPAN=m
|
|
+CONFIG_USB_SERIAL_KEYSPAN_MPR=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA28=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA28X=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA28XA=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA28XB=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA19=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA18X=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA19W=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA19QW=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA19QI=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA49W=y
|
|
+CONFIG_USB_SERIAL_KEYSPAN_USA49WLC=y
|
|
+CONFIG_USB_SERIAL_KLSI=m
|
|
+CONFIG_USB_SERIAL_KOBIL_SCT=m
|
|
+CONFIG_USB_SERIAL_MCT_U232=m
|
|
+CONFIG_USB_SERIAL_MOS7720=m
|
|
+CONFIG_USB_SERIAL_MOS7840=m
|
|
+CONFIG_USB_SERIAL_NAVMAN=m
|
|
+CONFIG_USB_SERIAL_PL2303=m
|
|
+# CONFIG_USB_SERIAL_OTI6858 is not set
|
|
+CONFIG_USB_SERIAL_HP4X=m
|
|
+CONFIG_USB_SERIAL_SAFE=m
|
|
+CONFIG_USB_SERIAL_SAFE_PADDED=y
|
|
+CONFIG_USB_SERIAL_SIERRAWIRELESS=m
|
|
+CONFIG_USB_SERIAL_TI=m
|
|
+CONFIG_USB_SERIAL_CYBERJACK=m
|
|
+CONFIG_USB_SERIAL_XIRCOM=m
|
|
+CONFIG_USB_SERIAL_OPTION=m
|
|
+CONFIG_USB_SERIAL_OMNINET=m
|
|
+# CONFIG_USB_SERIAL_DEBUG is not set
|
|
+CONFIG_USB_EZUSB=y
|
|
+
|
|
+#
|
|
+# USB Miscellaneous drivers
|
|
+#
|
|
+# CONFIG_USB_EMI62 is not set
|
|
+# CONFIG_USB_EMI26 is not set
|
|
+# CONFIG_USB_ADUTUX is not set
|
|
+# CONFIG_USB_AUERSWALD is not set
|
|
+# CONFIG_USB_RIO500 is not set
|
|
+# CONFIG_USB_LEGOTOWER is not set
|
|
+# CONFIG_USB_LCD is not set
|
|
+# CONFIG_USB_BERRY_CHARGE is not set
|
|
+# CONFIG_USB_LED is not set
|
|
+# CONFIG_USB_CYPRESS_CY7C63 is not set
|
|
+# CONFIG_USB_CYTHERM is not set
|
|
+# CONFIG_USB_PHIDGET is not set
|
|
+# CONFIG_USB_IDMOUSE is not set
|
|
+# CONFIG_USB_FTDI_ELAN is not set
|
|
+# CONFIG_USB_APPLEDISPLAY 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
|
|
+
|
|
+#
|
|
+# USB DSL modem support
|
|
+#
|
|
+
|
|
+#
|
|
+# USB Gadget Support
|
|
+#
|
|
+CONFIG_USB_GADGET=y
|
|
+# CONFIG_USB_GADGET_DEBUG is not set
|
|
+# CONFIG_USB_GADGET_DEBUG_FILES is not set
|
|
+CONFIG_USB_GADGET_SELECTED=y
|
|
+# CONFIG_USB_GADGET_AMD5536UDC is not set
|
|
+# CONFIG_USB_GADGET_ATMEL_USBA is not set
|
|
+# CONFIG_USB_GADGET_FSL_USB2 is not set
|
|
+# CONFIG_USB_GADGET_NET2280 is not set
|
|
+# CONFIG_USB_GADGET_PXA2XX is not set
|
|
+# CONFIG_USB_GADGET_M66592 is not set
|
|
+# CONFIG_USB_GADGET_GOKU is not set
|
|
+# CONFIG_USB_GADGET_LH7A40X is not set
|
|
+# CONFIG_USB_GADGET_OMAP is not set
|
|
+CONFIG_USB_GADGET_S3C2410=y
|
|
+CONFIG_USB_S3C2410=y
|
|
+# CONFIG_USB_S3C2410_DEBUG is not set
|
|
+# CONFIG_USB_GADGET_AT91 is not set
|
|
+# CONFIG_USB_GADGET_DUMMY_HCD is not set
|
|
+# CONFIG_USB_GADGET_DUALSPEED is not set
|
|
+# CONFIG_USB_ZERO is not set
|
|
+CONFIG_USB_ETH=y
|
|
+CONFIG_USB_ETH_RNDIS=y
|
|
+# CONFIG_USB_GADGETFS is not set
|
|
+# CONFIG_USB_FILE_STORAGE is not set
|
|
+# CONFIG_USB_G_SERIAL is not set
|
|
+CONFIG_USB_MIDI_GADGET=m
|
|
+
|
|
+#
|
|
+# SDIO support
|
|
+#
|
|
+# CONFIG_SDIO is not set
|
|
+CONFIG_MMC=y
|
|
+# CONFIG_MMC_DEBUG is not set
|
|
+CONFIG_MMC_UNSAFE_RESUME=y
|
|
+
|
|
+#
|
|
+# MMC/SD Card Drivers
|
|
+#
|
|
+CONFIG_MMC_BLOCK=y
|
|
+CONFIG_MMC_BLOCK_BOUNCE=y
|
|
+CONFIG_SDIO_UART=m
|
|
+
|
|
+#
|
|
+# MMC/SD Host Controller Drivers
|
|
+#
|
|
+# CONFIG_MMC_SPI is not set
|
|
+CONFIG_MMC_S3C=y
|
|
+CONFIG_NEW_LEDS=y
|
|
+CONFIG_LEDS_CLASS=y
|
|
+
|
|
+#
|
|
+# LED drivers
|
|
+#
|
|
+CONFIG_LEDS_S3C24XX=m
|
|
+# CONFIG_LEDS_GPIO is not set
|
|
+
|
|
+#
|
|
+# LED Triggers
|
|
+#
|
|
+CONFIG_LEDS_TRIGGERS=y
|
|
+CONFIG_LEDS_TRIGGER_TIMER=y
|
|
+# CONFIG_LEDS_TRIGGER_HEARTBEAT is not set
|
|
+CONFIG_RTC_LIB=y
|
|
+CONFIG_RTC_CLASS=y
|
|
+CONFIG_RTC_HCTOSYS=y
|
|
+CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
|
|
+CONFIG_RTC_DEBUG=y
|
|
+
|
|
+#
|
|
+# RTC interfaces
|
|
+#
|
|
+CONFIG_RTC_INTF_SYSFS=y
|
|
+CONFIG_RTC_INTF_PROC=y
|
|
+CONFIG_RTC_INTF_DEV=y
|
|
+# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
|
|
+# CONFIG_RTC_DRV_TEST is not set
|
|
+
|
|
+#
|
|
+# I2C RTC drivers
|
|
+#
|
|
+# CONFIG_RTC_DRV_DS1307 is not set
|
|
+# CONFIG_RTC_DRV_DS1374 is not set
|
|
+# CONFIG_RTC_DRV_DS1672 is not set
|
|
+# CONFIG_RTC_DRV_MAX6900 is not set
|
|
+# CONFIG_RTC_DRV_RS5C372 is not set
|
|
+# CONFIG_RTC_DRV_ISL1208 is not set
|
|
+# CONFIG_RTC_DRV_X1205 is not set
|
|
+# CONFIG_RTC_DRV_PCF8563 is not set
|
|
+# CONFIG_RTC_DRV_PCF8583 is not set
|
|
+# CONFIG_RTC_DRV_M41T80 is not set
|
|
+
|
|
+#
|
|
+# SPI RTC drivers
|
|
+#
|
|
+# CONFIG_RTC_DRV_RS5C348 is not set
|
|
+# CONFIG_RTC_DRV_MAX6902 is not set
|
|
+
|
|
+#
|
|
+# Platform RTC drivers
|
|
+#
|
|
+# CONFIG_RTC_DRV_CMOS is not set
|
|
+# CONFIG_RTC_DRV_DS1553 is not set
|
|
+# CONFIG_RTC_DRV_STK17TA8 is not set
|
|
+# CONFIG_RTC_DRV_DS1742 is not set
|
|
+# CONFIG_RTC_DRV_M48T86 is not set
|
|
+# CONFIG_RTC_DRV_M48T59 is not set
|
|
+# CONFIG_RTC_DRV_V3020 is not set
|
|
+
|
|
+#
|
|
+# on-CPU RTC drivers
|
|
+#
|
|
+CONFIG_RTC_DRV_S3C=m
|
|
+
|
|
+#
|
|
+# 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_FS_XATTR is not set
|
|
+# CONFIG_EXT4DEV_FS is not set
|
|
+CONFIG_JBD=y
|
|
+# CONFIG_REISERFS_FS is not set
|
|
+# CONFIG_JFS_FS is not set
|
|
+CONFIG_FS_POSIX_ACL=y
|
|
+# CONFIG_XFS_FS is not set
|
|
+# CONFIG_GFS2_FS is not set
|
|
+# CONFIG_OCFS2_FS is not set
|
|
+# CONFIG_MINIX_FS is not set
|
|
+CONFIG_ROMFS_FS=y
|
|
+CONFIG_INOTIFY=y
|
|
+CONFIG_INOTIFY_USER=y
|
|
+# CONFIG_QUOTA is not set
|
|
+CONFIG_DNOTIFY=y
|
|
+# CONFIG_AUTOFS_FS is not set
|
|
+CONFIG_AUTOFS4_FS=m
|
|
+CONFIG_FUSE_FS=m
|
|
+
|
|
+#
|
|
+# CD-ROM/DVD Filesystems
|
|
+#
|
|
+CONFIG_ISO9660_FS=m
|
|
+CONFIG_JOLIET=y
|
|
+# CONFIG_ZISOFS is not set
|
|
+CONFIG_UDF_FS=m
|
|
+CONFIG_UDF_NLS=y
|
|
+
|
|
+#
|
|
+# 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_SYSFS=y
|
|
+CONFIG_TMPFS=y
|
|
+# CONFIG_TMPFS_POSIX_ACL is not set
|
|
+# CONFIG_HUGETLB_PAGE is not set
|
|
+CONFIG_CONFIGFS_FS=m
|
|
+
|
|
+#
|
|
+# Miscellaneous filesystems
|
|
+#
|
|
+# CONFIG_ADFS_FS is not set
|
|
+# CONFIG_AFFS_FS is not set
|
|
+# CONFIG_HFS_FS is not set
|
|
+# CONFIG_HFSPLUS_FS is not set
|
|
+# CONFIG_BEFS_FS is not set
|
|
+# CONFIG_BFS_FS is not set
|
|
+# CONFIG_EFS_FS is not set
|
|
+CONFIG_JFFS2_FS=y
|
|
+CONFIG_JFFS2_FS_DEBUG=0
|
|
+CONFIG_JFFS2_FS_WRITEBUFFER=y
|
|
+# CONFIG_JFFS2_FS_WBUF_VERIFY is not set
|
|
+CONFIG_JFFS2_SUMMARY=y
|
|
+# CONFIG_JFFS2_FS_XATTR is not set
|
|
+# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set
|
|
+CONFIG_JFFS2_ZLIB=y
|
|
+# CONFIG_JFFS2_LZO is not set
|
|
+CONFIG_JFFS2_RTIME=y
|
|
+# CONFIG_JFFS2_RUBIN is not set
|
|
+CONFIG_CRAMFS=y
|
|
+# CONFIG_VXFS_FS is not set
|
|
+# CONFIG_HPFS_FS is not set
|
|
+# CONFIG_QNX4FS_FS is not set
|
|
+# CONFIG_SYSV_FS is not set
|
|
+# CONFIG_UFS_FS is not set
|
|
+CONFIG_NETWORK_FILESYSTEMS=y
|
|
+CONFIG_NFS_FS=y
|
|
+CONFIG_NFS_V3=y
|
|
+# CONFIG_NFS_V3_ACL is not set
|
|
+CONFIG_NFS_V4=y
|
|
+# CONFIG_NFS_DIRECTIO is not set
|
|
+CONFIG_NFSD=m
|
|
+CONFIG_NFSD_V3=y
|
|
+# CONFIG_NFSD_V3_ACL is not set
|
|
+CONFIG_NFSD_V4=y
|
|
+CONFIG_NFSD_TCP=y
|
|
+CONFIG_ROOT_NFS=y
|
|
+CONFIG_LOCKD=y
|
|
+CONFIG_LOCKD_V4=y
|
|
+CONFIG_EXPORTFS=m
|
|
+CONFIG_NFS_COMMON=y
|
|
+CONFIG_SUNRPC=y
|
|
+CONFIG_SUNRPC_GSS=y
|
|
+# CONFIG_SUNRPC_BIND34 is not set
|
|
+CONFIG_RPCSEC_GSS_KRB5=y
|
|
+# CONFIG_RPCSEC_GSS_SPKM3 is not set
|
|
+# CONFIG_SMB_FS is not set
|
|
+CONFIG_CIFS=m
|
|
+# CONFIG_CIFS_STATS is not set
|
|
+CONFIG_CIFS_WEAK_PW_HASH=y
|
|
+# CONFIG_CIFS_XATTR is not set
|
|
+# CONFIG_CIFS_DEBUG2 is not set
|
|
+# CONFIG_CIFS_EXPERIMENTAL is not set
|
|
+# CONFIG_NCP_FS is not set
|
|
+# CONFIG_CODA_FS is not set
|
|
+# CONFIG_AFS_FS is not set
|
|
+
|
|
+#
|
|
+# Partition Types
|
|
+#
|
|
+# CONFIG_PARTITION_ADVANCED is not set
|
|
+CONFIG_MSDOS_PARTITION=y
|
|
+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=m
|
|
+# 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=m
|
|
+CONFIG_NLS_CODEPAGE_950=m
|
|
+# CONFIG_NLS_CODEPAGE_932 is not set
|
|
+# CONFIG_NLS_CODEPAGE_949 is not set
|
|
+# CONFIG_NLS_CODEPAGE_874 is not set
|
|
+# CONFIG_NLS_ISO8859_8 is not set
|
|
+# CONFIG_NLS_CODEPAGE_1250 is not set
|
|
+# CONFIG_NLS_CODEPAGE_1251 is not set
|
|
+# CONFIG_NLS_ASCII is not set
|
|
+CONFIG_NLS_ISO8859_1=y
|
|
+# CONFIG_NLS_ISO8859_2 is not set
|
|
+# CONFIG_NLS_ISO8859_3 is not set
|
|
+# CONFIG_NLS_ISO8859_4 is not set
|
|
+# CONFIG_NLS_ISO8859_5 is not set
|
|
+# CONFIG_NLS_ISO8859_6 is not set
|
|
+# CONFIG_NLS_ISO8859_7 is not set
|
|
+# CONFIG_NLS_ISO8859_9 is not set
|
|
+# CONFIG_NLS_ISO8859_13 is not set
|
|
+# CONFIG_NLS_ISO8859_14 is not set
|
|
+# CONFIG_NLS_ISO8859_15 is not set
|
|
+# CONFIG_NLS_KOI8_R is not set
|
|
+# CONFIG_NLS_KOI8_U is not set
|
|
+CONFIG_NLS_UTF8=m
|
|
+# CONFIG_DLM is not set
|
|
+CONFIG_INSTRUMENTATION=y
|
|
+CONFIG_PROFILING=y
|
|
+CONFIG_OPROFILE=m
|
|
+# CONFIG_MARKERS is not set
|
|
+
|
|
+#
|
|
+# Kernel hacking
|
|
+#
|
|
+# CONFIG_PRINTK_TIME is not set
|
|
+CONFIG_ENABLE_WARN_DEPRECATED=y
|
|
+CONFIG_ENABLE_MUST_CHECK=y
|
|
+CONFIG_MAGIC_SYSRQ=y
|
|
+# CONFIG_UNUSED_SYMBOLS is not set
|
|
+# CONFIG_DEBUG_FS is not set
|
|
+# CONFIG_HEADERS_CHECK is not set
|
|
+CONFIG_DEBUG_KERNEL=y
|
|
+# CONFIG_DEBUG_SHIRQ is not set
|
|
+CONFIG_DETECT_SOFTLOCKUP=y
|
|
+# CONFIG_SCHED_DEBUG is not set
|
|
+# CONFIG_SCHEDSTATS is not set
|
|
+CONFIG_TIMER_STATS=y
|
|
+# CONFIG_DEBUG_SLAB is not set
|
|
+CONFIG_DEBUG_PREEMPT=y
|
|
+# CONFIG_DEBUG_RT_MUTEXES is not set
|
|
+# CONFIG_RT_MUTEX_TESTER is not set
|
|
+# CONFIG_DEBUG_SPINLOCK is not set
|
|
+# CONFIG_DEBUG_MUTEXES is not set
|
|
+# CONFIG_DEBUG_LOCK_ALLOC is not set
|
|
+# CONFIG_PROVE_LOCKING is not set
|
|
+# CONFIG_LOCK_STAT is not set
|
|
+# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
|
|
+# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
|
|
+# CONFIG_DEBUG_KOBJECT is not set
|
|
+CONFIG_DEBUG_BUGVERBOSE=y
|
|
+CONFIG_DEBUG_INFO=y
|
|
+# CONFIG_DEBUG_VM is not set
|
|
+# CONFIG_DEBUG_LIST is not set
|
|
+# CONFIG_DEBUG_SG is not set
|
|
+CONFIG_FRAME_POINTER=y
|
|
+CONFIG_FORCED_INLINING=y
|
|
+# CONFIG_BOOT_PRINTK_DELAY is not set
|
|
+# CONFIG_RCU_TORTURE_TEST is not set
|
|
+# CONFIG_FAULT_INJECTION is not set
|
|
+# CONFIG_SAMPLES is not set
|
|
+# CONFIG_DEBUG_USER is not set
|
|
+CONFIG_DEBUG_ERRORS=y
|
|
+# CONFIG_DEBUG_LL is not set
|
|
+CONFIG_DEBUG_S3C_UART=2
|
|
+
|
|
+#
|
|
+# Security options
|
|
+#
|
|
+# CONFIG_KEYS is not set
|
|
+# CONFIG_SECURITY is not set
|
|
+# CONFIG_SECURITY_FILE_CAPABILITIES is not set
|
|
+CONFIG_CRYPTO=y
|
|
+CONFIG_CRYPTO_ALGAPI=y
|
|
+CONFIG_CRYPTO_BLKCIPHER=y
|
|
+CONFIG_CRYPTO_HASH=y
|
|
+CONFIG_CRYPTO_MANAGER=y
|
|
+CONFIG_CRYPTO_HMAC=y
|
|
+CONFIG_CRYPTO_XCBC=m
|
|
+CONFIG_CRYPTO_NULL=m
|
|
+CONFIG_CRYPTO_MD4=m
|
|
+CONFIG_CRYPTO_MD5=y
|
|
+CONFIG_CRYPTO_SHA1=m
|
|
+CONFIG_CRYPTO_SHA256=m
|
|
+CONFIG_CRYPTO_SHA512=m
|
|
+CONFIG_CRYPTO_WP512=m
|
|
+CONFIG_CRYPTO_TGR192=m
|
|
+CONFIG_CRYPTO_GF128MUL=m
|
|
+CONFIG_CRYPTO_ECB=m
|
|
+CONFIG_CRYPTO_CBC=y
|
|
+CONFIG_CRYPTO_PCBC=m
|
|
+CONFIG_CRYPTO_LRW=m
|
|
+# CONFIG_CRYPTO_XTS is not set
|
|
+# CONFIG_CRYPTO_CRYPTD is not set
|
|
+CONFIG_CRYPTO_DES=y
|
|
+CONFIG_CRYPTO_FCRYPT=m
|
|
+CONFIG_CRYPTO_BLOWFISH=m
|
|
+CONFIG_CRYPTO_TWOFISH=m
|
|
+CONFIG_CRYPTO_TWOFISH_COMMON=m
|
|
+CONFIG_CRYPTO_SERPENT=m
|
|
+CONFIG_CRYPTO_AES=m
|
|
+CONFIG_CRYPTO_CAST5=m
|
|
+CONFIG_CRYPTO_CAST6=m
|
|
+CONFIG_CRYPTO_TEA=m
|
|
+CONFIG_CRYPTO_ARC4=m
|
|
+CONFIG_CRYPTO_KHAZAD=m
|
|
+CONFIG_CRYPTO_ANUBIS=m
|
|
+# CONFIG_CRYPTO_SEED is not set
|
|
+CONFIG_CRYPTO_DEFLATE=m
|
|
+CONFIG_CRYPTO_MICHAEL_MIC=m
|
|
+CONFIG_CRYPTO_CRC32C=m
|
|
+CONFIG_CRYPTO_CAMELLIA=m
|
|
+CONFIG_CRYPTO_TEST=m
|
|
+# CONFIG_CRYPTO_AUTHENC is not set
|
|
+CONFIG_CRYPTO_HW=y
|
|
+
|
|
+#
|
|
+# Library routines
|
|
+#
|
|
+CONFIG_BITREVERSE=y
|
|
+CONFIG_CRC_CCITT=m
|
|
+CONFIG_CRC16=m
|
|
+# CONFIG_CRC_ITU_T is not set
|
|
+CONFIG_CRC32=y
|
|
+# CONFIG_CRC7 is not set
|
|
+CONFIG_LIBCRC32C=m
|
|
+CONFIG_ZLIB_INFLATE=y
|
|
+CONFIG_ZLIB_DEFLATE=y
|
|
+CONFIG_TEXTSEARCH=y
|
|
+CONFIG_TEXTSEARCH_KMP=m
|
|
+CONFIG_TEXTSEARCH_BM=m
|
|
+CONFIG_TEXTSEARCH_FSM=m
|
|
+CONFIG_PLIST=y
|
|
+CONFIG_HAS_IOMEM=y
|
|
diff --git a/arch/arm/mach-s3c2440/mach-glofiish.c b/arch/arm/mach-s3c2440/mach-glofiish.c
|
|
new file mode 100644
|
|
index 0000000..ee97110
|
|
--- /dev/null
|
|
+++ b/arch/arm/mach-s3c2440/mach-glofiish.c
|
|
@@ -0,0 +1,620 @@
|
|
+/*
|
|
+ * linux/arch/arm/mach-s3c2440/mach-glofiish.c
|
|
+ *
|
|
+ * S3C2440 Machine Support for the E-TEN glofiish X800/M800
|
|
+ *
|
|
+ * Copyright (C) 2008 by Harald Welte <laforge@gnumonks.org>
|
|
+ * All rights reserved.
|
|
+ *
|
|
+ * This program is free software; you can redistribute it and/or
|
|
+ * modify it under the terms of the GNU General Public License as
|
|
+ * published by the Free Software Foundation; either version 2 of
|
|
+ * the License, or (at your option) any later version.
|
|
+ *
|
|
+ * This program is distributed in the hope that it will be useful,
|
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
+ * GNU General Public License for more details.
|
|
+ *
|
|
+ * You should have received a copy of the GNU General Public License
|
|
+ * along with this program; if not, write to the Free Software
|
|
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
+ * MA 02111-1307 USA
|
|
+ *
|
|
+ */
|
|
+
|
|
+#include <linux/kernel.h>
|
|
+#include <linux/types.h>
|
|
+#include <linux/interrupt.h>
|
|
+#include <linux/list.h>
|
|
+#include <linux/delay.h>
|
|
+#include <linux/timer.h>
|
|
+#include <linux/init.h>
|
|
+#include <linux/workqueue.h>
|
|
+#include <linux/platform_device.h>
|
|
+#include <linux/serial_core.h>
|
|
+#include <linux/spi/spi.h>
|
|
+#include <linux/spi/spi_bitbang.h>
|
|
+#include <linux/mmc/host.h>
|
|
+
|
|
+#include <linux/mtd/mtd.h>
|
|
+#include <linux/mtd/nand.h>
|
|
+#include <linux/mtd/nand_ecc.h>
|
|
+#include <linux/mtd/partitions.h>
|
|
+#include <linux/mtd/physmap.h>
|
|
+
|
|
+#include <asm/mach/arch.h>
|
|
+#include <asm/mach/map.h>
|
|
+#include <asm/mach/irq.h>
|
|
+
|
|
+#include <asm/hardware.h>
|
|
+#include <asm/io.h>
|
|
+#include <asm/irq.h>
|
|
+#include <asm/mach-types.h>
|
|
+
|
|
+#include <asm/arch-s3c2410/regs-irq.h>
|
|
+#include <asm/arch/regs-gpio.h>
|
|
+#include <asm/arch/regs-gpioj.h>
|
|
+#include <asm/arch/fb.h>
|
|
+#include <asm/arch/mci.h>
|
|
+#include <asm/arch/ts.h>
|
|
+#include <asm/arch/spi.h>
|
|
+#include <asm/arch/spi-gpio.h>
|
|
+#include <asm/arch/usb-control.h>
|
|
+
|
|
+#include <asm/arch/glofiish.h>
|
|
+#include <asm/arch/gta01.h>
|
|
+
|
|
+#include <asm/plat-s3c/regs-serial.h>
|
|
+#include <asm/plat-s3c/nand.h>
|
|
+#include <asm/plat-s3c24xx/devs.h>
|
|
+#include <asm/plat-s3c24xx/cpu.h>
|
|
+#include <asm/plat-s3c24xx/pm.h>
|
|
+#include <asm/plat-s3c24xx/udc.h>
|
|
+
|
|
+#include <linux/jbt6k74.h>
|
|
+
|
|
+/*
|
|
+ * this gets called every 1ms when we paniced.
|
|
+ */
|
|
+
|
|
+static long glofiish_panic_blink(long count)
|
|
+{
|
|
+ long delay = 0;
|
|
+ static long last_blink;
|
|
+ static char led;
|
|
+
|
|
+ if (count - last_blink < 100) /* 200ms period, fast blink */
|
|
+ return 0;
|
|
+
|
|
+ /* FIXME */
|
|
+#if 0
|
|
+ led ^= 1;
|
|
+ s3c2410_gpio_cfgpin(GTA02_GPIO_AUX_LED, S3C2410_GPIO_OUTPUT);
|
|
+ neo1973_gpb_setpin(GTA02_GPIO_AUX_LED, led);
|
|
+
|
|
+ last_blink = count;
|
|
+#endif
|
|
+ return delay;
|
|
+}
|
|
+
|
|
+struct platform_device gta02_version_device = {
|
|
+ .name = "neo1973-version",
|
|
+ .num_resources = 0,
|
|
+};
|
|
+
|
|
+struct platform_device gta02_resume_reason_device = {
|
|
+ .name = "neo1973-resume",
|
|
+ .num_resources = 0,
|
|
+};
|
|
+
|
|
+struct platform_device gta02_memconfig_device = {
|
|
+ .name = "neo1973-memconfig",
|
|
+ .num_resources = 0,
|
|
+};
|
|
+
|
|
+static struct map_desc m800_iodesc[] __initdata = {
|
|
+ {
|
|
+ .virtual = 0xe0000000,
|
|
+ .pfn = __phys_to_pfn(S3C2410_CS3+0x01000000),
|
|
+ .length = SZ_1M,
|
|
+ .type = MT_DEVICE
|
|
+ },
|
|
+};
|
|
+
|
|
+#define UCON S3C2410_UCON_DEFAULT
|
|
+#define ULCON S3C2410_LCON_CS8 | S3C2410_LCON_PNONE | S3C2410_LCON_STOPB
|
|
+#define UFCON S3C2410_UFCON_RXTRIG8 | S3C2410_UFCON_FIFOMODE
|
|
+
|
|
+static struct s3c2410_uartcfg m800_uartcfgs[] = {
|
|
+ [0] = {
|
|
+ .hwport = 0,
|
|
+ .flags = 0,
|
|
+ .ucon = UCON,
|
|
+ .ulcon = ULCON,
|
|
+ .ufcon = UFCON,
|
|
+ },
|
|
+ [1] = {
|
|
+ .hwport = 1,
|
|
+ .flags = 0,
|
|
+ .ucon = UCON,
|
|
+ .ulcon = ULCON,
|
|
+ .ufcon = UFCON,
|
|
+ },
|
|
+ [2] = {
|
|
+ .hwport = 2,
|
|
+ .flags = 0,
|
|
+ .ucon = UCON,
|
|
+ .ulcon = ULCON,
|
|
+ .ufcon = UFCON,
|
|
+ },
|
|
+
|
|
+};
|
|
+
|
|
+/* Configuration for 480x640 toppoly TD028TTEC1.
|
|
+ * Do not mark this as __initdata or it will break! */
|
|
+static struct s3c2410fb_display glofiish_displays[] = {
|
|
+ {
|
|
+ .type = S3C2410_LCDCON1_TFT,
|
|
+ .width = 43,
|
|
+ .height = 58,
|
|
+ .xres = 480,
|
|
+ .yres = 640,
|
|
+ .bpp = 16,
|
|
+
|
|
+ .pixclock = 40000, /* HCLK/4 */
|
|
+ .left_margin = 2,
|
|
+ .right_margin = 2,
|
|
+ .hsync_len = 2,
|
|
+ .upper_margin = 2,
|
|
+ .lower_margin = 66,
|
|
+ .vsync_len = 2,
|
|
+ .lcdcon5 = S3C2410_LCDCON5_FRM565 |
|
|
+ S3C2410_LCDCON5_INVVCLK |
|
|
+ S3C2410_LCDCON5_INVVLINE |
|
|
+ S3C2410_LCDCON5_INVVFRAME |
|
|
+ S3C2410_LCDCON5_PWREN |
|
|
+ S3C2410_LCDCON5_HWSWP,
|
|
+ },
|
|
+ {
|
|
+ .type = S3C2410_LCDCON1_TFT,
|
|
+ .width = 43,
|
|
+ .height = 58,
|
|
+ .xres = 480,
|
|
+ .yres = 640,
|
|
+ .bpp = 32,
|
|
+
|
|
+ .pixclock = 40000, /* HCLK/4 */
|
|
+ .left_margin = 104,
|
|
+ .right_margin = 8,
|
|
+ .hsync_len = 8,
|
|
+ .upper_margin = 2,
|
|
+ .lower_margin = 16,
|
|
+ .vsync_len = 2,
|
|
+ .lcdcon5 = S3C2410_LCDCON5_FRM565 |
|
|
+ S3C2410_LCDCON5_INVVCLK |
|
|
+ S3C2410_LCDCON5_INVVLINE |
|
|
+ S3C2410_LCDCON5_INVVFRAME |
|
|
+ S3C2410_LCDCON5_PWREN |
|
|
+ S3C2410_LCDCON5_HWSWP,
|
|
+ },
|
|
+ {
|
|
+ .type = S3C2410_LCDCON1_TFT,
|
|
+ .width = 43,
|
|
+ .height = 58,
|
|
+ .xres = 240,
|
|
+ .yres = 320,
|
|
+ .bpp = 16,
|
|
+
|
|
+ .pixclock = 40000, /* HCLK/4 */
|
|
+ .left_margin = 104,
|
|
+ .right_margin = 8,
|
|
+ .hsync_len = 8,
|
|
+ .upper_margin = 2,
|
|
+ .lower_margin = 16,
|
|
+ .vsync_len = 2,
|
|
+ .lcdcon5 = S3C2410_LCDCON5_FRM565 |
|
|
+ S3C2410_LCDCON5_INVVCLK |
|
|
+ S3C2410_LCDCON5_INVVLINE |
|
|
+ S3C2410_LCDCON5_INVVFRAME |
|
|
+ S3C2410_LCDCON5_PWREN |
|
|
+ S3C2410_LCDCON5_HWSWP,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct s3c2410fb_mach_info glofiish_lcd_cfg __initdata = {
|
|
+ .displays = glofiish_displays,
|
|
+ .num_displays = ARRAY_SIZE(glofiish_displays),
|
|
+ .default_display = 0,
|
|
+
|
|
+ .lpcsel = ((0xCE6) & ~7) | 1<<4,
|
|
+};
|
|
+
|
|
+
|
|
+static struct resource m800_sdio_resources[] = {
|
|
+ [0] = {
|
|
+ .flags = IORESOURCE_IRQ,
|
|
+ .start = IRQ_SDI,
|
|
+ .end = IRQ_SDI,
|
|
+ },
|
|
+ [1] = {
|
|
+ .flags = IORESOURCE_MEM,
|
|
+ .start = S3C2410_PA_SDI,
|
|
+ .end = S3C2410_PA_SDI + S3C24XX_SZ_SDI - 1,
|
|
+ },
|
|
+ [2] = {
|
|
+ .flags = IORESOURCE_DMA,
|
|
+ .start = 0, /* Channel 0 for SDI */
|
|
+ .end = 0,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct platform_device *glofiish_devices[] __initdata = {
|
|
+ &s3c_device_usb,
|
|
+ &s3c_device_lcd,
|
|
+ &s3c_device_wdt,
|
|
+ &s3c_device_i2c,
|
|
+ &s3c_device_iis,
|
|
+ &s3c_device_sdi,
|
|
+ &s3c_device_usbgadget,
|
|
+ &s3c_device_nand,
|
|
+ &s3c_device_ts,
|
|
+};
|
|
+
|
|
+static struct s3c2410_nand_set glofiish_nand_sets[] = {
|
|
+ [0] = {
|
|
+ .name = "glofiish-nand",
|
|
+ .nr_chips = 1,
|
|
+ .flags = S3C2410_NAND_BBT,
|
|
+ },
|
|
+};
|
|
+
|
|
+/* choose a set of timings derived from S3C@2442B MCP54
|
|
+ * data sheet (K5D2G13ACM-D075 MCP Memory)
|
|
+ */
|
|
+
|
|
+static struct s3c2410_platform_nand glofiish_nand_info = {
|
|
+ .tacls = 0,
|
|
+ .twrph0 = 25,
|
|
+ .twrph1 = 15,
|
|
+ .nr_sets = ARRAY_SIZE(glofiish_nand_sets),
|
|
+ .sets = glofiish_nand_sets,
|
|
+ .software_ecc = 1,
|
|
+};
|
|
+
|
|
+static struct s3c24xx_mci_pdata glofiish_mmc_cfg = {
|
|
+ .gpio_detect = M800_GPIO_nSD_DETECT,
|
|
+ .set_power = NULL,
|
|
+ .ocr_avail = MMC_VDD_32_33,
|
|
+};
|
|
+
|
|
+static void glofiish_udc_command(enum s3c2410_udc_cmd_e cmd)
|
|
+{
|
|
+ printk(KERN_DEBUG "%s(%d)\n", __func__, cmd);
|
|
+
|
|
+ switch (cmd) {
|
|
+ case S3C2410_UDC_P_ENABLE:
|
|
+ s3c2410_gpio_setpin(M800_GPIO_USB_PULLUP, 1);
|
|
+ break;
|
|
+ case S3C2410_UDC_P_DISABLE:
|
|
+ s3c2410_gpio_setpin(M800_GPIO_USB_PULLUP, 0);
|
|
+ break;
|
|
+ case S3C2410_UDC_P_RESET:
|
|
+ /* FIXME! */
|
|
+ break;
|
|
+ default:
|
|
+ break;
|
|
+ }
|
|
+}
|
|
+
|
|
+/* get PMU to set USB current limit accordingly */
|
|
+
|
|
+static void glofiish_udc_vbus_draw(unsigned int ma)
|
|
+{
|
|
+ //pcf50633_notify_usb_current_limit_change(pcf50633_global, ma);
|
|
+}
|
|
+
|
|
+static struct s3c2410_udc_mach_info glofiish_udc_cfg = {
|
|
+ .vbus_draw = glofiish_udc_vbus_draw,
|
|
+ .udc_command = glofiish_udc_command,
|
|
+
|
|
+};
|
|
+
|
|
+static struct s3c2410_ts_mach_info glofiish_ts_cfg = {
|
|
+ .delay = 10000,
|
|
+ .presc = 50000000 / 1000000, /* 50 MHz PCLK / 1MHz */
|
|
+ /* simple averaging, 2^n samples */
|
|
+ .oversampling_shift = 5,
|
|
+ /* averaging filter length, 2^n */
|
|
+ .excursion_filter_len_bits = 5,
|
|
+ /* flagged for beauty contest on next sample if differs from
|
|
+ * average more than this
|
|
+ */
|
|
+ .reject_threshold_vs_avg = 2,
|
|
+};
|
|
+
|
|
+
|
|
+/* SPI: LCM control interface attached to Glamo3362 */
|
|
+
|
|
+static void m800_jbt6k74_reset(int devidx, int level)
|
|
+{
|
|
+ //glamo_lcm_reset(level);
|
|
+ printk(KERN_DEBUG "gta01_jbt6k74_reset\n");
|
|
+}
|
|
+
|
|
+/* finally bring up deferred backlight resume now LCM is resumed itself */
|
|
+
|
|
+static void m800_jbt6k74_resuming(int devidx)
|
|
+{
|
|
+ //pcf50633_backlight_resume(pcf50633_global);
|
|
+ //gta01bl_deferred_resume();
|
|
+}
|
|
+
|
|
+const struct jbt6k74_platform_data jbt6k74_pdata = {
|
|
+ .reset = m800_jbt6k74_reset,
|
|
+ .resuming = m800_jbt6k74_resuming,
|
|
+};
|
|
+
|
|
+static struct spi_board_info glofiish_spi_board_info[] = {
|
|
+ {
|
|
+ .modalias = "jbt6k74",
|
|
+ /* platform_data */
|
|
+ .platform_data = &jbt6k74_pdata,
|
|
+ /* controller_data */
|
|
+ /* irq */
|
|
+ .max_speed_hz = 10 * 1000 * 1000,
|
|
+ .bus_num = 2,
|
|
+ /* chip_select */
|
|
+ },
|
|
+};
|
|
+
|
|
+static void spi_gpio_cs(struct s3c2410_spigpio_info *spi, int csidx, int cs)
|
|
+{
|
|
+ switch (cs) {
|
|
+ case BITBANG_CS_ACTIVE:
|
|
+ s3c2410_gpio_setpin(S3C2410_GPG3, 0);
|
|
+ break;
|
|
+ case BITBANG_CS_INACTIVE:
|
|
+ s3c2410_gpio_setpin(S3C2410_GPG3, 1);
|
|
+ break;
|
|
+ }
|
|
+}
|
|
+
|
|
+static struct s3c2410_spigpio_info spi_gpio_cfg = {
|
|
+ .pin_clk = S3C2410_GPG7,
|
|
+ .pin_mosi = S3C2410_GPG6,
|
|
+ .pin_miso = S3C2410_GPG5,
|
|
+ .board_size = ARRAY_SIZE(glofiish_spi_board_info),
|
|
+ .board_info = glofiish_spi_board_info,
|
|
+ .chip_select = &spi_gpio_cs,
|
|
+ .num_chipselect = 2, /*** Should be 1 or 2 for gta01? ***/
|
|
+};
|
|
+
|
|
+static struct resource s3c_spi_lcm_resource[] = {
|
|
+ [0] = {
|
|
+ .start = S3C2410_GPG3,
|
|
+ .end = S3C2410_GPG3,
|
|
+ },
|
|
+ [1] = {
|
|
+ .start = S3C2410_GPG5,
|
|
+ .end = S3C2410_GPG5,
|
|
+ },
|
|
+ [2] = {
|
|
+ .start = S3C2410_GPG6,
|
|
+ .end = S3C2410_GPG6,
|
|
+ },
|
|
+ [3] = {
|
|
+ .start = S3C2410_GPG7,
|
|
+ .end = S3C2410_GPG7,
|
|
+ },
|
|
+};
|
|
+
|
|
+struct platform_device s3c_device_spi_lcm = {
|
|
+ .name = "spi_s3c24xx_gpio",
|
|
+ .id = 1,
|
|
+ .num_resources = ARRAY_SIZE(s3c_spi_lcm_resource),
|
|
+ .resource = s3c_spi_lcm_resource,
|
|
+ .dev = {
|
|
+ .platform_data = &spi_gpio_cfg,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct gta01bl_machinfo backlight_machinfo = {
|
|
+ .default_intensity = 1,
|
|
+ .max_intensity = 1,
|
|
+ .limit_mask = 1,
|
|
+ .defer_resume_backlight = 1,
|
|
+};
|
|
+
|
|
+static struct resource gta01_bl_resources[] = {
|
|
+ [0] = {
|
|
+ .start = M800_GPIO_BACKLIGHT,
|
|
+ .end = M800_GPIO_BACKLIGHT,
|
|
+ },
|
|
+};
|
|
+
|
|
+struct platform_device gta01_bl_dev = {
|
|
+ .name = "gta01-bl",
|
|
+ .num_resources = ARRAY_SIZE(gta01_bl_resources),
|
|
+ .resource = gta01_bl_resources,
|
|
+ .dev = {
|
|
+ .platform_data = &backlight_machinfo,
|
|
+ },
|
|
+};
|
|
+
|
|
+
|
|
+#if 0 /* currently this is not used and we use gpio spi */
|
|
+static struct glamo_spi_info glamo_spi_cfg = {
|
|
+ .board_size = ARRAY_SIZE(gta02_spi_board_info),
|
|
+ .board_info = gta02_spi_board_info,
|
|
+};
|
|
+#endif /* 0 */
|
|
+
|
|
+#if 0
|
|
+static struct resource gta02_vibrator_resources[] = {
|
|
+ [0] = {
|
|
+ .start = GTA02_GPIO_VIBRATOR_ON,
|
|
+ .end = GTA02_GPIO_VIBRATOR_ON,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct platform_device gta02_vibrator_dev = {
|
|
+ .name = "neo1973-vibrator",
|
|
+ .num_resources = ARRAY_SIZE(gta02_vibrator_resources),
|
|
+ .resource = gta02_vibrator_resources,
|
|
+};
|
|
+
|
|
+static struct resource gta02_led_resources[] = {
|
|
+ {
|
|
+ .name = "gta02-power:orange",
|
|
+ .start = GTA02_GPIO_PWR_LED1,
|
|
+ .end = GTA02_GPIO_PWR_LED1,
|
|
+ }, {
|
|
+ .name = "gta02-power:blue",
|
|
+ .start = GTA02_GPIO_PWR_LED2,
|
|
+ .end = GTA02_GPIO_PWR_LED2,
|
|
+ }, {
|
|
+ .name = "gta02-aux:red",
|
|
+ .start = GTA02_GPIO_AUX_LED,
|
|
+ .end = GTA02_GPIO_AUX_LED,
|
|
+ },
|
|
+};
|
|
+
|
|
+struct platform_device gta02_led_dev = {
|
|
+ .name = "gta02-led",
|
|
+ .num_resources = ARRAY_SIZE(gta02_led_resources),
|
|
+ .resource = gta02_led_resources,
|
|
+};
|
|
+
|
|
+static struct resource gta02_button_resources[] = {
|
|
+ [0] = {
|
|
+ .start = GTA02_GPIO_AUX_KEY,
|
|
+ .end = GTA02_GPIO_AUX_KEY,
|
|
+ },
|
|
+ [1] = {
|
|
+ .start = GTA02_GPIO_HOLD_KEY,
|
|
+ .end = GTA02_GPIO_HOLD_KEY,
|
|
+ },
|
|
+ [2] = {
|
|
+ .start = GTA02_GPIO_JACK_INSERT,
|
|
+ .end = GTA02_GPIO_JACK_INSERT,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct platform_device gta02_button_dev = {
|
|
+ .name = "neo1973-button",
|
|
+ .num_resources = ARRAY_SIZE(gta02_button_resources),
|
|
+ .resource = gta02_button_resources,
|
|
+};
|
|
+#endif
|
|
+
|
|
+/* USB */
|
|
+static struct s3c2410_hcd_info glofiish_usb_info = {
|
|
+ .port[0] = {
|
|
+ .flags = S3C_HCDFLG_USED,
|
|
+ },
|
|
+ .port[1] = {
|
|
+ .flags = 0,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct resource m800_button_resources[] = {
|
|
+ [0] = {
|
|
+ .start = M800_GPIO_nKEY_POWER,
|
|
+ .end = M800_GPIO_nKEY_POWER,
|
|
+ },
|
|
+ [1] = {
|
|
+ .start = M800_GPIO_nKEY_CAMERA,
|
|
+ .end = M800_GPIO_nKEY_CAMERA,
|
|
+ },
|
|
+ [3] = {
|
|
+ .start = M800_GPIO_nKEY_RECORD,
|
|
+ .end = M800_GPIO_nKEY_RECORD,
|
|
+ },
|
|
+ [2] = {
|
|
+ .start = M800_GPIO_SLIDE,
|
|
+ .end = M800_GPIO_SLIDE,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct platform_device m800_button_dev = {
|
|
+ .name = "m800-button",
|
|
+ .num_resources = ARRAY_SIZE(m800_button_resources),
|
|
+ .resource = m800_button_resources,
|
|
+};
|
|
+
|
|
+static struct platform_device m800_pm_bt_dev = {
|
|
+ .name = "neo1973-pm-bt",
|
|
+};
|
|
+
|
|
+static void __init glofiish_map_io(void)
|
|
+{
|
|
+ s3c24xx_init_io(m800_iodesc, ARRAY_SIZE(m800_iodesc));
|
|
+ s3c24xx_init_clocks(16934400);
|
|
+ s3c24xx_init_uarts(m800_uartcfgs, ARRAY_SIZE(m800_uartcfgs));
|
|
+}
|
|
+
|
|
+static irqreturn_t gta02_modem_irq(int irq, void *param)
|
|
+{
|
|
+ printk(KERN_DEBUG "modem wakeup interrupt\n");
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+static irqreturn_t ar6000_wow_irq(int irq, void *param)
|
|
+{
|
|
+ printk(KERN_DEBUG "ar6000_wow interrupt\n");
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+/*
|
|
+ * hardware_ecc=1|0
|
|
+ */
|
|
+static char hardware_ecc_str[4] __initdata = "";
|
|
+
|
|
+static int __init hardware_ecc_setup(char *str)
|
|
+{
|
|
+ if (str)
|
|
+ strlcpy(hardware_ecc_str, str, sizeof(hardware_ecc_str));
|
|
+ return 1;
|
|
+}
|
|
+
|
|
+__setup("hardware_ecc=", hardware_ecc_setup);
|
|
+
|
|
+static void __init glofiish_machine_init(void)
|
|
+{
|
|
+ int rc;
|
|
+
|
|
+ /* set the panic callback to make AUX blink fast */
|
|
+ panic_blink = glofiish_panic_blink;
|
|
+
|
|
+ /* do not force soft ecc if we are asked to use hardware_ecc */
|
|
+ if (hardware_ecc_str[0] == '1')
|
|
+ glofiish_nand_info.software_ecc = 0;
|
|
+
|
|
+ s3c_device_usb.dev.platform_data = &glofiish_usb_info;
|
|
+ s3c_device_nand.dev.platform_data = &glofiish_nand_info;
|
|
+ s3c_device_sdi.dev.platform_data = &glofiish_mmc_cfg;
|
|
+
|
|
+ s3c24xx_fb_set_platdata(&glofiish_lcd_cfg);
|
|
+ s3c24xx_udc_set_platdata(&glofiish_udc_cfg);
|
|
+ set_s3c2410ts_info(&glofiish_ts_cfg);
|
|
+
|
|
+ platform_device_register(>a01_bl_dev);
|
|
+ platform_device_register(&m800_pm_bt_dev);
|
|
+ platform_device_register(&m800_button_dev);
|
|
+ platform_device_register(&s3c_device_spi_lcm);
|
|
+
|
|
+ platform_add_devices(glofiish_devices, ARRAY_SIZE(glofiish_devices));
|
|
+
|
|
+ s3c2410_pm_init();
|
|
+}
|
|
+
|
|
+MACHINE_START(M800, "Glofiish M800")
|
|
+ .phys_io = S3C2410_PA_UART,
|
|
+ .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc,
|
|
+ .boot_params = S3C2410_SDRAM_PA + 0x100,
|
|
+ .map_io = glofiish_map_io,
|
|
+ .init_irq = s3c24xx_init_irq,
|
|
+ .init_machine = glofiish_machine_init,
|
|
+ .timer = &s3c24xx_timer,
|
|
+MACHINE_END
|
|
diff --git a/drivers/input/keyboard/m800kbd.c b/drivers/input/keyboard/m800kbd.c
|
|
new file mode 100644
|
|
index 0000000..22f1aab
|
|
--- /dev/null
|
|
+++ b/drivers/input/keyboard/m800kbd.c
|
|
@@ -0,0 +1,330 @@
|
|
+/*
|
|
+ * Keyboard driver for E-TEN M800 GSM phone
|
|
+ *
|
|
+ * (C) 2008 by Harald Welte <laforge@gnumonks.org>
|
|
+ * All rights reserved.
|
|
+ *
|
|
+ * inspired by corkgbd.c by Richard Purdie
|
|
+ *
|
|
+ * 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/delay.h>
|
|
+#include <linux/platform_device.h>
|
|
+#include <linux/init.h>
|
|
+#include <linux/input.h>
|
|
+#include <linux/interrupt.h>
|
|
+#include <linux/jiffies.h>
|
|
+#include <linux/module.h>
|
|
+#include <linux/slab.h>
|
|
+#include <linux/workqueue.h>
|
|
+
|
|
+#include <asm/gpio.h>
|
|
+#include <asm/mach-types.h>
|
|
+
|
|
+struct m800kbd {
|
|
+ struct input_dev *input;
|
|
+ unsigned int suspended;
|
|
+ struct work_struct work;
|
|
+ int work_in_progress;
|
|
+ int hp_irq_count_in_work;
|
|
+ int hp_irq_count;
|
|
+ int jack_irq;
|
|
+};
|
|
+
|
|
+static irqreturn_t m800kbd_power_irq(int irq, void *dev_id)
|
|
+{
|
|
+ struct m800kbd *m800kbd_data = dev_id;
|
|
+ int key_pressed = !gpio_get_value(irq_to_gpio(irq));
|
|
+
|
|
+ input_report_key(m800kbd_data->input, KEY_POWER, key_pressed);
|
|
+ input_sync(m800kbd_data->input);
|
|
+
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+static irqreturn_t m800kbd_cam_irq(int irq, void *dev_id)
|
|
+{
|
|
+ struct m800kbd *m800kbd_data = dev_id;
|
|
+
|
|
+ int key_pressed = !gpio_get_value(irq_to_gpio(irq));
|
|
+ input_report_key(m800kbd_data->input, KEY_CAMERA, key_pressed);
|
|
+ input_sync(m800kbd_data->input);
|
|
+
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+static irqreturn_t m800kbd_rec_irq(int irq, void *dev_id)
|
|
+{
|
|
+ struct m800kbd *m800kbd_data = dev_id;
|
|
+
|
|
+ int key_pressed = !gpio_get_value(irq_to_gpio(irq));
|
|
+ input_report_key(m800kbd_data->input, KEY_RECORD, key_pressed);
|
|
+ input_sync(m800kbd_data->input);
|
|
+
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+static irqreturn_t m800kbd_slide_irq(int irq, void *dev_id)
|
|
+{
|
|
+ struct m800kbd *m800kbd_data = dev_id;
|
|
+
|
|
+ int key_pressed = gpio_get_value(irq_to_gpio(irq));
|
|
+ input_report_key(m800kbd_data->input, SW_LID, key_pressed);
|
|
+ input_sync(m800kbd_data->input);
|
|
+
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+
|
|
+#if 0
|
|
+static void m800kbd_debounce_jack(struct work_struct *work)
|
|
+{
|
|
+ struct m800kbd *kbd = container_of(work, struct m800kbd, work);
|
|
+ unsigned long flags;
|
|
+ int loop = 0;
|
|
+
|
|
+ do {
|
|
+ /*
|
|
+ * we wait out any multiple interrupt
|
|
+ * stuttering in 100ms lumps
|
|
+ */
|
|
+ do {
|
|
+ kbd->hp_irq_count_in_work = kbd->hp_irq_count;
|
|
+ msleep(100);
|
|
+ } while (kbd->hp_irq_count != kbd->hp_irq_count_in_work);
|
|
+ /*
|
|
+ * no new interrupts on jack for 100ms...
|
|
+ * ok we will report it
|
|
+ */
|
|
+ input_report_switch(kbd->input, SW_HEADPHONE_INSERT,
|
|
+ gpio_get_value(irq_to_gpio(kbd->jack_irq)));
|
|
+ input_sync(kbd->input);
|
|
+ /*
|
|
+ * we go around the outer loop again if we detect that more
|
|
+ * interrupts came while we are servicing here. But we have
|
|
+ * to sequence it carefully with interrupts off
|
|
+ */
|
|
+ local_save_flags(flags);
|
|
+ /* no interrupts during this work means we can exit the work */
|
|
+ loop = !!(kbd->hp_irq_count != kbd->hp_irq_count_in_work);
|
|
+ if (!loop)
|
|
+ kbd->work_in_progress = 0;
|
|
+ local_irq_restore(flags);
|
|
+ /*
|
|
+ * interrupt that comes here will either queue a new work action
|
|
+ * since work_in_progress is cleared now, or be dealt with
|
|
+ * when we loop.
|
|
+ */
|
|
+ } while (loop);
|
|
+}
|
|
+
|
|
+
|
|
+static irqreturn_t m800kbd_headphone_irq(int irq, void *dev_id)
|
|
+{
|
|
+ struct m800kbd *m800kbd_data = dev_id;
|
|
+
|
|
+ /*
|
|
+ * this interrupt is prone to bouncing and userspace doesn't like
|
|
+ * to have to deal with that kind of thing. So we do not accept
|
|
+ * that a jack interrupt is equal to a jack event. Instead we fire
|
|
+ * some work on the first interrupt, and it hangs about in 100ms units
|
|
+ * until no more interrupts come. Then it accepts the state it finds
|
|
+ * for jack insert and reports it once
|
|
+ */
|
|
+
|
|
+ m800kbd_data->hp_irq_count++;
|
|
+ /*
|
|
+ * the first interrupt we see for a while, we fire the work item
|
|
+ * and record the interrupt count when we did that. If more interrupts
|
|
+ * come in the meanwhile, we can tell by the difference in that
|
|
+ * stored count and hp_irq_count which increments every interrupt
|
|
+ */
|
|
+ if (!m800kbd_data->work_in_progress) {
|
|
+ m800kbd_data->jack_irq = irq;
|
|
+ m800kbd_data->hp_irq_count_in_work =
|
|
+ m800kbd_data->hp_irq_count;
|
|
+ if (!schedule_work(&m800kbd_data->work))
|
|
+ printk(KERN_ERR
|
|
+ "Unable to schedule headphone debounce\n");
|
|
+ else
|
|
+ m800kbd_data->work_in_progress = 1;
|
|
+ }
|
|
+
|
|
+ return IRQ_HANDLED;
|
|
+}
|
|
+#endif
|
|
+
|
|
+#ifdef CONFIG_PM
|
|
+static int m800kbd_suspend(struct platform_device *dev, pm_message_t state)
|
|
+{
|
|
+ struct m800kbd *m800kbd = platform_get_drvdata(dev);
|
|
+
|
|
+ m800kbd->suspended = 1;
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
+static int m800kbd_resume(struct platform_device *dev)
|
|
+{
|
|
+ struct m800kbd *m800kbd = platform_get_drvdata(dev);
|
|
+
|
|
+ m800kbd->suspended = 0;
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+#else
|
|
+#define m800kbd_suspend NULL
|
|
+#define m800kbd_resume NULL
|
|
+#endif
|
|
+
|
|
+static int m800kbd_probe(struct platform_device *pdev)
|
|
+{
|
|
+ struct m800kbd *m800kbd;
|
|
+ struct input_dev *input_dev;
|
|
+ int rc, irq_power, irq_cam, irq_rec, irq_slide;
|
|
+
|
|
+ m800kbd = kzalloc(sizeof(struct m800kbd), GFP_KERNEL);
|
|
+ input_dev = input_allocate_device();
|
|
+ if (!m800kbd || !input_dev) {
|
|
+ kfree(m800kbd);
|
|
+ input_free_device(input_dev);
|
|
+ return -ENOMEM;
|
|
+ }
|
|
+
|
|
+ if (pdev->resource[0].flags != 0)
|
|
+ return -EINVAL;
|
|
+
|
|
+ irq_power = gpio_to_irq(pdev->resource[0].start);
|
|
+ if (irq_power < 0)
|
|
+ return -EINVAL;
|
|
+
|
|
+ irq_cam = gpio_to_irq(pdev->resource[1].start);
|
|
+ if (irq_cam < 0)
|
|
+ return -EINVAL;
|
|
+
|
|
+ irq_rec = gpio_to_irq(pdev->resource[2].start);
|
|
+ if (irq_rec < 0)
|
|
+ return -EINVAL;
|
|
+
|
|
+ irq_slide = gpio_to_irq(pdev->resource[3].start);
|
|
+ if (irq_slide < 0)
|
|
+ return -EINVAL;
|
|
+
|
|
+ platform_set_drvdata(pdev, m800kbd);
|
|
+
|
|
+ m800kbd->input = input_dev;
|
|
+
|
|
+ //INIT_WORK(&m800kbd->work, m800kbd_debounce_jack);
|
|
+
|
|
+ input_dev->name = "M800 Buttons";
|
|
+ input_dev->phys = "m800kbd/input0";
|
|
+ input_dev->id.bustype = BUS_HOST;
|
|
+ input_dev->id.vendor = 0x0001;
|
|
+ input_dev->id.product = 0x0001;
|
|
+ input_dev->id.version = 0x0100;
|
|
+ input_dev->cdev.dev = &pdev->dev;
|
|
+ input_dev->private = m800kbd;
|
|
+
|
|
+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_SW);
|
|
+ set_bit(SW_HEADPHONE_INSERT, input_dev->swbit);
|
|
+ set_bit(SW_LID, input_dev->swbit);
|
|
+ set_bit(KEY_POWER, input_dev->keybit);
|
|
+ set_bit(KEY_CAMERA, input_dev->keybit);
|
|
+ set_bit(KEY_RECORD, input_dev->keybit);
|
|
+
|
|
+ rc = input_register_device(m800kbd->input);
|
|
+ if (rc)
|
|
+ goto out_register;
|
|
+
|
|
+ if (request_irq(irq_power, m800kbd_power_irq, IRQF_DISABLED |
|
|
+ IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
|
+ "M800 Power button", m800kbd)) {
|
|
+ dev_err(&pdev->dev, "Can't get IRQ %u\n", irq_power);
|
|
+ goto out_aux;
|
|
+ }
|
|
+
|
|
+ enable_irq_wake(irq_power);
|
|
+
|
|
+ if (request_irq(irq_cam, m800kbd_cam_irq, IRQF_DISABLED |
|
|
+ IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
|
+ "M800 Camera button", m800kbd)) {
|
|
+ dev_err(&pdev->dev, "Can't get IRQ %u\n", irq_cam);
|
|
+ goto out_hold;
|
|
+ }
|
|
+
|
|
+ if (request_irq(irq_rec, m800kbd_rec_irq, IRQF_DISABLED |
|
|
+ IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
|
+ "M800 Record button", m800kbd)) {
|
|
+ dev_err(&pdev->dev, "Can't get IRQ %u\n", irq_rec);
|
|
+ goto out_hold;
|
|
+ }
|
|
+
|
|
+ if (request_irq(irq_slide, m800kbd_slide_irq, IRQF_DISABLED |
|
|
+ IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING,
|
|
+ "M800 Slide", m800kbd)) {
|
|
+ dev_err(&pdev->dev, "Can't get IRQ %u\n", irq_slide);
|
|
+ goto out_jack;
|
|
+ }
|
|
+ enable_irq_wake(irq_slide);
|
|
+
|
|
+ return 0;
|
|
+
|
|
+out_jack:
|
|
+ free_irq(irq_cam, m800kbd);
|
|
+out_hold:
|
|
+ free_irq(irq_power, m800kbd);
|
|
+out_aux:
|
|
+ input_unregister_device(m800kbd->input);
|
|
+out_register:
|
|
+ input_free_device(m800kbd->input);
|
|
+ platform_set_drvdata(pdev, NULL);
|
|
+ kfree(m800kbd);
|
|
+
|
|
+ return -ENODEV;
|
|
+}
|
|
+
|
|
+static int m800kbd_remove(struct platform_device *pdev)
|
|
+{
|
|
+ struct m800kbd *m800kbd = platform_get_drvdata(pdev);
|
|
+
|
|
+ free_irq(gpio_to_irq(pdev->resource[2].start), m800kbd);
|
|
+ free_irq(gpio_to_irq(pdev->resource[1].start), m800kbd);
|
|
+ free_irq(gpio_to_irq(pdev->resource[0].start), m800kbd);
|
|
+
|
|
+ input_unregister_device(m800kbd->input);
|
|
+ input_free_device(m800kbd->input);
|
|
+ platform_set_drvdata(pdev, NULL);
|
|
+ kfree(m800kbd);
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
+static struct platform_driver m800kbd_driver = {
|
|
+ .probe = m800kbd_probe,
|
|
+ .remove = m800kbd_remove,
|
|
+ .suspend = m800kbd_suspend,
|
|
+ .resume = m800kbd_resume,
|
|
+ .driver = {
|
|
+ .name = "m800-button",
|
|
+ },
|
|
+};
|
|
+
|
|
+static int __devinit m800kbd_init(void)
|
|
+{
|
|
+ return platform_driver_register(&m800kbd_driver);
|
|
+}
|
|
+
|
|
+static void __exit m800kbd_exit(void)
|
|
+{
|
|
+ platform_driver_unregister(&m800kbd_driver);
|
|
+}
|
|
+
|
|
+module_init(m800kbd_init);
|
|
+module_exit(m800kbd_exit);
|
|
+
|
|
+MODULE_AUTHOR("Harald Welte <laforge@gnumonks.org>");
|
|
+MODULE_DESCRIPTION("E-TEN glofiish M800 GPIO buttons input driver");
|
|
+MODULE_LICENSE("GPL");
|
|
diff --git a/include/asm-arm/arch-s3c2410/glofiish.h b/include/asm-arm/arch-s3c2410/glofiish.h
|
|
new file mode 100644
|
|
index 0000000..1d0586f
|
|
--- /dev/null
|
|
+++ b/include/asm-arm/arch-s3c2410/glofiish.h
|
|
@@ -0,0 +1,39 @@
|
|
+#ifndef _GLOFIISH_H
|
|
+#define _GLOFIISH_H
|
|
+
|
|
+#include <asm/arch/regs-gpio.h>
|
|
+
|
|
+#define M800_GPIO_USB_PULLUP S3C2410_GPA21
|
|
+
|
|
+#define M800_GPIO_BACKLIGHT S3C2410_GPB0
|
|
+#define M800_GPIO_KBDLIGHT S3C2410_GPB1
|
|
+#define M800_GPIO_GPS_POWER S3C2410_GPB6
|
|
+
|
|
+#define M800_GPIO_BT_POWER_1 S3C2410_GPC8
|
|
+#define M800_GPIO_BT_POWER_2 S3C2410_GPC9
|
|
+
|
|
+#define M800_GPIO_nKEY_POWER S3C2410_GPF0
|
|
+#define M800_GPIO_CPLD S3C2410_GPF2
|
|
+#define M800_GPIO_USB_ATTACH S3C2410_GPF3
|
|
+#define M800_GPIO_WIFI_1 S3C2410_GPF5
|
|
+#define M800_GPIO_WIFI_2 S3C2410_GPF7
|
|
+
|
|
+#define M800_GPIO_FMRADIO S3C2410_GPG0
|
|
+#define M800_GPIO_nKEY_CAMERA S3C2410_GPG2
|
|
+#define M800_GPIO_nKEY_RECORD S3C2410_GPG4
|
|
+#define M800_GPIO_SLIDE S3C2410_GPG6
|
|
+#define M800_GPIO_nSD_DETECT S3C2410_GPG7
|
|
+
|
|
+#define M800_IRQ_nKEY_POWER IRQ_EINT0
|
|
+#define M800_IRQ_CPLD_KEY IRQ_EINT2
|
|
+#define M800_IRQ_USB_ATTACH IRQ_EINT3
|
|
+#define M800_IRQ_WIFI_1 IRQ_EINT5
|
|
+#define M800_IRQ_WIFI_2 IRQ_EINT7
|
|
+#define M800_IRQ_FMRADIO IRQ_EINT8
|
|
+#define M800_IRQ_nKEY_CAMERA IRQ_EINT10
|
|
+#define M800_IRQ_nKEY_RECORD IRQ_EINT12
|
|
+#define M800_IRQ_CAPSENSE IRQ_EINT13
|
|
+#define M800_IRQ_KBD_SLIDE IRQ_EINT14
|
|
+#define M800_IRQ_nSD_DETECT IRQ_EINT15
|
|
+
|
|
+#endif
|
|
--
|
|
1.5.6.5
|
|
|