diff options
| author | Ingo Molnar <mingo@elte.hu> | 2010-08-31 09:45:21 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-08-31 09:45:46 +0200 | 
| commit | daab7fc734a53fdeaf844b7c03053118ad1769da (patch) | |
| tree | 575deb3cdcc6dda562acaed6f7c29bc81ae01cf2 /arch/sparc | |
| parent | 774ea0bcb27f57b6fd521b3b6c43237782fed4b9 (diff) | |
| parent | 2bfc96a127bc1cc94d26bfaa40159966064f9c8c (diff) | |
| download | kernel_samsung_smdk4412-daab7fc734a53fdeaf844b7c03053118ad1769da.zip kernel_samsung_smdk4412-daab7fc734a53fdeaf844b7c03053118ad1769da.tar.gz kernel_samsung_smdk4412-daab7fc734a53fdeaf844b7c03053118ad1769da.tar.bz2 | |
Merge commit 'v2.6.36-rc3' into x86/memblock
Conflicts:
	arch/x86/kernel/trampoline.c
	mm/memblock.c
Merge reason: Resolve the conflicts, update to latest upstream.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/sparc')
77 files changed, 864 insertions, 3799 deletions
| diff --git a/arch/sparc/Kconfig b/arch/sparc/Kconfig index c0015db..491e9d6 100644 --- a/arch/sparc/Kconfig +++ b/arch/sparc/Kconfig @@ -18,6 +18,7 @@ config 64BIT  config SPARC  	bool  	default y +	select OF  	select HAVE_IDE  	select HAVE_OPROFILE  	select HAVE_ARCH_KGDB if !SMP || SPARC64 @@ -66,9 +67,6 @@ config BITS  	default 32 if SPARC32  	default 64 if SPARC64 -config GENERIC_TIME -	def_bool y -  config ARCH_USES_GETTIMEOFFSET  	bool  	default y if SPARC32 @@ -148,9 +146,6 @@ config GENERIC_GPIO  config ARCH_NO_VIRT_TO_BUS  	def_bool y -config OF -	def_bool y -  config ARCH_SUPPORTS_DEBUG_PAGEALLOC  	def_bool y if SPARC64 diff --git a/arch/sparc/Kconfig.debug b/arch/sparc/Kconfig.debug index 1b4a831..d9a795e 100644 --- a/arch/sparc/Kconfig.debug +++ b/arch/sparc/Kconfig.debug @@ -30,18 +30,4 @@ config FRAME_POINTER  	depends on MCOUNT  	default y -config DEBUG_STRICT_USER_COPY_CHECKS -	bool "Strict copy size checks" -	depends on DEBUG_KERNEL && !TRACE_BRANCH_PROFILING -	---help--- -	  Enabling this option turns a certain set of sanity checks for user -	  copy operations into compile time failures. - -	  The copy_from_user() etc checks are there to help test if there -	  are sufficient security checks on the length argument of -	  the copy operation, by having gcc prove that the argument is -	  within bounds. - -	  If unsure, or if you run an older (pre 4.4) gcc, say N. -  endmenu diff --git a/arch/sparc/boot/btfixupprep.c b/arch/sparc/boot/btfixupprep.c index e7f2940..da03115 100644 --- a/arch/sparc/boot/btfixupprep.c +++ b/arch/sparc/boot/btfixupprep.c @@ -216,7 +216,7 @@ main1:  		switch (buffer[nbase+3]) {  		case 'f':  			if (initval) { -				fprintf(stderr, "Cannot use pre-initalized fixups for calls\n%s\n", buffer); +				fprintf(stderr, "Cannot use pre-initialized fixups for calls\n%s\n", buffer);  				exit(1);  			}  			if (!strcmp (sect, "__ksymtab")) { @@ -273,7 +273,7 @@ main1:  			break;  		case 'i':  			if (initval) { -				fprintf(stderr, "Cannot use pre-initalized fixups for INT\n%s\n", buffer); +				fprintf(stderr, "Cannot use pre-initialized fixups for INT\n%s\n", buffer);  				exit(1);  			}  			if (strncmp (buffer + mode+9, "HI22      ", 10) && strncmp (buffer + mode+9, "LO10      ", 10)) { diff --git a/arch/sparc/configs/sparc32_defconfig b/arch/sparc/configs/sparc32_defconfig index 6a8d078..fb23fd6 100644 --- a/arch/sparc/configs/sparc32_defconfig +++ b/arch/sparc/configs/sparc32_defconfig @@ -1,1225 +1,105 @@ -# -# Automatically generated make config: don't edit -# Linux kernel version: 2.6.33 -# Wed Mar  3 02:52:23 2010 -# -# CONFIG_64BIT is not set -CONFIG_SPARC=y -CONFIG_SPARC32=y -# CONFIG_SPARC64 is not set -CONFIG_ARCH_DEFCONFIG="arch/sparc/configs/sparc32_defconfig" -CONFIG_BITS=32 -CONFIG_GENERIC_TIME=y -CONFIG_ARCH_USES_GETTIMEOFFSET=y -CONFIG_AUDIT_ARCH=y -CONFIG_MMU=y -CONFIG_HIGHMEM=y -CONFIG_ZONE_DMA=y -CONFIG_GENERIC_ISA_DMA=y -CONFIG_ARCH_NO_VIRT_TO_BUS=y -CONFIG_OF=y -CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" -CONFIG_CONSTRUCTORS=y - -# -# General setup -#  CONFIG_EXPERIMENTAL=y -CONFIG_BROKEN_ON_SMP=y -CONFIG_INIT_ENV_ARG_LIMIT=32 -CONFIG_LOCALVERSION="" -CONFIG_LOCALVERSION_AUTO=y -CONFIG_SWAP=y  CONFIG_SYSVIPC=y -CONFIG_SYSVIPC_SYSCTL=y  CONFIG_POSIX_MQUEUE=y -CONFIG_POSIX_MQUEUE_SYSCTL=y -# CONFIG_BSD_PROCESS_ACCT is not set -# CONFIG_TASKSTATS is not set -# CONFIG_AUDIT is not set - -# -# RCU Subsystem -# -CONFIG_TREE_RCU=y -# CONFIG_TREE_PREEMPT_RCU is not set -# CONFIG_TINY_RCU is not set -# CONFIG_RCU_TRACE is not set -CONFIG_RCU_FANOUT=32 -# CONFIG_RCU_FANOUT_EXACT is not set -# CONFIG_TREE_RCU_TRACE is not set -# CONFIG_IKCONFIG is not set  CONFIG_LOG_BUF_SHIFT=14 -# CONFIG_CGROUPS is not set -CONFIG_SYSFS_DEPRECATED=y  CONFIG_SYSFS_DEPRECATED_V2=y -# CONFIG_RELAY is not set -CONFIG_NAMESPACES=y -# CONFIG_UTS_NS is not set -# CONFIG_IPC_NS is not set -# CONFIG_USER_NS is not set -# CONFIG_PID_NS is not set -# CONFIG_NET_NS 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_LZO=y  # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set -CONFIG_SYSCTL=y -CONFIG_ANON_INODES=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_EPOLL=y -CONFIG_SIGNALFD=y -CONFIG_TIMERFD=y -CONFIG_EVENTFD=y -CONFIG_SHMEM=y -CONFIG_AIO=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_PCI_QUIRKS=y -CONFIG_COMPAT_BRK=y  CONFIG_SLAB=y -# CONFIG_SLUB is not set -# CONFIG_SLOB is not set -# CONFIG_PROFILING is not set -CONFIG_HAVE_OPROFILE=y -CONFIG_HAVE_ARCH_TRACEHOOK=y -CONFIG_HAVE_DMA_ATTRS=y -CONFIG_HAVE_DMA_API_DEBUG=y - -# -# GCOV-based kernel profiling -# -# CONFIG_SLOW_WORK is not set -# CONFIG_HAVE_GENERIC_DMA_COHERENT is not set -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=y -# CONFIG_INLINE_SPIN_UNLOCK_BH is not set -CONFIG_INLINE_SPIN_UNLOCK_IRQ=y -# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set -# CONFIG_INLINE_READ_TRYLOCK is not set -# CONFIG_INLINE_READ_LOCK is not set -# CONFIG_INLINE_READ_LOCK_BH is not set -# CONFIG_INLINE_READ_LOCK_IRQ is not set -# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set -CONFIG_INLINE_READ_UNLOCK=y -# CONFIG_INLINE_READ_UNLOCK_BH is not set -CONFIG_INLINE_READ_UNLOCK_IRQ=y -# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set -# CONFIG_INLINE_WRITE_TRYLOCK is not set -# CONFIG_INLINE_WRITE_LOCK is not set -# CONFIG_INLINE_WRITE_LOCK_BH is not set -# CONFIG_INLINE_WRITE_LOCK_IRQ is not set -# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set -CONFIG_INLINE_WRITE_UNLOCK=y -# CONFIG_INLINE_WRITE_UNLOCK_BH is not set -CONFIG_INLINE_WRITE_UNLOCK_IRQ=y -# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set -# CONFIG_MUTEX_SPIN_ON_OWNER is not set -# CONFIG_FREEZER is not set - -# -# Processor type and features -# -# CONFIG_SMP is not set -# CONFIG_HZ_100 is not set -CONFIG_HZ_250=y -# CONFIG_HZ_300 is not set -# CONFIG_HZ_1000 is not set -CONFIG_HZ=250 -# CONFIG_SCHED_HRTICK is not set -CONFIG_RWSEM_GENERIC_SPINLOCK=y -CONFIG_GENERIC_FIND_NEXT_BIT=y -CONFIG_GENERIC_HWEIGHT=y -CONFIG_GENERIC_CALIBRATE_DELAY=y -CONFIG_ARCH_MAY_HAVE_PC_FDC=y -CONFIG_EMULATED_CMPXCHG=y -CONFIG_SELECT_MEMORY_MODEL=y -CONFIG_FLATMEM_MANUAL=y -# CONFIG_DISCONTIGMEM_MANUAL is not set -# CONFIG_SPARSEMEM_MANUAL is not set -CONFIG_FLATMEM=y -CONFIG_FLAT_NODE_MEM_MAP=y -CONFIG_PAGEFLAGS_EXTENDED=y -CONFIG_SPLIT_PTLOCK_CPUS=4 -# CONFIG_PHYS_ADDR_T_64BIT is not set -CONFIG_ZONE_DMA_FLAG=1 -CONFIG_BOUNCE=y -# CONFIG_KSM is not set -CONFIG_DEFAULT_MMAP_MIN_ADDR=4096 -CONFIG_SUN_PM=y -# CONFIG_SPARC_LED is not set -CONFIG_SERIAL_CONSOLE=y -# CONFIG_SPARC_LEON is not set - -# -# Bus options (PCI etc.) -# -CONFIG_SBUS=y -CONFIG_SBUSCHAR=y  CONFIG_PCI=y -CONFIG_PCI_SYSCALL=y -# CONFIG_ARCH_SUPPORTS_MSI is not set -# CONFIG_PCI_DEBUG is not set -# CONFIG_PCI_STUB is not set -# CONFIG_PCI_IOV is not set -# CONFIG_PCCARD is not set  CONFIG_SUN_OPENPROMFS=m -CONFIG_SPARC32_PCI=y - -# -# Executable file formats -# -CONFIG_BINFMT_ELF=y -# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set -# CONFIG_HAVE_AOUT is not set  CONFIG_BINFMT_MISC=m  CONFIG_NET=y - -# -# Networking options -#  CONFIG_PACKET=y  CONFIG_UNIX=y -CONFIG_XFRM=y  CONFIG_XFRM_USER=m -# CONFIG_XFRM_SUB_POLICY is not set -# CONFIG_XFRM_MIGRATE is not set -# CONFIG_XFRM_STATISTICS is not set -CONFIG_XFRM_IPCOMP=y  CONFIG_NET_KEY=m -# CONFIG_NET_KEY_MIGRATE is not set  CONFIG_INET=y -# CONFIG_IP_MULTICAST is not set -# CONFIG_IP_ADVANCED_ROUTER is not set -CONFIG_IP_FIB_HASH=y  CONFIG_IP_PNP=y  CONFIG_IP_PNP_DHCP=y -# CONFIG_IP_PNP_BOOTP is not set -# CONFIG_IP_PNP_RARP is not set -# CONFIG_NET_IPIP is not set -# CONFIG_NET_IPGRE is not set -# CONFIG_ARPD is not set -# CONFIG_SYN_COOKIES is not set  CONFIG_INET_AH=y  CONFIG_INET_ESP=y  CONFIG_INET_IPCOMP=y -CONFIG_INET_XFRM_TUNNEL=y -CONFIG_INET_TUNNEL=y -CONFIG_INET_XFRM_MODE_TRANSPORT=y -CONFIG_INET_XFRM_MODE_TUNNEL=y -CONFIG_INET_XFRM_MODE_BEET=y  # CONFIG_INET_LRO is not set -CONFIG_INET_DIAG=y -CONFIG_INET_TCP_DIAG=y -# CONFIG_TCP_CONG_ADVANCED is not set -CONFIG_TCP_CONG_CUBIC=y -CONFIG_DEFAULT_TCP_CONG="cubic" -# CONFIG_TCP_MD5SIG is not set -CONFIG_IPV6=m  CONFIG_IPV6_PRIVACY=y -# 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_SIT_6RD is not set -CONFIG_IPV6_NDISC_NODETYPE=y  CONFIG_IPV6_TUNNEL=m -# CONFIG_IPV6_MULTIPLE_TABLES is not set -# CONFIG_IPV6_MROUTE is not set -# CONFIG_NETWORK_SECMARK is not set -# CONFIG_NETFILTER is not set -# CONFIG_IP_DCCP is not set -# CONFIG_IP_SCTP is not set -# CONFIG_RDS is not set -# CONFIG_TIPC is not set -# CONFIG_ATM is not set -# CONFIG_BRIDGE is not set -# CONFIG_NET_DSA is not set -# CONFIG_VLAN_8021Q is not set -# CONFIG_DECNET is not set -# CONFIG_LLC2 is not set -# CONFIG_IPX is not set -# CONFIG_ATALK is not set -# CONFIG_X25 is not set -# CONFIG_LAPB is not set -# CONFIG_ECONET is not set -# CONFIG_WAN_ROUTER is not set -# CONFIG_PHONET is not set -# CONFIG_IEEE802154 is not set -# CONFIG_NET_SCHED is not set -# CONFIG_DCB is not set - -# -# Network testing -#  CONFIG_NET_PKTGEN=m -# CONFIG_HAMRADIO is not set -# CONFIG_CAN is not set -# CONFIG_IRDA is not set -# CONFIG_BT is not set -# CONFIG_AF_RXRPC is not set -CONFIG_WIRELESS=y -# CONFIG_CFG80211 is not set -# CONFIG_LIB80211 is not set - -# -# CFG80211 needs to be enabled for MAC80211 -# -# CONFIG_WIMAX is not set -# CONFIG_RFKILL is not set -# CONFIG_NET_9P is not set - -# -# Device Drivers -# - -# -# Generic Driver Options -#  CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" -CONFIG_STANDALONE=y -CONFIG_PREVENT_FIRMWARE_BUILD=y -CONFIG_FW_LOADER=y -CONFIG_FIRMWARE_IN_KERNEL=y -CONFIG_EXTRA_FIRMWARE="" -# CONFIG_DEBUG_DRIVER is not set -# CONFIG_DEBUG_DEVRES is not set -# CONFIG_SYS_HYPERVISOR is not set -# CONFIG_CONNECTOR is not set -# CONFIG_MTD is not set -CONFIG_OF_DEVICE=y -# CONFIG_PARPORT is not set -CONFIG_BLK_DEV=y -# CONFIG_BLK_DEV_FD is not set -# CONFIG_BLK_CPQ_CISS_DA is not set -# CONFIG_BLK_DEV_DAC960 is not set -# CONFIG_BLK_DEV_UMEM is not set -# CONFIG_BLK_DEV_COW_COMMON is not set  CONFIG_BLK_DEV_LOOP=m  CONFIG_BLK_DEV_CRYPTOLOOP=m - -# -# DRBD disabled because PROC_FS, INET or CONNECTOR not selected -# -# CONFIG_BLK_DEV_NBD is not set -# CONFIG_BLK_DEV_SX8 is not set  CONFIG_BLK_DEV_RAM=y -CONFIG_BLK_DEV_RAM_COUNT=16 -CONFIG_BLK_DEV_RAM_SIZE=4096 -# CONFIG_BLK_DEV_XIP is not set -# CONFIG_CDROM_PKTCDVD is not set -# CONFIG_ATA_OVER_ETH is not set -# CONFIG_BLK_DEV_HD is not set -CONFIG_MISC_DEVICES=y -# CONFIG_PHANTOM is not set -# CONFIG_SGI_IOC4 is not set -# CONFIG_TIFM_CORE is not set -# CONFIG_ENCLOSURE_SERVICES is not set -# CONFIG_HP_ILO is not set -# CONFIG_TI_DAC7512 is not set -# CONFIG_C2PORT is not set - -# -# EEPROM support -# -# CONFIG_EEPROM_AT25 is not set -# CONFIG_EEPROM_93CX6 is not set -# CONFIG_CB710_CORE is not set -CONFIG_HAVE_IDE=y -# CONFIG_IDE is not set - -# -# SCSI device support -# -# CONFIG_RAID_ATTRS is not set  CONFIG_SCSI=y -CONFIG_SCSI_DMA=y -# CONFIG_SCSI_TGT is not set -# CONFIG_SCSI_NETLINK is not set -CONFIG_SCSI_PROC_FS=y - -# -# SCSI support type (disk, tape, CD-ROM) -#  CONFIG_BLK_DEV_SD=y -# CONFIG_CHR_DEV_ST is not set -# CONFIG_CHR_DEV_OSST is not set  CONFIG_BLK_DEV_SR=m -# CONFIG_BLK_DEV_SR_VENDOR is not set  CONFIG_CHR_DEV_SG=m -# CONFIG_CHR_DEV_SCH is not set -# CONFIG_SCSI_MULTI_LUN is not set -# CONFIG_SCSI_CONSTANTS is not set -# CONFIG_SCSI_LOGGING is not set -# CONFIG_SCSI_SCAN_ASYNC is not set -CONFIG_SCSI_WAIT_SCAN=m - -# -# SCSI Transports -# -CONFIG_SCSI_SPI_ATTRS=y -# 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_CXGB3_ISCSI is not set -# CONFIG_SCSI_BNX2_ISCSI is not set -# CONFIG_BE2ISCSI is not set -# CONFIG_BLK_DEV_3W_XXXX_RAID is not set -# CONFIG_SCSI_HPSA is not set -# CONFIG_SCSI_3W_9XXX is not set -# CONFIG_SCSI_3W_SAS is not set -# CONFIG_SCSI_ACARD is not set -# CONFIG_SCSI_AACRAID is not set -# CONFIG_SCSI_AIC7XXX is not set -# CONFIG_SCSI_AIC7XXX_OLD is not set -# CONFIG_SCSI_AIC79XX is not set -# CONFIG_SCSI_AIC94XX is not set -# CONFIG_SCSI_MVSAS is not set -# CONFIG_SCSI_ARCMSR is not set -# CONFIG_MEGARAID_NEWGEN is not set -# CONFIG_MEGARAID_LEGACY is not set -# CONFIG_MEGARAID_SAS is not set -# CONFIG_SCSI_MPT2SAS is not set -# CONFIG_SCSI_HPTIOP is not set -# CONFIG_LIBFC is not set -# CONFIG_LIBFCOE is not set -# CONFIG_FCOE is not set -# CONFIG_SCSI_DMX3191D is not set -# CONFIG_SCSI_FUTURE_DOMAIN is not set -# CONFIG_SCSI_IPS is not set -# CONFIG_SCSI_INITIO is not set -# CONFIG_SCSI_INIA100 is not set -# CONFIG_SCSI_STEX is not set -# CONFIG_SCSI_SYM53C8XX_2 is not set -# CONFIG_SCSI_QLOGIC_1280 is not set  CONFIG_SCSI_QLOGICPTI=m -# CONFIG_SCSI_QLA_FC is not set -# CONFIG_SCSI_QLA_ISCSI is not set -# CONFIG_SCSI_LPFC is not set -# CONFIG_SCSI_DC395x is not set -# CONFIG_SCSI_DC390T is not set -# CONFIG_SCSI_NSP32 is not set -# CONFIG_SCSI_DEBUG is not set  CONFIG_SCSI_SUNESP=y -# CONFIG_SCSI_PMCRAID is not set -# CONFIG_SCSI_PM8001 is not set -# CONFIG_SCSI_SRP is not set -# CONFIG_SCSI_BFA_FC 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_FUSION is not set - -# -# IEEE 1394 (FireWire) support -# - -# -# You can enable one or both FireWire driver stacks. -# - -# -# The newer stack is recommended. -# -# CONFIG_FIREWIRE is not set -# CONFIG_IEEE1394 is not set -# CONFIG_I2O is not set  CONFIG_NETDEVICES=y  CONFIG_DUMMY=m -# CONFIG_BONDING is not set -# CONFIG_MACVLAN is not set -# CONFIG_EQUALIZER is not set -# CONFIG_TUN is not set -# CONFIG_VETH is not set -# CONFIG_ARCNET is not set -# CONFIG_PHYLIB is not set  CONFIG_NET_ETHERNET=y  CONFIG_MII=m  CONFIG_SUNLANCE=y  CONFIG_HAPPYMEAL=m  CONFIG_SUNBMAC=m  CONFIG_SUNQE=m -# CONFIG_SUNGEM is not set -# CONFIG_CASSINI is not set -# CONFIG_NET_VENDOR_3COM is not set -# CONFIG_ENC28J60 is not set -# CONFIG_ETHOC is not set -# CONFIG_GRETH is not set -# CONFIG_DNET is not set -# CONFIG_NET_TULIP is not set -# CONFIG_HP100 is not set -# CONFIG_IBM_NEW_EMAC_ZMII is not set -# CONFIG_IBM_NEW_EMAC_RGMII is not set -# CONFIG_IBM_NEW_EMAC_TAH is not set -# CONFIG_IBM_NEW_EMAC_EMAC4 is not set -# CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set -# CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set -# CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set -# CONFIG_NET_PCI is not set -# CONFIG_B44 is not set -# CONFIG_KS8842 is not set -# CONFIG_KS8851 is not set -# CONFIG_KS8851_MLL is not set -# CONFIG_ATL2 is not set -CONFIG_NETDEV_1000=y -# CONFIG_ACENIC is not set -# CONFIG_DL2K is not set -# CONFIG_E1000 is not set -# CONFIG_IP1000 is not set -# CONFIG_IGB is not set -# CONFIG_IGBVF is not set -# CONFIG_MYRI_SBUS is not set -# CONFIG_NS83820 is not set -# CONFIG_HAMACHI is not set -# CONFIG_YELLOWFIN is not set -# CONFIG_R8169 is not set -# CONFIG_SIS190 is not set -# CONFIG_SKGE is not set -# CONFIG_SKY2 is not set -# CONFIG_VIA_VELOCITY is not set -# CONFIG_TIGON3 is not set -# CONFIG_BNX2 is not set -# CONFIG_CNIC is not set -# CONFIG_QLA3XXX is not set -# CONFIG_ATL1 is not set -# CONFIG_ATL1E is not set -# CONFIG_ATL1C is not set -# CONFIG_JME is not set -CONFIG_NETDEV_10000=y -# CONFIG_CHELSIO_T1 is not set -CONFIG_CHELSIO_T3_DEPENDS=y -# CONFIG_CHELSIO_T3 is not set -# CONFIG_ENIC is not set -# CONFIG_IXGBE is not set -# CONFIG_IXGB is not set -# CONFIG_S2IO is not set -# CONFIG_VXGE is not set -# CONFIG_MYRI10GE is not set -# CONFIG_NETXEN_NIC is not set -# CONFIG_NIU is not set -# CONFIG_MLX4_EN is not set -# CONFIG_MLX4_CORE is not set -# CONFIG_TEHUTI is not set -# CONFIG_BNX2X is not set -# CONFIG_QLCNIC is not set -# CONFIG_QLGE is not set -# CONFIG_SFC is not set -# CONFIG_BE2NET is not set -# CONFIG_TR is not set  # CONFIG_WLAN is not set - -# -# Enable WiMAX (Networking options) to see the WiMAX drivers -# -# CONFIG_WAN is not set -# CONFIG_FDDI is not set -# CONFIG_HIPPI is not set -# CONFIG_PPP is not set -# CONFIG_SLIP is not set -# CONFIG_NET_FC is not set -# CONFIG_NETCONSOLE is not set -# CONFIG_NETPOLL is not set -# CONFIG_NET_POLL_CONTROLLER is not set -# CONFIG_VMXNET3 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=m  CONFIG_INPUT_EVDEV=m  CONFIG_INPUT_EVBUG=m - -# -# Input Device Drivers -# -CONFIG_INPUT_KEYBOARD=y  CONFIG_KEYBOARD_ATKBD=m -# CONFIG_KEYBOARD_LKKBD is not set -# CONFIG_KEYBOARD_NEWTON is not set -# CONFIG_KEYBOARD_OPENCORES is not set -# CONFIG_KEYBOARD_STOWAWAY is not set  CONFIG_KEYBOARD_SUNKBD=m -# CONFIG_KEYBOARD_XTKBD is not set -CONFIG_INPUT_MOUSE=y  CONFIG_MOUSE_PS2=m -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=m -# CONFIG_MOUSE_APPLETOUCH is not set -# CONFIG_MOUSE_BCM5974 is not set -# CONFIG_MOUSE_VSXXXAA is not set -# CONFIG_INPUT_JOYSTICK is not set -# CONFIG_INPUT_TABLET is not set -# CONFIG_INPUT_TOUCHSCREEN is not set -# CONFIG_INPUT_MISC is not set - -# -# Hardware I/O ports -#  CONFIG_SERIO=m  # CONFIG_SERIO_I8042 is not set -CONFIG_SERIO_SERPORT=m -# CONFIG_SERIO_PCIPS2 is not set -CONFIG_SERIO_LIBPS2=m -# CONFIG_SERIO_RAW is not set -# CONFIG_SERIO_ALTERA_PS2 is not set -# CONFIG_GAMEPORT is not set - -# -# Character devices -# -CONFIG_VT=y -CONFIG_CONSOLE_TRANSLATIONS=y -CONFIG_VT_CONSOLE=y -CONFIG_HW_CONSOLE=y -# CONFIG_VT_HW_CONSOLE_BINDING is not set -CONFIG_DEVKMEM=y -# CONFIG_SERIAL_NONSTANDARD is not set -# CONFIG_NOZOMI is not set - -# -# Serial drivers -# -# CONFIG_SERIAL_8250 is not set - -# -# Non-8250 serial port support -# -# CONFIG_SERIAL_MAX3100 is not set -CONFIG_SERIAL_SUNCORE=y  CONFIG_SERIAL_SUNZILOG=y  CONFIG_SERIAL_SUNZILOG_CONSOLE=y  CONFIG_SERIAL_SUNSU=y  CONFIG_SERIAL_SUNSU_CONSOLE=y -# CONFIG_SERIAL_SUNSAB is not set -CONFIG_SERIAL_CORE=y -CONFIG_SERIAL_CORE_CONSOLE=y -CONFIG_CONSOLE_POLL=y -# CONFIG_SERIAL_JSM is not set -# CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set -CONFIG_UNIX98_PTYS=y -# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set -CONFIG_LEGACY_PTYS=y -CONFIG_LEGACY_PTY_COUNT=256 -# CONFIG_IPMI_HANDLER is not set -CONFIG_HW_RANDOM=m -# CONFIG_HW_RANDOM_TIMERIOMEM is not set -# CONFIG_R3964 is not set -# CONFIG_APPLICOM is not set -# CONFIG_RAW_DRIVER is not set -# CONFIG_TCG_TPM is not set -CONFIG_DEVPORT=y -# CONFIG_I2C is not set  CONFIG_SPI=y -# CONFIG_SPI_DEBUG is not set -CONFIG_SPI_MASTER=y - -# -# SPI Master Controller Drivers -# -CONFIG_SPI_BITBANG=m  CONFIG_SPI_XILINX=m  CONFIG_SPI_XILINX_PLTFM=m -# CONFIG_SPI_DESIGNWARE is not set - -# -# SPI Protocol Masters -# -# CONFIG_SPI_SPIDEV is not set -# CONFIG_SPI_TLE62X0 is not set - -# -# PPS support -# -# CONFIG_PPS is not set -CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y -# CONFIG_GPIOLIB is not set -# CONFIG_W1 is not set -# CONFIG_POWER_SUPPLY is not set -CONFIG_HWMON=y -# CONFIG_HWMON_VID is not set -# CONFIG_HWMON_DEBUG_CHIP is not set - -# -# Native drivers -# -# CONFIG_SENSORS_ADCXX is not set -# CONFIG_SENSORS_I5K_AMB is not set -# CONFIG_SENSORS_F71805F is not set -# CONFIG_SENSORS_F71882FG is not set -# CONFIG_SENSORS_IT87 is not set -# CONFIG_SENSORS_LM70 is not set -# CONFIG_SENSORS_MAX1111 is not set -# CONFIG_SENSORS_PC87360 is not set -# CONFIG_SENSORS_PC87427 is not set -# CONFIG_SENSORS_SIS5595 is not set -# CONFIG_SENSORS_SMSC47M1 is not set -# CONFIG_SENSORS_SMSC47B397 is not set -# CONFIG_SENSORS_VIA686A is not set -# CONFIG_SENSORS_VT1211 is not set -# CONFIG_SENSORS_VT8231 is not set -# CONFIG_SENSORS_W83627HF is not set -# CONFIG_SENSORS_W83627EHF is not set -# CONFIG_SENSORS_LIS3_SPI is not set -# CONFIG_THERMAL is not set -# CONFIG_WATCHDOG is not set -CONFIG_SSB_POSSIBLE=y - -# -# Sonics Silicon Backplane -# -# CONFIG_SSB is not set - -# -# Multifunction device drivers -# -# CONFIG_MFD_CORE is not set -# CONFIG_MFD_SM501 is not set -# CONFIG_HTC_PASIC3 is not set -# CONFIG_MFD_TMIO is not set -# CONFIG_MFD_MC13783 is not set -# CONFIG_AB4500_CORE is not set -# CONFIG_REGULATOR is not set -# CONFIG_MEDIA_SUPPORT is not set - -# -# Graphics support -# -CONFIG_VGA_ARB=y -CONFIG_VGA_ARB_MAX_GPUS=16 -# CONFIG_VGASTATE is not set -# CONFIG_VIDEO_OUTPUT_CONTROL is not set -# CONFIG_FB is not set -# CONFIG_BACKLIGHT_LCD_SUPPORT is not set - -# -# Display device support -# -# CONFIG_DISPLAY_SUPPORT is not set - -# -# Console display driver support -# -CONFIG_DUMMY_CONSOLE=y -# CONFIG_SOUND is not set -CONFIG_HID_SUPPORT=y -CONFIG_HID=y -# CONFIG_HIDRAW is not set -# CONFIG_HID_PID is not set - -# -# Special HID drivers -# -CONFIG_USB_SUPPORT=y -CONFIG_USB_ARCH_HAS_HCD=y -CONFIG_USB_ARCH_HAS_OHCI=y -CONFIG_USB_ARCH_HAS_EHCI=y -# CONFIG_USB is not set - -# -# Enable Host or Gadget support to see Inventra options -# - -# -# NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may -# -# CONFIG_USB_GADGET is not set - -# -# OTG and related infrastructure -# -# CONFIG_UWB is not set -# CONFIG_MMC is not set -# CONFIG_MEMSTICK is not set -# CONFIG_NEW_LEDS is not set -# CONFIG_ACCESSIBILITY is not set -# CONFIG_INFINIBAND is not set -CONFIG_RTC_LIB=y -CONFIG_RTC_CLASS=y -CONFIG_RTC_HCTOSYS=y -CONFIG_RTC_HCTOSYS_DEVICE="rtc0" -# CONFIG_RTC_DEBUG is not set - -# -# RTC interfaces -# -CONFIG_RTC_INTF_SYSFS=y -CONFIG_RTC_INTF_PROC=y -CONFIG_RTC_INTF_DEV=y -# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set -# CONFIG_RTC_DRV_TEST is not set - -# -# SPI RTC drivers -# -# CONFIG_RTC_DRV_M41T94 is not set -# CONFIG_RTC_DRV_DS1305 is not set -# CONFIG_RTC_DRV_DS1390 is not set -# CONFIG_RTC_DRV_MAX6902 is not set -# CONFIG_RTC_DRV_R9701 is not set -# CONFIG_RTC_DRV_RS5C348 is not set -# CONFIG_RTC_DRV_DS3234 is not set -# CONFIG_RTC_DRV_PCF2123 is not set - -# -# Platform RTC drivers -# -# 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=y -# CONFIG_RTC_DRV_MSM6242 is not set -# CONFIG_RTC_DRV_BQ4802 is not set -# CONFIG_RTC_DRV_RP5C01 is not set -# CONFIG_RTC_DRV_V3020 is not set - -# -# on-CPU RTC drivers -# -# CONFIG_DMADEVICES is not set -# CONFIG_AUXDISPLAY is not set -# CONFIG_UIO is not set - -# -# TI VLYNQ -# -# CONFIG_STAGING is not set - -# -# Misc Linux/SPARC drivers -#  CONFIG_SUN_OPENPROMIO=m -# CONFIG_TADPOLE_TS102_UCTRL is not set -# CONFIG_SUN_JSFLASH is not set - -# -# File systems -#  CONFIG_EXT2_FS=y  CONFIG_EXT2_FS_XATTR=y  CONFIG_EXT2_FS_POSIX_ACL=y  CONFIG_EXT2_FS_SECURITY=y -# CONFIG_EXT2_FS_XIP is not set -# CONFIG_EXT3_FS is not set -# CONFIG_EXT4_FS is not set -CONFIG_FS_MBCACHE=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_BTRFS_FS is not set -# CONFIG_NILFS2_FS is not set -CONFIG_FILE_LOCKING=y -CONFIG_FSNOTIFY=y -CONFIG_DNOTIFY=y -CONFIG_INOTIFY=y -CONFIG_INOTIFY_USER=y -# CONFIG_QUOTA is not set  CONFIG_AUTOFS_FS=m  CONFIG_AUTOFS4_FS=m -# CONFIG_FUSE_FS is not set - -# -# Caches -# -# CONFIG_FSCACHE is not set - -# -# CD-ROM/DVD Filesystems -#  CONFIG_ISO9660_FS=m -# CONFIG_JOLIET is not set -# CONFIG_ZISOFS is not set -# CONFIG_UDF_FS is not set - -# -# DOS/FAT/NT Filesystems -# -# CONFIG_MSDOS_FS is not set -# CONFIG_VFAT_FS is not set -# CONFIG_NTFS_FS is not set - -# -# Pseudo filesystems -# -CONFIG_PROC_FS=y  CONFIG_PROC_KCORE=y -CONFIG_PROC_SYSCTL=y -CONFIG_PROC_PAGE_MONITOR=y -CONFIG_SYSFS=y -# CONFIG_TMPFS is not set -# CONFIG_HUGETLB_PAGE is not set -# CONFIG_CONFIGFS_FS is not set -CONFIG_MISC_FILESYSTEMS=y -# CONFIG_ADFS_FS is not set -# CONFIG_AFFS_FS is not set -# CONFIG_HFS_FS is not set -# CONFIG_HFSPLUS_FS is not set -# CONFIG_BEFS_FS is not set -# CONFIG_BFS_FS is not set -# CONFIG_EFS_FS is not set -# CONFIG_CRAMFS is not set -# CONFIG_SQUASHFS is not set -# CONFIG_VXFS_FS is not set -# CONFIG_MINIX_FS is not set -# CONFIG_OMFS_FS is not set -# CONFIG_HPFS_FS is not set -# CONFIG_QNX4FS_FS is not set  CONFIG_ROMFS_FS=m -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_SYSV_FS is not set -# CONFIG_UFS_FS is not set -CONFIG_NETWORK_FILESYSTEMS=y  CONFIG_NFS_FS=y -# CONFIG_NFS_V3 is not set -# CONFIG_NFS_V4 is not set  CONFIG_ROOT_NFS=y -# CONFIG_NFSD is not set -CONFIG_LOCKD=y -CONFIG_NFS_COMMON=y -CONFIG_SUNRPC=y -CONFIG_SUNRPC_GSS=m  CONFIG_RPCSEC_GSS_KRB5=m -# CONFIG_RPCSEC_GSS_SPKM3 is not set -# CONFIG_SMB_FS is not set -# CONFIG_CIFS is not set -# CONFIG_NCP_FS is not set -# CONFIG_CODA_FS is not set -# CONFIG_AFS_FS is not set - -# -# Partition Types -# -# CONFIG_PARTITION_ADVANCED is not set -CONFIG_MSDOS_PARTITION=y -CONFIG_SUN_PARTITION=y  CONFIG_NLS=y -CONFIG_NLS_DEFAULT="iso8859-1" -# CONFIG_NLS_CODEPAGE_437 is not set -# CONFIG_NLS_CODEPAGE_737 is not set -# CONFIG_NLS_CODEPAGE_775 is not set -# CONFIG_NLS_CODEPAGE_850 is not set -# CONFIG_NLS_CODEPAGE_852 is not set -# CONFIG_NLS_CODEPAGE_855 is not set -# CONFIG_NLS_CODEPAGE_857 is not set -# CONFIG_NLS_CODEPAGE_860 is not set -# CONFIG_NLS_CODEPAGE_861 is not set -# CONFIG_NLS_CODEPAGE_862 is not set -# CONFIG_NLS_CODEPAGE_863 is not set -# CONFIG_NLS_CODEPAGE_864 is not set -# CONFIG_NLS_CODEPAGE_865 is not set -# CONFIG_NLS_CODEPAGE_866 is not set -# CONFIG_NLS_CODEPAGE_869 is not set -# CONFIG_NLS_CODEPAGE_936 is not set -# CONFIG_NLS_CODEPAGE_950 is not set -# CONFIG_NLS_CODEPAGE_932 is not set -# CONFIG_NLS_CODEPAGE_949 is not set -# CONFIG_NLS_CODEPAGE_874 is not set -# CONFIG_NLS_ISO8859_8 is not set -# CONFIG_NLS_CODEPAGE_1250 is not set -# CONFIG_NLS_CODEPAGE_1251 is not set -# CONFIG_NLS_ASCII is not set -# CONFIG_NLS_ISO8859_1 is not set -# CONFIG_NLS_ISO8859_2 is not set -# CONFIG_NLS_ISO8859_3 is not set -# CONFIG_NLS_ISO8859_4 is not set -# CONFIG_NLS_ISO8859_5 is not set -# CONFIG_NLS_ISO8859_6 is not set -# CONFIG_NLS_ISO8859_7 is not set -# CONFIG_NLS_ISO8859_9 is not set -# CONFIG_NLS_ISO8859_13 is not set -# CONFIG_NLS_ISO8859_14 is not set -# CONFIG_NLS_ISO8859_15 is not set -# CONFIG_NLS_KOI8_R is not set -# CONFIG_NLS_KOI8_U is not set -# CONFIG_NLS_UTF8 is not set -# CONFIG_DLM is not set - -# -# Kernel hacking -# -CONFIG_TRACE_IRQFLAGS_SUPPORT=y -# CONFIG_PRINTK_TIME is not set  # CONFIG_ENABLE_WARN_DEPRECATED is not set -CONFIG_ENABLE_MUST_CHECK=y -CONFIG_FRAME_WARN=1024 -CONFIG_MAGIC_SYSRQ=y -# CONFIG_STRIP_ASM_SYMS is not set -# CONFIG_UNUSED_SYMBOLS is not set -# CONFIG_DEBUG_FS is not set -# CONFIG_HEADERS_CHECK is not set  CONFIG_DEBUG_KERNEL=y -CONFIG_DETECT_SOFTLOCKUP=y -# CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set -CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0  CONFIG_DETECT_HUNG_TASK=y -# CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set -CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0  # CONFIG_SCHED_DEBUG is not set -# CONFIG_SCHEDSTATS is not set -# CONFIG_TIMER_STATS is not set -# CONFIG_DEBUG_OBJECTS is not set -# CONFIG_DEBUG_SLAB is not set -# CONFIG_DEBUG_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_SPINLOCK_SLEEP is not set -# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set -# CONFIG_DEBUG_KOBJECT is not set -# CONFIG_DEBUG_HIGHMEM is not set -CONFIG_DEBUG_BUGVERBOSE=y -# CONFIG_DEBUG_INFO is not set -# CONFIG_DEBUG_VM is not set -# CONFIG_DEBUG_WRITECOUNT is not set -CONFIG_DEBUG_MEMORY_INIT=y -# CONFIG_DEBUG_LIST is not set -# CONFIG_DEBUG_SG is not set -# CONFIG_DEBUG_NOTIFIERS is not set -# CONFIG_DEBUG_CREDENTIALS is not set -# CONFIG_BOOT_PRINTK_DELAY is not set -# CONFIG_RCU_TORTURE_TEST is not set  # CONFIG_RCU_CPU_STALL_DETECTOR is not set -# CONFIG_BACKTRACE_SELF_TEST is not set -# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set -# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set -# CONFIG_FAULT_INJECTION is not set -# CONFIG_SYSCTL_SYSCALL_CHECK is not set -# CONFIG_PAGE_POISONING is not set -# CONFIG_DMA_API_DEBUG is not set -# CONFIG_SAMPLES is not set -CONFIG_HAVE_ARCH_KGDB=y  CONFIG_KGDB=y -CONFIG_KGDB_SERIAL_CONSOLE=y  CONFIG_KGDB_TESTS=y -# CONFIG_KGDB_TESTS_ON_BOOT is not set -# CONFIG_DEBUG_STACK_USAGE is not set -# CONFIG_STACK_DEBUG is not set -# CONFIG_DEBUG_STRICT_USER_COPY_CHECKS is not set - -# -# Security options -# -# CONFIG_KEYS is not set -# CONFIG_SECURITY is not set -# CONFIG_SECURITYFS is not set -# CONFIG_DEFAULT_SECURITY_SELINUX is not set -# CONFIG_DEFAULT_SECURITY_SMACK is not set -# CONFIG_DEFAULT_SECURITY_TOMOYO is not set -CONFIG_DEFAULT_SECURITY_DAC=y -CONFIG_DEFAULT_SECURITY="" -CONFIG_CRYPTO=y - -# -# Crypto core or helper -# -CONFIG_CRYPTO_ALGAPI=y -CONFIG_CRYPTO_ALGAPI2=y -CONFIG_CRYPTO_AEAD=y -CONFIG_CRYPTO_AEAD2=y -CONFIG_CRYPTO_BLKCIPHER=y -CONFIG_CRYPTO_BLKCIPHER2=y -CONFIG_CRYPTO_HASH=y -CONFIG_CRYPTO_HASH2=y -CONFIG_CRYPTO_RNG2=y -CONFIG_CRYPTO_PCOMP=y -CONFIG_CRYPTO_MANAGER=y -CONFIG_CRYPTO_MANAGER2=y -# CONFIG_CRYPTO_GF128MUL is not set  CONFIG_CRYPTO_NULL=m -CONFIG_CRYPTO_WORKQUEUE=y -# CONFIG_CRYPTO_CRYPTD is not set -CONFIG_CRYPTO_AUTHENC=y -# CONFIG_CRYPTO_TEST is not set - -# -# Authenticated Encryption with Associated Data -# -# CONFIG_CRYPTO_CCM is not set -# CONFIG_CRYPTO_GCM is not set -# CONFIG_CRYPTO_SEQIV is not set - -# -# Block modes -# -CONFIG_CRYPTO_CBC=y -# CONFIG_CRYPTO_CTR is not set -# CONFIG_CRYPTO_CTS is not set  CONFIG_CRYPTO_ECB=m -# CONFIG_CRYPTO_LRW is not set  CONFIG_CRYPTO_PCBC=m -# CONFIG_CRYPTO_XTS is not set - -# -# Hash modes -# -CONFIG_CRYPTO_HMAC=y -# CONFIG_CRYPTO_XCBC is not set -# CONFIG_CRYPTO_VMAC is not set - -# -# Digest -# -CONFIG_CRYPTO_CRC32C=m -# CONFIG_CRYPTO_GHASH is not set  CONFIG_CRYPTO_MD4=y -CONFIG_CRYPTO_MD5=y  CONFIG_CRYPTO_MICHAEL_MIC=m -# 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=y  CONFIG_CRYPTO_SHA256=m  CONFIG_CRYPTO_SHA512=m -# CONFIG_CRYPTO_TGR192 is not set -# CONFIG_CRYPTO_WP512 is not set - -# -# Ciphers -#  CONFIG_CRYPTO_AES=m -# CONFIG_CRYPTO_ANUBIS is not set  CONFIG_CRYPTO_ARC4=m  CONFIG_CRYPTO_BLOWFISH=m -# CONFIG_CRYPTO_CAMELLIA is not set  CONFIG_CRYPTO_CAST5=m  CONFIG_CRYPTO_CAST6=m -CONFIG_CRYPTO_DES=y -# CONFIG_CRYPTO_FCRYPT is not set -# CONFIG_CRYPTO_KHAZAD is not set -# CONFIG_CRYPTO_SALSA20 is not set -# CONFIG_CRYPTO_SEED is not set  CONFIG_CRYPTO_SERPENT=m -# CONFIG_CRYPTO_TEA is not set  CONFIG_CRYPTO_TWOFISH=m -CONFIG_CRYPTO_TWOFISH_COMMON=m - -# -# Compression -# -CONFIG_CRYPTO_DEFLATE=y -# CONFIG_CRYPTO_ZLIB is not set -# CONFIG_CRYPTO_LZO is not set - -# -# Random Number Generation -#  # CONFIG_CRYPTO_ANSI_CPRNG is not set  # CONFIG_CRYPTO_HW is not set -# CONFIG_BINARY_PRINTF is not set - -# -# Library routines -# -CONFIG_BITREVERSE=y -CONFIG_GENERIC_FIND_LAST_BIT=y -# CONFIG_CRC_CCITT is not set -# CONFIG_CRC16 is not set -# CONFIG_CRC_T10DIF is not set -# CONFIG_CRC_ITU_T is not set -CONFIG_CRC32=y -# CONFIG_CRC7 is not set  CONFIG_LIBCRC32C=m -CONFIG_ZLIB_INFLATE=y -CONFIG_ZLIB_DEFLATE=y -CONFIG_LZO_DECOMPRESS=y -CONFIG_DECOMPRESS_GZIP=y -CONFIG_DECOMPRESS_BZIP2=y -CONFIG_DECOMPRESS_LZMA=y -CONFIG_DECOMPRESS_LZO=y -CONFIG_HAS_IOMEM=y -CONFIG_HAS_IOPORT=y -CONFIG_HAS_DMA=y -CONFIG_NLATTR=y diff --git a/arch/sparc/configs/sparc64_defconfig b/arch/sparc/configs/sparc64_defconfig index 1dc07a0..3c1e858 100644 --- a/arch/sparc/configs/sparc64_defconfig +++ b/arch/sparc/configs/sparc64_defconfig @@ -1,305 +1,41 @@ -# -# Automatically generated make config: don't edit -# Linux kernel version: 2.6.34 -# Wed May 26 21:14:01 2010 -#  CONFIG_64BIT=y -CONFIG_SPARC=y -# CONFIG_SPARC32 is not set -CONFIG_SPARC64=y -CONFIG_ARCH_DEFCONFIG="arch/sparc/configs/sparc64_defconfig" -CONFIG_BITS=64 -CONFIG_GENERIC_TIME=y -CONFIG_GENERIC_CMOS_UPDATE=y -CONFIG_GENERIC_CLOCKEVENTS=y -CONFIG_IOMMU_HELPER=y -CONFIG_QUICKLIST=y -CONFIG_STACKTRACE_SUPPORT=y -CONFIG_LOCKDEP_SUPPORT=y -CONFIG_HAVE_LATENCYTOP_SUPPORT=y -CONFIG_AUDIT_ARCH=y -CONFIG_HAVE_SETUP_PER_CPU_AREA=y -CONFIG_NEED_PER_CPU_EMBED_FIRST_CHUNK=y -CONFIG_NEED_PER_CPU_PAGE_FIRST_CHUNK=y -CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y -CONFIG_MMU=y -CONFIG_NEED_DMA_MAP_STATE=y -CONFIG_ARCH_NO_VIRT_TO_BUS=y -CONFIG_OF=y -CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y -CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" -CONFIG_CONSTRUCTORS=y - -# -# General setup -#  CONFIG_EXPERIMENTAL=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=y -CONFIG_POSIX_MQUEUE_SYSCTL=y -# CONFIG_BSD_PROCESS_ACCT is not set -# CONFIG_TASKSTATS is not set -# CONFIG_AUDIT is not set - -# -# RCU Subsystem -# -CONFIG_TREE_RCU=y -# CONFIG_TREE_PREEMPT_RCU is not set -# CONFIG_TINY_RCU is not set -# CONFIG_RCU_TRACE is not set -CONFIG_RCU_FANOUT=64 -# CONFIG_RCU_FANOUT_EXACT is not set -# CONFIG_RCU_FAST_NO_HZ is not set -# CONFIG_TREE_RCU_TRACE is not set -# CONFIG_IKCONFIG is not set  CONFIG_LOG_BUF_SHIFT=18 -# CONFIG_CGROUPS is not set -# CONFIG_SYSFS_DEPRECATED_V2 is not set -CONFIG_RELAY=y -CONFIG_NAMESPACES=y -# CONFIG_UTS_NS is not set -# CONFIG_IPC_NS is not set -# CONFIG_USER_NS is not set -# CONFIG_PID_NS is not set -# CONFIG_NET_NS 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_LZO=y -CONFIG_CC_OPTIMIZE_FOR_SIZE=y -CONFIG_SYSCTL=y -CONFIG_ANON_INODES=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_EPOLL=y -CONFIG_SIGNALFD=y -CONFIG_TIMERFD=y -CONFIG_EVENTFD=y -CONFIG_SHMEM=y -CONFIG_AIO=y -CONFIG_HAVE_PERF_EVENTS=y -CONFIG_PERF_USE_VMALLOC=y - -# -# Kernel Performance Events And Counters -# -CONFIG_PERF_EVENTS=y  CONFIG_PERF_COUNTERS=y -# CONFIG_DEBUG_PERF_USE_VMALLOC is not set -CONFIG_VM_EVENT_COUNTERS=y -CONFIG_PCI_QUIRKS=y  # CONFIG_COMPAT_BRK is not set  CONFIG_SLAB=y -# CONFIG_SLUB is not set -# CONFIG_SLOB is not set  CONFIG_PROFILING=y -CONFIG_TRACEPOINTS=y  CONFIG_OPROFILE=m -CONFIG_HAVE_OPROFILE=y  CONFIG_KPROBES=y -CONFIG_HAVE_SYSCALL_WRAPPERS=y -CONFIG_KRETPROBES=y -CONFIG_HAVE_KPROBES=y -CONFIG_HAVE_KRETPROBES=y -CONFIG_HAVE_ARCH_TRACEHOOK=y -CONFIG_HAVE_DMA_ATTRS=y -CONFIG_USE_GENERIC_SMP_HELPERS=y -CONFIG_HAVE_DMA_API_DEBUG=y - -# -# GCOV-based kernel profiling -# -# CONFIG_GCOV_KERNEL is not set -# CONFIG_SLOW_WORK is not set -# CONFIG_HAVE_GENERIC_DMA_COHERENT is not set -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=y  CONFIG_MODVERSIONS=y  CONFIG_MODULE_SRCVERSION_ALL=y -CONFIG_STOP_MACHINE=y -CONFIG_BLOCK=y -CONFIG_BLK_DEV_BSG=y -# CONFIG_BLK_DEV_INTEGRITY is not set -CONFIG_BLOCK_COMPAT=y - -# -# IO Schedulers -# -CONFIG_IOSCHED_NOOP=y -CONFIG_IOSCHED_DEADLINE=y -CONFIG_IOSCHED_CFQ=y -# CONFIG_DEFAULT_DEADLINE is not set -CONFIG_DEFAULT_CFQ=y -# CONFIG_DEFAULT_NOOP is not set -CONFIG_DEFAULT_IOSCHED="cfq" -# CONFIG_INLINE_SPIN_TRYLOCK is not set -# CONFIG_INLINE_SPIN_TRYLOCK_BH is not set -# CONFIG_INLINE_SPIN_LOCK is not set -# CONFIG_INLINE_SPIN_LOCK_BH is not set -# CONFIG_INLINE_SPIN_LOCK_IRQ is not set -# CONFIG_INLINE_SPIN_LOCK_IRQSAVE is not set -CONFIG_INLINE_SPIN_UNLOCK=y -# CONFIG_INLINE_SPIN_UNLOCK_BH is not set -CONFIG_INLINE_SPIN_UNLOCK_IRQ=y -# CONFIG_INLINE_SPIN_UNLOCK_IRQRESTORE is not set -# CONFIG_INLINE_READ_TRYLOCK is not set -# CONFIG_INLINE_READ_LOCK is not set -# CONFIG_INLINE_READ_LOCK_BH is not set -# CONFIG_INLINE_READ_LOCK_IRQ is not set -# CONFIG_INLINE_READ_LOCK_IRQSAVE is not set -CONFIG_INLINE_READ_UNLOCK=y -# CONFIG_INLINE_READ_UNLOCK_BH is not set -CONFIG_INLINE_READ_UNLOCK_IRQ=y -# CONFIG_INLINE_READ_UNLOCK_IRQRESTORE is not set -# CONFIG_INLINE_WRITE_TRYLOCK is not set -# CONFIG_INLINE_WRITE_LOCK is not set -# CONFIG_INLINE_WRITE_LOCK_BH is not set -# CONFIG_INLINE_WRITE_LOCK_IRQ is not set -# CONFIG_INLINE_WRITE_LOCK_IRQSAVE is not set -CONFIG_INLINE_WRITE_UNLOCK=y -# CONFIG_INLINE_WRITE_UNLOCK_BH is not set -CONFIG_INLINE_WRITE_UNLOCK_IRQ=y -# CONFIG_INLINE_WRITE_UNLOCK_IRQRESTORE is not set -CONFIG_MUTEX_SPIN_ON_OWNER=y -# CONFIG_FREEZER is not set - -# -# Processor type and features -#  CONFIG_SMP=y -CONFIG_NR_CPUS=64  CONFIG_HZ_100=y -# CONFIG_HZ_250 is not set -# CONFIG_HZ_300 is not set -# CONFIG_HZ_1000 is not set -CONFIG_HZ=100 -CONFIG_SCHED_HRTICK=y -CONFIG_RWSEM_XCHGADD_ALGORITHM=y -CONFIG_GENERIC_FIND_NEXT_BIT=y -CONFIG_GENERIC_HWEIGHT=y -CONFIG_GENERIC_CALIBRATE_DELAY=y -CONFIG_ARCH_MAY_HAVE_PC_FDC=y -CONFIG_SPARC64_SMP=y -CONFIG_EARLYFB=y -CONFIG_SPARC64_PAGE_SIZE_8KB=y -# CONFIG_SPARC64_PAGE_SIZE_64KB is not set -CONFIG_SECCOMP=y  CONFIG_HOTPLUG_CPU=y -CONFIG_GENERIC_HARDIRQS=y -CONFIG_TICK_ONESHOT=y  CONFIG_NO_HZ=y  CONFIG_HIGH_RES_TIMERS=y -CONFIG_GENERIC_CLOCKEVENTS_BUILD=y -# CONFIG_CPU_FREQ is not set -CONFIG_US3_MC=y -CONFIG_HUGETLB_PAGE_SIZE_4MB=y -# CONFIG_HUGETLB_PAGE_SIZE_512K is not set -# CONFIG_HUGETLB_PAGE_SIZE_64K is not set  CONFIG_NUMA=y -CONFIG_NODES_SHIFT=4 -CONFIG_NODES_SPAN_OTHER_NODES=y -CONFIG_ARCH_POPULATES_NODE_MAP=y -CONFIG_ARCH_SELECT_MEMORY_MODEL=y -CONFIG_ARCH_SPARSEMEM_ENABLE=y -CONFIG_ARCH_SPARSEMEM_DEFAULT=y -CONFIG_SELECT_MEMORY_MODEL=y -# CONFIG_FLATMEM_MANUAL is not set -# CONFIG_DISCONTIGMEM_MANUAL is not set -CONFIG_SPARSEMEM_MANUAL=y -CONFIG_SPARSEMEM=y -CONFIG_NEED_MULTIPLE_NODES=y -CONFIG_HAVE_MEMORY_PRESENT=y -CONFIG_SPARSEMEM_EXTREME=y -CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y -CONFIG_SPARSEMEM_VMEMMAP=y -CONFIG_PAGEFLAGS_EXTENDED=y -CONFIG_SPLIT_PTLOCK_CPUS=4 -# CONFIG_COMPACTION is not set -CONFIG_MIGRATION=y -CONFIG_PHYS_ADDR_T_64BIT=y -CONFIG_ZONE_DMA_FLAG=0 -CONFIG_NR_QUICK=1 -# CONFIG_KSM is not set  CONFIG_DEFAULT_MMAP_MIN_ADDR=8192 -CONFIG_SCHED_SMT=y -CONFIG_SCHED_MC=y -# CONFIG_PREEMPT_NONE is not set  CONFIG_PREEMPT_VOLUNTARY=y -# CONFIG_PREEMPT is not set -# CONFIG_CMDLINE_BOOL is not set - -# -# Bus options (PCI etc.) -# -CONFIG_SBUS=y -CONFIG_SBUSCHAR=y  CONFIG_SUN_LDOMS=y  CONFIG_PCI=y -CONFIG_PCI_DOMAINS=y -CONFIG_PCI_SYSCALL=y -CONFIG_ARCH_SUPPORTS_MSI=y  CONFIG_PCI_MSI=y -# CONFIG_PCI_DEBUG is not set -# CONFIG_PCI_STUB is not set -# CONFIG_PCI_IOV is not set -# CONFIG_PCCARD is not set  CONFIG_SUN_OPENPROMFS=m -CONFIG_SPARC64_PCI=y - -# -# Executable file formats -# -CONFIG_BINFMT_ELF=y -CONFIG_COMPAT_BINFMT_ELF=y -# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set -# CONFIG_HAVE_AOUT is not set  CONFIG_BINFMT_MISC=m -CONFIG_COMPAT=y -CONFIG_SYSVIPC_COMPAT=y -CONFIG_NET=y - -# -# Networking options -#  CONFIG_PACKET=y  CONFIG_UNIX=y -CONFIG_XFRM=y  CONFIG_XFRM_USER=m -# CONFIG_XFRM_SUB_POLICY is not set -CONFIG_XFRM_MIGRATE=y -# CONFIG_XFRM_STATISTICS is not set -CONFIG_XFRM_IPCOMP=y  CONFIG_NET_KEY=m  CONFIG_NET_KEY_MIGRATE=y  CONFIG_INET=y  CONFIG_IP_MULTICAST=y -# CONFIG_IP_ADVANCED_ROUTER is not set -CONFIG_IP_FIB_HASH=y -# CONFIG_IP_PNP is not set  CONFIG_NET_IPIP=m  CONFIG_NET_IPGRE=m  CONFIG_NET_IPGRE_BROADCAST=y @@ -311,19 +47,6 @@ CONFIG_SYN_COOKIES=y  CONFIG_INET_AH=y  CONFIG_INET_ESP=y  CONFIG_INET_IPCOMP=y -CONFIG_INET_XFRM_TUNNEL=y -CONFIG_INET_TUNNEL=y -CONFIG_INET_XFRM_MODE_TRANSPORT=y -CONFIG_INET_XFRM_MODE_TUNNEL=y -CONFIG_INET_XFRM_MODE_BEET=y -CONFIG_INET_LRO=y -CONFIG_INET_DIAG=y -CONFIG_INET_TCP_DIAG=y -# CONFIG_TCP_CONG_ADVANCED is not set -CONFIG_TCP_CONG_CUBIC=y -CONFIG_DEFAULT_TCP_CONG="cubic" -# CONFIG_TCP_MD5SIG is not set -CONFIG_IPV6=m  CONFIG_IPV6_PRIVACY=y  CONFIG_IPV6_ROUTER_PREF=y  CONFIG_IPV6_ROUTE_INFO=y @@ -331,276 +54,33 @@ CONFIG_IPV6_OPTIMISTIC_DAD=y  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_SIT_6RD is not set -CONFIG_IPV6_NDISC_NODETYPE=y  CONFIG_IPV6_TUNNEL=m -# CONFIG_IPV6_MULTIPLE_TABLES is not set -# CONFIG_IPV6_MROUTE is not set -# CONFIG_NETWORK_SECMARK is not set -# CONFIG_NETFILTER is not set -# CONFIG_IP_DCCP is not set -# CONFIG_IP_SCTP is not set -# CONFIG_RDS is not set -# CONFIG_TIPC is not set -# CONFIG_ATM is not set -# CONFIG_L2TP is not set -# CONFIG_BRIDGE is not set -# CONFIG_NET_DSA is not set  CONFIG_VLAN_8021Q=m -# CONFIG_VLAN_8021Q_GVRP is not set -# CONFIG_DECNET is not set -# CONFIG_LLC2 is not set -# CONFIG_IPX is not set -# CONFIG_ATALK is not set -# CONFIG_X25 is not set -# CONFIG_LAPB is not set -# CONFIG_ECONET is not set -# CONFIG_WAN_ROUTER is not set -# CONFIG_PHONET is not set -# CONFIG_IEEE802154 is not set -# CONFIG_NET_SCHED is not set -# CONFIG_DCB is not set -CONFIG_RPS=y - -# -# Network testing -#  CONFIG_NET_PKTGEN=m  CONFIG_NET_TCPPROBE=m -# CONFIG_NET_DROP_MONITOR is not set -# CONFIG_HAMRADIO is not set -# CONFIG_CAN is not set -# CONFIG_IRDA is not set -# CONFIG_BT is not set -# CONFIG_AF_RXRPC is not set -CONFIG_WIRELESS=y -# CONFIG_CFG80211 is not set -# CONFIG_LIB80211 is not set - -# -# CFG80211 needs to be enabled for MAC80211 -# - -# -# Some wireless drivers require a rate control algorithm -# -# CONFIG_WIMAX is not set -# CONFIG_RFKILL 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 is not set -CONFIG_STANDALONE=y  # CONFIG_PREVENT_FIRMWARE_BUILD is not set -CONFIG_FW_LOADER=y -CONFIG_FIRMWARE_IN_KERNEL=y -CONFIG_EXTRA_FIRMWARE="" -# CONFIG_DEBUG_DRIVER is not set -# CONFIG_DEBUG_DEVRES is not set -# CONFIG_SYS_HYPERVISOR is not set  CONFIG_CONNECTOR=m -# CONFIG_MTD is not set -CONFIG_OF_DEVICE=y -CONFIG_OF_MDIO=m -# CONFIG_PARPORT is not set -CONFIG_BLK_DEV=y -# CONFIG_BLK_DEV_FD is not set -# CONFIG_BLK_CPQ_CISS_DA is not set -# CONFIG_BLK_DEV_DAC960 is not set -# CONFIG_BLK_DEV_UMEM is not set -# CONFIG_BLK_DEV_COW_COMMON is not set  CONFIG_BLK_DEV_LOOP=m  CONFIG_BLK_DEV_CRYPTOLOOP=m -# CONFIG_BLK_DEV_DRBD is not set  CONFIG_BLK_DEV_NBD=m -# CONFIG_BLK_DEV_SX8 is not set -# CONFIG_BLK_DEV_UB is not set -# CONFIG_BLK_DEV_RAM is not set  CONFIG_CDROM_PKTCDVD=m -CONFIG_CDROM_PKTCDVD_BUFFERS=8  CONFIG_CDROM_PKTCDVD_WCACHE=y  CONFIG_ATA_OVER_ETH=m  CONFIG_SUNVDC=m -# CONFIG_BLK_DEV_HD is not set -CONFIG_MISC_DEVICES=y -# CONFIG_AD525X_DPOT is not set -# CONFIG_PHANTOM is not set -# CONFIG_SGI_IOC4 is not set -# CONFIG_TIFM_CORE is not set -# CONFIG_ICS932S401 is not set -# CONFIG_ENCLOSURE_SERVICES is not set -# CONFIG_HP_ILO is not set -# CONFIG_ISL29003 is not set -# CONFIG_SENSORS_TSL2550 is not set -# CONFIG_DS1682 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_CB710_CORE is not set -CONFIG_HAVE_IDE=y  CONFIG_IDE=y - -# -# Please see Documentation/ide/ide.txt for help/info on IDE drives -# -CONFIG_IDE_XFER_MODE=y -CONFIG_IDE_TIMINGS=y -CONFIG_IDE_ATAPI=y -# CONFIG_BLK_DEV_IDE_SATA is not set -CONFIG_IDE_GD=y -CONFIG_IDE_GD_ATA=y -# CONFIG_IDE_GD_ATAPI is not set  CONFIG_BLK_DEV_IDECD=y -CONFIG_BLK_DEV_IDECD_VERBOSE_ERRORS=y -# CONFIG_BLK_DEV_IDETAPE is not set -# CONFIG_IDE_TASK_IOCTL is not set -CONFIG_IDE_PROC_FS=y - -# -# IDE chipset support/bugfixes -# -# CONFIG_BLK_DEV_PLATFORM is not set -CONFIG_BLK_DEV_IDEDMA_SFF=y - -# -# PCI IDE chipsets support -# -CONFIG_BLK_DEV_IDEPCI=y -CONFIG_IDEPCI_PCIBUS_ORDER=y -# CONFIG_BLK_DEV_GENERIC is not set -# CONFIG_BLK_DEV_OPTI621 is not set -CONFIG_BLK_DEV_IDEDMA_PCI=y -# CONFIG_BLK_DEV_AEC62XX is not set  CONFIG_BLK_DEV_ALI15X3=y -# CONFIG_BLK_DEV_AMD74XX is not set -# CONFIG_BLK_DEV_CMD64X is not set -# CONFIG_BLK_DEV_TRIFLEX is not set -# CONFIG_BLK_DEV_CS5520 is not set -# CONFIG_BLK_DEV_CS5530 is not set -# CONFIG_BLK_DEV_HPT366 is not set -# CONFIG_BLK_DEV_JMICRON is not set -# CONFIG_BLK_DEV_SC1200 is not set -# CONFIG_BLK_DEV_PIIX is not set -# CONFIG_BLK_DEV_IT8172 is not set -# CONFIG_BLK_DEV_IT8213 is not set -# CONFIG_BLK_DEV_IT821X is not set -# CONFIG_BLK_DEV_NS87415 is not set -# CONFIG_BLK_DEV_PDC202XX_OLD is not set -# CONFIG_BLK_DEV_PDC202XX_NEW is not set -# CONFIG_BLK_DEV_SVWKS is not set -# CONFIG_BLK_DEV_SIIMAGE is not set -# CONFIG_BLK_DEV_SLC90E66 is not set -# CONFIG_BLK_DEV_TRM290 is not set -# CONFIG_BLK_DEV_VIA82CXXX is not set -# CONFIG_BLK_DEV_TC86C001 is not set -CONFIG_BLK_DEV_IDEDMA=y - -# -# SCSI device support -# -CONFIG_SCSI_MOD=y  CONFIG_RAID_ATTRS=m  CONFIG_SCSI=y -CONFIG_SCSI_DMA=y -# CONFIG_SCSI_TGT is not set -CONFIG_SCSI_NETLINK=y -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=m  CONFIG_BLK_DEV_SR_VENDOR=y  CONFIG_CHR_DEV_SG=m -# CONFIG_CHR_DEV_SCH is not set  CONFIG_SCSI_MULTI_LUN=y  CONFIG_SCSI_CONSTANTS=y -# CONFIG_SCSI_LOGGING is not set -# CONFIG_SCSI_SCAN_ASYNC is not set -CONFIG_SCSI_WAIT_SCAN=m - -# -# SCSI Transports -#  CONFIG_SCSI_SPI_ATTRS=y  CONFIG_SCSI_FC_ATTRS=y -# 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_TCP is not set -# CONFIG_SCSI_CXGB3_ISCSI is not set -# CONFIG_SCSI_BNX2_ISCSI is not set -# CONFIG_BE2ISCSI is not set -# CONFIG_BLK_DEV_3W_XXXX_RAID is not set -# CONFIG_SCSI_HPSA is not set -# CONFIG_SCSI_3W_9XXX is not set -# CONFIG_SCSI_3W_SAS is not set -# CONFIG_SCSI_ACARD is not set -# CONFIG_SCSI_AACRAID is not set -# CONFIG_SCSI_AIC7XXX is not set -# CONFIG_SCSI_AIC7XXX_OLD is not set -# CONFIG_SCSI_AIC79XX is not set -# CONFIG_SCSI_AIC94XX is not set -# CONFIG_SCSI_MVSAS is not set -# CONFIG_SCSI_ARCMSR is not set -# CONFIG_MEGARAID_NEWGEN is not set -# CONFIG_MEGARAID_LEGACY is not set -# CONFIG_MEGARAID_SAS is not set -# CONFIG_SCSI_MPT2SAS is not set -# CONFIG_SCSI_HPTIOP is not set -# CONFIG_LIBFC is not set -# CONFIG_LIBFCOE is not set -# CONFIG_FCOE is not set -# CONFIG_SCSI_DMX3191D is not set -# CONFIG_SCSI_FUTURE_DOMAIN is not set -# CONFIG_SCSI_IPS is not set -# CONFIG_SCSI_INITIO is not set -# CONFIG_SCSI_INIA100 is not set -# CONFIG_SCSI_STEX is not set -# CONFIG_SCSI_SYM53C8XX_2 is not set -# CONFIG_SCSI_QLOGIC_1280 is not set -# CONFIG_SCSI_QLOGICPTI is not set -# CONFIG_SCSI_QLA_FC is not set -# CONFIG_SCSI_QLA_ISCSI is not set -# CONFIG_SCSI_LPFC is not set -# CONFIG_SCSI_DC395x is not set -# CONFIG_SCSI_DC390T is not set -# CONFIG_SCSI_DEBUG is not set -# CONFIG_SCSI_SUNESP is not set -# CONFIG_SCSI_PMCRAID is not set -# CONFIG_SCSI_PM8001 is not set -# CONFIG_SCSI_SRP is not set -# CONFIG_SCSI_BFA_FC is not set -# CONFIG_SCSI_DH is not set -# CONFIG_SCSI_OSD_INITIATOR is not set -# CONFIG_ATA is not set  CONFIG_MD=y  CONFIG_BLK_DEV_MD=m  CONFIG_MD_LINEAR=m @@ -608,178 +88,26 @@ CONFIG_MD_RAID0=m  CONFIG_MD_RAID1=m  CONFIG_MD_RAID10=m  CONFIG_MD_RAID456=m -# CONFIG_MULTICORE_RAID456 is not set -CONFIG_MD_RAID6_PQ=m -# CONFIG_ASYNC_RAID6_TEST is not set  CONFIG_MD_MULTIPATH=m -# CONFIG_MD_FAULTY is not set  CONFIG_BLK_DEV_DM=m -# CONFIG_DM_DEBUG is not set  CONFIG_DM_CRYPT=m  CONFIG_DM_SNAPSHOT=m  CONFIG_DM_MIRROR=m -# CONFIG_DM_LOG_USERSPACE is not set  CONFIG_DM_ZERO=m -# CONFIG_DM_MULTIPATH is not set -# CONFIG_DM_DELAY is not set -# CONFIG_DM_UEVENT is not set -# CONFIG_FUSION is not set - -# -# IEEE 1394 (FireWire) support -# - -# -# You can enable one or both FireWire driver stacks. -# - -# -# The newer stack is recommended. -# -# CONFIG_FIREWIRE is not set -# CONFIG_IEEE1394 is not set -# CONFIG_I2O is not set  CONFIG_NETDEVICES=y -# CONFIG_DUMMY is not set -# CONFIG_BONDING is not set -# CONFIG_MACVLAN is not set -# CONFIG_EQUALIZER is not set -# CONFIG_TUN is not set -# CONFIG_VETH is not set -# CONFIG_ARCNET is not set -CONFIG_PHYLIB=m - -# -# MII PHY device drivers -# -# CONFIG_MARVELL_PHY is not set -# CONFIG_DAVICOM_PHY is not set -# CONFIG_QSEMI_PHY is not set -# CONFIG_LXT_PHY is not set -# CONFIG_CICADA_PHY is not set -# CONFIG_VITESSE_PHY is not set -# CONFIG_SMSC_PHY is not set -# CONFIG_BROADCOM_PHY is not set -# CONFIG_ICPLUS_PHY is not set -# CONFIG_REALTEK_PHY is not set -# CONFIG_NATIONAL_PHY is not set -# CONFIG_STE10XP is not set -# CONFIG_LSI_ET1011C_PHY is not set -# CONFIG_MICREL_PHY is not set -# CONFIG_MDIO_BITBANG is not set  CONFIG_NET_ETHERNET=y  CONFIG_MII=m  CONFIG_SUNLANCE=m  CONFIG_HAPPYMEAL=m -# CONFIG_SUNBMAC is not set -# CONFIG_SUNQE is not set  CONFIG_SUNGEM=m -# CONFIG_CASSINI is not set  CONFIG_SUNVNET=m -# CONFIG_NET_VENDOR_3COM is not set -# CONFIG_ETHOC is not set -# CONFIG_GRETH is not set -# CONFIG_DNET is not set -# CONFIG_NET_TULIP is not set -# CONFIG_HP100 is not set -# CONFIG_IBM_NEW_EMAC_ZMII is not set -# CONFIG_IBM_NEW_EMAC_RGMII is not set -# CONFIG_IBM_NEW_EMAC_TAH is not set -# CONFIG_IBM_NEW_EMAC_EMAC4 is not set -# CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set -# CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set -# CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set  CONFIG_NET_PCI=y -# CONFIG_PCNET32 is not set -# CONFIG_AMD8111_ETH is not set -# CONFIG_ADAPTEC_STARFIRE is not set -# CONFIG_KSZ884X_PCI is not set -# CONFIG_B44 is not set -# CONFIG_FORCEDETH is not set -# CONFIG_E100 is not set -# CONFIG_FEALNX is not set -# CONFIG_NATSEMI is not set -# CONFIG_NE2K_PCI is not set -# CONFIG_8139CP is not set -# CONFIG_8139TOO is not set -# CONFIG_R6040 is not set -# CONFIG_SIS900 is not set -# CONFIG_EPIC100 is not set -# CONFIG_SMSC9420 is not set -# CONFIG_SUNDANCE is not set -# CONFIG_TLAN is not set -# CONFIG_KS8842 is not set -# CONFIG_KS8851_MLL is not set -# CONFIG_VIA_RHINE is not set -# CONFIG_SC92031 is not set -# CONFIG_ATL2 is not set -CONFIG_NETDEV_1000=y -# CONFIG_ACENIC is not set -# CONFIG_DL2K is not set  CONFIG_E1000=m  CONFIG_E1000E=m -# CONFIG_IP1000 is not set -# CONFIG_IGB is not set -# CONFIG_IGBVF is not set -# CONFIG_MYRI_SBUS is not set -# CONFIG_NS83820 is not set -# CONFIG_HAMACHI is not set -# CONFIG_YELLOWFIN is not set -# CONFIG_R8169 is not set -# CONFIG_SIS190 is not set -# CONFIG_SKGE is not set -# CONFIG_SKY2 is not set -# CONFIG_VIA_VELOCITY is not set  CONFIG_TIGON3=m  CONFIG_BNX2=m -# CONFIG_CNIC is not set -# CONFIG_QLA3XXX is not set -# CONFIG_ATL1 is not set -# CONFIG_ATL1E is not set -# CONFIG_ATL1C is not set -# CONFIG_JME is not set -CONFIG_NETDEV_10000=y -# CONFIG_CHELSIO_T1 is not set -CONFIG_CHELSIO_T3_DEPENDS=y -# CONFIG_CHELSIO_T3 is not set -CONFIG_CHELSIO_T4_DEPENDS=y -# CONFIG_CHELSIO_T4 is not set -# CONFIG_ENIC is not set -# CONFIG_IXGBE is not set -# CONFIG_IXGBEVF is not set -# CONFIG_IXGB is not set -# CONFIG_S2IO is not set -# CONFIG_VXGE is not set -# CONFIG_MYRI10GE is not set -# CONFIG_NETXEN_NIC is not set  CONFIG_NIU=m -# CONFIG_MLX4_EN is not set -# CONFIG_MLX4_CORE is not set -# CONFIG_TEHUTI is not set -# CONFIG_BNX2X is not set -# CONFIG_QLCNIC is not set -# CONFIG_QLGE is not set -# CONFIG_SFC is not set -# CONFIG_BE2NET is not set -# CONFIG_TR is not set  # CONFIG_WLAN is not set - -# -# Enable WiMAX (Networking options) to see the WiMAX drivers -# - -# -# USB Network Adapters -# -# CONFIG_USB_CATC is not set -# CONFIG_USB_KAWETH is not set -# CONFIG_USB_PEGASUS is not set -# CONFIG_USB_RTL8150 is not set -# CONFIG_USB_USBNET is not set -# CONFIG_USB_IPHETH is not set -# CONFIG_WAN is not set -# CONFIG_FDDI is not set -# CONFIG_HIPPI is not set  CONFIG_PPP=m  CONFIG_PPP_MULTILINK=y  CONFIG_PPP_FILTER=y @@ -789,1157 +117,126 @@ CONFIG_PPP_DEFLATE=m  CONFIG_PPP_BSDCOMP=m  CONFIG_PPP_MPPE=m  CONFIG_PPPOE=m -# CONFIG_SLIP is not set -CONFIG_SLHC=m -# CONFIG_NET_FC is not set -# CONFIG_NETCONSOLE is not set -# CONFIG_NETPOLL is not set -# CONFIG_NET_POLL_CONTROLLER is not set -# CONFIG_VMXNET3 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 - -# -# Input Device Drivers -# -CONFIG_INPUT_KEYBOARD=y -# CONFIG_KEYBOARD_ADP5588 is not set -CONFIG_KEYBOARD_ATKBD=y -# CONFIG_QT2160 is not set  CONFIG_KEYBOARD_LKKBD=m -# CONFIG_KEYBOARD_TCA6416 is not set -# CONFIG_KEYBOARD_MAX7359 is not set -# CONFIG_KEYBOARD_NEWTON is not set -# CONFIG_KEYBOARD_OPENCORES is not set -# CONFIG_KEYBOARD_STOWAWAY is not set  CONFIG_KEYBOARD_SUNKBD=y -# 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=y -# CONFIG_MOUSE_APPLETOUCH is not set -# CONFIG_MOUSE_BCM5974 is not set -# CONFIG_MOUSE_VSXXXAA 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 is not set  CONFIG_INPUT_MISC=y -# CONFIG_INPUT_AD714X is not set  CONFIG_INPUT_SPARCSPKR=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_CM109 is not set -# CONFIG_INPUT_UINPUT is not set -# CONFIG_INPUT_PCF8574 is not set - -# -# Hardware I/O ports -# -CONFIG_SERIO=y -CONFIG_SERIO_I8042=y  # CONFIG_SERIO_SERPORT is not set  CONFIG_SERIO_PCIPS2=m -CONFIG_SERIO_LIBPS2=y  CONFIG_SERIO_RAW=m -# CONFIG_SERIO_ALTERA_PS2 is not set -# CONFIG_GAMEPORT is not set - -# -# Character devices -# -CONFIG_VT=y -CONFIG_CONSOLE_TRANSLATIONS=y -CONFIG_VT_CONSOLE=y -CONFIG_HW_CONSOLE=y -# CONFIG_VT_HW_CONSOLE_BINDING is not set  # CONFIG_DEVKMEM is not set -# CONFIG_SERIAL_NONSTANDARD is not set -# CONFIG_N_GSM is not set -# CONFIG_NOZOMI is not set - -# -# Serial drivers -# -# CONFIG_SERIAL_8250 is not set - -# -# Non-8250 serial port support -# -CONFIG_SERIAL_SUNCORE=y -# CONFIG_SERIAL_SUNZILOG is not set  CONFIG_SERIAL_SUNSU=y  CONFIG_SERIAL_SUNSU_CONSOLE=y  CONFIG_SERIAL_SUNSAB=y  CONFIG_SERIAL_SUNSAB_CONSOLE=y  CONFIG_SERIAL_SUNHV=y -CONFIG_SERIAL_CORE=y -CONFIG_SERIAL_CORE_CONSOLE=y -# CONFIG_SERIAL_JSM is not set -# CONFIG_SERIAL_TIMBERDALE is not set -# CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set -# CONFIG_SERIAL_ALTERA_JTAGUART is not set -# CONFIG_SERIAL_ALTERA_UART is not set -CONFIG_UNIX98_PTYS=y -# CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set  # CONFIG_LEGACY_PTYS is not set -# CONFIG_IPMI_HANDLER is not set -CONFIG_HW_RANDOM=m -# CONFIG_HW_RANDOM_TIMERIOMEM is not set -CONFIG_HW_RANDOM_N2RNG=m -# CONFIG_R3964 is not set -# CONFIG_APPLICOM is not set -# CONFIG_RAW_DRIVER is not set -# CONFIG_TCG_TPM is not set -CONFIG_DEVPORT=y -CONFIG_I2C=y -CONFIG_I2C_BOARDINFO=y -CONFIG_I2C_COMPAT=y -# CONFIG_I2C_CHARDEV is not set -CONFIG_I2C_HELPER_AUTO=y -CONFIG_I2C_ALGOBIT=y - -# -# I2C Hardware Bus support -# - -# -# PC SMBus host controller drivers -# -# CONFIG_I2C_ALI1535 is not set -# CONFIG_I2C_ALI1563 is not set -# CONFIG_I2C_ALI15X3 is not set -# CONFIG_I2C_AMD756 is not set -# CONFIG_I2C_AMD8111 is not set -# CONFIG_I2C_I801 is not set -# CONFIG_I2C_ISCH is not set -# CONFIG_I2C_PIIX4 is not set -# CONFIG_I2C_NFORCE2 is not set -# CONFIG_I2C_SIS5595 is not set -# CONFIG_I2C_SIS630 is not set -# CONFIG_I2C_SIS96X is not set -# CONFIG_I2C_VIA is not set -# CONFIG_I2C_VIAPRO is not set - -# -# I2C system bus drivers (mostly embedded / system-on-chip) -# -# CONFIG_I2C_OCORES is not set -# CONFIG_I2C_SIMTEC is not set -# CONFIG_I2C_XILINX is not set - -# -# External I2C/SMBus adapter drivers -# -# CONFIG_I2C_PARPORT_LIGHT is not set -# CONFIG_I2C_TAOS_EVM is not set -# CONFIG_I2C_TINY_USB is not set - -# -# Other I2C/SMBus bus drivers -# -# CONFIG_I2C_PCA_PLATFORM is not set -# CONFIG_I2C_STUB is not set -# 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 -CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y -# CONFIG_GPIOLIB is not set -# CONFIG_W1 is not set -# CONFIG_POWER_SUPPLY is not set -CONFIG_HWMON=y -# CONFIG_HWMON_VID is not set -# CONFIG_HWMON_DEBUG_CHIP is not set - -# -# Native drivers -# -# CONFIG_SENSORS_AD7414 is not set -# CONFIG_SENSORS_AD7418 is not set -# CONFIG_SENSORS_ADM1021 is not set -# CONFIG_SENSORS_ADM1025 is not set -# CONFIG_SENSORS_ADM1026 is not set -# CONFIG_SENSORS_ADM1029 is not set -# CONFIG_SENSORS_ADM1031 is not set -# CONFIG_SENSORS_ADM9240 is not set -# CONFIG_SENSORS_ADT7411 is not set -# CONFIG_SENSORS_ADT7462 is not set -# CONFIG_SENSORS_ADT7470 is not set -# CONFIG_SENSORS_ADT7475 is not set -# CONFIG_SENSORS_ASC7621 is not set -# CONFIG_SENSORS_ATXP1 is not set -# CONFIG_SENSORS_DS1621 is not set -# CONFIG_SENSORS_I5K_AMB is not set -# CONFIG_SENSORS_F71805F is not set -# CONFIG_SENSORS_F71882FG is not set -# CONFIG_SENSORS_F75375S is not set -# CONFIG_SENSORS_G760A is not set -# CONFIG_SENSORS_GL518SM is not set -# CONFIG_SENSORS_GL520SM is not set -# CONFIG_SENSORS_IT87 is not set -# CONFIG_SENSORS_LM63 is not set -# CONFIG_SENSORS_LM73 is not set -# CONFIG_SENSORS_LM75 is not set -# CONFIG_SENSORS_LM77 is not set -# CONFIG_SENSORS_LM78 is not set -# CONFIG_SENSORS_LM80 is not set -# CONFIG_SENSORS_LM83 is not set -# CONFIG_SENSORS_LM85 is not set -# CONFIG_SENSORS_LM87 is not set -# CONFIG_SENSORS_LM90 is not set -# CONFIG_SENSORS_LM92 is not set -# CONFIG_SENSORS_LM93 is not set -# CONFIG_SENSORS_LTC4215 is not set -# CONFIG_SENSORS_LTC4245 is not set -# CONFIG_SENSORS_LM95241 is not set -# CONFIG_SENSORS_MAX1619 is not set -# CONFIG_SENSORS_MAX6650 is not set -# CONFIG_SENSORS_PC87360 is not set -# CONFIG_SENSORS_PC87427 is not set -# CONFIG_SENSORS_PCF8591 is not set -# CONFIG_SENSORS_SIS5595 is not set -# CONFIG_SENSORS_DME1737 is not set -# CONFIG_SENSORS_SMSC47M1 is not set -# CONFIG_SENSORS_SMSC47M192 is not set -# CONFIG_SENSORS_SMSC47B397 is not set -# CONFIG_SENSORS_ADS7828 is not set -# CONFIG_SENSORS_AMC6821 is not set -# CONFIG_SENSORS_THMC50 is not set -# CONFIG_SENSORS_TMP401 is not set -# CONFIG_SENSORS_TMP421 is not set -# CONFIG_SENSORS_VIA686A is not set -# CONFIG_SENSORS_VT1211 is not set -# CONFIG_SENSORS_VT8231 is not set -# CONFIG_SENSORS_W83781D is not set -# CONFIG_SENSORS_W83791D is not set -# CONFIG_SENSORS_W83792D is not set -# CONFIG_SENSORS_W83793 is not set -# CONFIG_SENSORS_W83L785TS is not set -# CONFIG_SENSORS_W83L786NG is not set -# CONFIG_SENSORS_W83627HF is not set -# CONFIG_SENSORS_W83627EHF is not set -# CONFIG_SENSORS_ULTRA45 is not set -# CONFIG_SENSORS_LIS3_I2C is not set -# CONFIG_THERMAL is not set -# CONFIG_WATCHDOG is not set -CONFIG_SSB_POSSIBLE=y - -# -# Sonics Silicon Backplane -# -# CONFIG_SSB is not set - -# -# Multifunction device drivers -# -# CONFIG_MFD_CORE is not set -# CONFIG_MFD_88PM860X is not set -# CONFIG_MFD_SM501 is not set -# CONFIG_HTC_PASIC3 is not set -# CONFIG_TWL4030_CORE is not set -# CONFIG_MFD_TMIO is not set -# CONFIG_PMIC_DA903X is not set -# CONFIG_PMIC_ADP5520 is not set -# CONFIG_MFD_MAX8925 is not set -# CONFIG_MFD_WM8400 is not set -# CONFIG_MFD_WM831X is not set -# CONFIG_MFD_WM8350_I2C is not set -# CONFIG_MFD_WM8994 is not set -# CONFIG_MFD_PCF50633 is not set -# CONFIG_AB3100_CORE is not set -# CONFIG_LPC_SCH is not set -# CONFIG_REGULATOR is not set -# CONFIG_MEDIA_SUPPORT is not set - -# -# Graphics support -# -CONFIG_VGA_ARB=y -CONFIG_VGA_ARB_MAX_GPUS=16 -# CONFIG_DRM 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=y -# CONFIG_FB_BOOT_VESA_SUPPORT is not set -CONFIG_FB_CFB_FILLRECT=y -CONFIG_FB_CFB_COPYAREA=y -CONFIG_FB_CFB_IMAGEBLIT=y -# CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set -# CONFIG_FB_SYS_FILLRECT is not set -# CONFIG_FB_SYS_COPYAREA is not set -# CONFIG_FB_SYS_IMAGEBLIT is not set -# CONFIG_FB_FOREIGN_ENDIAN is not set -# CONFIG_FB_SYS_FOPS is not set -# CONFIG_FB_SVGALIB is not set -# CONFIG_FB_MACMODES is not set -# CONFIG_FB_BACKLIGHT is not set -CONFIG_FB_MODE_HELPERS=y  CONFIG_FB_TILEBLITTING=y - -# -# Frame buffer hardware drivers -# -# CONFIG_FB_CIRRUS is not set -# CONFIG_FB_PM2 is not set -# CONFIG_FB_ASILIANT is not set -# CONFIG_FB_IMSTT is not set -# CONFIG_FB_UVESA is not set  CONFIG_FB_SBUS=y -# CONFIG_FB_BW2 is not set -# CONFIG_FB_CG3 is not set  CONFIG_FB_CG6=y  CONFIG_FB_FFB=y -# CONFIG_FB_TCX is not set -# CONFIG_FB_CG14 is not set -# CONFIG_FB_P9100 is not set -# CONFIG_FB_LEO is not set  CONFIG_FB_XVR500=y  CONFIG_FB_XVR2500=y  CONFIG_FB_XVR1000=y -# CONFIG_FB_S1D13XXX is not set -# CONFIG_FB_NVIDIA is not set -# CONFIG_FB_RIVA is not set -# CONFIG_FB_MATROX is not set  CONFIG_FB_RADEON=y -CONFIG_FB_RADEON_I2C=y  # CONFIG_FB_RADEON_BACKLIGHT is not set -# CONFIG_FB_RADEON_DEBUG is not set -# CONFIG_FB_ATY128 is not set  CONFIG_FB_ATY=y -CONFIG_FB_ATY_CT=y -# CONFIG_FB_ATY_GENERIC_LCD is not set  CONFIG_FB_ATY_GX=y  # CONFIG_FB_ATY_BACKLIGHT is not set -# CONFIG_FB_S3 is not set -# CONFIG_FB_SAVAGE is not set -# CONFIG_FB_SIS is not set -# CONFIG_FB_VIA is not set -# CONFIG_FB_NEOMAGIC is not set -# CONFIG_FB_KYRO is not set -# CONFIG_FB_3DFX is not set -# CONFIG_FB_VOODOO1 is not set -# CONFIG_FB_VT8623 is not set -# CONFIG_FB_TRIDENT is not set -# CONFIG_FB_ARK is not set -# CONFIG_FB_PM3 is not set -# CONFIG_FB_CARMINE is not set -# CONFIG_FB_VIRTUAL is not set -# CONFIG_FB_METRONOME is not set -# CONFIG_FB_MB862XX is not set -# CONFIG_FB_BROADSHEET is not set -# CONFIG_BACKLIGHT_LCD_SUPPORT is not set - -# -# Display device support -# -# CONFIG_DISPLAY_SUPPORT is not set - -# -# Console display driver support -# -CONFIG_DUMMY_CONSOLE=y  CONFIG_FRAMEBUFFER_CONSOLE=y  CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y -# 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 is not set -# CONFIG_FONT_7x14 is not set -# CONFIG_FONT_PEARL_8x8 is not set -# CONFIG_FONT_ACORN_8x8 is not set  CONFIG_FONT_SUN8x16=y -# CONFIG_FONT_SUN12x22 is not set -# CONFIG_FONT_10x18 is not set  CONFIG_LOGO=y  # CONFIG_LOGO_LINUX_MONO is not set  # CONFIG_LOGO_LINUX_VGA16 is not set  # CONFIG_LOGO_LINUX_CLUT224 is not set -CONFIG_LOGO_SUN_CLUT224=y  CONFIG_SOUND=m -CONFIG_SOUND_OSS_CORE=y -CONFIG_SOUND_OSS_CORE_PRECLAIM=y  CONFIG_SND=m -CONFIG_SND_TIMER=m -CONFIG_SND_PCM=m -CONFIG_SND_RAWMIDI=m  CONFIG_SND_SEQUENCER=m  CONFIG_SND_SEQ_DUMMY=m -CONFIG_SND_OSSEMUL=y  CONFIG_SND_MIXER_OSS=m  CONFIG_SND_PCM_OSS=m -CONFIG_SND_PCM_OSS_PLUGINS=y  CONFIG_SND_SEQUENCER_OSS=y -# 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 is not set -# CONFIG_SND_DEBUG is not set -CONFIG_SND_VMASTER=y -CONFIG_SND_RAWMIDI_SEQ=m -# 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_MPU401_UART=m -CONFIG_SND_AC97_CODEC=m -CONFIG_SND_DRIVERS=y  CONFIG_SND_DUMMY=m  CONFIG_SND_VIRMIDI=m  CONFIG_SND_MTPAV=m -# CONFIG_SND_SERIAL_U16550 is not set -# CONFIG_SND_MPU401 is not set -# CONFIG_SND_AC97_POWER_SAVE is not set -CONFIG_SND_PCI=y -# CONFIG_SND_AD1889 is not set -# CONFIG_SND_ALS300 is not set  CONFIG_SND_ALI5451=m -# CONFIG_SND_ATIIXP is not set -# CONFIG_SND_ATIIXP_MODEM is not set -# CONFIG_SND_AU8810 is not set -# CONFIG_SND_AU8820 is not set -# CONFIG_SND_AU8830 is not set -# CONFIG_SND_AW2 is not set -# CONFIG_SND_AZT3328 is not set -# CONFIG_SND_BT87X is not set -# CONFIG_SND_CA0106 is not set -# CONFIG_SND_CMIPCI is not set -# CONFIG_SND_OXYGEN is not set -# CONFIG_SND_CS4281 is not set -# CONFIG_SND_CS46XX is not set -# CONFIG_SND_CS5535AUDIO is not set -# CONFIG_SND_CTXFI is not set -# CONFIG_SND_DARLA20 is not set -# CONFIG_SND_GINA20 is not set -# CONFIG_SND_LAYLA20 is not set -# CONFIG_SND_DARLA24 is not set -# CONFIG_SND_GINA24 is not set -# CONFIG_SND_LAYLA24 is not set -# CONFIG_SND_MONA is not set -# CONFIG_SND_MIA is not set -# CONFIG_SND_ECHO3G is not set -# CONFIG_SND_INDIGO is not set -# CONFIG_SND_INDIGOIO is not set -# CONFIG_SND_INDIGODJ is not set -# CONFIG_SND_INDIGOIOX is not set -# CONFIG_SND_INDIGODJX is not set -# CONFIG_SND_EMU10K1 is not set -# CONFIG_SND_EMU10K1X is not set -# CONFIG_SND_ENS1370 is not set -# CONFIG_SND_ENS1371 is not set -# CONFIG_SND_ES1938 is not set -# CONFIG_SND_ES1968 is not set -# CONFIG_SND_FM801 is not set -# CONFIG_SND_HDA_INTEL is not set -# CONFIG_SND_HDSP is not set -# CONFIG_SND_HDSPM is not set -# CONFIG_SND_HIFIER is not set -# CONFIG_SND_ICE1712 is not set -# CONFIG_SND_ICE1724 is not set -# CONFIG_SND_INTEL8X0 is not set -# CONFIG_SND_INTEL8X0M is not set -# CONFIG_SND_KORG1212 is not set -# CONFIG_SND_LX6464ES is not set -# CONFIG_SND_MAESTRO3 is not set -# CONFIG_SND_MIXART is not set -# CONFIG_SND_NM256 is not set -# CONFIG_SND_PCXHR is not set -# CONFIG_SND_RIPTIDE is not set -# CONFIG_SND_RME32 is not set -# CONFIG_SND_RME96 is not set -# CONFIG_SND_RME9652 is not set -# CONFIG_SND_SONICVIBES is not set -# CONFIG_SND_TRIDENT is not set -# CONFIG_SND_VIA82XX is not set -# CONFIG_SND_VIA82XX_MODEM is not set -# CONFIG_SND_VIRTUOSO is not set -# CONFIG_SND_VX222 is not set -# CONFIG_SND_YMFPCI is not set -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_SPARC=y -# CONFIG_SND_SUN_AMD7930 is not set  CONFIG_SND_SUN_CS4231=m -# CONFIG_SND_SUN_DBRI is not set -# CONFIG_SND_SOC is not set -# CONFIG_SOUND_PRIME is not set -CONFIG_AC97_BUS=m -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=y - -# -# Special HID drivers -# -# CONFIG_HID_3M_PCT is not set -CONFIG_HID_A4TECH=y -CONFIG_HID_APPLE=y -CONFIG_HID_BELKIN=y -# CONFIG_HID_CANDO is not set -CONFIG_HID_CHERRY=y -CONFIG_HID_CHICONY=y -# CONFIG_HID_PRODIKEYS is not set -CONFIG_HID_CYPRESS=y  CONFIG_HID_DRAGONRISE=y -# CONFIG_DRAGONRISE_FF is not set -# CONFIG_HID_EGALAX is not set -CONFIG_HID_EZKEY=y -CONFIG_HID_KYE=y  CONFIG_HID_GYRATION=y  CONFIG_HID_TWINHAN=y -CONFIG_HID_KENSINGTON=y -CONFIG_HID_LOGITECH=y -# CONFIG_LOGITECH_FF is not set -# CONFIG_LOGIRUMBLEPAD2_FF is not set -# CONFIG_LOGIG940_FF is not set -CONFIG_HID_MICROSOFT=y -# CONFIG_HID_MOSART is not set -CONFIG_HID_MONTEREY=y  CONFIG_HID_NTRIG=y  CONFIG_HID_ORTEK=y  CONFIG_HID_PANTHERLORD=y -# CONFIG_PANTHERLORD_FF is not set  CONFIG_HID_PETALYNX=y -# CONFIG_HID_PICOLCD is not set -# CONFIG_HID_QUANTA is not set -# CONFIG_HID_ROCCAT_KONE is not set  CONFIG_HID_SAMSUNG=y  CONFIG_HID_SONY=y -# CONFIG_HID_STANTUM is not set  CONFIG_HID_SUNPLUS=y  CONFIG_HID_GREENASIA=y -# CONFIG_GREENASIA_FF is not set  CONFIG_HID_SMARTJOYPLUS=y -# CONFIG_SMARTJOYPLUS_FF is not set  CONFIG_HID_TOPSEED=y  CONFIG_HID_THRUSTMASTER=y -# CONFIG_THRUSTMASTER_FF is not set  CONFIG_HID_ZEROPLUS=y -# CONFIG_ZEROPLUS_FF 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 is not set -# CONFIG_USB_DYNAMIC_MINORS 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_XHCI_HCD is not set  CONFIG_USB_EHCI_HCD=m -# CONFIG_USB_EHCI_ROOT_HUB_TT is not set  # CONFIG_USB_EHCI_TT_NEWSCHED is not set -# 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_BIG_ENDIAN_DESC is not set -# CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set -CONFIG_USB_OHCI_LITTLE_ENDIAN=y  CONFIG_USB_UHCI_HCD=m -# CONFIG_USB_SL811_HCD is not set -# CONFIG_USB_R8A66597_HCD is not set -# CONFIG_USB_WHCI_HCD is not set -# CONFIG_USB_HWA_HCD 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=m -# CONFIG_USB_STORAGE_DEBUG is not set -# CONFIG_USB_STORAGE_DATAFAB is not set -# CONFIG_USB_STORAGE_FREECOM is not set -# CONFIG_USB_STORAGE_ISD200 is not set -# CONFIG_USB_STORAGE_USBAT is not set -# CONFIG_USB_STORAGE_SDDR09 is not set -# CONFIG_USB_STORAGE_SDDR55 is not set -# CONFIG_USB_STORAGE_JUMPSHOT is not set -# CONFIG_USB_STORAGE_ALAUDA is not set -# CONFIG_USB_STORAGE_ONETOUCH is not set -# CONFIG_USB_STORAGE_KARMA is not set -# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set -# CONFIG_USB_LIBUSUAL is not set - -# -# USB Imaging devices -# -# CONFIG_USB_MDC800 is not set -# CONFIG_USB_MICROTEK is not set - -# -# USB port drivers -# -# CONFIG_USB_SERIAL is not set - -# -# USB Miscellaneous drivers -# -# CONFIG_USB_EMI62 is not set -# CONFIG_USB_EMI26 is not set -# CONFIG_USB_ADUTUX is not set -# CONFIG_USB_SEVSEG is not set -# CONFIG_USB_RIO500 is not set -# CONFIG_USB_LEGOTOWER is not set -# CONFIG_USB_LCD is not set -# CONFIG_USB_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_GADGET is not set - -# -# OTG and related infrastructure -# -# CONFIG_NOP_USB_XCEIV is not set -# CONFIG_UWB is not set -# CONFIG_MMC is not set -# CONFIG_MEMSTICK is not set -# CONFIG_NEW_LEDS is not set -# CONFIG_ACCESSIBILITY is not set -# CONFIG_INFINIBAND is not set -CONFIG_RTC_LIB=y -CONFIG_RTC_CLASS=y -CONFIG_RTC_HCTOSYS=y -CONFIG_RTC_HCTOSYS_DEVICE="rtc0" -# CONFIG_RTC_DEBUG is not set - -# -# RTC interfaces -# -CONFIG_RTC_INTF_SYSFS=y -CONFIG_RTC_INTF_PROC=y -CONFIG_RTC_INTF_DEV=y -# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set -# CONFIG_RTC_DRV_TEST is not set - -# -# I2C RTC drivers -# -# CONFIG_RTC_DRV_DS1307 is not set -# CONFIG_RTC_DRV_DS1374 is not set -# CONFIG_RTC_DRV_DS1672 is not set -# CONFIG_RTC_DRV_MAX6900 is not set -# CONFIG_RTC_DRV_RS5C372 is not set -# CONFIG_RTC_DRV_ISL1208 is not set -# CONFIG_RTC_DRV_X1205 is not set -# CONFIG_RTC_DRV_PCF8563 is not set -# CONFIG_RTC_DRV_PCF8583 is not set -# CONFIG_RTC_DRV_M41T80 is not set -# CONFIG_RTC_DRV_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 - -# -# SPI RTC drivers -# - -# -# Platform RTC drivers -# -CONFIG_RTC_DRV_CMOS=y -# 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=y -# CONFIG_RTC_DRV_MSM6242 is not set -CONFIG_RTC_DRV_BQ4802=y -# CONFIG_RTC_DRV_RP5C01 is not set -# CONFIG_RTC_DRV_V3020 is not set - -# -# on-CPU RTC drivers -# -CONFIG_RTC_DRV_SUN4V=y -CONFIG_RTC_DRV_STARFIRE=y -# CONFIG_DMADEVICES is not set -# CONFIG_AUXDISPLAY is not set -# CONFIG_UIO is not set -# CONFIG_STAGING is not set - -# -# Misc Linux/SPARC drivers -#  CONFIG_SUN_OPENPROMIO=y -# CONFIG_OBP_FLASH is not set -# CONFIG_TADPOLE_TS102_UCTRL is not set -# CONFIG_BBC_I2C is not set -# CONFIG_ENVCTRL is not set -# CONFIG_DISPLAY7SEG is not set - -# -# File systems -#  CONFIG_EXT2_FS=y  CONFIG_EXT2_FS_XATTR=y  CONFIG_EXT2_FS_POSIX_ACL=y  CONFIG_EXT2_FS_SECURITY=y -# CONFIG_EXT2_FS_XIP is not set  CONFIG_EXT3_FS=y  # CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set -CONFIG_EXT3_FS_XATTR=y  CONFIG_EXT3_FS_POSIX_ACL=y  CONFIG_EXT3_FS_SECURITY=y -# CONFIG_EXT4_FS is not set -CONFIG_JBD=y -# CONFIG_JBD_DEBUG is not set -CONFIG_FS_MBCACHE=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_BTRFS_FS is not set -# CONFIG_NILFS2_FS is not set -CONFIG_FILE_LOCKING=y -CONFIG_FSNOTIFY=y -CONFIG_DNOTIFY=y -CONFIG_INOTIFY=y -CONFIG_INOTIFY_USER=y -# CONFIG_QUOTA is not set -# CONFIG_AUTOFS_FS is not set -# CONFIG_AUTOFS4_FS is not set -# CONFIG_FUSE_FS is not set - -# -# Caches -# -# CONFIG_FSCACHE is not set - -# -# CD-ROM/DVD Filesystems -# -# CONFIG_ISO9660_FS is not set -# CONFIG_UDF_FS is not set - -# -# DOS/FAT/NT Filesystems -# -# CONFIG_MSDOS_FS is not set -# CONFIG_VFAT_FS is not set -# CONFIG_NTFS_FS is not set - -# -# Pseudo filesystems -# -CONFIG_PROC_FS=y  CONFIG_PROC_KCORE=y -CONFIG_PROC_SYSCTL=y -CONFIG_PROC_PAGE_MONITOR=y -CONFIG_SYSFS=y  CONFIG_TMPFS=y -# CONFIG_TMPFS_POSIX_ACL is not set  CONFIG_HUGETLBFS=y -CONFIG_HUGETLB_PAGE=y -# 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_LOGFS is not set -# CONFIG_CRAMFS is not set -# CONFIG_SQUASHFS is not set -# CONFIG_VXFS_FS is not set -# CONFIG_MINIX_FS is not set -# CONFIG_OMFS_FS is not set -# CONFIG_HPFS_FS is not set -# CONFIG_QNX4FS_FS is not set -# CONFIG_ROMFS_FS is not set -# CONFIG_SYSV_FS is not set -# CONFIG_UFS_FS is not set -CONFIG_NETWORK_FILESYSTEMS=y -# CONFIG_NFS_FS is not set -# CONFIG_NFSD is not set -# CONFIG_SMB_FS is not set -# CONFIG_CEPH_FS is not set -# CONFIG_CIFS is not set -# CONFIG_NCP_FS is not set -# CONFIG_CODA_FS is not set -# CONFIG_AFS_FS is not set - -# -# Partition Types -# -# CONFIG_PARTITION_ADVANCED is not set -CONFIG_MSDOS_PARTITION=y -CONFIG_SUN_PARTITION=y -CONFIG_NLS=y -CONFIG_NLS_DEFAULT="iso8859-1" -# CONFIG_NLS_CODEPAGE_437 is not set -# CONFIG_NLS_CODEPAGE_737 is not set -# CONFIG_NLS_CODEPAGE_775 is not set -# CONFIG_NLS_CODEPAGE_850 is not set -# CONFIG_NLS_CODEPAGE_852 is not set -# CONFIG_NLS_CODEPAGE_855 is not set -# CONFIG_NLS_CODEPAGE_857 is not set -# CONFIG_NLS_CODEPAGE_860 is not set -# CONFIG_NLS_CODEPAGE_861 is not set -# CONFIG_NLS_CODEPAGE_862 is not set -# CONFIG_NLS_CODEPAGE_863 is not set -# CONFIG_NLS_CODEPAGE_864 is not set -# CONFIG_NLS_CODEPAGE_865 is not set -# CONFIG_NLS_CODEPAGE_866 is not set -# CONFIG_NLS_CODEPAGE_869 is not set -# CONFIG_NLS_CODEPAGE_936 is not set -# CONFIG_NLS_CODEPAGE_950 is not set -# CONFIG_NLS_CODEPAGE_932 is not set -# CONFIG_NLS_CODEPAGE_949 is not set -# CONFIG_NLS_CODEPAGE_874 is not set -# CONFIG_NLS_ISO8859_8 is not set -# CONFIG_NLS_CODEPAGE_1250 is not set -# CONFIG_NLS_CODEPAGE_1251 is not set -# CONFIG_NLS_ASCII is not set -# CONFIG_NLS_ISO8859_1 is not set -# CONFIG_NLS_ISO8859_2 is not set -# CONFIG_NLS_ISO8859_3 is not set -# CONFIG_NLS_ISO8859_4 is not set -# CONFIG_NLS_ISO8859_5 is not set -# CONFIG_NLS_ISO8859_6 is not set -# CONFIG_NLS_ISO8859_7 is not set -# CONFIG_NLS_ISO8859_9 is not set -# CONFIG_NLS_ISO8859_13 is not set -# CONFIG_NLS_ISO8859_14 is not set -# CONFIG_NLS_ISO8859_15 is not set -# CONFIG_NLS_KOI8_R is not set -# CONFIG_NLS_KOI8_U is not set -# CONFIG_NLS_UTF8 is not set -# CONFIG_DLM is not set - -# -# Kernel hacking -# -CONFIG_TRACE_IRQFLAGS_SUPPORT=y  CONFIG_PRINTK_TIME=y  # CONFIG_ENABLE_WARN_DEPRECATED is not set -CONFIG_ENABLE_MUST_CHECK=y -CONFIG_FRAME_WARN=2048  CONFIG_MAGIC_SYSRQ=y -# CONFIG_STRIP_ASM_SYMS is not set -# CONFIG_UNUSED_SYMBOLS is not set -CONFIG_DEBUG_FS=y -# CONFIG_HEADERS_CHECK is not set  CONFIG_DEBUG_KERNEL=y -# CONFIG_DEBUG_SHIRQ is not set -CONFIG_DETECT_SOFTLOCKUP=y -# CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC is not set -CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC_VALUE=0 +CONFIG_LOCKUP_DETECTOR=y  CONFIG_DETECT_HUNG_TASK=y -# CONFIG_BOOTPARAM_HUNG_TASK_PANIC is not set -CONFIG_BOOTPARAM_HUNG_TASK_PANIC_VALUE=0  # CONFIG_SCHED_DEBUG is not set  CONFIG_SCHEDSTATS=y -# CONFIG_TIMER_STATS is not set -# CONFIG_DEBUG_OBJECTS is not set -# CONFIG_DEBUG_SLAB is not set -# CONFIG_DEBUG_KMEMLEAK is not set -# CONFIG_DEBUG_RT_MUTEXES is not set -# CONFIG_RT_MUTEX_TESTER is not set -# CONFIG_DEBUG_SPINLOCK is not set -# CONFIG_DEBUG_MUTEXES 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_STACKTRACE=y -# CONFIG_DEBUG_KOBJECT is not set -CONFIG_DEBUG_BUGVERBOSE=y -# CONFIG_DEBUG_INFO is not set -# CONFIG_DEBUG_VM is not set -# CONFIG_DEBUG_WRITECOUNT is not set -CONFIG_DEBUG_MEMORY_INIT=y -# CONFIG_DEBUG_LIST is not set -# CONFIG_DEBUG_SG is not set -# CONFIG_DEBUG_NOTIFIERS is not set -# CONFIG_DEBUG_CREDENTIALS is not set -# CONFIG_BOOT_PRINTK_DELAY is not set -# CONFIG_RCU_TORTURE_TEST is not set  # CONFIG_RCU_CPU_STALL_DETECTOR is not set -# CONFIG_KPROBES_SANITY_TEST is not set -# CONFIG_BACKTRACE_SELF_TEST is not set -# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set -# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set -# CONFIG_LKDTM is not set -# CONFIG_FAULT_INJECTION is not set -# CONFIG_LATENCYTOP is not set  CONFIG_SYSCTL_SYSCALL_CHECK=y -# CONFIG_DEBUG_PAGEALLOC is not set -CONFIG_NOP_TRACER=y -CONFIG_HAVE_FUNCTION_TRACER=y -CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y -CONFIG_HAVE_FUNCTION_GRAPH_FP_TEST=y -CONFIG_HAVE_FUNCTION_TRACE_MCOUNT_TEST=y -CONFIG_HAVE_DYNAMIC_FTRACE=y -CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y -CONFIG_HAVE_SYSCALL_TRACEPOINTS=y -CONFIG_RING_BUFFER=y -CONFIG_EVENT_TRACING=y -CONFIG_CONTEXT_SWITCH_TRACER=y -CONFIG_RING_BUFFER_ALLOW_SWAP=y -CONFIG_TRACING=y -CONFIG_GENERIC_TRACER=y -CONFIG_TRACING_SUPPORT=y -CONFIG_FTRACE=y -# CONFIG_FUNCTION_TRACER is not set -# CONFIG_IRQSOFF_TRACER is not set -# CONFIG_SCHED_TRACER is not set -# CONFIG_FTRACE_SYSCALLS is not set -# CONFIG_BOOT_TRACER is not set -CONFIG_BRANCH_PROFILE_NONE=y -# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set -# CONFIG_PROFILE_ALL_BRANCHES is not set -# CONFIG_STACK_TRACER is not set -# CONFIG_KMEMTRACE is not set -# CONFIG_WORKQUEUE_TRACER is not set  CONFIG_BLK_DEV_IO_TRACE=y -# CONFIG_FTRACE_STARTUP_TEST is not set -# CONFIG_RING_BUFFER_BENCHMARK is not set -# CONFIG_DYNAMIC_DEBUG 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_KGDB is not set -# CONFIG_DEBUG_STACK_USAGE is not set -# CONFIG_DEBUG_DCFLUSH is not set -# CONFIG_DEBUG_STRICT_USER_COPY_CHECKS is not set - -# -# Security options -#  CONFIG_KEYS=y -# CONFIG_KEYS_DEBUG_PROC_KEYS is not set -# CONFIG_SECURITY is not set -# CONFIG_SECURITYFS is not set -# CONFIG_DEFAULT_SECURITY_SELINUX is not set -# CONFIG_DEFAULT_SECURITY_SMACK is not set -# CONFIG_DEFAULT_SECURITY_TOMOYO is not set -CONFIG_DEFAULT_SECURITY_DAC=y -CONFIG_DEFAULT_SECURITY="" -CONFIG_XOR_BLOCKS=m -CONFIG_ASYNC_CORE=m -CONFIG_ASYNC_MEMCPY=m -CONFIG_ASYNC_XOR=m -CONFIG_ASYNC_PQ=m -CONFIG_ASYNC_RAID6_RECOV=m -CONFIG_CRYPTO=y - -# -# Crypto core or helper -# -CONFIG_CRYPTO_ALGAPI=y -CONFIG_CRYPTO_ALGAPI2=y -CONFIG_CRYPTO_AEAD=y -CONFIG_CRYPTO_AEAD2=y -CONFIG_CRYPTO_BLKCIPHER=y -CONFIG_CRYPTO_BLKCIPHER2=y -CONFIG_CRYPTO_HASH=y -CONFIG_CRYPTO_HASH2=y -CONFIG_CRYPTO_RNG2=y -CONFIG_CRYPTO_PCOMP=y -CONFIG_CRYPTO_MANAGER=y -CONFIG_CRYPTO_MANAGER2=y -CONFIG_CRYPTO_GF128MUL=m  CONFIG_CRYPTO_NULL=m -# CONFIG_CRYPTO_PCRYPT is not set -CONFIG_CRYPTO_WORKQUEUE=y -# CONFIG_CRYPTO_CRYPTD is not set -CONFIG_CRYPTO_AUTHENC=y  CONFIG_CRYPTO_TEST=m - -# -# Authenticated Encryption with Associated Data -# -# CONFIG_CRYPTO_CCM is not set -# CONFIG_CRYPTO_GCM is not set -# CONFIG_CRYPTO_SEQIV is not set - -# -# Block modes -# -CONFIG_CRYPTO_CBC=y -# CONFIG_CRYPTO_CTR is not set -# CONFIG_CRYPTO_CTS is not set -CONFIG_CRYPTO_ECB=m  CONFIG_CRYPTO_LRW=m  CONFIG_CRYPTO_PCBC=m  CONFIG_CRYPTO_XTS=m - -# -# Hash modes -# -CONFIG_CRYPTO_HMAC=y  CONFIG_CRYPTO_XCBC=y -# CONFIG_CRYPTO_VMAC is not set - -# -# Digest -# -CONFIG_CRYPTO_CRC32C=m -# CONFIG_CRYPTO_GHASH is not set  CONFIG_CRYPTO_MD4=y -CONFIG_CRYPTO_MD5=y  CONFIG_CRYPTO_MICHAEL_MIC=m -# 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=y  CONFIG_CRYPTO_SHA256=m  CONFIG_CRYPTO_SHA512=m  CONFIG_CRYPTO_TGR192=m  CONFIG_CRYPTO_WP512=m - -# -# Ciphers -#  CONFIG_CRYPTO_AES=m  CONFIG_CRYPTO_ANUBIS=m -CONFIG_CRYPTO_ARC4=m  CONFIG_CRYPTO_BLOWFISH=m  CONFIG_CRYPTO_CAMELLIA=m  CONFIG_CRYPTO_CAST5=m  CONFIG_CRYPTO_CAST6=m -CONFIG_CRYPTO_DES=y  CONFIG_CRYPTO_FCRYPT=m  CONFIG_CRYPTO_KHAZAD=m -# CONFIG_CRYPTO_SALSA20 is not set  CONFIG_CRYPTO_SEED=m  CONFIG_CRYPTO_SERPENT=m  CONFIG_CRYPTO_TEA=m  CONFIG_CRYPTO_TWOFISH=m -CONFIG_CRYPTO_TWOFISH_COMMON=m - -# -# Compression -# -CONFIG_CRYPTO_DEFLATE=y -# CONFIG_CRYPTO_ZLIB is not set -# CONFIG_CRYPTO_LZO is not set - -# -# Random Number Generation -#  # CONFIG_CRYPTO_ANSI_CPRNG is not set -CONFIG_CRYPTO_HW=y -# CONFIG_CRYPTO_DEV_NIAGARA2 is not set -# CONFIG_CRYPTO_DEV_HIFN_795X is not set -CONFIG_BINARY_PRINTF=y - -# -# Library routines -# -CONFIG_BITREVERSE=y -CONFIG_GENERIC_FIND_LAST_BIT=y -CONFIG_CRC_CCITT=m  CONFIG_CRC16=m -# CONFIG_CRC_T10DIF is not set -# 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_LZO_DECOMPRESS=y -CONFIG_DECOMPRESS_GZIP=y -CONFIG_DECOMPRESS_BZIP2=y -CONFIG_DECOMPRESS_LZMA=y -CONFIG_DECOMPRESS_LZO=y -CONFIG_HAS_IOMEM=y -CONFIG_HAS_IOPORT=y -CONFIG_HAS_DMA=y -CONFIG_HAVE_LMB=y -CONFIG_NLATTR=y diff --git a/arch/sparc/include/asm/atomic_64.h b/arch/sparc/include/asm/atomic_64.h index 2050ca0..bdb2ff8 100644 --- a/arch/sparc/include/asm/atomic_64.h +++ b/arch/sparc/include/asm/atomic_64.h @@ -20,14 +20,14 @@  #define atomic64_set(v, i)	(((v)->counter) = i)  extern void atomic_add(int, atomic_t *); -extern void atomic64_add(int, atomic64_t *); +extern void atomic64_add(long, atomic64_t *);  extern void atomic_sub(int, atomic_t *); -extern void atomic64_sub(int, atomic64_t *); +extern void atomic64_sub(long, atomic64_t *);  extern int atomic_add_ret(int, atomic_t *); -extern int atomic64_add_ret(int, atomic64_t *); +extern long atomic64_add_ret(long, atomic64_t *);  extern int atomic_sub_ret(int, atomic_t *); -extern int atomic64_sub_ret(int, atomic64_t *); +extern long atomic64_sub_ret(long, atomic64_t *);  #define atomic_dec_return(v) atomic_sub_ret(1, v)  #define atomic64_dec_return(v) atomic64_sub_ret(1, v) @@ -91,7 +91,7 @@ static inline int atomic_add_unless(atomic_t *v, int a, int u)  	((__typeof__((v)->counter))cmpxchg(&((v)->counter), (o), (n)))  #define atomic64_xchg(v, new) (xchg(&((v)->counter), new)) -static inline int atomic64_add_unless(atomic64_t *v, long a, long u) +static inline long atomic64_add_unless(atomic64_t *v, long a, long u)  {  	long c, old;  	c = atomic64_read(v); diff --git a/arch/sparc/include/asm/backoff.h b/arch/sparc/include/asm/backoff.h index fa1fdf6..db3af0d 100644 --- a/arch/sparc/include/asm/backoff.h +++ b/arch/sparc/include/asm/backoff.h @@ -8,6 +8,9 @@  #define BACKOFF_SETUP(reg)	\  	mov	1, reg +#define BACKOFF_LABEL(spin_label, continue_label) \ +	spin_label +  #define BACKOFF_SPIN(reg, tmp, label)	\  	mov	reg, tmp; \  88:	brnz,pt	tmp, 88b; \ @@ -22,9 +25,11 @@  #else  #define BACKOFF_SETUP(reg) -#define BACKOFF_SPIN(reg, tmp, label) \ -	ba,pt	%xcc, label; \ -	 nop; + +#define BACKOFF_LABEL(spin_label, continue_label) \ +	continue_label + +#define BACKOFF_SPIN(reg, tmp, label)  #endif diff --git a/arch/sparc/include/asm/device.h b/arch/sparc/include/asm/device.h index d4c4521..daa6a8a 100644 --- a/arch/sparc/include/asm/device.h +++ b/arch/sparc/include/asm/device.h @@ -6,18 +6,25 @@  #ifndef _ASM_SPARC_DEVICE_H  #define _ASM_SPARC_DEVICE_H +#include <asm/openprom.h> +  struct device_node; -struct of_device; +struct platform_device;  struct dev_archdata {  	void			*iommu;  	void			*stc;  	void			*host_controller; -	struct of_device	*op; +	struct platform_device	*op;  	int			numa_node;  }; +extern void of_propagate_archdata(struct platform_device *bus); +  struct pdev_archdata { +	struct resource		resource[PROMREG_MAX]; +	unsigned int		irqs[PROMINTR_MAX]; +	int			num_irqs;  };  #endif /* _ASM_SPARC_DEVICE_H */ diff --git a/arch/sparc/include/asm/dma-mapping.h b/arch/sparc/include/asm/dma-mapping.h index 4b4a0c0..8c0e4f7 100644 --- a/arch/sparc/include/asm/dma-mapping.h +++ b/arch/sparc/include/asm/dma-mapping.h @@ -11,7 +11,6 @@ extern int dma_supported(struct device *dev, u64 mask);  #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)  #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) -#define dma_is_consistent(d, h)	(1)  extern struct dma_map_ops *dma_ops, pci32_dma_ops;  extern struct bus_type pci_bus_type; @@ -52,15 +51,6 @@ static inline int dma_mapping_error(struct device *dev, dma_addr_t dma_addr)  	return (dma_addr == DMA_ERROR_CODE);  } -static inline int dma_get_cache_alignment(void) -{ -	/* -	 * no easy way to get cache size on all processors, so return -	 * the maximum possible, to be safe -	 */ -	return (1 << INTERNODE_CACHE_SHIFT); -} -  static inline int dma_set_mask(struct device *dev, u64 mask)  {  #ifdef CONFIG_PCI diff --git a/arch/sparc/include/asm/fb.h b/arch/sparc/include/asm/fb.h index e834880..2173432 100644 --- a/arch/sparc/include/asm/fb.h +++ b/arch/sparc/include/asm/fb.h @@ -1,5 +1,6 @@  #ifndef _SPARC_FB_H_  #define _SPARC_FB_H_ +#include <linux/console.h>  #include <linux/fb.h>  #include <linux/fs.h>  #include <asm/page.h> @@ -18,6 +19,9 @@ static inline int fb_is_primary_device(struct fb_info *info)  	struct device *dev = info->device;  	struct device_node *node; +	if (console_set_on_cmdline) +		return 0; +  	node = dev->of_node;  	if (node &&  	    node == of_console_device) diff --git a/arch/sparc/include/asm/floppy_64.h b/arch/sparc/include/asm/floppy_64.h index 8fac3ab..6597ce8 100644 --- a/arch/sparc/include/asm/floppy_64.h +++ b/arch/sparc/include/asm/floppy_64.h @@ -43,7 +43,7 @@ struct sun_flpy_controller {  /* You'll only ever find one controller on an Ultra anyways. */  static struct sun_flpy_controller *sun_fdc = (struct sun_flpy_controller *)-1;  unsigned long fdc_status; -static struct of_device *floppy_op = NULL; +static struct platform_device *floppy_op = NULL;  struct sun_floppy_ops {  	unsigned char	(*fd_inb) (unsigned long port); @@ -548,7 +548,7 @@ static unsigned long __init sun_floppy_init(void)  {  	static int initialized = 0;  	struct device_node *dp; -	struct of_device *op; +	struct platform_device *op;  	const char *prop;  	char state[128]; @@ -567,7 +567,7 @@ static unsigned long __init sun_floppy_init(void)  	}  	if (op) {  		floppy_op = op; -		FLOPPY_IRQ = op->irqs[0]; +		FLOPPY_IRQ = op->archdata.irqs[0];  	} else {  		struct device_node *ebus_dp;  		void __iomem *auxio_reg; @@ -593,7 +593,7 @@ static unsigned long __init sun_floppy_init(void)  		if (state_prop && !strncmp(state_prop, "disabled", 8))  			return 0; -		FLOPPY_IRQ = op->irqs[0]; +		FLOPPY_IRQ = op->archdata.irqs[0];  		/* Make sure the high density bit is set, some systems  		 * (most notably Ultra5/Ultra10) come up with it clear. @@ -661,7 +661,7 @@ static unsigned long __init sun_floppy_init(void)  		config = 0;  		for (dp = ebus_dp->child; dp; dp = dp->sibling) {  			if (!strcmp(dp->name, "ecpp")) { -				struct of_device *ecpp_op; +				struct platform_device *ecpp_op;  				ecpp_op = of_find_device_by_node(dp);  				if (ecpp_op) diff --git a/arch/sparc/include/asm/highmem.h b/arch/sparc/include/asm/highmem.h index 3de42e7..ec23b0a 100644 --- a/arch/sparc/include/asm/highmem.h +++ b/arch/sparc/include/asm/highmem.h @@ -71,7 +71,7 @@ static inline void kunmap(struct page *page)  }  extern void *kmap_atomic(struct page *page, enum km_type type); -extern void kunmap_atomic(void *kvaddr, enum km_type type); +extern void kunmap_atomic_notypecheck(void *kvaddr, enum km_type type);  extern struct page *kmap_atomic_to_page(void *vaddr);  #define flush_cache_kmaps()	flush_cache_all() diff --git a/arch/sparc/include/asm/ioctls.h b/arch/sparc/include/asm/ioctls.h index 1fe6855..53f4ee0 100644 --- a/arch/sparc/include/asm/ioctls.h +++ b/arch/sparc/include/asm/ioctls.h @@ -80,6 +80,7 @@  /* Get minor device of a pty master's FD -- Solaris equiv is ISPTM */  #define TIOCGPTN	_IOR('t', 134, unsigned int) /* Get Pty Number */  #define TIOCSPTLCK	_IOW('t', 135, int) /* Lock/unlock PTY */ +#define TIOCSIG		_IOW('t', 136, int) /* Generate signal on Pty slave */  /* Little f */  #define FIOCLEX		_IO('f', 1) @@ -132,5 +133,6 @@  #define TIOCPKT_START		 8  #define TIOCPKT_NOSTOP		16  #define TIOCPKT_DOSTOP		32 +#define TIOCPKT_IOCTL		64  #endif /* !(_ASM_SPARC_IOCTLS_H) */ diff --git a/arch/sparc/include/asm/local64.h b/arch/sparc/include/asm/local64.h new file mode 100644 index 0000000..36c93b5 --- /dev/null +++ b/arch/sparc/include/asm/local64.h @@ -0,0 +1 @@ +#include <asm-generic/local64.h> diff --git a/arch/sparc/include/asm/of_device.h b/arch/sparc/include/asm/of_device.h deleted file mode 100644 index f320246..0000000 --- a/arch/sparc/include/asm/of_device.h +++ /dev/null @@ -1,38 +0,0 @@ -#ifndef _ASM_SPARC_OF_DEVICE_H -#define _ASM_SPARC_OF_DEVICE_H -#ifdef __KERNEL__ - -#include <linux/device.h> -#include <linux/of.h> -#include <linux/mod_devicetable.h> -#include <asm/openprom.h> - -/* - * The of_device is a kind of "base class" that is a superset of - * struct device for use by devices attached to an OF node and - * probed using OF properties. - */ -struct of_device -{ -	struct device			dev; -	struct resource			resource[PROMREG_MAX]; -	unsigned int			irqs[PROMINTR_MAX]; -	int				num_irqs; - -	void				*sysdata; - -	int				slot; -	int				portid; -	int				clock_freq; -}; - -extern void __iomem *of_ioremap(struct resource *res, unsigned long offset, unsigned long size, char *name); -extern void of_iounmap(struct resource *res, void __iomem *base, unsigned long size); - -extern void of_propagate_archdata(struct of_device *bus); - -/* This is just here during the transition */ -#include <linux/of_platform.h> - -#endif /* __KERNEL__ */ -#endif /* _ASM_SPARC_OF_DEVICE_H */ diff --git a/arch/sparc/include/asm/of_platform.h b/arch/sparc/include/asm/of_platform.h deleted file mode 100644 index 90da990..0000000 --- a/arch/sparc/include/asm/of_platform.h +++ /dev/null @@ -1,18 +0,0 @@ -#ifndef ___ASM_SPARC_OF_PLATFORM_H -#define ___ASM_SPARC_OF_PLATFORM_H -/* - *    Copyright (C) 2006 Benjamin Herrenschmidt, IBM Corp. - *			 <benh@kernel.crashing.org> - *    Modified for Sparc by merging parts of asm/of_device.h - *		by Stephen Rothwell - * - *  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. - * - */ - -#define of_bus_type	of_platform_bus_type	/* for compatibility */ - -#endif diff --git a/arch/sparc/include/asm/oplib_64.h b/arch/sparc/include/asm/oplib_64.h index a5db031..3e0b2d6 100644 --- a/arch/sparc/include/asm/oplib_64.h +++ b/arch/sparc/include/asm/oplib_64.h @@ -185,9 +185,8 @@ extern int prom_getunumber(int syndrome_code,  			   char *buf, int buflen);  /* Retain physical memory to the caller across soft resets. */ -extern unsigned long prom_retain(const char *name, -				 unsigned long pa_low, unsigned long pa_high, -				 long size, long align); +extern int prom_retain(const char *name, unsigned long size, +		       unsigned long align, unsigned long *paddr);  /* Load explicit I/D TLB entries into the calling processor. */  extern long prom_itlb_load(unsigned long index, @@ -287,26 +286,6 @@ extern void prom_sun4v_guest_soft_state(void);  extern int prom_ihandle2path(int handle, char *buffer, int bufsize);  /* Client interface level routines. */ -extern long p1275_cmd(const char *, long, ...); - -#if 0 -#define P1275_SIZE(x) ((((long)((x) / 32)) << 32) | (x)) -#else -#define P1275_SIZE(x) x -#endif - -/* We support at most 16 input and 1 output argument */ -#define P1275_ARG_NUMBER		0 -#define P1275_ARG_IN_STRING		1 -#define P1275_ARG_OUT_BUF		2 -#define P1275_ARG_OUT_32B		3 -#define P1275_ARG_IN_FUNCTION		4 -#define P1275_ARG_IN_BUF		5 -#define P1275_ARG_IN_64B		6 - -#define P1275_IN(x) ((x) & 0xf) -#define P1275_OUT(x) (((x) << 4) & 0xf0) -#define P1275_INOUT(i,o) (P1275_IN(i)|P1275_OUT(o)) -#define P1275_ARG(n,x) ((x) << ((n)*3 + 8)) +extern void p1275_cmd_direct(unsigned long *);  #endif /* !(__SPARC64_OPLIB_H) */ diff --git a/arch/sparc/include/asm/parport.h b/arch/sparc/include/asm/parport.h index c333b8d..aa4c826 100644 --- a/arch/sparc/include/asm/parport.h +++ b/arch/sparc/include/asm/parport.h @@ -103,7 +103,7 @@ static inline unsigned int get_dma_residue(unsigned int dmanr)  	return ebus_dma_residue(&sparc_ebus_dmas[dmanr].info);  } -static int __devinit ecpp_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit ecpp_probe(struct platform_device *op, const struct of_device_id *match)  {  	unsigned long base = op->resource[0].start;  	unsigned long config = op->resource[1].start; @@ -116,7 +116,7 @@ static int __devinit ecpp_probe(struct of_device *op, const struct of_device_id  	parent = op->dev.of_node->parent;  	if (!strcmp(parent->name, "dma")) {  		p = parport_pc_probe_port(base, base + 0x400, -					  op->irqs[0], PARPORT_DMA_NOFIFO, +					  op->archdata.irqs[0], PARPORT_DMA_NOFIFO,  					  op->dev.parent->parent, 0);  		if (!p)  			return -ENOMEM; @@ -166,7 +166,7 @@ static int __devinit ecpp_probe(struct of_device *op, const struct of_device_id  		       0, PTR_LPT_REG_DIR);  	p = parport_pc_probe_port(base, base + 0x400, -				  op->irqs[0], +				  op->archdata.irqs[0],  				  slot,  				  op->dev.parent,  				  0); @@ -192,7 +192,7 @@ out_err:  	return err;  } -static int __devexit ecpp_remove(struct of_device *op) +static int __devexit ecpp_remove(struct platform_device *op)  {  	struct parport *p = dev_get_drvdata(&op->dev);  	int slot = p->dma; @@ -228,6 +228,10 @@ static const struct of_device_id ecpp_match[] = {  		.name = "parallel",  		.compatible = "ns87317-ecpp",  	}, +	{ +		.name = "parallel", +		.compatible = "pnpALI,1533,3", +	},  	{},  }; @@ -243,9 +247,7 @@ static struct of_platform_driver ecpp_driver = {  static int parport_pc_find_nonpci_ports(int autoirq, int autodma)  { -	of_register_driver(&ecpp_driver, &of_bus_type); - -	return 0; +	return of_register_platform_driver(&ecpp_driver);  }  #endif /* !(_ASM_SPARC64_PARPORT_H */ diff --git a/arch/sparc/include/asm/perf_event.h b/arch/sparc/include/asm/perf_event.h index 7e26698..727af70 100644 --- a/arch/sparc/include/asm/perf_event.h +++ b/arch/sparc/include/asm/perf_event.h @@ -6,7 +6,30 @@ extern void set_perf_event_pending(void);  #define	PERF_EVENT_INDEX_OFFSET	0  #ifdef CONFIG_PERF_EVENTS +#include <asm/ptrace.h> +  extern void init_hw_perf_events(void); + +#define perf_arch_fetch_caller_regs(regs, ip)		\ +do {							\ +	unsigned long _pstate, _asi, _pil, _i7, _fp;	\ +	__asm__ __volatile__("rdpr %%pstate, %0\n\t"	\ +			     "rd %%asi, %1\n\t"		\ +			     "rdpr %%pil, %2\n\t"	\ +			     "mov %%i7, %3\n\t"		\ +			     "mov %%i6, %4\n\t"		\ +			     : "=r" (_pstate),		\ +			       "=r" (_asi),		\ +			       "=r" (_pil),		\ +			       "=r" (_i7),		\ +			       "=r" (_fp));		\ +	(regs)->tstate = (_pstate << 8) |		\ +		(_asi << 24) | (_pil << 20);		\ +	(regs)->tpc = (ip);				\ +	(regs)->tnpc = (regs)->tpc + 4;			\ +	(regs)->u_regs[UREG_I6] = _fp;			\ +	(regs)->u_regs[UREG_I7] = _i7;			\ +} while (0)  #else  static inline void init_hw_perf_events(void)	{ }  #endif diff --git a/arch/sparc/include/asm/prom.h b/arch/sparc/include/asm/prom.h index f845828..291f125 100644 --- a/arch/sparc/include/asm/prom.h +++ b/arch/sparc/include/asm/prom.h @@ -43,20 +43,22 @@ extern int of_getintprop_default(struct device_node *np,  extern int of_find_in_proplist(const char *list, const char *match, int len);  #ifdef CONFIG_NUMA  extern int of_node_to_nid(struct device_node *dp); -#else -#define of_node_to_nid(dp)	(-1) +#define of_node_to_nid of_node_to_nid  #endif  extern void prom_build_devicetree(void);  extern void of_populate_present_mask(void);  extern void of_fill_in_cpu_data(void); +struct resource; +extern void __iomem *of_ioremap(struct resource *res, unsigned long offset, unsigned long size, char *name); +extern void of_iounmap(struct resource *res, void __iomem *base, unsigned long size); +  /* These routines are here to provide compatibility with how powerpc   * handles IRQ mapping for OF device nodes.  We precompute and permanently - * register them in the of_device objects, whereas powerpc computes them + * register them in the platform_device objects, whereas powerpc computes them   * on request.   */ -extern unsigned int irq_of_parse_and_map(struct device_node *node, int index);  static inline void irq_dispose_mapping(unsigned int virq)  {  } diff --git a/arch/sparc/include/asm/rwsem-const.h b/arch/sparc/include/asm/rwsem-const.h deleted file mode 100644 index a303c9d..0000000 --- a/arch/sparc/include/asm/rwsem-const.h +++ /dev/null @@ -1,12 +0,0 @@ -/* rwsem-const.h: RW semaphore counter constants.  */ -#ifndef _SPARC64_RWSEM_CONST_H -#define _SPARC64_RWSEM_CONST_H - -#define RWSEM_UNLOCKED_VALUE		0x00000000 -#define RWSEM_ACTIVE_BIAS		0x00000001 -#define RWSEM_ACTIVE_MASK		0x0000ffff -#define RWSEM_WAITING_BIAS		0xffff0000 -#define RWSEM_ACTIVE_READ_BIAS		RWSEM_ACTIVE_BIAS -#define RWSEM_ACTIVE_WRITE_BIAS		(RWSEM_WAITING_BIAS + RWSEM_ACTIVE_BIAS) - -#endif /* _SPARC64_RWSEM_CONST_H */ diff --git a/arch/sparc/include/asm/rwsem.h b/arch/sparc/include/asm/rwsem.h index 6e56210..a2b4302 100644 --- a/arch/sparc/include/asm/rwsem.h +++ b/arch/sparc/include/asm/rwsem.h @@ -15,16 +15,21 @@  #include <linux/list.h>  #include <linux/spinlock.h> -#include <asm/rwsem-const.h>  struct rwsem_waiter;  struct rw_semaphore { -	signed int count; -	spinlock_t		wait_lock; -	struct list_head	wait_list; +	signed long			count; +#define RWSEM_UNLOCKED_VALUE		0x00000000L +#define RWSEM_ACTIVE_BIAS		0x00000001L +#define RWSEM_ACTIVE_MASK		0xffffffffL +#define RWSEM_WAITING_BIAS		(-RWSEM_ACTIVE_MASK-1) +#define RWSEM_ACTIVE_READ_BIAS		RWSEM_ACTIVE_BIAS +#define RWSEM_ACTIVE_WRITE_BIAS		(RWSEM_WAITING_BIAS + RWSEM_ACTIVE_BIAS) +	spinlock_t			wait_lock; +	struct list_head		wait_list;  #ifdef CONFIG_DEBUG_LOCK_ALLOC -	struct lockdep_map	dep_map; +	struct lockdep_map		dep_map;  #endif  }; @@ -41,6 +46,11 @@ struct rw_semaphore {  #define DECLARE_RWSEM(name) \  	struct rw_semaphore name = __RWSEM_INITIALIZER(name) +extern struct rw_semaphore *rwsem_down_read_failed(struct rw_semaphore *sem); +extern struct rw_semaphore *rwsem_down_write_failed(struct rw_semaphore *sem); +extern struct rw_semaphore *rwsem_wake(struct rw_semaphore *sem); +extern struct rw_semaphore *rwsem_downgrade_wake(struct rw_semaphore *sem); +  extern void __init_rwsem(struct rw_semaphore *sem, const char *name,  			 struct lock_class_key *key); @@ -51,27 +61,103 @@ do {								\  	__init_rwsem((sem), #sem, &__key);			\  } while (0) -extern void __down_read(struct rw_semaphore *sem); -extern int __down_read_trylock(struct rw_semaphore *sem); -extern void __down_write(struct rw_semaphore *sem); -extern int __down_write_trylock(struct rw_semaphore *sem); -extern void __up_read(struct rw_semaphore *sem); -extern void __up_write(struct rw_semaphore *sem); -extern void __downgrade_write(struct rw_semaphore *sem); +/* + * lock for reading + */ +static inline void __down_read(struct rw_semaphore *sem) +{ +	if (unlikely(atomic64_inc_return((atomic64_t *)(&sem->count)) <= 0L)) +		rwsem_down_read_failed(sem); +} + +static inline int __down_read_trylock(struct rw_semaphore *sem) +{ +	long tmp; + +	while ((tmp = sem->count) >= 0L) { +		if (tmp == cmpxchg(&sem->count, tmp, +				   tmp + RWSEM_ACTIVE_READ_BIAS)) { +			return 1; +		} +	} +	return 0; +} +/* + * lock for writing + */  static inline void __down_write_nested(struct rw_semaphore *sem, int subclass)  { -	__down_write(sem); +	long tmp; + +	tmp = atomic64_add_return(RWSEM_ACTIVE_WRITE_BIAS, +				  (atomic64_t *)(&sem->count)); +	if (unlikely(tmp != RWSEM_ACTIVE_WRITE_BIAS)) +		rwsem_down_write_failed(sem);  } -static inline int rwsem_atomic_update(int delta, struct rw_semaphore *sem) +static inline void __down_write(struct rw_semaphore *sem)  { -	return atomic_add_return(delta, (atomic_t *)(&sem->count)); +	__down_write_nested(sem, 0); +} + +static inline int __down_write_trylock(struct rw_semaphore *sem) +{ +	long tmp; + +	tmp = cmpxchg(&sem->count, RWSEM_UNLOCKED_VALUE, +		      RWSEM_ACTIVE_WRITE_BIAS); +	return tmp == RWSEM_UNLOCKED_VALUE;  } -static inline void rwsem_atomic_add(int delta, struct rw_semaphore *sem) +/* + * unlock after reading + */ +static inline void __up_read(struct rw_semaphore *sem) +{ +	long tmp; + +	tmp = atomic64_dec_return((atomic64_t *)(&sem->count)); +	if (unlikely(tmp < -1L && (tmp & RWSEM_ACTIVE_MASK) == 0L)) +		rwsem_wake(sem); +} + +/* + * unlock after writing + */ +static inline void __up_write(struct rw_semaphore *sem) +{ +	if (unlikely(atomic64_sub_return(RWSEM_ACTIVE_WRITE_BIAS, +					 (atomic64_t *)(&sem->count)) < 0L)) +		rwsem_wake(sem); +} + +/* + * implement atomic add functionality + */ +static inline void rwsem_atomic_add(long delta, struct rw_semaphore *sem) +{ +	atomic64_add(delta, (atomic64_t *)(&sem->count)); +} + +/* + * downgrade write lock to read lock + */ +static inline void __downgrade_write(struct rw_semaphore *sem) +{ +	long tmp; + +	tmp = atomic64_add_return(-RWSEM_WAITING_BIAS, (atomic64_t *)(&sem->count)); +	if (tmp < 0L) +		rwsem_downgrade_wake(sem); +} + +/* + * implement exchange and add functionality + */ +static inline long rwsem_atomic_update(long delta, struct rw_semaphore *sem)  { -	atomic_add(delta, (atomic_t *)(&sem->count)); +	return atomic64_add_return(delta, (atomic64_t *)(&sem->count));  }  static inline int rwsem_is_locked(struct rw_semaphore *sem) diff --git a/arch/sparc/include/asm/scatterlist.h b/arch/sparc/include/asm/scatterlist.h index 433e45f..92bb638 100644 --- a/arch/sparc/include/asm/scatterlist.h +++ b/arch/sparc/include/asm/scatterlist.h @@ -3,7 +3,6 @@  #include <asm-generic/scatterlist.h> -#define ISA_DMA_THRESHOLD	(~0UL)  #define ARCH_HAS_SG_CHAIN  #endif /* !(_SPARC_SCATTERLIST_H) */ diff --git a/arch/sparc/include/asm/system_64.h b/arch/sparc/include/asm/system_64.h index d24cfe1..e3b65d8 100644 --- a/arch/sparc/include/asm/system_64.h +++ b/arch/sparc/include/asm/system_64.h @@ -106,6 +106,7 @@ do {	__asm__ __volatile__("ba,pt	%%xcc, 1f\n\t" \   */  #define write_pic(__p)  					\  	__asm__ __volatile__("ba,pt	%%xcc, 99f\n\t"		\ +			     " nop\n\t"				\  			     ".align	64\n"			\  			  "99:wr	%0, 0x0, %%pic\n\t"	\  			     "rd	%%pic, %%g0" : : "r" (__p)) diff --git a/arch/sparc/include/asm/termbits.h b/arch/sparc/include/asm/termbits.h index d72dfed..23b10ff 100644 --- a/arch/sparc/include/asm/termbits.h +++ b/arch/sparc/include/asm/termbits.h @@ -225,6 +225,7 @@ struct ktermios {  #define FLUSHO	0x00002000  #define PENDIN	0x00004000  #define IEXTEN	0x00008000 +#define EXTPROC	0x00010000  /* modem lines */  #define TIOCM_LE	0x001 diff --git a/arch/sparc/include/asm/uaccess_32.h b/arch/sparc/include/asm/uaccess_32.h index 25f1d10..8303ac4 100644 --- a/arch/sparc/include/asm/uaccess_32.h +++ b/arch/sparc/include/asm/uaccess_32.h @@ -260,23 +260,8 @@ static inline unsigned long __copy_to_user(void __user *to, const void *from, un  	return __copy_user(to, (__force void __user *) from, n);  } -extern void copy_from_user_overflow(void) -#ifdef CONFIG_DEBUG_STRICT_USER_COPY_CHECKS -	__compiletime_error("copy_from_user() buffer size is not provably correct") -#else -	__compiletime_warning("copy_from_user() buffer size is not provably correct") -#endif -; -  static inline unsigned long copy_from_user(void *to, const void __user *from, unsigned long n)  { -	int sz = __compiletime_object_size(to); - -	if (unlikely(sz != -1 && sz < n)) { -		copy_from_user_overflow(); -		return n; -	} -  	if (n && __access_ok((unsigned long) from, n))  		return __copy_user((__force void __user *) to, from, n);  	else diff --git a/arch/sparc/include/asm/uaccess_64.h b/arch/sparc/include/asm/uaccess_64.h index 2406788..3e1449f 100644 --- a/arch/sparc/include/asm/uaccess_64.h +++ b/arch/sparc/include/asm/uaccess_64.h @@ -205,14 +205,6 @@ __asm__ __volatile__(							\  extern int __get_user_bad(void); -extern void copy_from_user_overflow(void) -#ifdef CONFIG_DEBUG_STRICT_USER_COPY_CHECKS -	__compiletime_error("copy_from_user() buffer size is not provably correct") -#else -	__compiletime_warning("copy_from_user() buffer size is not provably correct") -#endif -; -  extern unsigned long __must_check ___copy_from_user(void *to,  						    const void __user *from,  						    unsigned long size); @@ -221,16 +213,11 @@ extern unsigned long copy_from_user_fixup(void *to, const void __user *from,  static inline unsigned long __must_check  copy_from_user(void *to, const void __user *from, unsigned long size)  { -	int sz = __compiletime_object_size(to); -	unsigned long ret = size; - -	if (likely(sz == -1 || sz >= size)) { -		ret = ___copy_from_user(to, from, size); -		if (unlikely(ret)) -			ret = copy_from_user_fixup(to, from, size); -	} else { -		copy_from_user_overflow(); -	} +	unsigned long ret = ___copy_from_user(to, from, size); + +	if (unlikely(ret)) +		ret = copy_from_user_fixup(to, from, size); +  	return ret;  }  #define __copy_from_user copy_from_user diff --git a/arch/sparc/include/asm/unistd.h b/arch/sparc/include/asm/unistd.h index d0b3b01..03eb5a8 100644 --- a/arch/sparc/include/asm/unistd.h +++ b/arch/sparc/include/asm/unistd.h @@ -397,8 +397,11 @@  #define __NR_rt_tgsigqueueinfo	326  #define __NR_perf_event_open	327  #define __NR_recvmmsg		328 +#define __NR_fanotify_init	329 +#define __NR_fanotify_mark	330 +#define __NR_prlimit64		331 -#define NR_syscalls		329 +#define NR_syscalls		332  #ifdef __32bit_syscall_numbers__  /* Sparc 32-bit only has the "setresuid32", "getresuid32" variants, diff --git a/arch/sparc/kernel/apc.c b/arch/sparc/kernel/apc.c index b27476c..2c0046e 100644 --- a/arch/sparc/kernel/apc.c +++ b/arch/sparc/kernel/apc.c @@ -68,7 +68,7 @@ static void apc_swift_idle(void)  #endif  }  -static inline void apc_free(struct of_device *op) +static inline void apc_free(struct platform_device *op)  {  	of_iounmap(&op->resource[0], regs, resource_size(&op->resource[0]));  } @@ -136,7 +136,7 @@ static const struct file_operations apc_fops = {  static struct miscdevice apc_miscdev = { APC_MINOR, APC_DEVNAME, &apc_fops }; -static int __devinit apc_probe(struct of_device *op, +static int __devinit apc_probe(struct platform_device *op,  			       const struct of_device_id *match)  {  	int err; @@ -184,7 +184,7 @@ static struct of_platform_driver apc_driver = {  static int __init apc_init(void)  { -	return of_register_driver(&apc_driver, &of_bus_type); +	return of_register_platform_driver(&apc_driver);  }  /* This driver is not critical to the boot process diff --git a/arch/sparc/kernel/auxio_64.c b/arch/sparc/kernel/auxio_64.c index ddc8412..3efd3c5 100644 --- a/arch/sparc/kernel/auxio_64.c +++ b/arch/sparc/kernel/auxio_64.c @@ -102,7 +102,8 @@ static struct of_device_id __initdata auxio_match[] = {  MODULE_DEVICE_TABLE(of, auxio_match); -static int __devinit auxio_probe(struct of_device *dev, const struct of_device_id *match) +static int __devinit auxio_probe(struct platform_device *dev, +				 const struct of_device_id *match)  {  	struct device_node *dp = dev->dev.of_node;  	unsigned long size; @@ -142,7 +143,7 @@ static struct of_platform_driver auxio_driver = {  static int __init auxio_init(void)  { -	return of_register_driver(&auxio_driver, &of_platform_bus_type); +	return of_register_platform_driver(&auxio_driver);  }  /* Must be after subsys_initcall() so that busses are probed.  Must diff --git a/arch/sparc/kernel/central.c b/arch/sparc/kernel/central.c index 434335f..cfa2624 100644 --- a/arch/sparc/kernel/central.c +++ b/arch/sparc/kernel/central.c @@ -59,7 +59,7 @@ static int __devinit clock_board_calc_nslots(struct clock_board *p)  	}  } -static int __devinit clock_board_probe(struct of_device *op, +static int __devinit clock_board_probe(struct platform_device *op,  				       const struct of_device_id *match)  {  	struct clock_board *p = kzalloc(sizeof(*p), GFP_KERNEL); @@ -157,7 +157,7 @@ static struct of_platform_driver clock_board_driver = {  	},  }; -static int __devinit fhc_probe(struct of_device *op, +static int __devinit fhc_probe(struct platform_device *op,  			       const struct of_device_id *match)  {  	struct fhc *p = kzalloc(sizeof(*p), GFP_KERNEL); @@ -265,8 +265,8 @@ static struct of_platform_driver fhc_driver = {  static int __init sunfire_init(void)  { -	(void) of_register_driver(&fhc_driver, &of_platform_bus_type); -	(void) of_register_driver(&clock_board_driver, &of_platform_bus_type); +	(void) of_register_platform_driver(&fhc_driver); +	(void) of_register_platform_driver(&clock_board_driver);  	return 0;  } diff --git a/arch/sparc/kernel/chmc.c b/arch/sparc/kernel/chmc.c index 870cb65..08c466e 100644 --- a/arch/sparc/kernel/chmc.c +++ b/arch/sparc/kernel/chmc.c @@ -392,7 +392,7 @@ static void __devinit jbusmc_construct_dimm_groups(struct jbusmc *p,  	}  } -static int __devinit jbusmc_probe(struct of_device *op, +static int __devinit jbusmc_probe(struct platform_device *op,  				  const struct of_device_id *match)  {  	const struct linux_prom64_registers *mem_regs; @@ -690,7 +690,7 @@ static void chmc_fetch_decode_regs(struct chmc *p)  				      chmc_read_mcreg(p, CHMCTRL_DECODE4));  } -static int __devinit chmc_probe(struct of_device *op, +static int __devinit chmc_probe(struct platform_device *op,  				const struct of_device_id *match)  {  	struct device_node *dp = op->dev.of_node; @@ -765,7 +765,7 @@ out_free:  	goto out;  } -static int __devinit us3mc_probe(struct of_device *op, +static int __devinit us3mc_probe(struct platform_device *op,  				const struct of_device_id *match)  {  	if (mc_type == MC_TYPE_SAFARI) @@ -775,21 +775,21 @@ static int __devinit us3mc_probe(struct of_device *op,  	return -ENODEV;  } -static void __devexit chmc_destroy(struct of_device *op, struct chmc *p) +static void __devexit chmc_destroy(struct platform_device *op, struct chmc *p)  {  	list_del(&p->list);  	of_iounmap(&op->resource[0], p->regs, 0x48);  	kfree(p);  } -static void __devexit jbusmc_destroy(struct of_device *op, struct jbusmc *p) +static void __devexit jbusmc_destroy(struct platform_device *op, struct jbusmc *p)  {  	mc_list_del(&p->list);  	of_iounmap(&op->resource[0], p->regs, JBUSMC_REGS_SIZE);  	kfree(p);  } -static int __devexit us3mc_remove(struct of_device *op) +static int __devexit us3mc_remove(struct platform_device *op)  {  	void *p = dev_get_drvdata(&op->dev); @@ -848,7 +848,7 @@ static int __init us3mc_init(void)  	ret = register_dimm_printer(us3mc_dimm_printer);  	if (!ret) { -		ret = of_register_driver(&us3mc_driver, &of_bus_type); +		ret = of_register_platform_driver(&us3mc_driver);  		if (ret)  			unregister_dimm_printer(us3mc_dimm_printer);  	} @@ -859,7 +859,7 @@ static void __exit us3mc_cleanup(void)  {  	if (us3mc_platform()) {  		unregister_dimm_printer(us3mc_dimm_printer); -		of_unregister_driver(&us3mc_driver); +		of_unregister_platform_driver(&us3mc_driver);  	}  } diff --git a/arch/sparc/kernel/helpers.S b/arch/sparc/kernel/helpers.S index 92090cc..314dd0c 100644 --- a/arch/sparc/kernel/helpers.S +++ b/arch/sparc/kernel/helpers.S @@ -46,81 +46,6 @@ stack_trace_flush:  	 nop  	.size		stack_trace_flush,.-stack_trace_flush -#ifdef CONFIG_PERF_EVENTS -	.globl		perf_arch_fetch_caller_regs -	.type		perf_arch_fetch_caller_regs,#function -perf_arch_fetch_caller_regs: -	/* We always read the %pstate into %o5 since we will use -	 * that to construct a fake %tstate to store into the regs. -	 */ -	rdpr		%pstate, %o5 -	brz,pn		%o2, 50f -	 mov		%o2, %g7 - -	/* Turn off interrupts while we walk around the register -	 * window by hand. -	 */ -	wrpr		%o5, PSTATE_IE, %pstate - -	/* The %canrestore tells us how many register windows are -	 * still live in the chip above us, past that we have to -	 * walk the frame as saved on the stack.   We stash away -	 * the %cwp in %g1 so we can return back to the original -	 * register window. -	 */ -	rdpr		%cwp, %g1 -	rdpr		%canrestore, %g2 -	sub		%g1, 1, %g3 - -	/* We have the skip count in %g7, if it hits zero then -	 * %fp/%i7 are the registers we need.  Otherwise if our -	 * %canrestore count maintained in %g2 hits zero we have -	 * to start traversing the stack. -	 */ -10:	brz,pn		%g2, 4f -	 sub		%g2, 1, %g2 -	wrpr		%g3, %cwp -	subcc		%g7, 1, %g7 -	bne,pt		%xcc, 10b -	 sub		%g3, 1, %g3 - -	/* We found the values we need in the cpu's register -	 * windows. -	 */ -	mov		%fp, %g3 -	ba,pt		%xcc, 3f -	 mov		%i7, %g2 - -50:	mov		%fp, %g3 -	ba,pt		%xcc, 2f -	 mov		%i7, %g2 - -	/* We hit the end of the valid register windows in the -	 * cpu, start traversing the stack frame. -	 */ -4:	mov		%fp, %g3 - -20:	ldx		[%g3 + STACK_BIAS + RW_V9_I7], %g2 -	subcc		%g7, 1, %g7 -	bne,pn		%xcc, 20b -	 ldx		[%g3 + STACK_BIAS + RW_V9_I6], %g3 - -	/* Restore the current register window position and -	 * re-enable interrupts. -	 */ -3:	wrpr		%g1, %cwp -	wrpr		%o5, %pstate - -2:	stx		%g3, [%o0 + PT_V9_FP] -	sllx		%o5, 8, %o5 -	stx		%o5, [%o0 + PT_V9_TSTATE] -	stx		%g2, [%o0 + PT_V9_TPC] -	add		%g2, 4, %g2 -	retl -	 stx		%g2, [%o0 + PT_V9_TNPC] -	.size		perf_arch_fetch_caller_regs,.-perf_arch_fetch_caller_regs -#endif /* CONFIG_PERF_EVENTS */ -  #ifdef CONFIG_SMP  	.globl		hard_smp_processor_id  	.type		hard_smp_processor_id,#function diff --git a/arch/sparc/kernel/ioport.c b/arch/sparc/kernel/ioport.c index 703e4aa..41f7e4e 100644 --- a/arch/sparc/kernel/ioport.c +++ b/arch/sparc/kernel/ioport.c @@ -253,7 +253,7 @@ EXPORT_SYMBOL(sbus_set_sbus64);  static void *sbus_alloc_coherent(struct device *dev, size_t len,  				 dma_addr_t *dma_addrp, gfp_t gfp)  { -	struct of_device *op = to_of_device(dev); +	struct platform_device *op = to_platform_device(dev);  	unsigned long len_total = (len + PAGE_SIZE-1) & PAGE_MASK;  	unsigned long va;  	struct resource *res; diff --git a/arch/sparc/kernel/of_device_32.c b/arch/sparc/kernel/of_device_32.c index 47e63f1..2d055a1 100644 --- a/arch/sparc/kernel/of_device_32.c +++ b/arch/sparc/kernel/of_device_32.c @@ -241,10 +241,10 @@ static int __init use_1to1_mapping(struct device_node *pp)  static int of_resource_verbose; -static void __init build_device_resources(struct of_device *op, +static void __init build_device_resources(struct platform_device *op,  					  struct device *parent)  { -	struct of_device *p_op; +	struct platform_device *p_op;  	struct of_bus *bus;  	int na, ns;  	int index, num_reg; @@ -253,7 +253,7 @@ static void __init build_device_resources(struct of_device *op,  	if (!parent)  		return; -	p_op = to_of_device(parent); +	p_op = to_platform_device(parent);  	bus = of_match_bus(p_op->dev.of_node);  	bus->count_cells(op->dev.of_node, &na, &ns); @@ -267,6 +267,8 @@ static void __init build_device_resources(struct of_device *op,  	/* Conver to num-entries.  */  	num_reg /= na + ns; +	op->resource = op->archdata.resource; +	op->num_resources = num_reg;  	for (index = 0; index < num_reg; index++) {  		struct resource *r = &op->resource[index];  		u32 addr[OF_MAX_ADDR_CELLS]; @@ -333,10 +335,10 @@ static void __init build_device_resources(struct of_device *op,  	}  } -static struct of_device * __init scan_one_device(struct device_node *dp, +static struct platform_device * __init scan_one_device(struct device_node *dp,  						 struct device *parent)  { -	struct of_device *op = kzalloc(sizeof(*op), GFP_KERNEL); +	struct platform_device *op = kzalloc(sizeof(*op), GFP_KERNEL);  	const struct linux_prom_irqs *intr;  	struct dev_archdata *sd;  	int len, i; @@ -349,27 +351,21 @@ static struct of_device * __init scan_one_device(struct device_node *dp,  	op->dev.of_node = dp; -	op->clock_freq = of_getintprop_default(dp, "clock-frequency", -					       (25*1000*1000)); -	op->portid = of_getintprop_default(dp, "upa-portid", -1); -	if (op->portid == -1) -		op->portid = of_getintprop_default(dp, "portid", -1); -  	intr = of_get_property(dp, "intr", &len);  	if (intr) { -		op->num_irqs = len / sizeof(struct linux_prom_irqs); -		for (i = 0; i < op->num_irqs; i++) -			op->irqs[i] = intr[i].pri; +		op->archdata.num_irqs = len / sizeof(struct linux_prom_irqs); +		for (i = 0; i < op->archdata.num_irqs; i++) +			op->archdata.irqs[i] = intr[i].pri;  	} else {  		const unsigned int *irq =  			of_get_property(dp, "interrupts", &len);  		if (irq) { -			op->num_irqs = len / sizeof(unsigned int); -			for (i = 0; i < op->num_irqs; i++) -				op->irqs[i] = irq[i]; +			op->archdata.num_irqs = len / sizeof(unsigned int); +			for (i = 0; i < op->archdata.num_irqs; i++) +				op->archdata.irqs[i] = irq[i];  		} else { -			op->num_irqs = 0; +			op->archdata.num_irqs = 0;  		}  	}  	if (sparc_cpu_model == sun4d) { @@ -411,8 +407,8 @@ static struct of_device * __init scan_one_device(struct device_node *dp,  			goto build_resources;  		} -		for (i = 0; i < op->num_irqs; i++) { -			int this_irq = op->irqs[i]; +		for (i = 0; i < op->archdata.num_irqs; i++) { +			int this_irq = op->archdata.irqs[i];  			int sbusl = pil_to_sbus[this_irq];  			if (sbusl) @@ -420,7 +416,7 @@ static struct of_device * __init scan_one_device(struct device_node *dp,  					    (sbusl << 2) +  					    slot); -			op->irqs[i] = this_irq; +			op->archdata.irqs[i] = this_irq;  		}  	} @@ -428,7 +424,7 @@ build_resources:  	build_device_resources(op, parent);  	op->dev.parent = parent; -	op->dev.bus = &of_platform_bus_type; +	op->dev.bus = &platform_bus_type;  	if (!parent)  		dev_set_name(&op->dev, "root");  	else @@ -447,7 +443,7 @@ build_resources:  static void __init scan_tree(struct device_node *dp, struct device *parent)  {  	while (dp) { -		struct of_device *op = scan_one_device(dp, parent); +		struct platform_device *op = scan_one_device(dp, parent);  		if (op)  			scan_tree(dp->child, &op->dev); @@ -456,30 +452,19 @@ static void __init scan_tree(struct device_node *dp, struct device *parent)  	}  } -static void __init scan_of_devices(void) +static int __init scan_of_devices(void)  {  	struct device_node *root = of_find_node_by_path("/"); -	struct of_device *parent; +	struct platform_device *parent;  	parent = scan_one_device(root, NULL);  	if (!parent) -		return; +		return 0;  	scan_tree(root->child, &parent->dev); +	return 0;  } - -static int __init of_bus_driver_init(void) -{ -	int err; - -	err = of_bus_type_init(&of_platform_bus_type, "of"); -	if (!err) -		scan_of_devices(); - -	return err; -} - -postcore_initcall(of_bus_driver_init); +postcore_initcall(scan_of_devices);  static int __init of_debug(char *str)  { diff --git a/arch/sparc/kernel/of_device_64.c b/arch/sparc/kernel/of_device_64.c index 1dae807..63cd4e5 100644 --- a/arch/sparc/kernel/of_device_64.c +++ b/arch/sparc/kernel/of_device_64.c @@ -310,10 +310,10 @@ static int __init use_1to1_mapping(struct device_node *pp)  static int of_resource_verbose; -static void __init build_device_resources(struct of_device *op, +static void __init build_device_resources(struct platform_device *op,  					  struct device *parent)  { -	struct of_device *p_op; +	struct platform_device *p_op;  	struct of_bus *bus;  	int na, ns;  	int index, num_reg; @@ -322,7 +322,7 @@ static void __init build_device_resources(struct of_device *op,  	if (!parent)  		return; -	p_op = to_of_device(parent); +	p_op = to_platform_device(parent);  	bus = of_match_bus(p_op->dev.of_node);  	bus->count_cells(op->dev.of_node, &na, &ns); @@ -344,6 +344,8 @@ static void __init build_device_resources(struct of_device *op,  		num_reg = PROMREG_MAX;  	} +	op->resource = op->archdata.resource; +	op->num_resources = num_reg;  	for (index = 0; index < num_reg; index++) {  		struct resource *r = &op->resource[index];  		u32 addr[OF_MAX_ADDR_CELLS]; @@ -526,7 +528,7 @@ static unsigned int __init pci_irq_swizzle(struct device_node *dp,  static int of_irq_verbose; -static unsigned int __init build_one_device_irq(struct of_device *op, +static unsigned int __init build_one_device_irq(struct platform_device *op,  						struct device *parent,  						unsigned int irq)  { @@ -628,10 +630,10 @@ out:  	return irq;  } -static struct of_device * __init scan_one_device(struct device_node *dp, +static struct platform_device * __init scan_one_device(struct device_node *dp,  						 struct device *parent)  { -	struct of_device *op = kzalloc(sizeof(*op), GFP_KERNEL); +	struct platform_device *op = kzalloc(sizeof(*op), GFP_KERNEL);  	const unsigned int *irq;  	struct dev_archdata *sd;  	int len, i; @@ -644,34 +646,28 @@ static struct of_device * __init scan_one_device(struct device_node *dp,  	op->dev.of_node = dp; -	op->clock_freq = of_getintprop_default(dp, "clock-frequency", -					       (25*1000*1000)); -	op->portid = of_getintprop_default(dp, "upa-portid", -1); -	if (op->portid == -1) -		op->portid = of_getintprop_default(dp, "portid", -1); -  	irq = of_get_property(dp, "interrupts", &len);  	if (irq) { -		op->num_irqs = len / 4; +		op->archdata.num_irqs = len / 4;  		/* Prevent overrunning the op->irqs[] array.  */ -		if (op->num_irqs > PROMINTR_MAX) { +		if (op->archdata.num_irqs > PROMINTR_MAX) {  			printk(KERN_WARNING "%s: Too many irqs (%d), "  			       "limiting to %d.\n", -			       dp->full_name, op->num_irqs, PROMINTR_MAX); -			op->num_irqs = PROMINTR_MAX; +			       dp->full_name, op->archdata.num_irqs, PROMINTR_MAX); +			op->archdata.num_irqs = PROMINTR_MAX;  		} -		memcpy(op->irqs, irq, op->num_irqs * 4); +		memcpy(op->archdata.irqs, irq, op->archdata.num_irqs * 4);  	} else { -		op->num_irqs = 0; +		op->archdata.num_irqs = 0;  	}  	build_device_resources(op, parent); -	for (i = 0; i < op->num_irqs; i++) -		op->irqs[i] = build_one_device_irq(op, parent, op->irqs[i]); +	for (i = 0; i < op->archdata.num_irqs; i++) +		op->archdata.irqs[i] = build_one_device_irq(op, parent, op->archdata.irqs[i]);  	op->dev.parent = parent; -	op->dev.bus = &of_platform_bus_type; +	op->dev.bus = &platform_bus_type;  	if (!parent)  		dev_set_name(&op->dev, "root");  	else @@ -690,7 +686,7 @@ static struct of_device * __init scan_one_device(struct device_node *dp,  static void __init scan_tree(struct device_node *dp, struct device *parent)  {  	while (dp) { -		struct of_device *op = scan_one_device(dp, parent); +		struct platform_device *op = scan_one_device(dp, parent);  		if (op)  			scan_tree(dp->child, &op->dev); @@ -699,30 +695,19 @@ static void __init scan_tree(struct device_node *dp, struct device *parent)  	}  } -static void __init scan_of_devices(void) +static int __init scan_of_devices(void)  {  	struct device_node *root = of_find_node_by_path("/"); -	struct of_device *parent; +	struct platform_device *parent;  	parent = scan_one_device(root, NULL);  	if (!parent) -		return; +		return 0;  	scan_tree(root->child, &parent->dev); +	return 0;  } - -static int __init of_bus_driver_init(void) -{ -	int err; - -	err = of_bus_type_init(&of_platform_bus_type, "of"); -	if (!err) -		scan_of_devices(); - -	return err; -} - -postcore_initcall(of_bus_driver_init); +postcore_initcall(scan_of_devices);  static int __init of_debug(char *str)  { diff --git a/arch/sparc/kernel/of_device_common.c b/arch/sparc/kernel/of_device_common.c index 10c6c36..49ddff5 100644 --- a/arch/sparc/kernel/of_device_common.c +++ b/arch/sparc/kernel/of_device_common.c @@ -11,48 +11,28 @@  #include "of_device_common.h" -static int node_match(struct device *dev, void *data) -{ -	struct of_device *op = to_of_device(dev); -	struct device_node *dp = data; - -	return (op->dev.of_node == dp); -} - -struct of_device *of_find_device_by_node(struct device_node *dp) -{ -	struct device *dev = bus_find_device(&of_platform_bus_type, NULL, -					     dp, node_match); - -	if (dev) -		return to_of_device(dev); - -	return NULL; -} -EXPORT_SYMBOL(of_find_device_by_node); -  unsigned int irq_of_parse_and_map(struct device_node *node, int index)  { -	struct of_device *op = of_find_device_by_node(node); +	struct platform_device *op = of_find_device_by_node(node); -	if (!op || index >= op->num_irqs) +	if (!op || index >= op->archdata.num_irqs)  		return 0; -	return op->irqs[index]; +	return op->archdata.irqs[index];  }  EXPORT_SYMBOL(irq_of_parse_and_map);  /* Take the archdata values for IOMMU, STC, and HOSTDATA found in - * BUS and propagate to all child of_device objects. + * BUS and propagate to all child platform_device objects.   */ -void of_propagate_archdata(struct of_device *bus) +void of_propagate_archdata(struct platform_device *bus)  {  	struct dev_archdata *bus_sd = &bus->dev.archdata;  	struct device_node *bus_dp = bus->dev.of_node;  	struct device_node *dp;  	for (dp = bus_dp->child; dp; dp = dp->sibling) { -		struct of_device *op = of_find_device_by_node(dp); +		struct platform_device *op = of_find_device_by_node(dp);  		op->dev.archdata.iommu = bus_sd->iommu;  		op->dev.archdata.stc = bus_sd->stc; @@ -64,9 +44,6 @@ void of_propagate_archdata(struct of_device *bus)  	}  } -struct bus_type of_platform_bus_type; -EXPORT_SYMBOL(of_platform_bus_type); -  static void get_cells(struct device_node *dp, int *addrc, int *sizec)  {  	if (addrc) diff --git a/arch/sparc/kernel/pci.c b/arch/sparc/kernel/pci.c index 8a8363a..4137579 100644 --- a/arch/sparc/kernel/pci.c +++ b/arch/sparc/kernel/pci.c @@ -198,7 +198,7 @@ static unsigned long pci_parse_of_flags(u32 addr0)   * into physical address resources, we only have to figure out the register   * mapping.   */ -static void pci_parse_of_addrs(struct of_device *op, +static void pci_parse_of_addrs(struct platform_device *op,  			       struct device_node *node,  			       struct pci_dev *dev)  { @@ -248,7 +248,7 @@ static struct pci_dev *of_create_pci_dev(struct pci_pbm_info *pbm,  {  	struct dev_archdata *sd;  	struct pci_slot *slot; -	struct of_device *op; +	struct platform_device *op;  	struct pci_dev *dev;  	const char *type;  	u32 class; @@ -340,7 +340,7 @@ static struct pci_dev *of_create_pci_dev(struct pci_pbm_info *pbm,  		dev->hdr_type = PCI_HEADER_TYPE_NORMAL;  		dev->rom_base_reg = PCI_ROM_ADDRESS; -		dev->irq = sd->op->irqs[0]; +		dev->irq = sd->op->archdata.irqs[0];  		if (dev->irq == 0xffffffff)  			dev->irq = PCI_IRQ_NONE;  	} diff --git a/arch/sparc/kernel/pci_fire.c b/arch/sparc/kernel/pci_fire.c index 51cfa09..efb896d 100644 --- a/arch/sparc/kernel/pci_fire.c +++ b/arch/sparc/kernel/pci_fire.c @@ -410,7 +410,7 @@ static void pci_fire_hw_init(struct pci_pbm_info *pbm)  }  static int __devinit pci_fire_pbm_init(struct pci_pbm_info *pbm, -				       struct of_device *op, u32 portid) +				       struct platform_device *op, u32 portid)  {  	const struct linux_prom64_registers *regs;  	struct device_node *dp = op->dev.of_node; @@ -455,7 +455,7 @@ static int __devinit pci_fire_pbm_init(struct pci_pbm_info *pbm,  	return 0;  } -static int __devinit fire_probe(struct of_device *op, +static int __devinit fire_probe(struct platform_device *op,  				const struct of_device_id *match)  {  	struct device_node *dp = op->dev.of_node; @@ -518,7 +518,7 @@ static struct of_platform_driver fire_driver = {  static int __init fire_init(void)  { -	return of_register_driver(&fire_driver, &of_bus_type); +	return of_register_platform_driver(&fire_driver);  }  subsys_initcall(fire_init); diff --git a/arch/sparc/kernel/pci_impl.h b/arch/sparc/kernel/pci_impl.h index 0318682..e20ed5f 100644 --- a/arch/sparc/kernel/pci_impl.h +++ b/arch/sparc/kernel/pci_impl.h @@ -91,7 +91,7 @@ struct pci_pbm_info {  	char				*name;  	/* OBP specific information. */ -	struct of_device		*op; +	struct platform_device		*op;  	u64				ino_bitmap;  	/* PBM I/O and Memory space resources. */ diff --git a/arch/sparc/kernel/pci_psycho.c b/arch/sparc/kernel/pci_psycho.c index 558a705..22eab7c 100644 --- a/arch/sparc/kernel/pci_psycho.c +++ b/arch/sparc/kernel/pci_psycho.c @@ -285,7 +285,7 @@ static irqreturn_t psycho_ce_intr(int irq, void *dev_id)  #define  PSYCHO_ECCCTRL_CE	 0x2000000000000000UL /* Enable CE INterrupts */  static void psycho_register_error_handlers(struct pci_pbm_info *pbm)  { -	struct of_device *op = of_find_device_by_node(pbm->op->dev.of_node); +	struct platform_device *op = of_find_device_by_node(pbm->op->dev.of_node);  	unsigned long base = pbm->controller_regs;  	u64 tmp;  	int err; @@ -302,23 +302,23 @@ static void psycho_register_error_handlers(struct pci_pbm_info *pbm)  	 * 5: POWER MANAGEMENT  	 */ -	if (op->num_irqs < 6) +	if (op->archdata.num_irqs < 6)  		return;  	/* We really mean to ignore the return result here.  Two  	 * PCI controller share the same interrupt numbers and  	 * drive the same front-end hardware.  	 */ -	err = request_irq(op->irqs[1], psycho_ue_intr, IRQF_SHARED, +	err = request_irq(op->archdata.irqs[1], psycho_ue_intr, IRQF_SHARED,  			  "PSYCHO_UE", pbm); -	err = request_irq(op->irqs[2], psycho_ce_intr, IRQF_SHARED, +	err = request_irq(op->archdata.irqs[2], psycho_ce_intr, IRQF_SHARED,  			  "PSYCHO_CE", pbm);  	/* This one, however, ought not to fail.  We can just warn  	 * about it since the system can still operate properly even  	 * if this fails.  	 */ -	err = request_irq(op->irqs[0], psycho_pcierr_intr, IRQF_SHARED, +	err = request_irq(op->archdata.irqs[0], psycho_pcierr_intr, IRQF_SHARED,  			  "PSYCHO_PCIERR", pbm);  	if (err)  		printk(KERN_WARNING "%s: Could not register PCIERR, " @@ -483,7 +483,7 @@ static void psycho_pbm_strbuf_init(struct pci_pbm_info *pbm,  #define PSYCHO_MEMSPACE_SIZE	0x07fffffffUL  static void __devinit psycho_pbm_init(struct pci_pbm_info *pbm, -				      struct of_device *op, int is_pbm_a) +				      struct platform_device *op, int is_pbm_a)  {  	psycho_pbm_init_common(pbm, op, "PSYCHO", PBM_CHIP_TYPE_PSYCHO);  	psycho_pbm_strbuf_init(pbm, is_pbm_a); @@ -503,7 +503,7 @@ static struct pci_pbm_info * __devinit psycho_find_sibling(u32 upa_portid)  #define PSYCHO_CONFIGSPACE	0x001000000UL -static int __devinit psycho_probe(struct of_device *op, +static int __devinit psycho_probe(struct platform_device *op,  				  const struct of_device_id *match)  {  	const struct linux_prom64_registers *pr_regs; @@ -612,7 +612,7 @@ static struct of_platform_driver psycho_driver = {  static int __init psycho_init(void)  { -	return of_register_driver(&psycho_driver, &of_bus_type); +	return of_register_platform_driver(&psycho_driver);  }  subsys_initcall(psycho_init); diff --git a/arch/sparc/kernel/pci_sabre.c b/arch/sparc/kernel/pci_sabre.c index 6dad8e3..5c3f5ec 100644 --- a/arch/sparc/kernel/pci_sabre.c +++ b/arch/sparc/kernel/pci_sabre.c @@ -311,7 +311,7 @@ static irqreturn_t sabre_ce_intr(int irq, void *dev_id)  static void sabre_register_error_handlers(struct pci_pbm_info *pbm)  {  	struct device_node *dp = pbm->op->dev.of_node; -	struct of_device *op; +	struct platform_device *op;  	unsigned long base = pbm->controller_regs;  	u64 tmp;  	int err; @@ -329,7 +329,7 @@ static void sabre_register_error_handlers(struct pci_pbm_info *pbm)  	 * 2: CE ERR  	 * 3: POWER FAIL  	 */ -	if (op->num_irqs < 4) +	if (op->archdata.num_irqs < 4)  		return;  	/* We clear the error bits in the appropriate AFSR before @@ -341,7 +341,7 @@ static void sabre_register_error_handlers(struct pci_pbm_info *pbm)  		    SABRE_UEAFSR_SDTE | SABRE_UEAFSR_PDTE),  		   base + SABRE_UE_AFSR); -	err = request_irq(op->irqs[1], sabre_ue_intr, 0, "SABRE_UE", pbm); +	err = request_irq(op->archdata.irqs[1], sabre_ue_intr, 0, "SABRE_UE", pbm);  	if (err)  		printk(KERN_WARNING "%s: Couldn't register UE, err=%d.\n",  		       pbm->name, err); @@ -351,11 +351,11 @@ static void sabre_register_error_handlers(struct pci_pbm_info *pbm)  		   base + SABRE_CE_AFSR); -	err = request_irq(op->irqs[2], sabre_ce_intr, 0, "SABRE_CE", pbm); +	err = request_irq(op->archdata.irqs[2], sabre_ce_intr, 0, "SABRE_CE", pbm);  	if (err)  		printk(KERN_WARNING "%s: Couldn't register CE, err=%d.\n",  		       pbm->name, err); -	err = request_irq(op->irqs[0], psycho_pcierr_intr, 0, +	err = request_irq(op->archdata.irqs[0], psycho_pcierr_intr, 0,  			  "SABRE_PCIERR", pbm);  	if (err)  		printk(KERN_WARNING "%s: Couldn't register PCIERR, err=%d.\n", @@ -443,7 +443,7 @@ static void __devinit sabre_scan_bus(struct pci_pbm_info *pbm,  }  static void __devinit sabre_pbm_init(struct pci_pbm_info *pbm, -				     struct of_device *op) +				     struct platform_device *op)  {  	psycho_pbm_init_common(pbm, op, "SABRE", PBM_CHIP_TYPE_SABRE);  	pbm->pci_afsr = pbm->controller_regs + SABRE_PIOAFSR; @@ -452,7 +452,7 @@ static void __devinit sabre_pbm_init(struct pci_pbm_info *pbm,  	sabre_scan_bus(pbm, &op->dev);  } -static int __devinit sabre_probe(struct of_device *op, +static int __devinit sabre_probe(struct platform_device *op,  				 const struct of_device_id *match)  {  	const struct linux_prom64_registers *pr_regs; @@ -606,7 +606,7 @@ static struct of_platform_driver sabre_driver = {  static int __init sabre_init(void)  { -	return of_register_driver(&sabre_driver, &of_bus_type); +	return of_register_platform_driver(&sabre_driver);  }  subsys_initcall(sabre_init); diff --git a/arch/sparc/kernel/pci_schizo.c b/arch/sparc/kernel/pci_schizo.c index 97a1ae2..445a47a 100644 --- a/arch/sparc/kernel/pci_schizo.c +++ b/arch/sparc/kernel/pci_schizo.c @@ -844,7 +844,7 @@ static int pbm_routes_this_ino(struct pci_pbm_info *pbm, u32 ino)   */  static void tomatillo_register_error_handlers(struct pci_pbm_info *pbm)  { -	struct of_device *op = of_find_device_by_node(pbm->op->dev.of_node); +	struct platform_device *op = of_find_device_by_node(pbm->op->dev.of_node);  	u64 tmp, err_mask, err_no_mask;  	int err; @@ -857,14 +857,14 @@ static void tomatillo_register_error_handlers(struct pci_pbm_info *pbm)  	 */  	if (pbm_routes_this_ino(pbm, SCHIZO_UE_INO)) { -		err = request_irq(op->irqs[1], schizo_ue_intr, 0, +		err = request_irq(op->archdata.irqs[1], schizo_ue_intr, 0,  				  "TOMATILLO_UE", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register UE, "  			       "err=%d\n", pbm->name, err);  	}  	if (pbm_routes_this_ino(pbm, SCHIZO_CE_INO)) { -		err = request_irq(op->irqs[2], schizo_ce_intr, 0, +		err = request_irq(op->archdata.irqs[2], schizo_ce_intr, 0,  				  "TOMATILLO_CE", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register CE, " @@ -872,10 +872,10 @@ static void tomatillo_register_error_handlers(struct pci_pbm_info *pbm)  	}  	err = 0;  	if (pbm_routes_this_ino(pbm, SCHIZO_PCIERR_A_INO)) { -		err = request_irq(op->irqs[0], schizo_pcierr_intr, 0, +		err = request_irq(op->archdata.irqs[0], schizo_pcierr_intr, 0,  				  "TOMATILLO_PCIERR", pbm);  	} else if (pbm_routes_this_ino(pbm, SCHIZO_PCIERR_B_INO)) { -		err = request_irq(op->irqs[0], schizo_pcierr_intr, 0, +		err = request_irq(op->archdata.irqs[0], schizo_pcierr_intr, 0,  				  "TOMATILLO_PCIERR", pbm);  	}  	if (err) @@ -883,7 +883,7 @@ static void tomatillo_register_error_handlers(struct pci_pbm_info *pbm)  		       "err=%d\n", pbm->name, err);  	if (pbm_routes_this_ino(pbm, SCHIZO_SERR_INO)) { -		err = request_irq(op->irqs[3], schizo_safarierr_intr, 0, +		err = request_irq(op->archdata.irqs[3], schizo_safarierr_intr, 0,  				  "TOMATILLO_SERR", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register SERR, " @@ -939,7 +939,7 @@ static void tomatillo_register_error_handlers(struct pci_pbm_info *pbm)  static void schizo_register_error_handlers(struct pci_pbm_info *pbm)  { -	struct of_device *op = of_find_device_by_node(pbm->op->dev.of_node); +	struct platform_device *op = of_find_device_by_node(pbm->op->dev.of_node);  	u64 tmp, err_mask, err_no_mask;  	int err; @@ -952,14 +952,14 @@ static void schizo_register_error_handlers(struct pci_pbm_info *pbm)  	 */  	if (pbm_routes_this_ino(pbm, SCHIZO_UE_INO)) { -		err = request_irq(op->irqs[1], schizo_ue_intr, 0, +		err = request_irq(op->archdata.irqs[1], schizo_ue_intr, 0,  				  "SCHIZO_UE", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register UE, "  			       "err=%d\n", pbm->name, err);  	}  	if (pbm_routes_this_ino(pbm, SCHIZO_CE_INO)) { -		err = request_irq(op->irqs[2], schizo_ce_intr, 0, +		err = request_irq(op->archdata.irqs[2], schizo_ce_intr, 0,  				  "SCHIZO_CE", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register CE, " @@ -967,10 +967,10 @@ static void schizo_register_error_handlers(struct pci_pbm_info *pbm)  	}  	err = 0;  	if (pbm_routes_this_ino(pbm, SCHIZO_PCIERR_A_INO)) { -		err = request_irq(op->irqs[0], schizo_pcierr_intr, 0, +		err = request_irq(op->archdata.irqs[0], schizo_pcierr_intr, 0,  				  "SCHIZO_PCIERR", pbm);  	} else if (pbm_routes_this_ino(pbm, SCHIZO_PCIERR_B_INO)) { -		err = request_irq(op->irqs[0], schizo_pcierr_intr, 0, +		err = request_irq(op->archdata.irqs[0], schizo_pcierr_intr, 0,  				  "SCHIZO_PCIERR", pbm);  	}  	if (err) @@ -978,7 +978,7 @@ static void schizo_register_error_handlers(struct pci_pbm_info *pbm)  		       "err=%d\n", pbm->name, err);  	if (pbm_routes_this_ino(pbm, SCHIZO_SERR_INO)) { -		err = request_irq(op->irqs[3], schizo_safarierr_intr, 0, +		err = request_irq(op->archdata.irqs[3], schizo_safarierr_intr, 0,  				  "SCHIZO_SERR", pbm);  		if (err)  			printk(KERN_WARNING "%s: Could not register SERR, " @@ -1307,7 +1307,7 @@ static void schizo_pbm_hw_init(struct pci_pbm_info *pbm)  }  static int __devinit schizo_pbm_init(struct pci_pbm_info *pbm, -				     struct of_device *op, u32 portid, +				     struct platform_device *op, u32 portid,  				     int chip_type)  {  	const struct linux_prom64_registers *regs; @@ -1413,7 +1413,7 @@ static struct pci_pbm_info * __devinit schizo_find_sibling(u32 portid,  	return NULL;  } -static int __devinit __schizo_init(struct of_device *op, unsigned long chip_type) +static int __devinit __schizo_init(struct platform_device *op, unsigned long chip_type)  {  	struct device_node *dp = op->dev.of_node;  	struct pci_pbm_info *pbm; @@ -1460,7 +1460,7 @@ out_err:  	return err;  } -static int __devinit schizo_probe(struct of_device *op, +static int __devinit schizo_probe(struct platform_device *op,  				  const struct of_device_id *match)  {  	return __schizo_init(op, (unsigned long) match->data); @@ -1501,7 +1501,7 @@ static struct of_platform_driver schizo_driver = {  static int __init schizo_init(void)  { -	return of_register_driver(&schizo_driver, &of_bus_type); +	return of_register_platform_driver(&schizo_driver);  }  subsys_initcall(schizo_init); diff --git a/arch/sparc/kernel/pci_sun4v.c b/arch/sparc/kernel/pci_sun4v.c index a24af6f..743344a 100644 --- a/arch/sparc/kernel/pci_sun4v.c +++ b/arch/sparc/kernel/pci_sun4v.c @@ -879,7 +879,7 @@ static void pci_sun4v_msi_init(struct pci_pbm_info *pbm)  #endif /* !(CONFIG_PCI_MSI) */  static int __devinit pci_sun4v_pbm_init(struct pci_pbm_info *pbm, -					struct of_device *op, u32 devhandle) +					struct platform_device *op, u32 devhandle)  {  	struct device_node *dp = op->dev.of_node;  	int err; @@ -918,7 +918,7 @@ static int __devinit pci_sun4v_pbm_init(struct pci_pbm_info *pbm,  	return 0;  } -static int __devinit pci_sun4v_probe(struct of_device *op, +static int __devinit pci_sun4v_probe(struct platform_device *op,  				     const struct of_device_id *match)  {  	const struct linux_prom64_registers *regs; @@ -1019,7 +1019,7 @@ static struct of_platform_driver pci_sun4v_driver = {  static int __init pci_sun4v_init(void)  { -	return of_register_driver(&pci_sun4v_driver, &of_bus_type); +	return of_register_platform_driver(&pci_sun4v_driver);  }  subsys_initcall(pci_sun4v_init); diff --git a/arch/sparc/kernel/perf_event.c b/arch/sparc/kernel/perf_event.c index 44faabc..357ced3 100644 --- a/arch/sparc/kernel/perf_event.c +++ b/arch/sparc/kernel/perf_event.c @@ -572,18 +572,18 @@ static u64 sparc_perf_event_update(struct perf_event *event,  	s64 delta;  again: -	prev_raw_count = atomic64_read(&hwc->prev_count); +	prev_raw_count = local64_read(&hwc->prev_count);  	new_raw_count = read_pmc(idx); -	if (atomic64_cmpxchg(&hwc->prev_count, prev_raw_count, +	if (local64_cmpxchg(&hwc->prev_count, prev_raw_count,  			     new_raw_count) != prev_raw_count)  		goto again;  	delta = (new_raw_count << shift) - (prev_raw_count << shift);  	delta >>= shift; -	atomic64_add(delta, &event->count); -	atomic64_sub(delta, &hwc->period_left); +	local64_add(delta, &event->count); +	local64_sub(delta, &hwc->period_left);  	return new_raw_count;  } @@ -591,27 +591,27 @@ again:  static int sparc_perf_event_set_period(struct perf_event *event,  				       struct hw_perf_event *hwc, int idx)  { -	s64 left = atomic64_read(&hwc->period_left); +	s64 left = local64_read(&hwc->period_left);  	s64 period = hwc->sample_period;  	int ret = 0;  	if (unlikely(left <= -period)) {  		left = period; -		atomic64_set(&hwc->period_left, left); +		local64_set(&hwc->period_left, left);  		hwc->last_period = period;  		ret = 1;  	}  	if (unlikely(left <= 0)) {  		left += period; -		atomic64_set(&hwc->period_left, left); +		local64_set(&hwc->period_left, left);  		hwc->last_period = period;  		ret = 1;  	}  	if (left > MAX_PERIOD)  		left = MAX_PERIOD; -	atomic64_set(&hwc->prev_count, (u64)-left); +	local64_set(&hwc->prev_count, (u64)-left);  	write_pmc(idx, (u64)(-left) & 0xffffffff); @@ -1006,7 +1006,7 @@ static int sparc_pmu_enable(struct perf_event *event)  	 * skip the schedulability test here, it will be peformed  	 * at commit time(->commit_txn) as a whole  	 */ -	if (cpuc->group_flag & PERF_EVENT_TXN_STARTED) +	if (cpuc->group_flag & PERF_EVENT_TXN)  		goto nocheck;  	if (check_excludes(cpuc->event, n0, 1)) @@ -1088,7 +1088,7 @@ static int __hw_perf_event_init(struct perf_event *event)  	if (!hwc->sample_period) {  		hwc->sample_period = MAX_PERIOD;  		hwc->last_period = hwc->sample_period; -		atomic64_set(&hwc->period_left, hwc->sample_period); +		local64_set(&hwc->period_left, hwc->sample_period);  	}  	return 0; @@ -1103,7 +1103,7 @@ static void sparc_pmu_start_txn(const struct pmu *pmu)  {  	struct cpu_hw_events *cpuhw = &__get_cpu_var(cpu_hw_events); -	cpuhw->group_flag |= PERF_EVENT_TXN_STARTED; +	cpuhw->group_flag |= PERF_EVENT_TXN;  }  /* @@ -1115,7 +1115,7 @@ static void sparc_pmu_cancel_txn(const struct pmu *pmu)  {  	struct cpu_hw_events *cpuhw = &__get_cpu_var(cpu_hw_events); -	cpuhw->group_flag &= ~PERF_EVENT_TXN_STARTED; +	cpuhw->group_flag &= ~PERF_EVENT_TXN;  }  /* @@ -1138,6 +1138,7 @@ static int sparc_pmu_commit_txn(const struct pmu *pmu)  	if (sparc_check_constraints(cpuc->event, cpuc->events, n))  		return -EAGAIN; +	cpuc->group_flag &= ~PERF_EVENT_TXN;  	return 0;  } diff --git a/arch/sparc/kernel/pmc.c b/arch/sparc/kernel/pmc.c index 9589d8b..94536a8 100644 --- a/arch/sparc/kernel/pmc.c +++ b/arch/sparc/kernel/pmc.c @@ -51,7 +51,7 @@ static void pmc_swift_idle(void)  #endif  } -static int __devinit pmc_probe(struct of_device *op, +static int __devinit pmc_probe(struct platform_device *op,  			       const struct of_device_id *match)  {  	regs = of_ioremap(&op->resource[0], 0, @@ -89,7 +89,7 @@ static struct of_platform_driver pmc_driver = {  static int __init pmc_init(void)  { -	return of_register_driver(&pmc_driver, &of_bus_type); +	return of_register_platform_driver(&pmc_driver);  }  /* This driver is not critical to the boot process diff --git a/arch/sparc/kernel/power.c b/arch/sparc/kernel/power.c index 168d4cb..2c59f4d 100644 --- a/arch/sparc/kernel/power.c +++ b/arch/sparc/kernel/power.c @@ -33,10 +33,10 @@ static int __devinit has_button_interrupt(unsigned int irq, struct device_node *  	return 1;  } -static int __devinit power_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit power_probe(struct platform_device *op, const struct of_device_id *match)  {  	struct resource *res = &op->resource[0]; -	unsigned int irq= op->irqs[0]; +	unsigned int irq = op->archdata.irqs[0];  	power_reg = of_ioremap(res, 0, 0x4, "power"); @@ -70,7 +70,7 @@ static struct of_platform_driver power_driver = {  static int __init power_init(void)  { -	return of_register_driver(&power_driver, &of_platform_bus_type); +	return of_register_platform_driver(&power_driver);  }  device_initcall(power_init); diff --git a/arch/sparc/kernel/process_32.c b/arch/sparc/kernel/process_32.c index 40e29fc..1752929 100644 --- a/arch/sparc/kernel/process_32.c +++ b/arch/sparc/kernel/process_32.c @@ -633,8 +633,10 @@ asmlinkage int sparc_execve(struct pt_regs *regs)  	if(IS_ERR(filename))  		goto out;  	error = do_execve(filename, -			  (char __user * __user *)regs->u_regs[base + UREG_I1], -			  (char __user * __user *)regs->u_regs[base + UREG_I2], +			  (const char __user *const  __user *) +			  regs->u_regs[base + UREG_I1], +			  (const char __user *const  __user *) +			  regs->u_regs[base + UREG_I2],  			  regs);  	putname(filename);  out: diff --git a/arch/sparc/kernel/process_64.c b/arch/sparc/kernel/process_64.c index dbe81a3..c158a95 100644 --- a/arch/sparc/kernel/process_64.c +++ b/arch/sparc/kernel/process_64.c @@ -303,7 +303,7 @@ void arch_trigger_all_cpu_backtrace(void)  #ifdef CONFIG_MAGIC_SYSRQ -static void sysrq_handle_globreg(int key, struct tty_struct *tty) +static void sysrq_handle_globreg(int key)  {  	arch_trigger_all_cpu_backtrace();  } @@ -739,9 +739,9 @@ asmlinkage int sparc_execve(struct pt_regs *regs)  	if (IS_ERR(filename))  		goto out;  	error = do_execve(filename, -			  (char __user * __user *) +			  (const char __user *const __user *)  			  regs->u_regs[base + UREG_I1], -			  (char __user * __user *) +			  (const char __user *const __user *)  			  regs->u_regs[base + UREG_I2], regs);  	putname(filename);  	if (!error) { diff --git a/arch/sparc/kernel/prom.h b/arch/sparc/kernel/prom.h index a8591ef..eeb04a7 100644 --- a/arch/sparc/kernel/prom.h +++ b/arch/sparc/kernel/prom.h @@ -9,14 +9,6 @@ extern void irq_trans_init(struct device_node *dp);  extern unsigned int prom_unique_id; -static inline int is_root_node(const struct device_node *dp) -{ -	if (!dp) -		return 0; - -	return (dp->parent == NULL); -} -  extern char *build_path_component(struct device_node *dp);  extern void of_console_init(void); diff --git a/arch/sparc/kernel/prom_64.c b/arch/sparc/kernel/prom_64.c index 466a327..86597d9 100644 --- a/arch/sparc/kernel/prom_64.c +++ b/arch/sparc/kernel/prom_64.c @@ -21,7 +21,7 @@  #include <linux/mm.h>  #include <linux/module.h>  #include <linux/memblock.h> -#include <linux/of_device.h> +#include <linux/of.h>  #include <asm/prom.h>  #include <asm/oplib.h> @@ -81,7 +81,7 @@ static void __init sun4v_path_component(struct device_node *dp, char *tmp_buf)  		return;  	regs = rprop->value; -	if (!is_root_node(dp->parent)) { +	if (!of_node_is_root(dp->parent)) {  		sprintf(tmp_buf, "%s@%x,%x",  			dp->name,  			(unsigned int) (regs->phys_addr >> 32UL), @@ -121,7 +121,7 @@ static void __init sun4u_path_component(struct device_node *dp, char *tmp_buf)  		return;  	regs = prop->value; -	if (!is_root_node(dp->parent)) { +	if (!of_node_is_root(dp->parent)) {  		sprintf(tmp_buf, "%s@%x,%x",  			dp->name,  			(unsigned int) (regs->phys_addr >> 32UL), diff --git a/arch/sparc/kernel/prom_common.c b/arch/sparc/kernel/prom_common.c index 57ac9e2..1f830da 100644 --- a/arch/sparc/kernel/prom_common.c +++ b/arch/sparc/kernel/prom_common.c @@ -244,7 +244,7 @@ char * __init build_full_name(struct device_node *dp)  	n = prom_early_alloc(len);  	strcpy(n, dp->parent->full_name); -	if (!is_root_node(dp->parent)) { +	if (!of_node_is_root(dp->parent)) {  		strcpy(n + plen, "/");  		plen++;  	} diff --git a/arch/sparc/kernel/prom_irqtrans.c b/arch/sparc/kernel/prom_irqtrans.c index 5702ad4..ce65114 100644 --- a/arch/sparc/kernel/prom_irqtrans.c +++ b/arch/sparc/kernel/prom_irqtrans.c @@ -719,7 +719,7 @@ static unsigned int central_build_irq(struct device_node *dp,  				      void *_data)  {  	struct device_node *central_dp = _data; -	struct of_device *central_op = of_find_device_by_node(central_dp); +	struct platform_device *central_op = of_find_device_by_node(central_dp);  	struct resource *res;  	unsigned long imap, iclr;  	u32 tmp; diff --git a/arch/sparc/kernel/psycho_common.c b/arch/sparc/kernel/psycho_common.c index 3f34ac8..fe2af66 100644 --- a/arch/sparc/kernel/psycho_common.c +++ b/arch/sparc/kernel/psycho_common.c @@ -447,7 +447,7 @@ int psycho_iommu_init(struct pci_pbm_info *pbm, int tsbsize,  } -void psycho_pbm_init_common(struct pci_pbm_info *pbm, struct of_device *op, +void psycho_pbm_init_common(struct pci_pbm_info *pbm, struct platform_device *op,  			    const char *chip_name, int chip_type)  {  	struct device_node *dp = op->dev.of_node; diff --git a/arch/sparc/kernel/psycho_common.h b/arch/sparc/kernel/psycho_common.h index 092c278..590b4ed 100644 --- a/arch/sparc/kernel/psycho_common.h +++ b/arch/sparc/kernel/psycho_common.h @@ -42,7 +42,7 @@ extern int psycho_iommu_init(struct pci_pbm_info *pbm, int tsbsize,  			     unsigned long write_complete_offset);  extern void psycho_pbm_init_common(struct pci_pbm_info *pbm, -				   struct of_device *op, +				   struct platform_device *op,  				   const char *chip_name, int chip_type);  #endif /* _PSYCHO_COMMON_H */ diff --git a/arch/sparc/kernel/sbus.c b/arch/sparc/kernel/sbus.c index cfeaf04..2ca32d1 100644 --- a/arch/sparc/kernel/sbus.c +++ b/arch/sparc/kernel/sbus.c @@ -57,7 +57,7 @@  void sbus_set_sbus64(struct device *dev, int bursts)  {  	struct iommu *iommu = dev->archdata.iommu; -	struct of_device *op = to_of_device(dev); +	struct platform_device *op = to_platform_device(dev);  	const struct linux_prom_registers *regs;  	unsigned long cfg_reg;  	int slot; @@ -204,7 +204,7 @@ static unsigned long sysio_imap_to_iclr(unsigned long imap)  	return imap + diff;  } -static unsigned int sbus_build_irq(struct of_device *op, unsigned int ino) +static unsigned int sbus_build_irq(struct platform_device *op, unsigned int ino)  {  	struct iommu *iommu = op->dev.archdata.iommu;  	unsigned long reg_base = iommu->write_complete_reg - 0x2000UL; @@ -267,7 +267,7 @@ static unsigned int sbus_build_irq(struct of_device *op, unsigned int ino)  #define  SYSIO_UEAFSR_RESV2 0x0000001fffffffffUL /* Reserved                  */  static irqreturn_t sysio_ue_handler(int irq, void *dev_id)  { -	struct of_device *op = dev_id; +	struct platform_device *op = dev_id;  	struct iommu *iommu = op->dev.archdata.iommu;  	unsigned long reg_base = iommu->write_complete_reg - 0x2000UL;  	unsigned long afsr_reg, afar_reg; @@ -341,7 +341,7 @@ static irqreturn_t sysio_ue_handler(int irq, void *dev_id)  #define  SYSIO_CEAFSR_RESV2 0x0000001fffffffffUL /* Reserved                  */  static irqreturn_t sysio_ce_handler(int irq, void *dev_id)  { -	struct of_device *op = dev_id; +	struct platform_device *op = dev_id;  	struct iommu *iommu = op->dev.archdata.iommu;  	unsigned long reg_base = iommu->write_complete_reg - 0x2000UL;  	unsigned long afsr_reg, afar_reg; @@ -420,7 +420,7 @@ static irqreturn_t sysio_ce_handler(int irq, void *dev_id)  #define  SYSIO_SBAFSR_RESV3 0x0000001fffffffffUL /* Reserved                  */  static irqreturn_t sysio_sbus_error_handler(int irq, void *dev_id)  { -	struct of_device *op = dev_id; +	struct platform_device *op = dev_id;  	struct iommu *iommu = op->dev.archdata.iommu;  	unsigned long afsr_reg, afar_reg, reg_base;  	unsigned long afsr, afar, error_bits; @@ -488,7 +488,7 @@ static irqreturn_t sysio_sbus_error_handler(int irq, void *dev_id)  #define SYSIO_CE_INO		0x35  #define SYSIO_SBUSERR_INO	0x36 -static void __init sysio_register_error_handlers(struct of_device *op) +static void __init sysio_register_error_handlers(struct platform_device *op)  {  	struct iommu *iommu = op->dev.archdata.iommu;  	unsigned long reg_base = iommu->write_complete_reg - 0x2000UL; @@ -534,7 +534,7 @@ static void __init sysio_register_error_handlers(struct of_device *op)  }  /* Boot time initialization. */ -static void __init sbus_iommu_init(struct of_device *op) +static void __init sbus_iommu_init(struct platform_device *op)  {  	const struct linux_prom64_registers *pr;  	struct device_node *dp = op->dev.of_node; @@ -663,7 +663,7 @@ static int __init sbus_init(void)  	struct device_node *dp;  	for_each_node_by_name(dp, "sbus") { -		struct of_device *op = of_find_device_by_node(dp); +		struct platform_device *op = of_find_device_by_node(dp);  		sbus_iommu_init(op);  		of_propagate_archdata(op); diff --git a/arch/sparc/kernel/sys32.S b/arch/sparc/kernel/sys32.S index 46a76ba..44e5faf 100644 --- a/arch/sparc/kernel/sys32.S +++ b/arch/sparc/kernel/sys32.S @@ -330,6 +330,15 @@ do_sys_accept4: /* sys_accept4(int, struct sockaddr *, int *, int) */  	nop  	nop +	.globl		sys32_fanotify_mark +sys32_fanotify_mark: +	sethi		%hi(sys_fanotify_mark), %g1 +	sllx		%o2, 32, %o2 +	or		%o2, %o3, %o2 +	mov		%o4, %o3 +	jmpl		%g1 + %lo(sys_fanotify_mark), %g0 +	 mov		%o5, %o4 +  	.section	__ex_table,"a"  	.align		4  	.word		1b, __retl_efault, 2b, __retl_efault diff --git a/arch/sparc/kernel/sys_sparc32.c b/arch/sparc/kernel/sys_sparc32.c index c0ca875..e6375a7 100644 --- a/arch/sparc/kernel/sys_sparc32.c +++ b/arch/sparc/kernel/sys_sparc32.c @@ -162,7 +162,7 @@ static int cp_compat_stat64(struct kstat *stat,  	return err;  } -asmlinkage long compat_sys_stat64(char __user * filename, +asmlinkage long compat_sys_stat64(const char __user * filename,  		struct compat_stat64 __user *statbuf)  {  	struct kstat stat; @@ -173,7 +173,7 @@ asmlinkage long compat_sys_stat64(char __user * filename,  	return error;  } -asmlinkage long compat_sys_lstat64(char __user * filename, +asmlinkage long compat_sys_lstat64(const char __user * filename,  		struct compat_stat64 __user *statbuf)  {  	struct kstat stat; @@ -195,7 +195,8 @@ asmlinkage long compat_sys_fstat64(unsigned int fd,  	return error;  } -asmlinkage long compat_sys_fstatat64(unsigned int dfd, char __user *filename, +asmlinkage long compat_sys_fstatat64(unsigned int dfd, +		const char __user *filename,  		struct compat_stat64 __user * statbuf, int flag)  {  	struct kstat stat; diff --git a/arch/sparc/kernel/sys_sparc_32.c b/arch/sparc/kernel/sys_sparc_32.c index ee995b7..5079413 100644 --- a/arch/sparc/kernel/sys_sparc_32.c +++ b/arch/sparc/kernel/sys_sparc_32.c @@ -282,7 +282,9 @@ out:   * Do a system call from kernel instead of calling sys_execve so we   * end up with proper pt_regs.   */ -int kernel_execve(const char *filename, char *const argv[], char *const envp[]) +int kernel_execve(const char *filename, +		  const char *const argv[], +		  const char *const envp[])  {  	long __res;  	register long __g1 __asm__ ("g1") = __NR_execve; diff --git a/arch/sparc/kernel/sys_sparc_64.c b/arch/sparc/kernel/sys_sparc_64.c index 3d435c4..f836f4e 100644 --- a/arch/sparc/kernel/sys_sparc_64.c +++ b/arch/sparc/kernel/sys_sparc_64.c @@ -758,7 +758,9 @@ SYSCALL_DEFINE5(rt_sigaction, int, sig, const struct sigaction __user *, act,   * Do a system call from kernel instead of calling sys_execve so we   * end up with proper pt_regs.   */ -int kernel_execve(const char *filename, char *const argv[], char *const envp[]) +int kernel_execve(const char *filename, +		  const char *const argv[], +		  const char *const envp[])  {  	long __res;  	register long __g1 __asm__ ("g1") = __NR_execve; diff --git a/arch/sparc/kernel/systbls_32.S b/arch/sparc/kernel/systbls_32.S index 801fc8e..ec396e1 100644 --- a/arch/sparc/kernel/systbls_32.S +++ b/arch/sparc/kernel/systbls_32.S @@ -82,5 +82,6 @@ sys_call_table:  /*310*/	.long sys_utimensat, sys_signalfd, sys_timerfd_create, sys_eventfd, sys_fallocate  /*315*/	.long sys_timerfd_settime, sys_timerfd_gettime, sys_signalfd4, sys_eventfd2, sys_epoll_create1  /*320*/	.long sys_dup3, sys_pipe2, sys_inotify_init1, sys_accept4, sys_preadv -/*325*/	.long sys_pwritev, sys_rt_tgsigqueueinfo, sys_perf_event_open, sys_recvmmsg +/*325*/	.long sys_pwritev, sys_rt_tgsigqueueinfo, sys_perf_event_open, sys_recvmmsg, sys_fanotify_init +/*330*/	.long sys_fanotify_mark, sys_prlimit64 diff --git a/arch/sparc/kernel/systbls_64.S b/arch/sparc/kernel/systbls_64.S index 9db058d..8cfcaa5 100644 --- a/arch/sparc/kernel/systbls_64.S +++ b/arch/sparc/kernel/systbls_64.S @@ -83,7 +83,8 @@ sys_call_table32:  /*310*/	.word compat_sys_utimensat, compat_sys_signalfd, sys_timerfd_create, sys_eventfd, compat_sys_fallocate  	.word compat_sys_timerfd_settime, compat_sys_timerfd_gettime, compat_sys_signalfd4, sys_eventfd2, sys_epoll_create1  /*320*/	.word sys_dup3, sys_pipe2, sys_inotify_init1, sys_accept4, compat_sys_preadv -	.word compat_sys_pwritev, compat_sys_rt_tgsigqueueinfo, sys_perf_event_open, compat_sys_recvmmsg +	.word compat_sys_pwritev, compat_sys_rt_tgsigqueueinfo, sys_perf_event_open, compat_sys_recvmmsg, sys_fanotify_init +/*330*/	.word sys32_fanotify_mark, sys_prlimit64  #endif /* CONFIG_COMPAT */ @@ -158,4 +159,5 @@ sys_call_table:  /*310*/	.word sys_utimensat, sys_signalfd, sys_timerfd_create, sys_eventfd, sys_fallocate  	.word sys_timerfd_settime, sys_timerfd_gettime, sys_signalfd4, sys_eventfd2, sys_epoll_create1  /*320*/	.word sys_dup3, sys_pipe2, sys_inotify_init1, sys_accept4, sys_preadv -	.word sys_pwritev, sys_rt_tgsigqueueinfo, sys_perf_event_open, sys_recvmmsg +	.word sys_pwritev, sys_rt_tgsigqueueinfo, sys_perf_event_open, sys_recvmmsg, sys_fanotify_init +/*330*/	.word sys_fanotify_mark, sys_prlimit64 diff --git a/arch/sparc/kernel/time_32.c b/arch/sparc/kernel/time_32.c index e404b06..9c743b1 100644 --- a/arch/sparc/kernel/time_32.c +++ b/arch/sparc/kernel/time_32.c @@ -142,7 +142,7 @@ static struct platform_device m48t59_rtc = {  	},  }; -static int __devinit clock_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit clock_probe(struct platform_device *op, const struct of_device_id *match)  {  	struct device_node *dp = op->dev.of_node;  	const char *model = of_get_property(dp, "model", NULL); @@ -189,7 +189,7 @@ static struct of_platform_driver clock_driver = {  /* Probe for the mostek real time clock chip. */  static int __init clock_init(void)  { -	return of_register_driver(&clock_driver, &of_platform_bus_type); +	return of_register_platform_driver(&clock_driver);  }  /* Must be after subsys_initcall() so that busses are probed.  Must   * be before device_initcall() because things like the RTC driver diff --git a/arch/sparc/kernel/time_64.c b/arch/sparc/kernel/time_64.c index 21e9fca..3bc9c99 100644 --- a/arch/sparc/kernel/time_64.c +++ b/arch/sparc/kernel/time_64.c @@ -419,7 +419,7 @@ static struct platform_device rtc_cmos_device = {  	.num_resources	= 1,  }; -static int __devinit rtc_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit rtc_probe(struct platform_device *op, const struct of_device_id *match)  {  	struct resource *r; @@ -477,7 +477,7 @@ static struct platform_device rtc_bq4802_device = {  	.num_resources	= 1,  }; -static int __devinit bq4802_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit bq4802_probe(struct platform_device *op, const struct of_device_id *match)  {  	printk(KERN_INFO "%s: BQ4802 regs at 0x%llx\n", @@ -534,7 +534,7 @@ static struct platform_device m48t59_rtc = {  	},  }; -static int __devinit mostek_probe(struct of_device *op, const struct of_device_id *match) +static int __devinit mostek_probe(struct platform_device *op, const struct of_device_id *match)  {  	struct device_node *dp = op->dev.of_node; @@ -586,9 +586,9 @@ static int __init clock_init(void)  	if (tlb_type == hypervisor)  		return platform_device_register(&rtc_sun4v_device); -	(void) of_register_driver(&rtc_driver, &of_platform_bus_type); -	(void) of_register_driver(&mostek_driver, &of_platform_bus_type); -	(void) of_register_driver(&bq4802_driver, &of_platform_bus_type); +	(void) of_register_platform_driver(&rtc_driver); +	(void) of_register_platform_driver(&mostek_driver); +	(void) of_register_platform_driver(&bq4802_driver);  	return 0;  } diff --git a/arch/sparc/lib/Makefile b/arch/sparc/lib/Makefile index c4b5e03..846d1c4 100644 --- a/arch/sparc/lib/Makefile +++ b/arch/sparc/lib/Makefile @@ -15,7 +15,7 @@ lib-$(CONFIG_SPARC32) += divdi3.o udivdi3.o  lib-$(CONFIG_SPARC32) += copy_user.o locks.o  lib-y                 += atomic_$(BITS).o  lib-$(CONFIG_SPARC32) += lshrdi3.o ashldi3.o -lib-y                 += rwsem_$(BITS).o +lib-$(CONFIG_SPARC32) += rwsem_32.o  lib-$(CONFIG_SPARC32) += muldi3.o bitext.o cmpdi2.o  lib-$(CONFIG_SPARC64) += copy_page.o clear_page.o bzero.o diff --git a/arch/sparc/lib/atomic_64.S b/arch/sparc/lib/atomic_64.S index 0268210..59186e0 100644 --- a/arch/sparc/lib/atomic_64.S +++ b/arch/sparc/lib/atomic_64.S @@ -21,7 +21,7 @@ atomic_add: /* %o0 = increment, %o1 = atomic_ptr */  	add	%g1, %o0, %g7  	cas	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%icc, 2f +	bne,pn	%icc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -36,7 +36,7 @@ atomic_sub: /* %o0 = decrement, %o1 = atomic_ptr */  	sub	%g1, %o0, %g7  	cas	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%icc, 2f +	bne,pn	%icc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -51,11 +51,10 @@ atomic_add_ret: /* %o0 = increment, %o1 = atomic_ptr */  	add	%g1, %o0, %g7  	cas	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%icc, 2f -	 add	%g7, %o0, %g7 -	sra	%g7, 0, %o0 +	bne,pn	%icc, BACKOFF_LABEL(2f, 1b) +	 add	%g1, %o0, %g1  	retl -	 nop +	 sra	%g1, 0, %o0  2:	BACKOFF_SPIN(%o2, %o3, 1b)  	.size	atomic_add_ret, .-atomic_add_ret @@ -67,11 +66,10 @@ atomic_sub_ret: /* %o0 = decrement, %o1 = atomic_ptr */  	sub	%g1, %o0, %g7  	cas	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%icc, 2f -	 sub	%g7, %o0, %g7 -	sra	%g7, 0, %o0 +	bne,pn	%icc, BACKOFF_LABEL(2f, 1b) +	 sub	%g1, %o0, %g1  	retl -	 nop +	 sra	%g1, 0, %o0  2:	BACKOFF_SPIN(%o2, %o3, 1b)  	.size	atomic_sub_ret, .-atomic_sub_ret @@ -83,7 +81,7 @@ atomic64_add: /* %o0 = increment, %o1 = atomic_ptr */  	add	%g1, %o0, %g7  	casx	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -98,7 +96,7 @@ atomic64_sub: /* %o0 = decrement, %o1 = atomic_ptr */  	sub	%g1, %o0, %g7  	casx	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -113,11 +111,10 @@ atomic64_add_ret: /* %o0 = increment, %o1 = atomic_ptr */  	add	%g1, %o0, %g7  	casx	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%xcc, 2f -	 add	%g7, %o0, %g7 -	mov	%g7, %o0 -	retl +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop +	retl +	 add	%g1, %o0, %o0  2:	BACKOFF_SPIN(%o2, %o3, 1b)  	.size	atomic64_add_ret, .-atomic64_add_ret @@ -129,10 +126,9 @@ atomic64_sub_ret: /* %o0 = decrement, %o1 = atomic_ptr */  	sub	%g1, %o0, %g7  	casx	[%o1], %g1, %g7  	cmp	%g1, %g7 -	bne,pn	%xcc, 2f -	 sub	%g7, %o0, %g7 -	mov	%g7, %o0 -	retl +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop +	retl +	 sub	%g1, %o0, %o0  2:	BACKOFF_SPIN(%o2, %o3, 1b)  	.size	atomic64_sub_ret, .-atomic64_sub_ret diff --git a/arch/sparc/lib/bitops.S b/arch/sparc/lib/bitops.S index 2b7228c..3dc61d5 100644 --- a/arch/sparc/lib/bitops.S +++ b/arch/sparc/lib/bitops.S @@ -22,7 +22,7 @@ test_and_set_bit:	/* %o0=nr, %o1=addr */  	or	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 and	%g7, %o2, %g2  	clr	%o0  	movrne	%g2, 1, %o0 @@ -45,7 +45,7 @@ test_and_clear_bit:	/* %o0=nr, %o1=addr */  	andn	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 and	%g7, %o2, %g2  	clr	%o0  	movrne	%g2, 1, %o0 @@ -68,7 +68,7 @@ test_and_change_bit:	/* %o0=nr, %o1=addr */  	xor	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 and	%g7, %o2, %g2  	clr	%o0  	movrne	%g2, 1, %o0 @@ -91,7 +91,7 @@ set_bit:		/* %o0=nr, %o1=addr */  	or	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -112,7 +112,7 @@ clear_bit:		/* %o0=nr, %o1=addr */  	andn	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop @@ -133,7 +133,7 @@ change_bit:		/* %o0=nr, %o1=addr */  	xor	%g7, %o2, %g1  	casx	[%o1], %g7, %g1  	cmp	%g7, %g1 -	bne,pn	%xcc, 2f +	bne,pn	%xcc, BACKOFF_LABEL(2f, 1b)  	 nop  	retl  	 nop diff --git a/arch/sparc/lib/rwsem_64.S b/arch/sparc/lib/rwsem_64.S deleted file mode 100644 index 91a7d29..0000000 --- a/arch/sparc/lib/rwsem_64.S +++ /dev/null @@ -1,163 +0,0 @@ -/* rwsem.S: RW semaphore assembler. - * - * Written by David S. Miller (davem@redhat.com), 2001. - * Derived from asm-i386/rwsem.h - */ - -#include <asm/rwsem-const.h> - -	.section	.sched.text, "ax" - -	.globl		__down_read -__down_read: -1:	lduw		[%o0], %g1 -	add		%g1, 1, %g7 -	cas		[%o0], %g1, %g7 -	cmp		%g1, %g7 -	bne,pn		%icc, 1b -	 add		%g7, 1, %g7 -	cmp		%g7, 0 -	bl,pn		%icc, 3f -	 nop -2: -	retl -	 nop -3: -	save		%sp, -192, %sp -	call		rwsem_down_read_failed -	 mov		%i0, %o0 -	ret -	 restore -	.size		__down_read, .-__down_read - -	.globl		__down_read_trylock -__down_read_trylock: -1:	lduw		[%o0], %g1 -	add		%g1, 1, %g7 -	cmp		%g7, 0 -	bl,pn		%icc, 2f -	 mov		0, %o1 -	cas		[%o0], %g1, %g7 -	cmp		%g1, %g7 -	bne,pn		%icc, 1b -	 mov		1, %o1 -2:	retl -	 mov		%o1, %o0 -	.size		__down_read_trylock, .-__down_read_trylock - -	.globl		__down_write -__down_write: -	sethi		%hi(RWSEM_ACTIVE_WRITE_BIAS), %g1 -	or		%g1, %lo(RWSEM_ACTIVE_WRITE_BIAS), %g1 -1: -	lduw		[%o0], %g3 -	add		%g3, %g1, %g7 -	cas		[%o0], %g3, %g7 -	cmp		%g3, %g7 -	bne,pn		%icc, 1b -	 cmp		%g7, 0 -	bne,pn		%icc, 3f -	 nop -2:	retl -	 nop -3: -	save		%sp, -192, %sp -	call		rwsem_down_write_failed -	 mov		%i0, %o0 -	ret -	 restore -	.size		__down_write, .-__down_write - -	.globl		__down_write_trylock -__down_write_trylock: -	sethi		%hi(RWSEM_ACTIVE_WRITE_BIAS), %g1 -	or		%g1, %lo(RWSEM_ACTIVE_WRITE_BIAS), %g1 -1: -	lduw		[%o0], %g3 -	cmp		%g3, 0 -	bne,pn		%icc, 2f -	 mov		0, %o1 -	add		%g3, %g1, %g7 -	cas		[%o0], %g3, %g7 -	cmp		%g3, %g7 -	bne,pn		%icc, 1b -	 mov		1, %o1 -2:	retl -	 mov		%o1, %o0 -	.size		__down_write_trylock, .-__down_write_trylock - -	.globl		__up_read -__up_read: -1: -	lduw		[%o0], %g1 -	sub		%g1, 1, %g7 -	cas		[%o0], %g1, %g7 -	cmp		%g1, %g7 -	bne,pn		%icc, 1b -	 cmp		%g7, 0 -	bl,pn		%icc, 3f -	 nop -2:	retl -	 nop -3:	sethi		%hi(RWSEM_ACTIVE_MASK), %g1 -	sub		%g7, 1, %g7 -	or		%g1, %lo(RWSEM_ACTIVE_MASK), %g1 -	andcc		%g7, %g1, %g0 -	bne,pn		%icc, 2b -	 nop -	save		%sp, -192, %sp -	call		rwsem_wake -	 mov		%i0, %o0 -	ret -	 restore -	.size		__up_read, .-__up_read - -	.globl		__up_write -__up_write: -	sethi		%hi(RWSEM_ACTIVE_WRITE_BIAS), %g1 -	or		%g1, %lo(RWSEM_ACTIVE_WRITE_BIAS), %g1 -1: -	lduw		[%o0], %g3 -	sub		%g3, %g1, %g7 -	cas		[%o0], %g3, %g7 -	cmp		%g3, %g7 -	bne,pn		%icc, 1b -	 sub		%g7, %g1, %g7 -	cmp		%g7, 0 -	bl,pn		%icc, 3f -	 nop -2: -	retl -	 nop -3: -	save		%sp, -192, %sp -	call		rwsem_wake -	 mov		%i0, %o0 -	ret -	 restore -	.size		__up_write, .-__up_write - -	.globl		__downgrade_write -__downgrade_write: -	sethi		%hi(RWSEM_WAITING_BIAS), %g1 -	or		%g1, %lo(RWSEM_WAITING_BIAS), %g1 -1: -	lduw		[%o0], %g3 -	sub		%g3, %g1, %g7 -	cas		[%o0], %g3, %g7 -	cmp		%g3, %g7 -	bne,pn		%icc, 1b -	 sub		%g7, %g1, %g7 -	cmp		%g7, 0 -	bl,pn		%icc, 3f -	 nop -2: -	retl -	 nop -3: -	save		%sp, -192, %sp -	call		rwsem_downgrade_wake -	 mov		%i0, %o0 -	ret -	 restore -	.size		__downgrade_write, .-__downgrade_write diff --git a/arch/sparc/mm/highmem.c b/arch/sparc/mm/highmem.c index 7916feb..e139e9c 100644 --- a/arch/sparc/mm/highmem.c +++ b/arch/sparc/mm/highmem.c @@ -65,7 +65,7 @@ void *kmap_atomic(struct page *page, enum km_type type)  }  EXPORT_SYMBOL(kmap_atomic); -void kunmap_atomic(void *kvaddr, enum km_type type) +void kunmap_atomic_notypecheck(void *kvaddr, enum km_type type)  {  #ifdef CONFIG_DEBUG_HIGHMEM  	unsigned long vaddr = (unsigned long) kvaddr & PAGE_MASK; @@ -100,7 +100,7 @@ void kunmap_atomic(void *kvaddr, enum km_type type)  	pagefault_enable();  } -EXPORT_SYMBOL(kunmap_atomic); +EXPORT_SYMBOL(kunmap_atomic_notypecheck);  /* We may be fed a pagetable here by ptep_to_xxx and others. */  struct page *kmap_atomic_to_page(void *ptr) diff --git a/arch/sparc/mm/io-unit.c b/arch/sparc/mm/io-unit.c index 005e758..fc58c3e 100644 --- a/arch/sparc/mm/io-unit.c +++ b/arch/sparc/mm/io-unit.c @@ -35,7 +35,7 @@  #define IOPERM        (IOUPTE_CACHE | IOUPTE_WRITE | IOUPTE_VALID)  #define MKIOPTE(phys) __iopte((((phys)>>4) & IOUPTE_PAGE) | IOPERM) -static void __init iounit_iommu_init(struct of_device *op) +static void __init iounit_iommu_init(struct platform_device *op)  {  	struct iounit_struct *iounit;  	iopte_t *xpt, *xptend; @@ -74,7 +74,7 @@ static int __init iounit_init(void)  	struct device_node *dp;  	for_each_node_by_name(dp, "sbi") { -		struct of_device *op = of_find_device_by_node(dp); +		struct platform_device *op = of_find_device_by_node(dp);  		iounit_iommu_init(op);  		of_propagate_archdata(op); diff --git a/arch/sparc/mm/iommu.c b/arch/sparc/mm/iommu.c index b2e6e73..07fc6a6 100644 --- a/arch/sparc/mm/iommu.c +++ b/arch/sparc/mm/iommu.c @@ -56,14 +56,14 @@ static pgprot_t dvma_prot;		/* Consistent mapping pte flags */  #define IOPERM        (IOPTE_CACHE | IOPTE_WRITE | IOPTE_VALID)  #define MKIOPTE(pfn, perm) (((((pfn)<<8) & IOPTE_PAGE) | (perm)) & ~IOPTE_WAZ) -static void __init sbus_iommu_init(struct of_device *op) +static void __init sbus_iommu_init(struct platform_device *op)  {  	struct iommu_struct *iommu;  	unsigned int impl, vers;  	unsigned long *bitmap;  	unsigned long tmp; -	iommu = kmalloc(sizeof(struct iommu_struct), GFP_ATOMIC); +	iommu = kmalloc(sizeof(struct iommu_struct), GFP_KERNEL);  	if (!iommu) {  		prom_printf("Unable to allocate iommu structure\n");  		prom_halt(); @@ -132,7 +132,7 @@ static int __init iommu_init(void)  	struct device_node *dp;  	for_each_node_by_name(dp, "iommu") { -		struct of_device *op = of_find_device_by_node(dp); +		struct platform_device *op = of_find_device_by_node(dp);  		sbus_iommu_init(op);  		of_propagate_archdata(op); diff --git a/arch/sparc/prom/cif.S b/arch/sparc/prom/cif.S index 5f27ad7..9c86b4b 100644 --- a/arch/sparc/prom/cif.S +++ b/arch/sparc/prom/cif.S @@ -9,18 +9,18 @@  #include <asm/thread_info.h>  	.text -	.globl	prom_cif_interface -prom_cif_interface: -	sethi	%hi(p1275buf), %o0 -	or	%o0, %lo(p1275buf), %o0 -	ldx	[%o0 + 0x010], %o1	! prom_cif_stack -	save	%o1, -192, %sp -	ldx	[%i0 + 0x008], %l2	! prom_cif_handler +	.globl	prom_cif_direct +prom_cif_direct: +	sethi	%hi(p1275buf), %o1 +	or	%o1, %lo(p1275buf), %o1 +	ldx	[%o1 + 0x0010], %o2	! prom_cif_stack +	save	%o2, -192, %sp +	ldx	[%i1 + 0x0008], %l2	! prom_cif_handler  	mov	%g4, %l0  	mov	%g5, %l1  	mov	%g6, %l3  	call	%l2 -	 add	%i0, 0x018, %o0		! prom_args +	 mov	%i0, %o0		! prom_args  	mov	%l0, %g4  	mov	%l1, %g5  	mov	%l3, %g6 diff --git a/arch/sparc/prom/console_64.c b/arch/sparc/prom/console_64.c index f55d58a..10322dc 100644 --- a/arch/sparc/prom/console_64.c +++ b/arch/sparc/prom/console_64.c @@ -21,14 +21,22 @@ extern int prom_stdin, prom_stdout;  inline int  prom_nbgetchar(void)  { +	unsigned long args[7];  	char inc; -	if (p1275_cmd("read", P1275_ARG(1,P1275_ARG_OUT_BUF)| -			      P1275_INOUT(3,1), -			      prom_stdin, &inc, P1275_SIZE(1)) == 1) +	args[0] = (unsigned long) "read"; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) prom_stdin; +	args[4] = (unsigned long) &inc; +	args[5] = 1; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	if (args[6] == 1)  		return inc; -	else -		return -1; +	return -1;  }  /* Non blocking put character to console device, returns -1 if @@ -37,12 +45,22 @@ prom_nbgetchar(void)  inline int  prom_nbputchar(char c)  { +	unsigned long args[7];  	char outc;  	outc = c; -	if (p1275_cmd("write", P1275_ARG(1,P1275_ARG_IN_BUF)| -			       P1275_INOUT(3,1), -			       prom_stdout, &outc, P1275_SIZE(1)) == 1) + +	args[0] = (unsigned long) "write"; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) prom_stdout; +	args[4] = (unsigned long) &outc; +	args[5] = 1; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	if (args[6] == 1)  		return 0;  	else  		return -1; @@ -67,7 +85,15 @@ prom_putchar(char c)  void  prom_puts(const char *s, int len)  { -	p1275_cmd("write", P1275_ARG(1,P1275_ARG_IN_BUF)| -			   P1275_INOUT(3,1), -			   prom_stdout, s, P1275_SIZE(len)); +	unsigned long args[7]; + +	args[0] = (unsigned long) "write"; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) prom_stdout; +	args[4] = (unsigned long) s; +	args[5] = len; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args);  } diff --git a/arch/sparc/prom/devops_64.c b/arch/sparc/prom/devops_64.c index 9dbd803..a017119 100644 --- a/arch/sparc/prom/devops_64.c +++ b/arch/sparc/prom/devops_64.c @@ -18,16 +18,32 @@  int  prom_devopen(const char *dstr)  { -	return p1275_cmd ("open", P1275_ARG(0,P1275_ARG_IN_STRING)| -				  P1275_INOUT(1,1), -				  dstr); +	unsigned long args[5]; + +	args[0] = (unsigned long) "open"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned long) dstr; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[4];  }  /* Close the device described by device handle 'dhandle'. */  int  prom_devclose(int dhandle)  { -	p1275_cmd ("close", P1275_INOUT(1,0), dhandle); +	unsigned long args[4]; + +	args[0] = (unsigned long) "close"; +	args[1] = 1; +	args[2] = 0; +	args[3] = (unsigned int) dhandle; + +	p1275_cmd_direct(args); +  	return 0;  } @@ -37,5 +53,15 @@ prom_devclose(int dhandle)  void  prom_seek(int dhandle, unsigned int seekhi, unsigned int seeklo)  { -	p1275_cmd ("seek", P1275_INOUT(3,1), dhandle, seekhi, seeklo); +	unsigned long args[7]; + +	args[0] = (unsigned long) "seek"; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) dhandle; +	args[4] = seekhi; +	args[5] = seeklo; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args);  } diff --git a/arch/sparc/prom/misc_64.c b/arch/sparc/prom/misc_64.c index 39fc6af..6cb1581 100644 --- a/arch/sparc/prom/misc_64.c +++ b/arch/sparc/prom/misc_64.c @@ -20,10 +20,17 @@  int prom_service_exists(const char *service_name)  { -	int err = p1275_cmd("test", P1275_ARG(0, P1275_ARG_IN_STRING) | -			    P1275_INOUT(1, 1), service_name); +	unsigned long args[5]; -	if (err) +	args[0] = (unsigned long) "test"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned long) service_name; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	if (args[4])  		return 0;  	return 1;  } @@ -31,30 +38,47 @@ int prom_service_exists(const char *service_name)  void prom_sun4v_guest_soft_state(void)  {  	const char *svc = "SUNW,soft-state-supported"; +	unsigned long args[3];  	if (!prom_service_exists(svc))  		return; -	p1275_cmd(svc, P1275_INOUT(0, 0)); +	args[0] = (unsigned long) svc; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  }  /* Reset and reboot the machine with the command 'bcommand'. */  void prom_reboot(const char *bcommand)  { +	unsigned long args[4]; +  #ifdef CONFIG_SUN_LDOMS  	if (ldom_domaining_enabled)  		ldom_reboot(bcommand);  #endif -	p1275_cmd("boot", P1275_ARG(0, P1275_ARG_IN_STRING) | -		  P1275_INOUT(1, 0), bcommand); +	args[0] = (unsigned long) "boot"; +	args[1] = 1; +	args[2] = 0; +	args[3] = (unsigned long) bcommand; + +	p1275_cmd_direct(args);  }  /* Forth evaluate the expression contained in 'fstring'. */  void prom_feval(const char *fstring)  { +	unsigned long args[5]; +  	if (!fstring || fstring[0] == 0)  		return; -	p1275_cmd("interpret", P1275_ARG(0, P1275_ARG_IN_STRING) | -		  P1275_INOUT(1, 1), fstring); +	args[0] = (unsigned long) "interpret"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned long) fstring; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args);  }  EXPORT_SYMBOL(prom_feval); @@ -68,6 +92,7 @@ extern void smp_release(void);   */  void prom_cmdline(void)  { +	unsigned long args[3];  	unsigned long flags;  	local_irq_save(flags); @@ -76,7 +101,11 @@ void prom_cmdline(void)  	smp_capture();  #endif -	p1275_cmd("enter", P1275_INOUT(0, 0)); +	args[0] = (unsigned long) "enter"; +	args[1] = 0; +	args[2] = 0; + +	p1275_cmd_direct(args);  #ifdef CONFIG_SMP  	smp_release(); @@ -90,22 +119,32 @@ void prom_cmdline(void)   */  void notrace prom_halt(void)  { +	unsigned long args[3]; +  #ifdef CONFIG_SUN_LDOMS  	if (ldom_domaining_enabled)  		ldom_power_off();  #endif  again: -	p1275_cmd("exit", P1275_INOUT(0, 0)); +	args[0] = (unsigned long) "exit"; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  	goto again; /* PROM is out to get me -DaveM */  }  void prom_halt_power_off(void)  { +	unsigned long args[3]; +  #ifdef CONFIG_SUN_LDOMS  	if (ldom_domaining_enabled)  		ldom_power_off();  #endif -	p1275_cmd("SUNW,power-off", P1275_INOUT(0, 0)); +	args[0] = (unsigned long) "SUNW,power-off"; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  	/* if nothing else helps, we just halt */  	prom_halt(); @@ -114,10 +153,15 @@ void prom_halt_power_off(void)  /* Set prom sync handler to call function 'funcp'. */  void prom_setcallback(callback_func_t funcp)  { +	unsigned long args[5];  	if (!funcp)  		return; -	p1275_cmd("set-callback", P1275_ARG(0, P1275_ARG_IN_FUNCTION) | -		  P1275_INOUT(1, 1), funcp); +	args[0] = (unsigned long) "set-callback"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned long) funcp; +	args[4] = (unsigned long) -1; +	p1275_cmd_direct(args);  }  /* Get the idprom and stuff it into buffer 'idbuf'.  Returns the @@ -173,57 +217,61 @@ static int prom_get_memory_ihandle(void)  }  /* Load explicit I/D TLB entries. */ +static long tlb_load(const char *type, unsigned long index, +		     unsigned long tte_data, unsigned long vaddr) +{ +	unsigned long args[9]; + +	args[0] = (unsigned long) prom_callmethod_name; +	args[1] = 5; +	args[2] = 1; +	args[3] = (unsigned long) type; +	args[4] = (unsigned int) prom_get_mmu_ihandle(); +	args[5] = vaddr; +	args[6] = tte_data; +	args[7] = index; +	args[8] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (long) args[8]; +} +  long prom_itlb_load(unsigned long index,  		    unsigned long tte_data,  		    unsigned long vaddr)  { -	return p1275_cmd(prom_callmethod_name, -			 (P1275_ARG(0, P1275_ARG_IN_STRING) | -			  P1275_ARG(2, P1275_ARG_IN_64B) | -			  P1275_ARG(3, P1275_ARG_IN_64B) | -			  P1275_INOUT(5, 1)), -			 "SUNW,itlb-load", -			 prom_get_mmu_ihandle(), -			 /* And then our actual args are pushed backwards. */ -			 vaddr, -			 tte_data, -			 index); +	return tlb_load("SUNW,itlb-load", index, tte_data, vaddr);  }  long prom_dtlb_load(unsigned long index,  		    unsigned long tte_data,  		    unsigned long vaddr)  { -	return p1275_cmd(prom_callmethod_name, -			 (P1275_ARG(0, P1275_ARG_IN_STRING) | -			  P1275_ARG(2, P1275_ARG_IN_64B) | -			  P1275_ARG(3, P1275_ARG_IN_64B) | -			  P1275_INOUT(5, 1)), -			 "SUNW,dtlb-load", -			 prom_get_mmu_ihandle(), -			 /* And then our actual args are pushed backwards. */ -			 vaddr, -			 tte_data, -			 index); +	return tlb_load("SUNW,dtlb-load", index, tte_data, vaddr);  }  int prom_map(int mode, unsigned long size,  	     unsigned long vaddr, unsigned long paddr)  { -	int ret = p1275_cmd(prom_callmethod_name, -			    (P1275_ARG(0, P1275_ARG_IN_STRING) | -			     P1275_ARG(3, P1275_ARG_IN_64B) | -			     P1275_ARG(4, P1275_ARG_IN_64B) | -			     P1275_ARG(6, P1275_ARG_IN_64B) | -			     P1275_INOUT(7, 1)), -			    prom_map_name, -			    prom_get_mmu_ihandle(), -			    mode, -			    size, -			    vaddr, -			    0, -			    paddr); - +	unsigned long args[11]; +	int ret; + +	args[0] = (unsigned long) prom_callmethod_name; +	args[1] = 7; +	args[2] = 1; +	args[3] = (unsigned long) prom_map_name; +	args[4] = (unsigned int) prom_get_mmu_ihandle(); +	args[5] = (unsigned int) mode; +	args[6] = size; +	args[7] = vaddr; +	args[8] = 0; +	args[9] = paddr; +	args[10] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	ret = (int) args[10];  	if (ret == 0)  		ret = -1;  	return ret; @@ -231,40 +279,51 @@ int prom_map(int mode, unsigned long size,  void prom_unmap(unsigned long size, unsigned long vaddr)  { -	p1275_cmd(prom_callmethod_name, -		  (P1275_ARG(0, P1275_ARG_IN_STRING) | -		   P1275_ARG(2, P1275_ARG_IN_64B) | -		   P1275_ARG(3, P1275_ARG_IN_64B) | -		   P1275_INOUT(4, 0)), -		  prom_unmap_name, -		  prom_get_mmu_ihandle(), -		  size, -		  vaddr); +	unsigned long args[7]; + +	args[0] = (unsigned long) prom_callmethod_name; +	args[1] = 4; +	args[2] = 0; +	args[3] = (unsigned long) prom_unmap_name; +	args[4] = (unsigned int) prom_get_mmu_ihandle(); +	args[5] = size; +	args[6] = vaddr; + +	p1275_cmd_direct(args);  }  /* Set aside physical memory which is not touched or modified   * across soft resets.   */ -unsigned long prom_retain(const char *name, -			  unsigned long pa_low, unsigned long pa_high, -			  long size, long align) +int prom_retain(const char *name, unsigned long size, +		unsigned long align, unsigned long *paddr)  { -	/* XXX I don't think we return multiple values correctly. -	 * XXX OBP supposedly returns pa_low/pa_high here, how does -	 * XXX it work? +	unsigned long args[11]; + +	args[0] = (unsigned long) prom_callmethod_name; +	args[1] = 5; +	args[2] = 3; +	args[3] = (unsigned long) "SUNW,retain"; +	args[4] = (unsigned int) prom_get_memory_ihandle(); +	args[5] = align; +	args[6] = size; +	args[7] = (unsigned long) name; +	args[8] = (unsigned long) -1; +	args[9] = (unsigned long) -1; +	args[10] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	if (args[8]) +		return (int) args[8]; + +	/* Next we get "phys_high" then "phys_low".  On 64-bit +	 * the phys_high cell is don't care since the phys_low +	 * cell has the full value.  	 */ +	*paddr = args[10]; -	/* If align is zero, the pa_low/pa_high args are passed, -	 * else they are not. -	 */ -	if (align == 0) -		return p1275_cmd("SUNW,retain", -				 (P1275_ARG(0, P1275_ARG_IN_BUF) | P1275_INOUT(5, 2)), -				 name, pa_low, pa_high, size, align); -	else -		return p1275_cmd("SUNW,retain", -				 (P1275_ARG(0, P1275_ARG_IN_BUF) | P1275_INOUT(3, 2)), -				 name, size, align); +	return 0;  }  /* Get "Unumber" string for the SIMM at the given @@ -277,62 +336,129 @@ int prom_getunumber(int syndrome_code,  		    unsigned long phys_addr,  		    char *buf, int buflen)  { -	return p1275_cmd(prom_callmethod_name, -			 (P1275_ARG(0, P1275_ARG_IN_STRING)	| -			  P1275_ARG(3, P1275_ARG_OUT_BUF)	| -			  P1275_ARG(6, P1275_ARG_IN_64B)	| -			  P1275_INOUT(8, 2)), -			 "SUNW,get-unumber", prom_get_memory_ihandle(), -			 buflen, buf, P1275_SIZE(buflen), -			 0, phys_addr, syndrome_code); +	unsigned long args[12]; + +	args[0] = (unsigned long) prom_callmethod_name; +	args[1] = 7; +	args[2] = 2; +	args[3] = (unsigned long) "SUNW,get-unumber"; +	args[4] = (unsigned int) prom_get_memory_ihandle(); +	args[5] = buflen; +	args[6] = (unsigned long) buf; +	args[7] = 0; +	args[8] = phys_addr; +	args[9] = (unsigned int) syndrome_code; +	args[10] = (unsigned long) -1; +	args[11] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[10];  }  /* Power management extensions. */  void prom_sleepself(void)  { -	p1275_cmd("SUNW,sleep-self", P1275_INOUT(0, 0)); +	unsigned long args[3]; + +	args[0] = (unsigned long) "SUNW,sleep-self"; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  }  int prom_sleepsystem(void)  { -	return p1275_cmd("SUNW,sleep-system", P1275_INOUT(0, 1)); +	unsigned long args[4]; + +	args[0] = (unsigned long) "SUNW,sleep-system"; +	args[1] = 0; +	args[2] = 1; +	args[3] = (unsigned long) -1; +	p1275_cmd_direct(args); + +	return (int) args[3];  }  int prom_wakeupsystem(void)  { -	return p1275_cmd("SUNW,wakeup-system", P1275_INOUT(0, 1)); +	unsigned long args[4]; + +	args[0] = (unsigned long) "SUNW,wakeup-system"; +	args[1] = 0; +	args[2] = 1; +	args[3] = (unsigned long) -1; +	p1275_cmd_direct(args); + +	return (int) args[3];  }  #ifdef CONFIG_SMP  void prom_startcpu(int cpunode, unsigned long pc, unsigned long arg)  { -	p1275_cmd("SUNW,start-cpu", P1275_INOUT(3, 0), cpunode, pc, arg); +	unsigned long args[6]; + +	args[0] = (unsigned long) "SUNW,start-cpu"; +	args[1] = 3; +	args[2] = 0; +	args[3] = (unsigned int) cpunode; +	args[4] = pc; +	args[5] = arg; +	p1275_cmd_direct(args);  }  void prom_startcpu_cpuid(int cpuid, unsigned long pc, unsigned long arg)  { -	p1275_cmd("SUNW,start-cpu-by-cpuid", P1275_INOUT(3, 0), -		  cpuid, pc, arg); +	unsigned long args[6]; + +	args[0] = (unsigned long) "SUNW,start-cpu-by-cpuid"; +	args[1] = 3; +	args[2] = 0; +	args[3] = (unsigned int) cpuid; +	args[4] = pc; +	args[5] = arg; +	p1275_cmd_direct(args);  }  void prom_stopcpu_cpuid(int cpuid)  { -	p1275_cmd("SUNW,stop-cpu-by-cpuid", P1275_INOUT(1, 0), -		  cpuid); +	unsigned long args[4]; + +	args[0] = (unsigned long) "SUNW,stop-cpu-by-cpuid"; +	args[1] = 1; +	args[2] = 0; +	args[3] = (unsigned int) cpuid; +	p1275_cmd_direct(args);  }  void prom_stopself(void)  { -	p1275_cmd("SUNW,stop-self", P1275_INOUT(0, 0)); +	unsigned long args[3]; + +	args[0] = (unsigned long) "SUNW,stop-self"; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  }  void prom_idleself(void)  { -	p1275_cmd("SUNW,idle-self", P1275_INOUT(0, 0)); +	unsigned long args[3]; + +	args[0] = (unsigned long) "SUNW,idle-self"; +	args[1] = 0; +	args[2] = 0; +	p1275_cmd_direct(args);  }  void prom_resumecpu(int cpunode)  { -	p1275_cmd("SUNW,resume-cpu", P1275_INOUT(1, 0), cpunode); +	unsigned long args[4]; + +	args[0] = (unsigned long) "SUNW,resume-cpu"; +	args[1] = 1; +	args[2] = 0; +	args[3] = (unsigned int) cpunode; +	p1275_cmd_direct(args);  }  #endif diff --git a/arch/sparc/prom/p1275.c b/arch/sparc/prom/p1275.c index 2d8b70d..fa6e4e2 100644 --- a/arch/sparc/prom/p1275.c +++ b/arch/sparc/prom/p1275.c @@ -22,13 +22,11 @@ struct {  	long prom_callback;			/* 0x00 */  	void (*prom_cif_handler)(long *);	/* 0x08 */  	unsigned long prom_cif_stack;		/* 0x10 */ -	unsigned long prom_args [23];		/* 0x18 */ -	char prom_buffer [3000];  } p1275buf;  extern void prom_world(int); -extern void prom_cif_interface(void); +extern void prom_cif_direct(unsigned long *args);  extern void prom_cif_callback(void);  /* @@ -36,114 +34,20 @@ extern void prom_cif_callback(void);   */  DEFINE_RAW_SPINLOCK(prom_entry_lock); -long p1275_cmd(const char *service, long fmt, ...) +void p1275_cmd_direct(unsigned long *args)  { -	char *p, *q;  	unsigned long flags; -	int nargs, nrets, i; -	va_list list; -	long attrs, x; -	 -	p = p1275buf.prom_buffer;  	raw_local_save_flags(flags);  	raw_local_irq_restore(PIL_NMI);  	raw_spin_lock(&prom_entry_lock); -	p1275buf.prom_args[0] = (unsigned long)p;		/* service */ -	strcpy (p, service); -	p = (char *)(((long)(strchr (p, 0) + 8)) & ~7); -	p1275buf.prom_args[1] = nargs = (fmt & 0x0f);		/* nargs */ -	p1275buf.prom_args[2] = nrets = ((fmt & 0xf0) >> 4); 	/* nrets */ -	attrs = fmt >> 8; -	va_start(list, fmt); -	for (i = 0; i < nargs; i++, attrs >>= 3) { -		switch (attrs & 0x7) { -		case P1275_ARG_NUMBER: -			p1275buf.prom_args[i + 3] = -						(unsigned)va_arg(list, long); -			break; -		case P1275_ARG_IN_64B: -			p1275buf.prom_args[i + 3] = -				va_arg(list, unsigned long); -			break; -		case P1275_ARG_IN_STRING: -			strcpy (p, va_arg(list, char *)); -			p1275buf.prom_args[i + 3] = (unsigned long)p; -			p = (char *)(((long)(strchr (p, 0) + 8)) & ~7); -			break; -		case P1275_ARG_OUT_BUF: -			(void) va_arg(list, char *); -			p1275buf.prom_args[i + 3] = (unsigned long)p; -			x = va_arg(list, long); -			i++; attrs >>= 3; -			p = (char *)(((long)(p + (int)x + 7)) & ~7); -			p1275buf.prom_args[i + 3] = x; -			break; -		case P1275_ARG_IN_BUF: -			q = va_arg(list, char *); -			p1275buf.prom_args[i + 3] = (unsigned long)p; -			x = va_arg(list, long); -			i++; attrs >>= 3; -			memcpy (p, q, (int)x); -			p = (char *)(((long)(p + (int)x + 7)) & ~7); -			p1275buf.prom_args[i + 3] = x; -			break; -		case P1275_ARG_OUT_32B: -			(void) va_arg(list, char *); -			p1275buf.prom_args[i + 3] = (unsigned long)p; -			p += 32; -			break; -		case P1275_ARG_IN_FUNCTION: -			p1275buf.prom_args[i + 3] = -					(unsigned long)prom_cif_callback; -			p1275buf.prom_callback = va_arg(list, long); -			break; -		} -	} -	va_end(list); -  	prom_world(1); -	prom_cif_interface(); +	prom_cif_direct(args);  	prom_world(0); -	attrs = fmt >> 8; -	va_start(list, fmt); -	for (i = 0; i < nargs; i++, attrs >>= 3) { -		switch (attrs & 0x7) { -		case P1275_ARG_NUMBER: -			(void) va_arg(list, long); -			break; -		case P1275_ARG_IN_STRING: -			(void) va_arg(list, char *); -			break; -		case P1275_ARG_IN_FUNCTION: -			(void) va_arg(list, long); -			break; -		case P1275_ARG_IN_BUF: -			(void) va_arg(list, char *); -			(void) va_arg(list, long); -			i++; attrs >>= 3; -			break; -		case P1275_ARG_OUT_BUF: -			p = va_arg(list, char *); -			x = va_arg(list, long); -			memcpy (p, (char *)(p1275buf.prom_args[i + 3]), (int)x); -			i++; attrs >>= 3; -			break; -		case P1275_ARG_OUT_32B: -			p = va_arg(list, char *); -			memcpy (p, (char *)(p1275buf.prom_args[i + 3]), 32); -			break; -		} -	} -	va_end(list); -	x = p1275buf.prom_args [nargs + 3]; -  	raw_spin_unlock(&prom_entry_lock);  	raw_local_irq_restore(flags); - -	return x;  }  void prom_cif_init(void *cif_handler, void *cif_stack) diff --git a/arch/sparc/prom/tree_64.c b/arch/sparc/prom/tree_64.c index 3c0d2dd..9d3f913 100644 --- a/arch/sparc/prom/tree_64.c +++ b/arch/sparc/prom/tree_64.c @@ -16,22 +16,39 @@  #include <asm/oplib.h>  #include <asm/ldc.h> +static int prom_node_to_node(const char *type, int node) +{ +	unsigned long args[5]; + +	args[0] = (unsigned long) type; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[4]; +} +  /* Return the child of node 'node' or zero if no this node has no   * direct descendent.   */  inline int __prom_getchild(int node)  { -	return p1275_cmd ("child", P1275_INOUT(1, 1), node); +	return prom_node_to_node("child", node);  }  inline int prom_getchild(int node)  {  	int cnode; -	if(node == -1) return 0; +	if (node == -1) +		return 0;  	cnode = __prom_getchild(node); -	if(cnode == -1) return 0; -	return (int)cnode; +	if (cnode == -1) +		return 0; +	return cnode;  }  EXPORT_SYMBOL(prom_getchild); @@ -39,10 +56,12 @@ inline int prom_getparent(int node)  {  	int cnode; -	if(node == -1) return 0; -	cnode = p1275_cmd ("parent", P1275_INOUT(1, 1), node); -	if(cnode == -1) return 0; -	return (int)cnode; +	if (node == -1) +		return 0; +	cnode = prom_node_to_node("parent", node); +	if (cnode == -1) +		return 0; +	return cnode;  }  /* Return the next sibling of node 'node' or zero if no more siblings @@ -50,7 +69,7 @@ inline int prom_getparent(int node)   */  inline int __prom_getsibling(int node)  { -	return p1275_cmd(prom_peer_name, P1275_INOUT(1, 1), node); +	return prom_node_to_node(prom_peer_name, node);  }  inline int prom_getsibling(int node) @@ -72,11 +91,21 @@ EXPORT_SYMBOL(prom_getsibling);   */  inline int prom_getproplen(int node, const char *prop)  { -	if((!node) || (!prop)) return -1; -	return p1275_cmd ("getproplen",  -			  P1275_ARG(1,P1275_ARG_IN_STRING)| -			  P1275_INOUT(2, 1),  -			  node, prop); +	unsigned long args[6]; + +	if (!node || !prop) +		return -1; + +	args[0] = (unsigned long) "getproplen"; +	args[1] = 2; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = (unsigned long) prop; +	args[5] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[5];  }  EXPORT_SYMBOL(prom_getproplen); @@ -87,19 +116,25 @@ EXPORT_SYMBOL(prom_getproplen);  inline int prom_getproperty(int node, const char *prop,  			    char *buffer, int bufsize)  { +	unsigned long args[8];  	int plen;  	plen = prom_getproplen(node, prop); -	if ((plen > bufsize) || (plen == 0) || (plen == -1)) { +	if ((plen > bufsize) || (plen == 0) || (plen == -1))  		return -1; -	} else { -		/* Ok, things seem all right. */ -		return p1275_cmd(prom_getprop_name,  -				 P1275_ARG(1,P1275_ARG_IN_STRING)| -				 P1275_ARG(2,P1275_ARG_OUT_BUF)| -				 P1275_INOUT(4, 1),  -				 node, prop, buffer, P1275_SIZE(plen)); -	} + +	args[0] = (unsigned long) prom_getprop_name; +	args[1] = 4; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = (unsigned long) prop; +	args[5] = (unsigned long) buffer; +	args[6] = bufsize; +	args[7] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[7];  }  EXPORT_SYMBOL(prom_getproperty); @@ -110,7 +145,7 @@ inline int prom_getint(int node, const char *prop)  {  	int intprop; -	if(prom_getproperty(node, prop, (char *) &intprop, sizeof(int)) != -1) +	if (prom_getproperty(node, prop, (char *) &intprop, sizeof(int)) != -1)  		return intprop;  	return -1; @@ -126,7 +161,8 @@ int prom_getintdefault(int node, const char *property, int deflt)  	int retval;  	retval = prom_getint(node, property); -	if(retval == -1) return deflt; +	if (retval == -1) +		return deflt;  	return retval;  } @@ -138,7 +174,8 @@ int prom_getbool(int node, const char *prop)  	int retval;  	retval = prom_getproplen(node, prop); -	if(retval == -1) return 0; +	if (retval == -1) +		return 0;  	return 1;  }  EXPORT_SYMBOL(prom_getbool); @@ -152,7 +189,8 @@ void prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size)  	int len;  	len = prom_getproperty(node, prop, user_buf, ubuf_size); -	if(len != -1) return; +	if (len != -1) +		return;  	user_buf[0] = 0;  }  EXPORT_SYMBOL(prom_getstring); @@ -164,7 +202,8 @@ int prom_nodematch(int node, const char *name)  {  	char namebuf[128];  	prom_getproperty(node, "name", namebuf, sizeof(namebuf)); -	if(strcmp(namebuf, name) == 0) return 1; +	if (strcmp(namebuf, name) == 0) +		return 1;  	return 0;  } @@ -190,16 +229,29 @@ int prom_searchsiblings(int node_start, const char *nodename)  }  EXPORT_SYMBOL(prom_searchsiblings); +static const char *prom_nextprop_name = "nextprop"; +  /* Return the first property type for node 'node'.   * buffer should be at least 32B in length   */  inline char *prom_firstprop(int node, char *buffer)  { +	unsigned long args[7]; +  	*buffer = 0; -	if(node == -1) return buffer; -	p1275_cmd ("nextprop", P1275_ARG(2,P1275_ARG_OUT_32B)| -			       P1275_INOUT(3, 0),  -			       node, (char *) 0x0, buffer); +	if (node == -1) +		return buffer; + +	args[0] = (unsigned long) prom_nextprop_name; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = 0; +	args[5] = (unsigned long) buffer; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args); +  	return buffer;  }  EXPORT_SYMBOL(prom_firstprop); @@ -210,9 +262,10 @@ EXPORT_SYMBOL(prom_firstprop);   */  inline char *prom_nextprop(int node, const char *oprop, char *buffer)  { +	unsigned long args[7];  	char buf[32]; -	if(node == -1) { +	if (node == -1) {  		*buffer = 0;  		return buffer;  	} @@ -220,10 +273,17 @@ inline char *prom_nextprop(int node, const char *oprop, char *buffer)  		strcpy (buf, oprop);  		oprop = buf;  	} -	p1275_cmd ("nextprop", P1275_ARG(1,P1275_ARG_IN_STRING)| -				    P1275_ARG(2,P1275_ARG_OUT_32B)| -				    P1275_INOUT(3, 0),  -				    node, oprop, buffer);  + +	args[0] = (unsigned long) prom_nextprop_name; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = (unsigned long) oprop; +	args[5] = (unsigned long) buffer; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args); +  	return buffer;  }  EXPORT_SYMBOL(prom_nextprop); @@ -231,12 +291,19 @@ EXPORT_SYMBOL(prom_nextprop);  int  prom_finddevice(const char *name)  { +	unsigned long args[5]; +  	if (!name)  		return 0; -	return p1275_cmd(prom_finddev_name, -			 P1275_ARG(0,P1275_ARG_IN_STRING)| -			 P1275_INOUT(1, 1),  -			 name); +	args[0] = (unsigned long) "finddevice"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned long) name; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[4];  }  EXPORT_SYMBOL(prom_finddevice); @@ -247,7 +314,7 @@ int prom_node_has_property(int node, const char *prop)  	*buf = 0;  	do {  		prom_nextprop(node, buf, buf); -		if(!strcmp(buf, prop)) +		if (!strcmp(buf, prop))  			return 1;  	} while (*buf);  	return 0; @@ -260,6 +327,8 @@ EXPORT_SYMBOL(prom_node_has_property);  int  prom_setprop(int node, const char *pname, char *value, int size)  { +	unsigned long args[8]; +  	if (size == 0)  		return 0;  	if ((pname == 0) || (value == 0)) @@ -271,19 +340,37 @@ prom_setprop(int node, const char *pname, char *value, int size)  		return 0;  	}  #endif -	return p1275_cmd ("setprop", P1275_ARG(1,P1275_ARG_IN_STRING)| -					  P1275_ARG(2,P1275_ARG_IN_BUF)| -					  P1275_INOUT(4, 1),  -					  node, pname, value, P1275_SIZE(size)); +	args[0] = (unsigned long) "setprop"; +	args[1] = 4; +	args[2] = 1; +	args[3] = (unsigned int) node; +	args[4] = (unsigned long) pname; +	args[5] = (unsigned long) value; +	args[6] = size; +	args[7] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[7];  }  EXPORT_SYMBOL(prom_setprop);  inline int prom_inst2pkg(int inst)  { +	unsigned long args[5];  	int node; -	node = p1275_cmd ("instance-to-package", P1275_INOUT(1, 1), inst); -	if (node == -1) return 0; +	args[0] = (unsigned long) "instance-to-package"; +	args[1] = 1; +	args[2] = 1; +	args[3] = (unsigned int) inst; +	args[4] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	node = (int) args[4]; +	if (node == -1) +		return 0;  	return node;  } @@ -296,17 +383,28 @@ prom_pathtoinode(const char *path)  	int node, inst;  	inst = prom_devopen (path); -	if (inst == 0) return 0; -	node = prom_inst2pkg (inst); -	prom_devclose (inst); -	if (node == -1) return 0; +	if (inst == 0) +		return 0; +	node = prom_inst2pkg(inst); +	prom_devclose(inst); +	if (node == -1) +		return 0;  	return node;  }  int prom_ihandle2path(int handle, char *buffer, int bufsize)  { -	return p1275_cmd("instance-to-path", -			 P1275_ARG(1,P1275_ARG_OUT_BUF)| -			 P1275_INOUT(3, 1), -			 handle, buffer, P1275_SIZE(bufsize)); +	unsigned long args[7]; + +	args[0] = (unsigned long) "instance-to-path"; +	args[1] = 3; +	args[2] = 1; +	args[3] = (unsigned int) handle; +	args[4] = (unsigned long) buffer; +	args[5] = bufsize; +	args[6] = (unsigned long) -1; + +	p1275_cmd_direct(args); + +	return (int) args[6];  } | 
