mirror of
https://github.com/joel16/android_kernel_sony_msm8994.git
synced 2025-01-27 07:22:28 +00:00
Merge branch 'master' of hera.kernel.org:/pub/scm/linux/kernel/git/kyle/parisc-2.6
* 'master' of hera.kernel.org:/pub/scm/linux/kernel/git/kyle/parisc-2.6: (29 commits) [PARISC] fix uninitialized variable warning in asm/rtc.h [PARISC] Port checkstack.pl to parisc [PARISC] Make palo target work when $obj != $src [PARISC] Zap unused variable warnings in pci.c [PARISC] Fix tests in palo target [PARISC] Fix palo target [PARISC] Restore palo target [PARISC] Attempt to clean up parisc/Makefile [PARISC] Fix infinite loop in /proc/iomem [PARISC] Quiet sysfs_create_link __must_check warnings in pdc_stable [PARISC] Squelch pci_enable_device __must_check warning in superio [PARISC] Kill off broken irqstack code [PARISC] Remove hardcoded uses of PAGE_SIZE [PARISC] Clean up pointless ASM_PAGE_SIZE_DIV use [PARISC] Kill off the last vestiges of ASM_PAGE_SIZE [PARISC] Kill off ASM_PAGE_SIZE use [PARISC] Beautify parisc vmlinux.lds.S [PARISC] Clean up a resource_size_t warning in sba_iommu [PARISC] Kill incorrect cast warning in unwinder [PARISC] Kill zone_to_nid printk warning ... Fixed trivial conflict in include/asm-parisc/tlbflush.h manually
This commit is contained in:
commit
cfa76f024f
@ -19,26 +19,27 @@
|
||||
NM = sh $(srctree)/arch/parisc/nm
|
||||
CHECKFLAGS += -D__hppa__=1
|
||||
|
||||
MACHINE := $(shell uname -m)
|
||||
ifeq ($(MACHINE),parisc*)
|
||||
NATIVE := 1
|
||||
endif
|
||||
|
||||
ifdef CONFIG_64BIT
|
||||
CROSS_COMPILE := $(shell if [ -x /usr/bin/hppa64-linux-gnu-gcc ]; then \
|
||||
echo hppa64-linux-gnu-; else echo hppa64-linux-; fi)
|
||||
UTS_MACHINE := parisc64
|
||||
CHECKFLAGS += -D__LP64__=1 -m64
|
||||
else
|
||||
MACHINE := $(subst 64,,$(shell uname -m))
|
||||
ifneq ($(MACHINE),parisc)
|
||||
CROSS_COMPILE := hppa-linux-
|
||||
endif
|
||||
WIDTH := 64
|
||||
CROSS_COMPILE := hppa64-linux-gnu-
|
||||
else # 32-bit
|
||||
WIDTH :=
|
||||
endif
|
||||
|
||||
FINAL_LD=$(CROSS_COMPILE)ld --warn-common --warn-section-align
|
||||
# attempt to help out folks who are cross-compiling
|
||||
ifeq ($(NATIVE),1)
|
||||
CROSS_COMPILE := hppa$(WIDTH)-linux-
|
||||
endif
|
||||
|
||||
OBJCOPY_FLAGS =-O binary -R .note -R .comment -S
|
||||
|
||||
ifneq ($(call cc-ifversion, -lt, 0303, "bad"),)
|
||||
$(error Sorry, GCC v3.3 or above is required.)
|
||||
endif
|
||||
|
||||
cflags-y := -pipe
|
||||
|
||||
# These flags should be implied by an hppa-linux configuration, but they
|
||||
@ -69,7 +70,7 @@ kernel-y := mm/ kernel/ math-emu/ kernel/init_task.o
|
||||
kernel-$(CONFIG_HPUX) += hpux/
|
||||
|
||||
core-y += $(addprefix arch/parisc/, $(kernel-y))
|
||||
libs-y += arch/parisc/lib/ `$(CC) -print-libgcc-file-name`
|
||||
libs-y += arch/parisc/lib/
|
||||
|
||||
drivers-$(CONFIG_OPROFILE) += arch/parisc/oprofile/
|
||||
|
||||
@ -77,27 +78,27 @@ PALO := $(shell if which palo; then : ; \
|
||||
elif [ -x /sbin/palo ]; then echo /sbin/palo; \
|
||||
fi)
|
||||
|
||||
PALOCONF := $(shell if [ -f $(src)/palo.conf ]; then echo $(src)/palo.conf; \
|
||||
else echo $(obj)/palo.conf; \
|
||||
fi)
|
||||
|
||||
palo: vmlinux
|
||||
@if [ -x $PALO ]; then \
|
||||
@if test ! -x "$(PALO)"; then \
|
||||
echo 'ERROR: Please install palo first (apt-get install palo)';\
|
||||
echo 'or build it from source and install it somewhere in your $$PATH';\
|
||||
false; \
|
||||
fi
|
||||
@if [ ! -f ./palo.conf ]; then \
|
||||
cp arch/parisc/defpalo.conf palo.conf; \
|
||||
echo 'A generic palo config file (./palo.conf) has been created for you.'; \
|
||||
@if test ! -f "$(PALOCONF)"; then \
|
||||
cp $(src)/arch/parisc/defpalo.conf $(obj)/palo.conf; \
|
||||
echo 'A generic palo config file ($(obj)/palo.conf) has been created for you.'; \
|
||||
echo 'You should check it and re-run "make palo".'; \
|
||||
echo 'WARNING: the "lifimage" file is now placed in this directory by default!'; \
|
||||
false; \
|
||||
fi
|
||||
$(PALO) -f ./palo.conf
|
||||
$(PALO) -f $(PALOCONF)
|
||||
|
||||
oldpalo: vmlinux
|
||||
export TOPDIR=`pwd`; \
|
||||
unset STRIP LDFLAGS CPP CPPFLAGS AFLAGS CFLAGS CC LD; cd ../palo && make lifimage
|
||||
|
||||
# Shorthands for known targets not supported by parisc, use palo as default
|
||||
Image zImage bzImage: palo
|
||||
# Shorthands for known targets not supported by parisc, use vmlinux as default
|
||||
Image zImage bzImage: vmlinux
|
||||
|
||||
kernel_install: vmlinux
|
||||
sh $(src)/arch/parisc/install.sh \
|
||||
@ -116,3 +117,12 @@ define archhelp
|
||||
@echo ' (distribution) /sbin/installkernel or'
|
||||
@echo ' copy to $$(INSTALL_PATH)'
|
||||
endef
|
||||
|
||||
# we require gcc 3.3 or above to compile the kernel
|
||||
archprepare: checkbin
|
||||
checkbin:
|
||||
@if test "$(call cc-version)" -lt "0303"; then \
|
||||
echo -n "Sorry, GCC v3.3 or above is required to build " ; \
|
||||
echo "the kernel." ; \
|
||||
false ; \
|
||||
fi
|
||||
|
@ -1,39 +1,51 @@
|
||||
#
|
||||
# Automatically generated make config: don't edit
|
||||
# Linux kernel version: 2.6.16-pa6
|
||||
# Sun Mar 26 19:59:51 2006
|
||||
# Linux kernel version: 2.6.23
|
||||
# Fri Oct 12 21:00:07 2007
|
||||
#
|
||||
CONFIG_PARISC=y
|
||||
CONFIG_MMU=y
|
||||
CONFIG_STACK_GROWSUP=y
|
||||
CONFIG_RWSEM_GENERIC_SPINLOCK=y
|
||||
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
||||
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
||||
CONFIG_GENERIC_FIND_NEXT_BIT=y
|
||||
CONFIG_GENERIC_BUG=y
|
||||
CONFIG_GENERIC_HWEIGHT=y
|
||||
CONFIG_GENERIC_CALIBRATE_DELAY=y
|
||||
CONFIG_GENERIC_TIME=y
|
||||
CONFIG_GENERIC_HARDIRQS=y
|
||||
CONFIG_GENERIC_IRQ_PROBE=y
|
||||
|
||||
#
|
||||
# Code maturity level options
|
||||
#
|
||||
CONFIG_EXPERIMENTAL=y
|
||||
CONFIG_BROKEN_ON_SMP=y
|
||||
CONFIG_INIT_ENV_ARG_LIMIT=32
|
||||
CONFIG_IRQ_PER_CPU=y
|
||||
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
|
||||
|
||||
#
|
||||
# General setup
|
||||
#
|
||||
CONFIG_EXPERIMENTAL=y
|
||||
CONFIG_BROKEN_ON_SMP=y
|
||||
CONFIG_INIT_ENV_ARG_LIMIT=32
|
||||
CONFIG_LOCALVERSION=""
|
||||
# CONFIG_LOCALVERSION_AUTO is not set
|
||||
CONFIG_SWAP=y
|
||||
CONFIG_SYSVIPC=y
|
||||
CONFIG_SYSVIPC_SYSCTL=y
|
||||
CONFIG_POSIX_MQUEUE=y
|
||||
# CONFIG_BSD_PROCESS_ACCT is not set
|
||||
CONFIG_SYSCTL=y
|
||||
# CONFIG_TASKSTATS is not set
|
||||
# CONFIG_USER_NS is not set
|
||||
# CONFIG_AUDIT is not set
|
||||
CONFIG_IKCONFIG=y
|
||||
CONFIG_IKCONFIG_PROC=y
|
||||
CONFIG_LOG_BUF_SHIFT=16
|
||||
CONFIG_SYSFS_DEPRECATED=y
|
||||
# CONFIG_RELAY is not set
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_INITRAMFS_SOURCE=""
|
||||
CONFIG_CC_OPTIMIZE_FOR_SIZE=y
|
||||
CONFIG_SYSCTL=y
|
||||
# CONFIG_EMBEDDED is not set
|
||||
CONFIG_SYSCTL_SYSCALL=y
|
||||
CONFIG_KALLSYMS=y
|
||||
CONFIG_KALLSYMS_ALL=y
|
||||
# CONFIG_KALLSYMS_EXTRA_PASS is not set
|
||||
@ -43,31 +55,29 @@ CONFIG_BUG=y
|
||||
CONFIG_ELF_CORE=y
|
||||
CONFIG_BASE_FULL=y
|
||||
CONFIG_FUTEX=y
|
||||
CONFIG_ANON_INODES=y
|
||||
CONFIG_EPOLL=y
|
||||
CONFIG_SIGNALFD=y
|
||||
CONFIG_EVENTFD=y
|
||||
CONFIG_SHMEM=y
|
||||
CONFIG_CC_ALIGN_FUNCTIONS=0
|
||||
CONFIG_CC_ALIGN_LABELS=0
|
||||
CONFIG_CC_ALIGN_LOOPS=0
|
||||
CONFIG_CC_ALIGN_JUMPS=0
|
||||
CONFIG_VM_EVENT_COUNTERS=y
|
||||
CONFIG_SLAB=y
|
||||
# CONFIG_SLUB is not set
|
||||
# CONFIG_SLOB is not set
|
||||
CONFIG_RT_MUTEXES=y
|
||||
# CONFIG_TINY_SHMEM is not set
|
||||
CONFIG_BASE_SMALL=0
|
||||
# CONFIG_SLOB is not set
|
||||
|
||||
#
|
||||
# Loadable module support
|
||||
#
|
||||
CONFIG_MODULES=y
|
||||
CONFIG_MODULE_UNLOAD=y
|
||||
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||
CONFIG_OBSOLETE_MODPARM=y
|
||||
# CONFIG_MODVERSIONS is not set
|
||||
# CONFIG_MODULE_SRCVERSION_ALL is not set
|
||||
CONFIG_KMOD=y
|
||||
|
||||
#
|
||||
# Block layer
|
||||
#
|
||||
CONFIG_BLOCK=y
|
||||
# CONFIG_LBD is not set
|
||||
# CONFIG_BLK_DEV_IO_TRACE is not set
|
||||
# CONFIG_LSF is not set
|
||||
# CONFIG_BLK_DEV_BSG is not set
|
||||
|
||||
#
|
||||
# IO Schedulers
|
||||
@ -91,6 +101,9 @@ CONFIG_PA7100LC=y
|
||||
# CONFIG_PA7300LC is not set
|
||||
# CONFIG_PA8X00 is not set
|
||||
CONFIG_PA11=y
|
||||
CONFIG_PARISC_PAGE_SIZE_4KB=y
|
||||
# CONFIG_PARISC_PAGE_SIZE_16KB is not set
|
||||
# CONFIG_PARISC_PAGE_SIZE_64KB is not set
|
||||
# CONFIG_SMP is not set
|
||||
CONFIG_ARCH_FLATMEM_ENABLE=y
|
||||
# CONFIG_PREEMPT_NONE is not set
|
||||
@ -98,6 +111,7 @@ CONFIG_PREEMPT_VOLUNTARY=y
|
||||
# CONFIG_PREEMPT 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_SELECT_MEMORY_MODEL=y
|
||||
@ -108,6 +122,9 @@ CONFIG_FLATMEM=y
|
||||
CONFIG_FLAT_NODE_MEM_MAP=y
|
||||
# CONFIG_SPARSEMEM_STATIC is not set
|
||||
CONFIG_SPLIT_PTLOCK_CPUS=4096
|
||||
# CONFIG_RESOURCES_64BIT is not set
|
||||
CONFIG_ZONE_DMA_FLAG=0
|
||||
CONFIG_VIRT_TO_BUS=y
|
||||
# CONFIG_HPUX is not set
|
||||
|
||||
#
|
||||
@ -120,21 +137,19 @@ CONFIG_GSC_LASI=y
|
||||
# CONFIG_GSC_WAX is not set
|
||||
# CONFIG_EISA is not set
|
||||
# CONFIG_PCI is not set
|
||||
# CONFIG_ARCH_SUPPORTS_MSI is not set
|
||||
|
||||
#
|
||||
# PCCARD (PCMCIA/CardBus) support
|
||||
#
|
||||
# CONFIG_PCCARD is not set
|
||||
|
||||
#
|
||||
# PCI Hotplug Support
|
||||
#
|
||||
|
||||
#
|
||||
# PA-RISC specific drivers
|
||||
#
|
||||
CONFIG_CHASSIS_LCD_LED=y
|
||||
# CONFIG_PDC_CHASSIS is not set
|
||||
CONFIG_PDC_CHASSIS_WARN=y
|
||||
CONFIG_PDC_STABLE=y
|
||||
|
||||
#
|
||||
@ -151,13 +166,15 @@ CONFIG_NET=y
|
||||
#
|
||||
# Networking options
|
||||
#
|
||||
# CONFIG_NETDEBUG is not set
|
||||
CONFIG_PACKET=y
|
||||
CONFIG_PACKET_MMAP=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_NET_KEY=m
|
||||
# CONFIG_NET_KEY_MIGRATE is not set
|
||||
CONFIG_INET=y
|
||||
CONFIG_IP_MULTICAST=y
|
||||
# CONFIG_IP_ADVANCED_ROUTER is not set
|
||||
@ -174,17 +191,23 @@ CONFIG_IP_PNP_BOOTP=y
|
||||
CONFIG_INET_AH=m
|
||||
CONFIG_INET_ESP=m
|
||||
# CONFIG_INET_IPCOMP is not set
|
||||
CONFIG_INET_TUNNEL=m
|
||||
# CONFIG_INET_XFRM_TUNNEL is not set
|
||||
# CONFIG_INET_TUNNEL is not set
|
||||
CONFIG_INET_XFRM_MODE_TRANSPORT=y
|
||||
CONFIG_INET_XFRM_MODE_TUNNEL=y
|
||||
CONFIG_INET_XFRM_MODE_BEET=y
|
||||
# CONFIG_INET_LRO is not set
|
||||
CONFIG_INET_DIAG=m
|
||||
CONFIG_INET_TCP_DIAG=m
|
||||
# CONFIG_TCP_CONG_ADVANCED is not set
|
||||
CONFIG_TCP_CONG_BIC=y
|
||||
|
||||
#
|
||||
# IP: Virtual Server Configuration
|
||||
#
|
||||
CONFIG_TCP_CONG_CUBIC=y
|
||||
CONFIG_DEFAULT_TCP_CONG="cubic"
|
||||
# CONFIG_TCP_MD5SIG is not set
|
||||
# CONFIG_IP_VS is not set
|
||||
# CONFIG_IPV6 is not set
|
||||
# CONFIG_INET6_XFRM_TUNNEL is not set
|
||||
# CONFIG_INET6_TUNNEL is not set
|
||||
# CONFIG_NETWORK_SECMARK is not set
|
||||
CONFIG_NETFILTER=y
|
||||
# CONFIG_NETFILTER_DEBUG is not set
|
||||
|
||||
@ -192,37 +215,18 @@ CONFIG_NETFILTER=y
|
||||
# Core Netfilter Configuration
|
||||
#
|
||||
# CONFIG_NETFILTER_NETLINK is not set
|
||||
# CONFIG_NF_CONNTRACK_ENABLED is not set
|
||||
# CONFIG_NF_CONNTRACK is not set
|
||||
# CONFIG_NETFILTER_XTABLES is not set
|
||||
|
||||
#
|
||||
# IP: Netfilter Configuration
|
||||
#
|
||||
CONFIG_IP_NF_CONNTRACK=m
|
||||
# CONFIG_IP_NF_CT_ACCT is not set
|
||||
CONFIG_IP_NF_CONNTRACK_MARK=y
|
||||
# CONFIG_IP_NF_CONNTRACK_EVENTS is not set
|
||||
CONFIG_IP_NF_CT_PROTO_SCTP=m
|
||||
CONFIG_IP_NF_FTP=m
|
||||
CONFIG_IP_NF_IRC=m
|
||||
# CONFIG_IP_NF_NETBIOS_NS is not set
|
||||
CONFIG_IP_NF_TFTP=m
|
||||
CONFIG_IP_NF_AMANDA=m
|
||||
# CONFIG_IP_NF_PPTP is not set
|
||||
CONFIG_IP_NF_QUEUE=m
|
||||
|
||||
#
|
||||
# DCCP Configuration (EXPERIMENTAL)
|
||||
#
|
||||
# CONFIG_IP_NF_IPTABLES is not set
|
||||
# CONFIG_IP_NF_ARPTABLES is not set
|
||||
# CONFIG_IP_DCCP is not set
|
||||
|
||||
#
|
||||
# SCTP Configuration (EXPERIMENTAL)
|
||||
#
|
||||
# CONFIG_IP_SCTP is not set
|
||||
|
||||
#
|
||||
# TIPC Configuration (EXPERIMENTAL)
|
||||
#
|
||||
# CONFIG_TIPC is not set
|
||||
# CONFIG_ATM is not set
|
||||
# CONFIG_BRIDGE is not set
|
||||
@ -234,7 +238,6 @@ CONFIG_LLC2=m
|
||||
# CONFIG_ATALK is not set
|
||||
# CONFIG_X25 is not set
|
||||
# CONFIG_LAPB is not set
|
||||
# CONFIG_NET_DIVERT is not set
|
||||
# CONFIG_ECONET is not set
|
||||
# CONFIG_WAN_ROUTER is not set
|
||||
|
||||
@ -250,7 +253,17 @@ CONFIG_NET_PKTGEN=m
|
||||
# CONFIG_HAMRADIO is not set
|
||||
# CONFIG_IRDA is not set
|
||||
# CONFIG_BT is not set
|
||||
# CONFIG_AF_RXRPC is not set
|
||||
|
||||
#
|
||||
# Wireless
|
||||
#
|
||||
# CONFIG_CFG80211 is not set
|
||||
# CONFIG_WIRELESS_EXT is not set
|
||||
# CONFIG_MAC80211 is not set
|
||||
# CONFIG_IEEE80211 is not set
|
||||
# CONFIG_RFKILL is not set
|
||||
# CONFIG_NET_9P is not set
|
||||
|
||||
#
|
||||
# Device Drivers
|
||||
@ -259,39 +272,24 @@ CONFIG_NET_PKTGEN=m
|
||||
#
|
||||
# Generic Driver Options
|
||||
#
|
||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||
# CONFIG_STANDALONE is not set
|
||||
# CONFIG_PREVENT_FIRMWARE_BUILD is not set
|
||||
CONFIG_FW_LOADER=y
|
||||
# CONFIG_DEBUG_DRIVER is not set
|
||||
|
||||
#
|
||||
# Connector - unified userspace <-> kernelspace linker
|
||||
#
|
||||
# CONFIG_DEBUG_DEVRES is not set
|
||||
# CONFIG_SYS_HYPERVISOR is not set
|
||||
# CONFIG_CONNECTOR is not set
|
||||
|
||||
#
|
||||
# Memory Technology Devices (MTD)
|
||||
#
|
||||
# CONFIG_MTD is not set
|
||||
|
||||
#
|
||||
# Parallel port support
|
||||
#
|
||||
CONFIG_PARPORT=y
|
||||
CONFIG_PARPORT_PC=m
|
||||
# CONFIG_PARPORT_PC_FIFO is not set
|
||||
# CONFIG_PARPORT_PC_SUPERIO is not set
|
||||
CONFIG_PARPORT_NOT_PC=y
|
||||
CONFIG_PARPORT_GSC=y
|
||||
# CONFIG_PARPORT_AX88796 is not set
|
||||
# CONFIG_PARPORT_1284 is not set
|
||||
|
||||
#
|
||||
# Plug and Play support
|
||||
#
|
||||
|
||||
#
|
||||
# Block devices
|
||||
#
|
||||
CONFIG_PARPORT_NOT_PC=y
|
||||
CONFIG_BLK_DEV=y
|
||||
# CONFIG_PARIDE is not set
|
||||
# CONFIG_BLK_DEV_COW_COMMON is not set
|
||||
CONFIG_BLK_DEV_LOOP=y
|
||||
@ -300,13 +298,11 @@ CONFIG_BLK_DEV_CRYPTOLOOP=y
|
||||
CONFIG_BLK_DEV_RAM=y
|
||||
CONFIG_BLK_DEV_RAM_COUNT=16
|
||||
CONFIG_BLK_DEV_RAM_SIZE=6144
|
||||
CONFIG_BLK_DEV_INITRD=y
|
||||
CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024
|
||||
# CONFIG_CDROM_PKTCDVD is not set
|
||||
CONFIG_ATA_OVER_ETH=m
|
||||
|
||||
#
|
||||
# ATA/ATAPI/MFM/RLL support
|
||||
#
|
||||
CONFIG_MISC_DEVICES=y
|
||||
# CONFIG_EEPROM_93CX6 is not set
|
||||
# CONFIG_IDE is not set
|
||||
|
||||
#
|
||||
@ -314,6 +310,9 @@ CONFIG_ATA_OVER_ETH=m
|
||||
#
|
||||
# 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
|
||||
|
||||
#
|
||||
@ -333,104 +332,61 @@ CONFIG_CHR_DEV_SG=y
|
||||
# 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 Transport Attributes
|
||||
# SCSI Transports
|
||||
#
|
||||
CONFIG_SCSI_SPI_ATTRS=y
|
||||
# CONFIG_SCSI_FC_ATTRS is not set
|
||||
CONFIG_SCSI_ISCSI_ATTRS=m
|
||||
# CONFIG_SCSI_SAS_ATTRS is not set
|
||||
|
||||
#
|
||||
# SCSI low-level drivers
|
||||
#
|
||||
# CONFIG_SCSI_SAS_LIBSAS is not set
|
||||
CONFIG_SCSI_LOWLEVEL=y
|
||||
# CONFIG_ISCSI_TCP is not set
|
||||
# CONFIG_SCSI_SATA is not set
|
||||
# CONFIG_SCSI_PPA is not set
|
||||
# CONFIG_SCSI_IMM is not set
|
||||
CONFIG_SCSI_LASI700=y
|
||||
CONFIG_53C700_LE_ON_BE=y
|
||||
# CONFIG_SCSI_ZALON is not set
|
||||
CONFIG_SCSI_DEBUG=m
|
||||
|
||||
#
|
||||
# Multi-device support (RAID and LVM)
|
||||
#
|
||||
# CONFIG_ATA is not set
|
||||
CONFIG_MD=y
|
||||
CONFIG_BLK_DEV_MD=m
|
||||
CONFIG_MD_LINEAR=m
|
||||
CONFIG_MD_RAID0=m
|
||||
CONFIG_MD_RAID1=m
|
||||
# CONFIG_MD_RAID10 is not set
|
||||
# CONFIG_MD_RAID5 is not set
|
||||
# CONFIG_MD_RAID6 is not set
|
||||
# CONFIG_MD_RAID456 is not set
|
||||
# CONFIG_MD_MULTIPATH is not set
|
||||
# CONFIG_MD_FAULTY is not set
|
||||
# CONFIG_BLK_DEV_DM is not set
|
||||
|
||||
#
|
||||
# Fusion MPT device support
|
||||
#
|
||||
# CONFIG_FUSION is not set
|
||||
|
||||
#
|
||||
# IEEE 1394 (FireWire) support
|
||||
#
|
||||
|
||||
#
|
||||
# I2O device support
|
||||
#
|
||||
|
||||
#
|
||||
# Network device support
|
||||
#
|
||||
CONFIG_NETDEVICES=y
|
||||
# CONFIG_NETDEVICES_MULTIQUEUE is not set
|
||||
CONFIG_DUMMY=m
|
||||
CONFIG_BONDING=m
|
||||
# CONFIG_MACVLAN is not set
|
||||
# CONFIG_EQUALIZER is not set
|
||||
CONFIG_TUN=m
|
||||
|
||||
#
|
||||
# PHY device support
|
||||
#
|
||||
# CONFIG_VETH is not set
|
||||
# CONFIG_PHYLIB is not set
|
||||
|
||||
#
|
||||
# Ethernet (10 or 100Mbit)
|
||||
#
|
||||
CONFIG_NET_ETHERNET=y
|
||||
CONFIG_MII=m
|
||||
CONFIG_LASI_82596=y
|
||||
# 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_B44 is not set
|
||||
# CONFIG_NET_POCKET is not set
|
||||
CONFIG_NETDEV_1000=y
|
||||
CONFIG_NETDEV_10000=y
|
||||
|
||||
#
|
||||
# Ethernet (1000 Mbit)
|
||||
#
|
||||
|
||||
#
|
||||
# Ethernet (10000 Mbit)
|
||||
#
|
||||
|
||||
#
|
||||
# Token Ring devices
|
||||
#
|
||||
|
||||
#
|
||||
# Wireless LAN (non-hamradio)
|
||||
#
|
||||
CONFIG_NET_RADIO=y
|
||||
|
||||
#
|
||||
# Obsolete Wireless cards support (pre-802.11)
|
||||
#
|
||||
# CONFIG_STRIP is not set
|
||||
# CONFIG_ATMEL is not set
|
||||
# CONFIG_HOSTAP is not set
|
||||
|
||||
#
|
||||
# Wan interfaces
|
||||
# Wireless LAN
|
||||
#
|
||||
# CONFIG_WLAN_PRE80211 is not set
|
||||
# CONFIG_WLAN_80211 is not set
|
||||
# CONFIG_WAN is not set
|
||||
# CONFIG_PLIP is not set
|
||||
CONFIG_PPP=m
|
||||
@ -442,26 +398,22 @@ CONFIG_PPP_DEFLATE=m
|
||||
CONFIG_PPP_BSDCOMP=m
|
||||
CONFIG_PPP_MPPE=m
|
||||
CONFIG_PPPOE=m
|
||||
# CONFIG_PPPOL2TP is not set
|
||||
# CONFIG_SLIP is not set
|
||||
CONFIG_SLHC=m
|
||||
# CONFIG_SHAPER is not set
|
||||
# CONFIG_NETCONSOLE is not set
|
||||
# CONFIG_NETPOLL is not set
|
||||
# CONFIG_NET_POLL_CONTROLLER is not set
|
||||
|
||||
#
|
||||
# ISDN subsystem
|
||||
#
|
||||
# CONFIG_ISDN is not set
|
||||
|
||||
#
|
||||
# Telephony Support
|
||||
#
|
||||
# CONFIG_PHONE is not set
|
||||
|
||||
#
|
||||
# Input device support
|
||||
#
|
||||
CONFIG_INPUT=y
|
||||
# CONFIG_INPUT_FF_MEMLESS is not set
|
||||
# CONFIG_INPUT_POLLDEV is not set
|
||||
|
||||
#
|
||||
# Userland interfaces
|
||||
@ -486,14 +438,22 @@ CONFIG_KEYBOARD_ATKBD_HP_KEYCODES=y
|
||||
# CONFIG_KEYBOARD_LKKBD is not set
|
||||
# CONFIG_KEYBOARD_XTKBD is not set
|
||||
# CONFIG_KEYBOARD_NEWTON is not set
|
||||
# CONFIG_KEYBOARD_STOWAWAY is not set
|
||||
# CONFIG_KEYBOARD_HIL_OLD is not set
|
||||
CONFIG_KEYBOARD_HIL=y
|
||||
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_LIFEBOOK=y
|
||||
CONFIG_MOUSE_PS2_TRACKPOINT=y
|
||||
# CONFIG_MOUSE_PS2_TOUCHKIT is not set
|
||||
CONFIG_MOUSE_SERIAL=m
|
||||
# CONFIG_MOUSE_VSXXXAA is not set
|
||||
CONFIG_MOUSE_HIL=m
|
||||
# CONFIG_INPUT_JOYSTICK is not set
|
||||
# CONFIG_INPUT_TABLET is not set
|
||||
# CONFIG_INPUT_TOUCHSCREEN is not set
|
||||
# CONFIG_INPUT_MISC is not set
|
||||
|
||||
@ -516,6 +476,7 @@ CONFIG_SERIO_LIBPS2=y
|
||||
CONFIG_VT=y
|
||||
CONFIG_VT_CONSOLE=y
|
||||
CONFIG_HW_CONSOLE=y
|
||||
# CONFIG_VT_HW_CONSOLE_BINDING is not set
|
||||
# CONFIG_SERIAL_NONSTANDARD is not set
|
||||
|
||||
#
|
||||
@ -523,6 +484,7 @@ CONFIG_HW_CONSOLE=y
|
||||
#
|
||||
CONFIG_SERIAL_8250=y
|
||||
CONFIG_SERIAL_8250_CONSOLE=y
|
||||
CONFIG_SERIAL_8250_GSC=y
|
||||
CONFIG_SERIAL_8250_NR_UARTS=17
|
||||
CONFIG_SERIAL_8250_RUNTIME_UARTS=4
|
||||
CONFIG_SERIAL_8250_EXTENDED=y
|
||||
@ -545,36 +507,15 @@ CONFIG_PRINTER=m
|
||||
# CONFIG_LP_CONSOLE is not set
|
||||
CONFIG_PPDEV=m
|
||||
# CONFIG_TIPAR is not set
|
||||
|
||||
#
|
||||
# IPMI
|
||||
#
|
||||
# CONFIG_IPMI_HANDLER is not set
|
||||
|
||||
#
|
||||
# Watchdog Cards
|
||||
#
|
||||
# CONFIG_WATCHDOG is not set
|
||||
# CONFIG_HW_RANDOM is not set
|
||||
CONFIG_GEN_RTC=y
|
||||
CONFIG_GEN_RTC_X=y
|
||||
# CONFIG_DTLK is not set
|
||||
# CONFIG_R3964 is not set
|
||||
|
||||
#
|
||||
# Ftape, the floppy tape device driver
|
||||
#
|
||||
CONFIG_RAW_DRIVER=y
|
||||
CONFIG_MAX_RAW_DEVS=256
|
||||
|
||||
#
|
||||
# TPM devices
|
||||
#
|
||||
# CONFIG_TCG_TPM is not set
|
||||
# CONFIG_TELCLOCK is not set
|
||||
|
||||
#
|
||||
# I2C support
|
||||
#
|
||||
# CONFIG_I2C is not set
|
||||
|
||||
#
|
||||
@ -582,46 +523,59 @@ CONFIG_MAX_RAW_DEVS=256
|
||||
#
|
||||
# CONFIG_SPI is not set
|
||||
# CONFIG_SPI_MASTER is not set
|
||||
|
||||
#
|
||||
# Dallas's 1-wire bus
|
||||
#
|
||||
# CONFIG_W1 is not set
|
||||
|
||||
#
|
||||
# Hardware Monitoring support
|
||||
#
|
||||
# CONFIG_POWER_SUPPLY is not set
|
||||
# CONFIG_HWMON is not set
|
||||
# CONFIG_HWMON_VID is not set
|
||||
|
||||
#
|
||||
# Misc devices
|
||||
# Sonics Silicon Backplane
|
||||
#
|
||||
CONFIG_SSB_POSSIBLE=y
|
||||
# CONFIG_SSB is not set
|
||||
|
||||
#
|
||||
# Multimedia Capabilities Port drivers
|
||||
# Multifunction device drivers
|
||||
#
|
||||
# CONFIG_MFD_SM501 is not set
|
||||
|
||||
#
|
||||
# Multimedia devices
|
||||
#
|
||||
# CONFIG_VIDEO_DEV is not set
|
||||
|
||||
#
|
||||
# Digital Video Broadcasting Devices
|
||||
#
|
||||
# CONFIG_DVB is not set
|
||||
# CONFIG_DVB_CORE is not set
|
||||
# CONFIG_DAB is not set
|
||||
|
||||
#
|
||||
# Graphics support
|
||||
#
|
||||
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
|
||||
|
||||
#
|
||||
# Display device support
|
||||
#
|
||||
# CONFIG_DISPLAY_SUPPORT is not set
|
||||
# CONFIG_VGASTATE is not set
|
||||
CONFIG_VIDEO_OUTPUT_CONTROL=m
|
||||
CONFIG_FB=y
|
||||
# CONFIG_FIRMWARE_EDID is not set
|
||||
# CONFIG_FB_DDC is not set
|
||||
CONFIG_FB_CFB_FILLRECT=y
|
||||
CONFIG_FB_CFB_COPYAREA=y
|
||||
CONFIG_FB_CFB_IMAGEBLIT=y
|
||||
# CONFIG_FB_SYS_FILLRECT is not set
|
||||
# CONFIG_FB_SYS_COPYAREA is not set
|
||||
# CONFIG_FB_SYS_IMAGEBLIT is not set
|
||||
# CONFIG_FB_SYS_FOPS is not set
|
||||
CONFIG_FB_DEFERRED_IO=y
|
||||
# CONFIG_FB_SVGALIB is not set
|
||||
# CONFIG_FB_MACMODES is not set
|
||||
# CONFIG_FB_BACKLIGHT is not set
|
||||
CONFIG_FB_MODE_HELPERS=y
|
||||
CONFIG_FB_TILEBLITTING=y
|
||||
|
||||
#
|
||||
# Frame buffer hardware drivers
|
||||
#
|
||||
CONFIG_FB_STI=y
|
||||
# CONFIG_FB_S1D13XXX is not set
|
||||
# CONFIG_FB_VIRTUAL is not set
|
||||
@ -633,6 +587,7 @@ CONFIG_DUMMY_CONSOLE=y
|
||||
CONFIG_DUMMY_CONSOLE_COLUMNS=128
|
||||
CONFIG_DUMMY_CONSOLE_ROWS=48
|
||||
CONFIG_FRAMEBUFFER_CONSOLE=y
|
||||
# CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY is not set
|
||||
# CONFIG_FRAMEBUFFER_CONSOLE_ROTATION is not set
|
||||
CONFIG_STI_CONSOLE=y
|
||||
CONFIG_FONTS=y
|
||||
@ -646,16 +601,11 @@ CONFIG_FONT_8x16=y
|
||||
# CONFIG_FONT_SUN8x16 is not set
|
||||
# CONFIG_FONT_SUN12x22 is not set
|
||||
# CONFIG_FONT_10x18 is not set
|
||||
|
||||
#
|
||||
# Logo configuration
|
||||
#
|
||||
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_PARISC_CLUT224=y
|
||||
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
|
||||
|
||||
#
|
||||
# Sound
|
||||
@ -673,9 +623,11 @@ CONFIG_SND_SEQUENCER=y
|
||||
CONFIG_SND_OSSEMUL=y
|
||||
CONFIG_SND_MIXER_OSS=y
|
||||
CONFIG_SND_PCM_OSS=y
|
||||
CONFIG_SND_PCM_OSS_PLUGINS=y
|
||||
CONFIG_SND_SEQUENCER_OSS=y
|
||||
# CONFIG_SND_DYNAMIC_MINORS is not set
|
||||
CONFIG_SND_SUPPORT_OLD_API=y
|
||||
CONFIG_SND_VERBOSE_PROCFS=y
|
||||
# CONFIG_SND_VERBOSE_PRINTK is not set
|
||||
# CONFIG_SND_DEBUG is not set
|
||||
|
||||
@ -685,24 +637,36 @@ CONFIG_SND_SUPPORT_OLD_API=y
|
||||
# CONFIG_SND_DUMMY is not set
|
||||
# CONFIG_SND_VIRMIDI is not set
|
||||
# CONFIG_SND_MTPAV is not set
|
||||
# CONFIG_SND_MTS64 is not set
|
||||
# CONFIG_SND_SERIAL_U16550 is not set
|
||||
# CONFIG_SND_MPU401 is not set
|
||||
# CONFIG_SND_PORTMAN2X4 is not set
|
||||
|
||||
#
|
||||
# GSC devices
|
||||
#
|
||||
CONFIG_SND_HARMONY=y
|
||||
|
||||
#
|
||||
# System on Chip audio support
|
||||
#
|
||||
# CONFIG_SND_SOC is not set
|
||||
|
||||
#
|
||||
# SoC Audio support for SuperH
|
||||
#
|
||||
|
||||
#
|
||||
# Open Sound System
|
||||
#
|
||||
# CONFIG_SOUND_PRIME is not set
|
||||
|
||||
#
|
||||
# USB support
|
||||
#
|
||||
CONFIG_HID_SUPPORT=y
|
||||
CONFIG_HID=y
|
||||
CONFIG_HID_DEBUG=y
|
||||
CONFIG_USB_SUPPORT=y
|
||||
# CONFIG_USB_ARCH_HAS_HCD is not set
|
||||
# CONFIG_USB_ARCH_HAS_OHCI is not set
|
||||
# CONFIG_USB_ARCH_HAS_EHCI is not set
|
||||
|
||||
#
|
||||
# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support'
|
||||
@ -712,19 +676,28 @@ CONFIG_SND_HARMONY=y
|
||||
# USB Gadget Support
|
||||
#
|
||||
# CONFIG_USB_GADGET is not set
|
||||
|
||||
#
|
||||
# MMC/SD Card support
|
||||
#
|
||||
# CONFIG_MMC is not set
|
||||
# CONFIG_NEW_LEDS is not set
|
||||
# CONFIG_RTC_CLASS is not set
|
||||
|
||||
#
|
||||
# InfiniBand support
|
||||
# DMA Engine support
|
||||
#
|
||||
# CONFIG_DMA_ENGINE is not set
|
||||
|
||||
#
|
||||
# DMA Clients
|
||||
#
|
||||
|
||||
#
|
||||
# EDAC - error detection and reporting (RAS) (EXPERIMENTAL)
|
||||
# DMA Devices
|
||||
#
|
||||
# CONFIG_AUXDISPLAY is not set
|
||||
|
||||
#
|
||||
# Userspace I/O
|
||||
#
|
||||
# CONFIG_UIO is not set
|
||||
|
||||
#
|
||||
# File systems
|
||||
@ -734,6 +707,7 @@ CONFIG_EXT2_FS=y
|
||||
# CONFIG_EXT2_FS_XIP is not set
|
||||
CONFIG_EXT3_FS=y
|
||||
# CONFIG_EXT3_FS_XATTR is not set
|
||||
# CONFIG_EXT4DEV_FS is not set
|
||||
CONFIG_JBD=y
|
||||
# CONFIG_JBD_DEBUG is not set
|
||||
# CONFIG_REISERFS_FS is not set
|
||||
@ -744,15 +718,16 @@ CONFIG_JFS_FS=m
|
||||
# CONFIG_JFS_STATISTICS is not set
|
||||
CONFIG_FS_POSIX_ACL=y
|
||||
CONFIG_XFS_FS=m
|
||||
CONFIG_XFS_EXPORT=y
|
||||
# CONFIG_XFS_QUOTA is not set
|
||||
# CONFIG_XFS_SECURITY is not set
|
||||
# CONFIG_XFS_POSIX_ACL is not set
|
||||
# CONFIG_XFS_RT is not set
|
||||
# CONFIG_GFS2_FS is not set
|
||||
# CONFIG_OCFS2_FS is not set
|
||||
# CONFIG_MINIX_FS is not set
|
||||
# CONFIG_ROMFS_FS is not set
|
||||
CONFIG_INOTIFY=y
|
||||
CONFIG_INOTIFY_USER=y
|
||||
# CONFIG_QUOTA is not set
|
||||
CONFIG_DNOTIFY=y
|
||||
# CONFIG_AUTOFS_FS is not set
|
||||
@ -783,11 +758,12 @@ CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1"
|
||||
#
|
||||
CONFIG_PROC_FS=y
|
||||
CONFIG_PROC_KCORE=y
|
||||
CONFIG_PROC_SYSCTL=y
|
||||
CONFIG_SYSFS=y
|
||||
CONFIG_TMPFS=y
|
||||
# CONFIG_TMPFS_POSIX_ACL is not set
|
||||
# CONFIG_HUGETLB_PAGE is not set
|
||||
CONFIG_RAMFS=y
|
||||
# CONFIG_RELAYFS_FS is not set
|
||||
# CONFIG_CONFIGFS_FS is not set
|
||||
|
||||
#
|
||||
@ -795,6 +771,7 @@ CONFIG_RAMFS=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
|
||||
@ -806,6 +783,8 @@ CONFIG_RAMFS=y
|
||||
# CONFIG_QNX4FS_FS is not set
|
||||
# CONFIG_SYSV_FS is not set
|
||||
CONFIG_UFS_FS=m
|
||||
# CONFIG_UFS_FS_WRITE is not set
|
||||
# CONFIG_UFS_DEBUG is not set
|
||||
|
||||
#
|
||||
# Network File Systems
|
||||
@ -827,6 +806,7 @@ CONFIG_EXPORTFS=m
|
||||
CONFIG_NFS_COMMON=y
|
||||
CONFIG_SUNRPC=y
|
||||
CONFIG_SUNRPC_GSS=y
|
||||
# CONFIG_SUNRPC_BIND34 is not set
|
||||
CONFIG_RPCSEC_GSS_KRB5=y
|
||||
CONFIG_RPCSEC_GSS_SPKM3=m
|
||||
CONFIG_SMB_FS=m
|
||||
@ -834,12 +814,13 @@ CONFIG_SMB_NLS_DEFAULT=y
|
||||
CONFIG_SMB_NLS_REMOTE="cp437"
|
||||
CONFIG_CIFS=m
|
||||
# CONFIG_CIFS_STATS is not set
|
||||
# CONFIG_CIFS_WEAK_PW_HASH is not set
|
||||
# CONFIG_CIFS_XATTR is not set
|
||||
# CONFIG_CIFS_DEBUG2 is not set
|
||||
# CONFIG_CIFS_EXPERIMENTAL is not set
|
||||
# CONFIG_NCP_FS is not set
|
||||
# CONFIG_CODA_FS is not set
|
||||
# CONFIG_AFS_FS is not set
|
||||
# CONFIG_9P_FS is not set
|
||||
|
||||
#
|
||||
# Partition Types
|
||||
@ -891,6 +872,11 @@ CONFIG_NLS_KOI8_R=m
|
||||
CONFIG_NLS_KOI8_U=m
|
||||
CONFIG_NLS_UTF8=m
|
||||
|
||||
#
|
||||
# Distributed Lock Manager
|
||||
#
|
||||
# CONFIG_DLM is not set
|
||||
|
||||
#
|
||||
# Profiling support
|
||||
#
|
||||
@ -901,21 +887,32 @@ CONFIG_OPROFILE=m
|
||||
# Kernel hacking
|
||||
#
|
||||
# CONFIG_PRINTK_TIME is not set
|
||||
CONFIG_ENABLE_MUST_CHECK=y
|
||||
CONFIG_MAGIC_SYSRQ=y
|
||||
CONFIG_DEBUG_KERNEL=y
|
||||
CONFIG_LOG_BUF_SHIFT=16
|
||||
CONFIG_DETECT_SOFTLOCKUP=y
|
||||
# CONFIG_SCHEDSTATS is not set
|
||||
# CONFIG_DEBUG_SLAB is not set
|
||||
CONFIG_DEBUG_MUTEXES=y
|
||||
# CONFIG_DEBUG_SPINLOCK is not set
|
||||
# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
|
||||
# CONFIG_DEBUG_KOBJECT is not set
|
||||
# CONFIG_DEBUG_INFO is not set
|
||||
# CONFIG_UNUSED_SYMBOLS is not set
|
||||
# CONFIG_DEBUG_FS is not set
|
||||
# CONFIG_HEADERS_CHECK is not set
|
||||
CONFIG_DEBUG_KERNEL=y
|
||||
# CONFIG_DEBUG_SHIRQ is not set
|
||||
CONFIG_DETECT_SOFTLOCKUP=y
|
||||
CONFIG_SCHED_DEBUG=y
|
||||
# CONFIG_SCHEDSTATS is not set
|
||||
# CONFIG_TIMER_STATS 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=y
|
||||
# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
|
||||
# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
|
||||
# CONFIG_DEBUG_KOBJECT is not set
|
||||
CONFIG_DEBUG_BUGVERBOSE=y
|
||||
# CONFIG_DEBUG_INFO is not set
|
||||
# CONFIG_DEBUG_VM is not set
|
||||
# CONFIG_DEBUG_LIST is not set
|
||||
CONFIG_FORCED_INLINING=y
|
||||
# CONFIG_RCU_TORTURE_TEST is not set
|
||||
# CONFIG_FAULT_INJECTION is not set
|
||||
CONFIG_DEBUG_RODATA=y
|
||||
|
||||
#
|
||||
@ -924,12 +921,13 @@ CONFIG_DEBUG_RODATA=y
|
||||
CONFIG_KEYS=y
|
||||
CONFIG_KEYS_DEBUG_PROC_KEYS=y
|
||||
# CONFIG_SECURITY is not set
|
||||
|
||||
#
|
||||
# Cryptographic options
|
||||
#
|
||||
CONFIG_CRYPTO=y
|
||||
CONFIG_CRYPTO_ALGAPI=y
|
||||
CONFIG_CRYPTO_BLKCIPHER=y
|
||||
CONFIG_CRYPTO_HASH=y
|
||||
CONFIG_CRYPTO_MANAGER=y
|
||||
CONFIG_CRYPTO_HMAC=y
|
||||
# CONFIG_CRYPTO_XCBC is not set
|
||||
CONFIG_CRYPTO_NULL=m
|
||||
CONFIG_CRYPTO_MD4=m
|
||||
CONFIG_CRYPTO_MD5=y
|
||||
@ -938,9 +936,18 @@ CONFIG_CRYPTO_SHA256=m
|
||||
CONFIG_CRYPTO_SHA512=m
|
||||
CONFIG_CRYPTO_WP512=m
|
||||
CONFIG_CRYPTO_TGR192=m
|
||||
# CONFIG_CRYPTO_GF128MUL is not set
|
||||
CONFIG_CRYPTO_ECB=m
|
||||
CONFIG_CRYPTO_CBC=y
|
||||
# CONFIG_CRYPTO_PCBC is not set
|
||||
# CONFIG_CRYPTO_LRW is not set
|
||||
# CONFIG_CRYPTO_XTS is not set
|
||||
# CONFIG_CRYPTO_CRYPTD is not set
|
||||
CONFIG_CRYPTO_DES=y
|
||||
# CONFIG_CRYPTO_FCRYPT is not set
|
||||
CONFIG_CRYPTO_BLOWFISH=m
|
||||
CONFIG_CRYPTO_TWOFISH=m
|
||||
CONFIG_CRYPTO_TWOFISH_COMMON=m
|
||||
CONFIG_CRYPTO_SERPENT=m
|
||||
CONFIG_CRYPTO_AES=m
|
||||
CONFIG_CRYPTO_CAST5=m
|
||||
@ -949,21 +956,28 @@ CONFIG_CRYPTO_TEA=m
|
||||
CONFIG_CRYPTO_ARC4=m
|
||||
CONFIG_CRYPTO_KHAZAD=m
|
||||
CONFIG_CRYPTO_ANUBIS=m
|
||||
# CONFIG_CRYPTO_SEED is not set
|
||||
CONFIG_CRYPTO_DEFLATE=m
|
||||
CONFIG_CRYPTO_MICHAEL_MIC=m
|
||||
CONFIG_CRYPTO_CRC32C=m
|
||||
# CONFIG_CRYPTO_CAMELLIA is not set
|
||||
CONFIG_CRYPTO_TEST=m
|
||||
|
||||
#
|
||||
# Hardware crypto devices
|
||||
#
|
||||
# CONFIG_CRYPTO_AUTHENC is not set
|
||||
# CONFIG_CRYPTO_HW is not set
|
||||
|
||||
#
|
||||
# Library routines
|
||||
#
|
||||
CONFIG_BITREVERSE=y
|
||||
CONFIG_CRC_CCITT=m
|
||||
# CONFIG_CRC16 is not set
|
||||
# CONFIG_CRC_ITU_T is not set
|
||||
CONFIG_CRC32=y
|
||||
# CONFIG_CRC7 is not set
|
||||
CONFIG_LIBCRC32C=m
|
||||
CONFIG_ZLIB_INFLATE=m
|
||||
CONFIG_ZLIB_DEFLATE=m
|
||||
CONFIG_PLIST=y
|
||||
CONFIG_HAS_IOMEM=y
|
||||
CONFIG_HAS_IOPORT=y
|
||||
CONFIG_HAS_DMA=y
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -20,7 +20,7 @@
|
||||
.import hpux_call_table
|
||||
.import hpux_syscall_exit,code
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
ENTRY(hpux_gateway_page)
|
||||
nop
|
||||
#ifdef CONFIG_64BIT
|
||||
@ -103,5 +103,5 @@ syscall_nosys:
|
||||
ldo -ENOSYS(%r0),%r28
|
||||
ENDPROC(hpux_gateway_page)
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
ENTRY(end_hpux_gateway_page)
|
||||
|
@ -290,9 +290,6 @@ int main(void)
|
||||
DEFINE(ASM_PTE_ENTRY_SIZE, PTE_ENTRY_SIZE);
|
||||
DEFINE(ASM_PFN_PTE_SHIFT, PFN_PTE_SHIFT);
|
||||
DEFINE(ASM_PT_INITIAL, PT_INITIAL);
|
||||
DEFINE(ASM_PAGE_SIZE, PAGE_SIZE);
|
||||
DEFINE(ASM_PAGE_SIZE_DIV64, PAGE_SIZE/64);
|
||||
DEFINE(ASM_PAGE_SIZE_DIV128, PAGE_SIZE/128);
|
||||
BLANK();
|
||||
DEFINE(EXCDATA_IP, offsetof(struct exception_data, fault_ip));
|
||||
DEFINE(EXCDATA_SPACE, offsetof(struct exception_data, fault_space));
|
||||
|
@ -98,7 +98,6 @@
|
||||
* The "get_stack" macros are responsible for determining the
|
||||
* kernel stack value.
|
||||
*
|
||||
* For Faults:
|
||||
* If sr7 == 0
|
||||
* Already using a kernel stack, so call the
|
||||
* get_stack_use_r30 macro to push a pt_regs structure
|
||||
@ -110,26 +109,6 @@
|
||||
* task pointer pointed to by cr30. Set the stack
|
||||
* pointer to point to the end of the task structure.
|
||||
*
|
||||
* For Interrupts:
|
||||
* If sr7 == 0
|
||||
* Already using a kernel stack, check to see if r30
|
||||
* is already pointing to the per processor interrupt
|
||||
* stack. If it is, call the get_stack_use_r30 macro
|
||||
* to push a pt_regs structure on the stack, and store
|
||||
* registers there. Otherwise, call get_stack_use_cr31
|
||||
* to get a pointer to the base of the interrupt stack
|
||||
* and push a pt_regs structure on that stack.
|
||||
* else
|
||||
* Need to set up a kernel stack, so call the
|
||||
* get_stack_use_cr30 macro to set up a pointer
|
||||
* to the pt_regs structure contained within the
|
||||
* task pointer pointed to by cr30. Set the stack
|
||||
* pointer to point to the end of the task structure.
|
||||
* N.B: We don't use the interrupt stack for the
|
||||
* first interrupt from userland, because signals/
|
||||
* resched's are processed when returning to userland,
|
||||
* and we can sleep in those cases.
|
||||
*
|
||||
* Note that we use shadowed registers for temps until
|
||||
* we can save %r26 and %r29. %r26 is used to preserve
|
||||
* %r8 (a shadowed register) which temporarily contained
|
||||
@ -652,7 +631,7 @@
|
||||
|
||||
.text
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
|
||||
ENTRY(fault_vector_20)
|
||||
/* First vector is invalid (0) */
|
||||
@ -904,7 +883,7 @@ ENDPROC(_switch_to)
|
||||
*
|
||||
*/
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
|
||||
ENTRY(syscall_exit_rfi)
|
||||
mfctl %cr30,%r16
|
||||
@ -1086,23 +1065,13 @@ intr_do_preempt:
|
||||
|
||||
intr_extint:
|
||||
CMPIB=,n 0,%r16,1f
|
||||
|
||||
get_stack_use_cr30
|
||||
b,n 3f
|
||||
b,n 2f
|
||||
|
||||
1:
|
||||
#if 0 /* Interrupt Stack support not working yet! */
|
||||
mfctl %cr31,%r1
|
||||
copy %r30,%r17
|
||||
/* FIXME! depi below has hardcoded idea of interrupt stack size (32k)*/
|
||||
DEPI 0,31,15,%r17
|
||||
CMPB=,n %r1,%r17,2f
|
||||
get_stack_use_cr31
|
||||
b,n 3f
|
||||
#endif
|
||||
2:
|
||||
get_stack_use_r30
|
||||
|
||||
3:
|
||||
2:
|
||||
save_specials %r29
|
||||
virt_map
|
||||
save_general %r29
|
||||
|
@ -95,7 +95,7 @@ $bss_loop:
|
||||
|
||||
1:
|
||||
stw %r3,0(%r4)
|
||||
ldo (ASM_PAGE_SIZE >> PxD_VALUE_SHIFT)(%r3),%r3
|
||||
ldo (PAGE_SIZE >> PxD_VALUE_SHIFT)(%r3),%r3
|
||||
addib,> -1,%r1,1b
|
||||
#if PT_NLEVELS == 3
|
||||
ldo ASM_PMD_ENTRY_SIZE(%r4),%r4
|
||||
@ -128,10 +128,6 @@ $pgt_fill_loop:
|
||||
/* And the stack pointer too */
|
||||
ldo THREAD_SZ_ALGN(%r6),%sp
|
||||
|
||||
/* And the interrupt stack */
|
||||
load32 interrupt_stack,%r6
|
||||
mtctl %r6,%cr31
|
||||
|
||||
#ifdef CONFIG_SMP
|
||||
/* Set the smp rendevous address into page zero.
|
||||
** It would be safer to do this in init_smp_config() but
|
||||
|
@ -55,13 +55,13 @@
|
||||
* IODC requires 7K byte stack. That leaves 1K byte for os_hpmc.
|
||||
*/
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
hpmc_stack:
|
||||
.block 16384
|
||||
|
||||
#define HPMC_IODC_BUF_SIZE 0x8000
|
||||
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
hpmc_iodc_buf:
|
||||
.block HPMC_IODC_BUF_SIZE
|
||||
|
||||
|
@ -49,7 +49,6 @@ EXPORT_SYMBOL(init_mm);
|
||||
* way process stacks are handled. This is done by having a special
|
||||
* "init_task" linker map entry..
|
||||
*/
|
||||
unsigned char interrupt_stack[ISTACK_SIZE] __attribute__ ((section("init_istack"), aligned(4096)));
|
||||
union thread_union init_thread_union
|
||||
__attribute__((aligned(128))) __attribute__((__section__(".data.init_task"))) =
|
||||
{ INIT_THREAD_INFO(init_task) };
|
||||
|
@ -289,7 +289,7 @@ ENTRY(copy_user_page_asm)
|
||||
*/
|
||||
|
||||
ldd 0(%r25), %r19
|
||||
ldi ASM_PAGE_SIZE_DIV128, %r1
|
||||
ldi (PAGE_SIZE / 128), %r1
|
||||
|
||||
ldw 64(%r25), %r0 /* prefetch 1 cacheline ahead */
|
||||
ldw 128(%r25), %r0 /* prefetch 2 */
|
||||
@ -355,7 +355,7 @@ ENTRY(copy_user_page_asm)
|
||||
* use ldd/std on a 32 bit kernel.
|
||||
*/
|
||||
ldw 0(%r25), %r19
|
||||
ldi ASM_PAGE_SIZE_DIV64, %r1
|
||||
ldi (PAGE_SIZE / 64), %r1
|
||||
|
||||
1:
|
||||
ldw 4(%r25), %r20
|
||||
@ -553,7 +553,7 @@ ENTRY(__clear_user_page_asm)
|
||||
pdtlb 0(%r28)
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
ldi ASM_PAGE_SIZE_DIV128, %r1
|
||||
ldi (PAGE_SIZE / 128), %r1
|
||||
|
||||
/* PREFETCH (Write) has not (yet) been proven to help here */
|
||||
/* #define PREFETCHW_OP ldd 256(%0), %r0 */
|
||||
@ -578,7 +578,7 @@ ENTRY(__clear_user_page_asm)
|
||||
ldo 128(%r28), %r28
|
||||
|
||||
#else /* ! CONFIG_64BIT */
|
||||
ldi ASM_PAGE_SIZE_DIV64, %r1
|
||||
ldi (PAGE_SIZE / 64), %r1
|
||||
|
||||
1:
|
||||
stw %r0, 0(%r28)
|
||||
|
@ -122,31 +122,9 @@ EXPORT_SYMBOL($$divI_12);
|
||||
EXPORT_SYMBOL($$divI_14);
|
||||
EXPORT_SYMBOL($$divI_15);
|
||||
|
||||
extern void __ashrdi3(void);
|
||||
extern void __ashldi3(void);
|
||||
extern void __lshrdi3(void);
|
||||
extern void __muldi3(void);
|
||||
|
||||
EXPORT_SYMBOL(__ashrdi3);
|
||||
EXPORT_SYMBOL(__ashldi3);
|
||||
EXPORT_SYMBOL(__lshrdi3);
|
||||
EXPORT_SYMBOL(__muldi3);
|
||||
|
||||
asmlinkage void * __canonicalize_funcptr_for_compare(void *);
|
||||
EXPORT_SYMBOL(__canonicalize_funcptr_for_compare);
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
extern void __divdi3(void);
|
||||
extern void __udivdi3(void);
|
||||
extern void __umoddi3(void);
|
||||
extern void __moddi3(void);
|
||||
|
||||
EXPORT_SYMBOL(__divdi3);
|
||||
EXPORT_SYMBOL(__udivdi3);
|
||||
EXPORT_SYMBOL(__umoddi3);
|
||||
EXPORT_SYMBOL(__moddi3);
|
||||
#endif
|
||||
|
||||
#ifndef CONFIG_64BIT
|
||||
extern void $$dyncall(void);
|
||||
EXPORT_SYMBOL($$dyncall);
|
||||
|
@ -569,11 +569,10 @@ static void *fail_alloc_consistent(struct device *dev, size_t size,
|
||||
static void *pa11_dma_alloc_noncoherent(struct device *dev, size_t size,
|
||||
dma_addr_t *dma_handle, gfp_t flag)
|
||||
{
|
||||
void *addr = NULL;
|
||||
void *addr;
|
||||
|
||||
/* rely on kmalloc to be cacheline aligned */
|
||||
addr = kmalloc(size, flag);
|
||||
if(addr)
|
||||
addr = (void *)__get_free_pages(flag, get_order(size));
|
||||
if (addr)
|
||||
*dma_handle = (dma_addr_t)virt_to_phys(addr);
|
||||
|
||||
return addr;
|
||||
@ -582,7 +581,7 @@ static void *pa11_dma_alloc_noncoherent(struct device *dev, size_t size,
|
||||
static void pa11_dma_free_noncoherent(struct device *dev, size_t size,
|
||||
void *vaddr, dma_addr_t iova)
|
||||
{
|
||||
kfree(vaddr);
|
||||
free_pages((unsigned long)vaddr, get_order(size));
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -194,37 +194,13 @@ void __init pcibios_init_bus(struct pci_bus *bus)
|
||||
pci_write_config_word(dev, PCI_BRIDGE_CONTROL, bridge_ctl);
|
||||
}
|
||||
|
||||
|
||||
/* KLUGE: Link the child and parent resources - generic PCI didn't */
|
||||
static void
|
||||
pcibios_link_hba_resources( struct resource *hba_res, struct resource *r)
|
||||
{
|
||||
if (!r->parent) {
|
||||
printk(KERN_EMERG "PCI: resource not parented! [%p-%p]\n",
|
||||
(void*) r->start, (void*) r->end);
|
||||
r->parent = hba_res;
|
||||
|
||||
/* reverse link is harder *sigh* */
|
||||
if (r->parent->child) {
|
||||
if (r->parent->sibling) {
|
||||
struct resource *next = r->parent->sibling;
|
||||
while (next->sibling)
|
||||
next = next->sibling;
|
||||
next->sibling = r;
|
||||
} else {
|
||||
r->parent->sibling = r;
|
||||
}
|
||||
} else
|
||||
r->parent->child = r;
|
||||
}
|
||||
}
|
||||
|
||||
/* called by drivers/pci/setup-bus.c:pci_setup_bridge(). */
|
||||
void __devinit pcibios_resource_to_bus(struct pci_dev *dev,
|
||||
struct pci_bus_region *region, struct resource *res)
|
||||
{
|
||||
struct pci_bus *bus = dev->bus;
|
||||
struct pci_hba_data *hba = HBA_DATA(bus->bridge->platform_data);
|
||||
#ifdef CONFIG_64BIT
|
||||
struct pci_hba_data *hba = HBA_DATA(dev->bus->bridge->platform_data);
|
||||
#endif
|
||||
|
||||
if (res->flags & IORESOURCE_IO) {
|
||||
/*
|
||||
@ -243,23 +219,15 @@ void __devinit pcibios_resource_to_bus(struct pci_dev *dev,
|
||||
}
|
||||
|
||||
DBG_RES("pcibios_resource_to_bus(%02x %s [%lx,%lx])\n",
|
||||
bus->number, res->flags & IORESOURCE_IO ? "IO" : "MEM",
|
||||
dev->bus->number, res->flags & IORESOURCE_IO ? "IO" : "MEM",
|
||||
region->start, region->end);
|
||||
|
||||
/* KLUGE ALERT
|
||||
** if this resource isn't linked to a "parent", then it seems
|
||||
** to be a child of the HBA - lets link it in.
|
||||
*/
|
||||
pcibios_link_hba_resources(&hba->io_space, bus->resource[0]);
|
||||
pcibios_link_hba_resources(&hba->lmmio_space, bus->resource[1]);
|
||||
}
|
||||
|
||||
void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res,
|
||||
struct pci_bus_region *region)
|
||||
{
|
||||
#ifdef CONFIG_64BIT
|
||||
struct pci_bus *bus = dev->bus;
|
||||
struct pci_hba_data *hba = HBA_DATA(bus->bridge->platform_data);
|
||||
struct pci_hba_data *hba = HBA_DATA(dev->bus->bridge->platform_data);
|
||||
#endif
|
||||
|
||||
if (res->flags & IORESOURCE_MEM) {
|
||||
|
@ -82,7 +82,12 @@ static int __cpuinit processor_probe(struct parisc_device *dev)
|
||||
unsigned long cpuid;
|
||||
struct cpuinfo_parisc *p;
|
||||
|
||||
#ifndef CONFIG_SMP
|
||||
#ifdef CONFIG_SMP
|
||||
if (num_online_cpus() >= NR_CPUS) {
|
||||
printk(KERN_INFO "num_online_cpus() >= NR_CPUS\n");
|
||||
return 1;
|
||||
}
|
||||
#else
|
||||
if (boot_cpu_data.cpu_count > 0) {
|
||||
printk(KERN_INFO "CONFIG_SMP=n ignoring additional CPUs\n");
|
||||
return 1;
|
||||
|
@ -432,22 +432,10 @@ smp_cpu_init(int cpunum)
|
||||
void __init smp_callin(void)
|
||||
{
|
||||
int slave_id = cpu_now_booting;
|
||||
#if 0
|
||||
void *istack;
|
||||
#endif
|
||||
|
||||
smp_cpu_init(slave_id);
|
||||
preempt_disable();
|
||||
|
||||
#if 0 /* NOT WORKING YET - see entry.S */
|
||||
istack = (void *)__get_free_pages(GFP_KERNEL,ISTACK_ORDER);
|
||||
if (istack == NULL) {
|
||||
printk(KERN_CRIT "Failed to allocate interrupt stack for cpu %d\n",slave_id);
|
||||
BUG();
|
||||
}
|
||||
mtctl(istack,31);
|
||||
#endif
|
||||
|
||||
flush_cache_all_local(); /* start with known state */
|
||||
flush_tlb_all_local(NULL);
|
||||
|
||||
|
@ -473,3 +473,10 @@ long sys32_lookup_dcookie(u32 cookie_high, u32 cookie_low, char __user *buf,
|
||||
return sys_lookup_dcookie((u64)cookie_high << 32 | cookie_low,
|
||||
buf, len);
|
||||
}
|
||||
|
||||
asmlinkage long compat_sys_fallocate(int fd, int mode, u32 offhi, u32 offlo,
|
||||
u32 lenhi, u32 lenlo)
|
||||
{
|
||||
return sys_fallocate(fd, mode, ((loff_t)offhi << 32) | offlo,
|
||||
((loff_t)lenhi << 32) | lenlo);
|
||||
}
|
||||
|
@ -10,6 +10,7 @@
|
||||
#include <asm/asm-offsets.h>
|
||||
#include <asm/unistd.h>
|
||||
#include <asm/errno.h>
|
||||
#include <asm/page.h>
|
||||
#include <asm/psw.h>
|
||||
#include <asm/thread_info.h>
|
||||
#include <asm/assembly.h>
|
||||
@ -38,7 +39,7 @@
|
||||
* pointers.
|
||||
*/
|
||||
|
||||
.align ASM_PAGE_SIZE
|
||||
.align PAGE_SIZE
|
||||
ENTRY(linux_gateway_page)
|
||||
|
||||
/* ADDRESS 0x00 to 0xb0 = 176 bytes / 4 bytes per insn = 44 insns */
|
||||
@ -597,7 +598,7 @@ cas_action:
|
||||
|
||||
|
||||
/* Make sure nothing else is placed on this page */
|
||||
.align ASM_PAGE_SIZE
|
||||
.align PAGE_SIZE
|
||||
END(linux_gateway_page)
|
||||
ENTRY(end_linux_gateway_page)
|
||||
|
||||
@ -608,7 +609,7 @@ ENTRY(end_linux_gateway_page)
|
||||
|
||||
.section .rodata,"a"
|
||||
|
||||
.align ASM_PAGE_SIZE
|
||||
.align PAGE_SIZE
|
||||
/* Light-weight-syscall table */
|
||||
/* Start of lws table. */
|
||||
ENTRY(lws_table)
|
||||
@ -617,13 +618,13 @@ ENTRY(lws_table)
|
||||
END(lws_table)
|
||||
/* End of lws table */
|
||||
|
||||
.align ASM_PAGE_SIZE
|
||||
.align PAGE_SIZE
|
||||
ENTRY(sys_call_table)
|
||||
#include "syscall_table.S"
|
||||
END(sys_call_table)
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
.align ASM_PAGE_SIZE
|
||||
.align PAGE_SIZE
|
||||
ENTRY(sys_call_table64)
|
||||
#define SYSCALL_TABLE_64BIT
|
||||
#include "syscall_table.S"
|
||||
@ -636,7 +637,7 @@ END(sys_call_table64)
|
||||
will use this set of locks
|
||||
*/
|
||||
.section .data
|
||||
.align 4096
|
||||
.align PAGE_SIZE
|
||||
ENTRY(lws_lock_start)
|
||||
/* lws locks */
|
||||
.align 16
|
||||
|
@ -403,6 +403,7 @@
|
||||
ENTRY_COMP(signalfd)
|
||||
ENTRY_COMP(timerfd)
|
||||
ENTRY_SAME(eventfd)
|
||||
ENTRY_COMP(fallocate) /* 305 */
|
||||
|
||||
/* Nothing yet */
|
||||
|
||||
|
@ -189,16 +189,14 @@ static struct clocksource clocksource_cr16 = {
|
||||
#ifdef CONFIG_SMP
|
||||
int update_cr16_clocksource(void)
|
||||
{
|
||||
int change = 0;
|
||||
|
||||
/* since the cr16 cycle counters are not synchronized across CPUs,
|
||||
we'll check if we should switch to a safe clocksource: */
|
||||
if (clocksource_cr16.rating != 0 && num_online_cpus() > 1) {
|
||||
clocksource_change_rating(&clocksource_cr16, 0);
|
||||
change = 1;
|
||||
return 1;
|
||||
}
|
||||
|
||||
return change;
|
||||
return 0;
|
||||
}
|
||||
#else
|
||||
int update_cr16_clocksource(void)
|
||||
|
@ -209,8 +209,8 @@ static int unwind_init(void)
|
||||
|
||||
static int unwind_special(struct unwind_frame_info *info, unsigned long pc, int frame_size)
|
||||
{
|
||||
void handle_interruption(int, struct pt_regs *);
|
||||
static unsigned long *hi = (unsigned long)&handle_interruption;
|
||||
extern void handle_interruption(int, struct pt_regs *);
|
||||
static unsigned long *hi = (unsigned long *)&handle_interruption;
|
||||
|
||||
if (pc == get_func_addr(hi)) {
|
||||
struct pt_regs *regs = (struct pt_regs *)(info->sp - frame_size - PT_SZ_ALGN);
|
||||
|
@ -46,168 +46,211 @@ jiffies = jiffies_64;
|
||||
#endif
|
||||
SECTIONS
|
||||
{
|
||||
. = KERNEL_BINARY_TEXT_START;
|
||||
|
||||
. = KERNEL_BINARY_TEXT_START;
|
||||
|
||||
_text = .; /* Text and read-only data */
|
||||
.text ALIGN(16) : {
|
||||
TEXT_TEXT
|
||||
SCHED_TEXT
|
||||
LOCK_TEXT
|
||||
*(.text.do_softirq)
|
||||
*(.text.sys_exit)
|
||||
*(.text.do_sigaltstack)
|
||||
*(.text.do_fork)
|
||||
*(.text.*)
|
||||
*(.fixup)
|
||||
*(.lock.text) /* out-of-line lock text */
|
||||
*(.gnu.warning)
|
||||
_text = .; /* Text and read-only data */
|
||||
.text ALIGN(16) : {
|
||||
TEXT_TEXT
|
||||
SCHED_TEXT
|
||||
LOCK_TEXT
|
||||
*(.text.do_softirq)
|
||||
*(.text.sys_exit)
|
||||
*(.text.do_sigaltstack)
|
||||
*(.text.do_fork)
|
||||
*(.text.*)
|
||||
*(.fixup)
|
||||
*(.lock.text) /* out-of-line lock text */
|
||||
*(.gnu.warning)
|
||||
} = 0
|
||||
/* End of text section */
|
||||
_etext = .;
|
||||
|
||||
_etext = .; /* End of text section */
|
||||
RODATA
|
||||
BUG_TABLE
|
||||
|
||||
RODATA
|
||||
|
||||
BUG_TABLE
|
||||
|
||||
/* writeable */
|
||||
. = ALIGN(ASM_PAGE_SIZE); /* Make sure this is page aligned so
|
||||
that we can properly leave these
|
||||
as writable */
|
||||
data_start = .;
|
||||
|
||||
. = ALIGN(16); /* Exception table */
|
||||
__start___ex_table = .;
|
||||
__ex_table : { *(__ex_table) }
|
||||
__stop___ex_table = .;
|
||||
|
||||
NOTES
|
||||
|
||||
__start___unwind = .; /* unwind info */
|
||||
.PARISC.unwind : { *(.PARISC.unwind) }
|
||||
__stop___unwind = .;
|
||||
|
||||
/* rarely changed data like cpu maps */
|
||||
. = ALIGN(16);
|
||||
.data.read_mostly : { *(.data.read_mostly) }
|
||||
|
||||
. = ALIGN(L1_CACHE_BYTES);
|
||||
.data : { /* Data */
|
||||
DATA_DATA
|
||||
CONSTRUCTORS
|
||||
/* writeable */
|
||||
/* Make sure this is page aligned so
|
||||
* that we can properly leave these
|
||||
* as writable
|
||||
*/
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
data_start = .;
|
||||
. = ALIGN(16);
|
||||
/* Exception table */
|
||||
__ex_table : {
|
||||
__start___ex_table = .;
|
||||
*(__ex_table)
|
||||
__stop___ex_table = .;
|
||||
}
|
||||
|
||||
. = ALIGN(L1_CACHE_BYTES);
|
||||
.data.cacheline_aligned : { *(.data.cacheline_aligned) }
|
||||
NOTES
|
||||
|
||||
/* PA-RISC locks requires 16-byte alignment */
|
||||
. = ALIGN(16);
|
||||
.data.lock_aligned : { *(.data.lock_aligned) }
|
||||
|
||||
. = ALIGN(ASM_PAGE_SIZE);
|
||||
/* nosave data is really only used for software suspend...it's here
|
||||
* just in case we ever implement it */
|
||||
__nosave_begin = .;
|
||||
.data_nosave : { *(.data.nosave) }
|
||||
. = ALIGN(ASM_PAGE_SIZE);
|
||||
__nosave_end = .;
|
||||
|
||||
_edata = .; /* End of data section */
|
||||
|
||||
__bss_start = .; /* BSS */
|
||||
/* page table entries need to be PAGE_SIZE aligned */
|
||||
. = ALIGN(ASM_PAGE_SIZE);
|
||||
.data.vmpages : {
|
||||
*(.data.vm0.pmd)
|
||||
*(.data.vm0.pgd)
|
||||
*(.data.vm0.pte)
|
||||
/* unwind info */
|
||||
.PARISC.unwind : {
|
||||
__start___unwind = .;
|
||||
*(.PARISC.unwind)
|
||||
__stop___unwind = .;
|
||||
}
|
||||
.bss : { *(.bss) *(COMMON) }
|
||||
__bss_stop = .;
|
||||
|
||||
/* rarely changed data like cpu maps */
|
||||
. = ALIGN(16);
|
||||
.data.read_mostly : {
|
||||
*(.data.read_mostly)
|
||||
}
|
||||
|
||||
. = ALIGN(L1_CACHE_BYTES);
|
||||
/* Data */
|
||||
.data : {
|
||||
DATA_DATA
|
||||
CONSTRUCTORS
|
||||
}
|
||||
|
||||
. = ALIGN(L1_CACHE_BYTES);
|
||||
.data.cacheline_aligned : {
|
||||
*(.data.cacheline_aligned)
|
||||
}
|
||||
|
||||
/* PA-RISC locks requires 16-byte alignment */
|
||||
. = ALIGN(16);
|
||||
.data.lock_aligned : {
|
||||
*(.data.lock_aligned)
|
||||
}
|
||||
|
||||
/* nosave data is really only used for software suspend...it's here
|
||||
* just in case we ever implement it
|
||||
*/
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
__nosave_begin = .;
|
||||
.data_nosave : {
|
||||
*(.data.nosave)
|
||||
}
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
__nosave_end = .;
|
||||
|
||||
/* End of data section */
|
||||
_edata = .;
|
||||
|
||||
/* BSS */
|
||||
__bss_start = .;
|
||||
/* page table entries need to be PAGE_SIZE aligned */
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
.data.vmpages : {
|
||||
*(.data.vm0.pmd)
|
||||
*(.data.vm0.pgd)
|
||||
*(.data.vm0.pte)
|
||||
}
|
||||
.bss : {
|
||||
*(.bss)
|
||||
*(COMMON)
|
||||
}
|
||||
__bss_stop = .;
|
||||
|
||||
|
||||
/* assembler code expects init_task to be 16k aligned */
|
||||
. = ALIGN(16384); /* init_task */
|
||||
.data.init_task : { *(.data.init_task) }
|
||||
|
||||
/* The interrupt stack is currently partially coded, but not yet
|
||||
* implemented */
|
||||
. = ALIGN(16384);
|
||||
init_istack : { *(init_istack) }
|
||||
/* assembler code expects init_task to be 16k aligned */
|
||||
. = ALIGN(16384);
|
||||
/* init_task */
|
||||
.data.init_task : {
|
||||
*(.data.init_task)
|
||||
}
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
. = ALIGN(16); /* Linkage tables */
|
||||
.opd : { *(.opd) } PROVIDE (__gp = .);
|
||||
.plt : { *(.plt) }
|
||||
.dlt : { *(.dlt) }
|
||||
. = ALIGN(16);
|
||||
/* Linkage tables */
|
||||
.opd : {
|
||||
*(.opd)
|
||||
} PROVIDE (__gp = .);
|
||||
.plt : {
|
||||
*(.plt)
|
||||
}
|
||||
.dlt : {
|
||||
*(.dlt)
|
||||
}
|
||||
#endif
|
||||
|
||||
/* reserve space for interrupt stack by aligning __init* to 16k */
|
||||
. = ALIGN(16384);
|
||||
__init_begin = .;
|
||||
.init.text : {
|
||||
_sinittext = .;
|
||||
*(.init.text)
|
||||
_einittext = .;
|
||||
}
|
||||
.init.data : { *(.init.data) }
|
||||
. = ALIGN(16);
|
||||
__setup_start = .;
|
||||
.init.setup : { *(.init.setup) }
|
||||
__setup_end = .;
|
||||
__initcall_start = .;
|
||||
.initcall.init : {
|
||||
INITCALLS
|
||||
}
|
||||
__initcall_end = .;
|
||||
__con_initcall_start = .;
|
||||
.con_initcall.init : { *(.con_initcall.init) }
|
||||
__con_initcall_end = .;
|
||||
SECURITY_INIT
|
||||
/* alternate instruction replacement. This is a mechanism x86 uses
|
||||
* to detect the CPU type and replace generic instruction sequences
|
||||
* with CPU specific ones. We don't currently do this in PA, but
|
||||
* it seems like a good idea... */
|
||||
. = ALIGN(4);
|
||||
__alt_instructions = .;
|
||||
.altinstructions : { *(.altinstructions) }
|
||||
__alt_instructions_end = .;
|
||||
.altinstr_replacement : { *(.altinstr_replacement) }
|
||||
/* .exit.text is discard at runtime, not link time, to deal with references
|
||||
from .altinstructions and .eh_frame */
|
||||
.exit.text : { *(.exit.text) }
|
||||
.exit.data : { *(.exit.data) }
|
||||
/* reserve space for interrupt stack by aligning __init* to 16k */
|
||||
. = ALIGN(16384);
|
||||
__init_begin = .;
|
||||
.init.text : {
|
||||
_sinittext = .;
|
||||
*(.init.text)
|
||||
_einittext = .;
|
||||
}
|
||||
.init.data : {
|
||||
*(.init.data)
|
||||
}
|
||||
. = ALIGN(16);
|
||||
.init.setup : {
|
||||
__setup_start = .;
|
||||
*(.init.setup)
|
||||
__setup_end = .;
|
||||
}
|
||||
.initcall.init : {
|
||||
__initcall_start = .;
|
||||
INITCALLS
|
||||
__initcall_end = .;
|
||||
}
|
||||
.con_initcall.init : {
|
||||
__con_initcall_start = .;
|
||||
*(.con_initcall.init)
|
||||
__con_initcall_end = .;
|
||||
}
|
||||
SECURITY_INIT
|
||||
|
||||
/* alternate instruction replacement. This is a mechanism x86 uses
|
||||
* to detect the CPU type and replace generic instruction sequences
|
||||
* with CPU specific ones. We don't currently do this in PA, but
|
||||
* it seems like a good idea...
|
||||
*/
|
||||
. = ALIGN(4);
|
||||
.altinstructions : {
|
||||
__alt_instructions = .;
|
||||
*(.altinstructions)
|
||||
__alt_instructions_end = .;
|
||||
}
|
||||
.altinstr_replacement : {
|
||||
*(.altinstr_replacement)
|
||||
}
|
||||
|
||||
/* .exit.text is discard at runtime, not link time, to deal with references
|
||||
* from .altinstructions and .eh_frame
|
||||
*/
|
||||
.exit.text : {
|
||||
*(.exit.text)
|
||||
}
|
||||
.exit.data : {
|
||||
*(.exit.data)
|
||||
}
|
||||
#ifdef CONFIG_BLK_DEV_INITRD
|
||||
. = ALIGN(ASM_PAGE_SIZE);
|
||||
__initramfs_start = .;
|
||||
.init.ramfs : { *(.init.ramfs) }
|
||||
__initramfs_end = .;
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
.init.ramfs : {
|
||||
__initramfs_start = .;
|
||||
*(.init.ramfs)
|
||||
__initramfs_end = .;
|
||||
}
|
||||
#endif
|
||||
|
||||
PERCPU(ASM_PAGE_SIZE)
|
||||
PERCPU(PAGE_SIZE)
|
||||
. = ALIGN(PAGE_SIZE);
|
||||
__init_end = .;
|
||||
/* freed after init ends here */
|
||||
_end = . ;
|
||||
|
||||
. = ALIGN(ASM_PAGE_SIZE);
|
||||
__init_end = .;
|
||||
/* freed after init ends here */
|
||||
|
||||
_end = . ;
|
||||
|
||||
/* Sections to be discarded */
|
||||
/DISCARD/ : {
|
||||
*(.exitcall.exit)
|
||||
/* Sections to be discarded */
|
||||
/DISCARD/ : {
|
||||
*(.exitcall.exit)
|
||||
#ifdef CONFIG_64BIT
|
||||
/* temporary hack until binutils is fixed to not emit these
|
||||
for static binaries */
|
||||
*(.interp)
|
||||
*(.dynsym)
|
||||
*(.dynstr)
|
||||
*(.dynamic)
|
||||
*(.hash)
|
||||
*(.gnu.hash)
|
||||
/* temporary hack until binutils is fixed to not emit these
|
||||
* for static binaries
|
||||
*/
|
||||
*(.interp)
|
||||
*(.dynsym)
|
||||
*(.dynstr)
|
||||
*(.dynamic)
|
||||
*(.hash)
|
||||
*(.gnu.hash)
|
||||
#endif
|
||||
}
|
||||
|
||||
STABS_DEBUG
|
||||
.note 0 : { *(.note) }
|
||||
|
||||
STABS_DEBUG
|
||||
.note 0 : { *(.note) }
|
||||
}
|
||||
|
@ -4,4 +4,4 @@
|
||||
|
||||
lib-y := lusercopy.o bitops.o checksum.o io.o memset.o fixup.o memcpy.o
|
||||
|
||||
obj-y := iomap.o
|
||||
obj-y := libgcc/ milli/ iomap.o
|
||||
|
4
arch/parisc/lib/libgcc/Makefile
Normal file
4
arch/parisc/lib/libgcc/Makefile
Normal file
@ -0,0 +1,4 @@
|
||||
obj-y := __ashldi3.o __ashrdi3.o __clzsi2.o __divdi3.o __divsi3.o \
|
||||
__lshrdi3.o __moddi3.o __modsi3.o __udivdi3.o \
|
||||
__udivmoddi4.o __udivmodsi4.o __udivsi3.o \
|
||||
__umoddi3.o __umodsi3.o __muldi3.o __umulsidi3.o
|
19
arch/parisc/lib/libgcc/__ashldi3.c
Normal file
19
arch/parisc/lib/libgcc/__ashldi3.c
Normal file
@ -0,0 +1,19 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __ashldi3(u64 v, int cnt)
|
||||
{
|
||||
int c = cnt & 31;
|
||||
u32 vl = (u32) v;
|
||||
u32 vh = (u32) (v >> 32);
|
||||
|
||||
if (cnt & 32) {
|
||||
vh = (vl << c);
|
||||
vl = 0;
|
||||
} else {
|
||||
vh = (vh << c) + (vl >> (32 - c));
|
||||
vl = (vl << c);
|
||||
}
|
||||
|
||||
return ((u64) vh << 32) + vl;
|
||||
}
|
||||
EXPORT_SYMBOL(__ashldi3);
|
19
arch/parisc/lib/libgcc/__ashrdi3.c
Normal file
19
arch/parisc/lib/libgcc/__ashrdi3.c
Normal file
@ -0,0 +1,19 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __ashrdi3(u64 v, int cnt)
|
||||
{
|
||||
int c = cnt & 31;
|
||||
u32 vl = (u32) v;
|
||||
u32 vh = (u32) (v >> 32);
|
||||
|
||||
if (cnt & 32) {
|
||||
vl = ((s32) vh >> c);
|
||||
vh = (s32) vh >> 31;
|
||||
} else {
|
||||
vl = (vl >> c) + (vh << (32 - c));
|
||||
vh = ((s32) vh >> c);
|
||||
}
|
||||
|
||||
return ((u64) vh << 32) + vl;
|
||||
}
|
||||
EXPORT_SYMBOL(__ashrdi3);
|
30
arch/parisc/lib/libgcc/__clzsi2.c
Normal file
30
arch/parisc/lib/libgcc/__clzsi2.c
Normal file
@ -0,0 +1,30 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u32 __clzsi2(u32 v)
|
||||
{
|
||||
int p = 31;
|
||||
|
||||
if (v & 0xffff0000) {
|
||||
p -= 16;
|
||||
v >>= 16;
|
||||
}
|
||||
if (v & 0xff00) {
|
||||
p -= 8;
|
||||
v >>= 8;
|
||||
}
|
||||
if (v & 0xf0) {
|
||||
p -= 4;
|
||||
v >>= 4;
|
||||
}
|
||||
if (v & 0xc) {
|
||||
p -= 2;
|
||||
v >>= 2;
|
||||
}
|
||||
if (v & 0x2) {
|
||||
p -= 1;
|
||||
v >>= 1;
|
||||
}
|
||||
|
||||
return p;
|
||||
}
|
||||
EXPORT_SYMBOL(__clzsi2);
|
23
arch/parisc/lib/libgcc/__divdi3.c
Normal file
23
arch/parisc/lib/libgcc/__divdi3.c
Normal file
@ -0,0 +1,23 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
s64 __divdi3(s64 num, s64 den)
|
||||
{
|
||||
int minus = 0;
|
||||
s64 v;
|
||||
|
||||
if (num < 0) {
|
||||
num = -num;
|
||||
minus = 1;
|
||||
}
|
||||
if (den < 0) {
|
||||
den = -den;
|
||||
minus ^= 1;
|
||||
}
|
||||
|
||||
v = __udivmoddi4(num, den, NULL);
|
||||
if (minus)
|
||||
v = -v;
|
||||
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__divdi3);
|
23
arch/parisc/lib/libgcc/__divsi3.c
Normal file
23
arch/parisc/lib/libgcc/__divsi3.c
Normal file
@ -0,0 +1,23 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
s32 __divsi3(s32 num, s32 den)
|
||||
{
|
||||
int minus = 0;
|
||||
s32 v;
|
||||
|
||||
if (num < 0) {
|
||||
num = -num;
|
||||
minus = 1;
|
||||
}
|
||||
if (den < 0) {
|
||||
den = -den;
|
||||
minus ^= 1;
|
||||
}
|
||||
|
||||
v = __udivmodsi4(num, den, NULL);
|
||||
if (minus)
|
||||
v = -v;
|
||||
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__divsi3);
|
19
arch/parisc/lib/libgcc/__lshrdi3.c
Normal file
19
arch/parisc/lib/libgcc/__lshrdi3.c
Normal file
@ -0,0 +1,19 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __lshrdi3(u64 v, int cnt)
|
||||
{
|
||||
int c = cnt & 31;
|
||||
u32 vl = (u32) v;
|
||||
u32 vh = (u32) (v >> 32);
|
||||
|
||||
if (cnt & 32) {
|
||||
vl = (vh >> c);
|
||||
vh = 0;
|
||||
} else {
|
||||
vl = (vl >> c) + (vh << (32 - c));
|
||||
vh = (vh >> c);
|
||||
}
|
||||
|
||||
return ((u64) vh << 32) + vl;
|
||||
}
|
||||
EXPORT_SYMBOL(__lshrdi3);
|
23
arch/parisc/lib/libgcc/__moddi3.c
Normal file
23
arch/parisc/lib/libgcc/__moddi3.c
Normal file
@ -0,0 +1,23 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
s64 __moddi3(s64 num, s64 den)
|
||||
{
|
||||
int minus = 0;
|
||||
s64 v;
|
||||
|
||||
if (num < 0) {
|
||||
num = -num;
|
||||
minus = 1;
|
||||
}
|
||||
if (den < 0) {
|
||||
den = -den;
|
||||
minus ^= 1;
|
||||
}
|
||||
|
||||
(void)__udivmoddi4(num, den, (u64 *) & v);
|
||||
if (minus)
|
||||
v = -v;
|
||||
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__moddi3);
|
23
arch/parisc/lib/libgcc/__modsi3.c
Normal file
23
arch/parisc/lib/libgcc/__modsi3.c
Normal file
@ -0,0 +1,23 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
s32 __modsi3(s32 num, s32 den)
|
||||
{
|
||||
int minus = 0;
|
||||
s32 v;
|
||||
|
||||
if (num < 0) {
|
||||
num = -num;
|
||||
minus = 1;
|
||||
}
|
||||
if (den < 0) {
|
||||
den = -den;
|
||||
minus ^= 1;
|
||||
}
|
||||
|
||||
(void)__udivmodsi4(num, den, (u32 *) & v);
|
||||
if (minus)
|
||||
v = -v;
|
||||
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__modsi3);
|
22
arch/parisc/lib/libgcc/__muldi3.c
Normal file
22
arch/parisc/lib/libgcc/__muldi3.c
Normal file
@ -0,0 +1,22 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
union DWunion {
|
||||
struct {
|
||||
s32 high;
|
||||
s32 low;
|
||||
} s;
|
||||
s64 ll;
|
||||
};
|
||||
|
||||
s64 __muldi3(s64 u, s64 v)
|
||||
{
|
||||
const union DWunion uu = { .ll = u };
|
||||
const union DWunion vv = { .ll = v };
|
||||
union DWunion w = { .ll = __umulsidi3(uu.s.low, vv.s.low) };
|
||||
|
||||
w.s.high += ((u32)uu.s.low * (u32)vv.s.high
|
||||
+ (u32)uu.s.high * (u32)vv.s.low);
|
||||
|
||||
return w.ll;
|
||||
}
|
||||
EXPORT_SYMBOL(__muldi3);
|
7
arch/parisc/lib/libgcc/__udivdi3.c
Normal file
7
arch/parisc/lib/libgcc/__udivdi3.c
Normal file
@ -0,0 +1,7 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __udivdi3(u64 num, u64 den)
|
||||
{
|
||||
return __udivmoddi4(num, den, NULL);
|
||||
}
|
||||
EXPORT_SYMBOL(__udivdi3);
|
31
arch/parisc/lib/libgcc/__udivmoddi4.c
Normal file
31
arch/parisc/lib/libgcc/__udivmoddi4.c
Normal file
@ -0,0 +1,31 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __udivmoddi4(u64 num, u64 den, u64 * rem_p)
|
||||
{
|
||||
u64 quot = 0, qbit = 1;
|
||||
|
||||
if (den == 0) {
|
||||
BUG();
|
||||
}
|
||||
|
||||
/* Left-justify denominator and count shift */
|
||||
while ((s64) den >= 0) {
|
||||
den <<= 1;
|
||||
qbit <<= 1;
|
||||
}
|
||||
|
||||
while (qbit) {
|
||||
if (den <= num) {
|
||||
num -= den;
|
||||
quot += qbit;
|
||||
}
|
||||
den >>= 1;
|
||||
qbit >>= 1;
|
||||
}
|
||||
|
||||
if (rem_p)
|
||||
*rem_p = num;
|
||||
|
||||
return quot;
|
||||
}
|
||||
EXPORT_SYMBOL(__udivmoddi4);
|
31
arch/parisc/lib/libgcc/__udivmodsi4.c
Normal file
31
arch/parisc/lib/libgcc/__udivmodsi4.c
Normal file
@ -0,0 +1,31 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u32 __udivmodsi4(u32 num, u32 den, u32 * rem_p)
|
||||
{
|
||||
u32 quot = 0, qbit = 1;
|
||||
|
||||
if (den == 0) {
|
||||
BUG();
|
||||
}
|
||||
|
||||
/* Left-justify denominator and count shift */
|
||||
while ((s32) den >= 0) {
|
||||
den <<= 1;
|
||||
qbit <<= 1;
|
||||
}
|
||||
|
||||
while (qbit) {
|
||||
if (den <= num) {
|
||||
num -= den;
|
||||
quot += qbit;
|
||||
}
|
||||
den >>= 1;
|
||||
qbit >>= 1;
|
||||
}
|
||||
|
||||
if (rem_p)
|
||||
*rem_p = num;
|
||||
|
||||
return quot;
|
||||
}
|
||||
EXPORT_SYMBOL(__udivmodsi4);
|
7
arch/parisc/lib/libgcc/__udivsi3.c
Normal file
7
arch/parisc/lib/libgcc/__udivsi3.c
Normal file
@ -0,0 +1,7 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u32 __udivsi3(u32 num, u32 den)
|
||||
{
|
||||
return __udivmodsi4(num, den, NULL);
|
||||
}
|
||||
EXPORT_SYMBOL(__udivsi3);
|
10
arch/parisc/lib/libgcc/__umoddi3.c
Normal file
10
arch/parisc/lib/libgcc/__umoddi3.c
Normal file
@ -0,0 +1,10 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u64 __umoddi3(u64 num, u64 den)
|
||||
{
|
||||
u64 v;
|
||||
|
||||
(void)__udivmoddi4(num, den, &v);
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__umoddi3);
|
10
arch/parisc/lib/libgcc/__umodsi3.c
Normal file
10
arch/parisc/lib/libgcc/__umodsi3.c
Normal file
@ -0,0 +1,10 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
u32 __umodsi3(u32 num, u32 den)
|
||||
{
|
||||
u32 v;
|
||||
|
||||
(void)__udivmodsi4(num, den, &v);
|
||||
return v;
|
||||
}
|
||||
EXPORT_SYMBOL(__umodsi3);
|
46
arch/parisc/lib/libgcc/__umulsidi3.c
Normal file
46
arch/parisc/lib/libgcc/__umulsidi3.c
Normal file
@ -0,0 +1,46 @@
|
||||
#include "libgcc.h"
|
||||
|
||||
#define __ll_B ((u32) 1 << (32 / 2))
|
||||
#define __ll_lowpart(t) ((u32) (t) & (__ll_B - 1))
|
||||
#define __ll_highpart(t) ((u32) (t) >> 16)
|
||||
|
||||
#define umul_ppmm(w1, w0, u, v) \
|
||||
do { \
|
||||
u32 __x0, __x1, __x2, __x3; \
|
||||
u16 __ul, __vl, __uh, __vh; \
|
||||
\
|
||||
__ul = __ll_lowpart (u); \
|
||||
__uh = __ll_highpart (u); \
|
||||
__vl = __ll_lowpart (v); \
|
||||
__vh = __ll_highpart (v); \
|
||||
\
|
||||
__x0 = (u32) __ul * __vl; \
|
||||
__x1 = (u32) __ul * __vh; \
|
||||
__x2 = (u32) __uh * __vl; \
|
||||
__x3 = (u32) __uh * __vh; \
|
||||
\
|
||||
__x1 += __ll_highpart (__x0);/* this can't give carry */ \
|
||||
__x1 += __x2; /* but this indeed can */ \
|
||||
if (__x1 < __x2) /* did we get it? */ \
|
||||
__x3 += __ll_B; /* yes, add it in the proper pos. */ \
|
||||
\
|
||||
(w1) = __x3 + __ll_highpart (__x1); \
|
||||
(w0) = __ll_lowpart (__x1) * __ll_B + __ll_lowpart (__x0); \
|
||||
} while (0)
|
||||
|
||||
union DWunion {
|
||||
struct {
|
||||
s32 high;
|
||||
s32 low;
|
||||
} s;
|
||||
s64 ll;
|
||||
};
|
||||
|
||||
u64 __umulsidi3(u32 u, u32 v)
|
||||
{
|
||||
union DWunion __w;
|
||||
|
||||
umul_ppmm(__w.s.high, __w.s.low, u, v);
|
||||
|
||||
return __w.ll;
|
||||
}
|
32
arch/parisc/lib/libgcc/libgcc.h
Normal file
32
arch/parisc/lib/libgcc/libgcc.h
Normal file
@ -0,0 +1,32 @@
|
||||
#ifndef _PA_LIBGCC_H_
|
||||
#define _PA_LIBGCC_H_
|
||||
|
||||
#include <linux/types.h>
|
||||
#include <linux/module.h>
|
||||
|
||||
/* Cribbed from klibc/libgcc/ */
|
||||
u64 __ashldi3(u64 v, int cnt);
|
||||
u64 __ashrdi3(u64 v, int cnt);
|
||||
|
||||
u32 __clzsi2(u32 v);
|
||||
|
||||
s64 __divdi3(s64 num, s64 den);
|
||||
s32 __divsi3(s32 num, s32 den);
|
||||
|
||||
u64 __lshrdi3(u64 v, int cnt);
|
||||
|
||||
s64 __moddi3(s64 num, s64 den);
|
||||
s32 __modsi3(s32 num, s32 den);
|
||||
|
||||
u64 __udivdi3(u64 num, u64 den);
|
||||
u32 __udivsi3(u32 num, u32 den);
|
||||
|
||||
u64 __udivmoddi4(u64 num, u64 den, u64 * rem_p);
|
||||
u32 __udivmodsi4(u32 num, u32 den, u32 * rem_p);
|
||||
|
||||
u64 __umulsidi3(u32 u, u32 v);
|
||||
|
||||
u64 __umoddi3(u64 num, u64 den);
|
||||
u32 __umodsi3(u32 num, u32 den);
|
||||
|
||||
#endif /*_PA_LIBGCC_H_*/
|
@ -139,12 +139,12 @@ DECLARE_PER_CPU(struct exception_data, exception_data);
|
||||
#define stw(_s,_t,_o,_a,_e) def_store_insn(stw,"r",_s,_t,_o,_a,_e)
|
||||
|
||||
#ifdef CONFIG_PREFETCH
|
||||
extern inline void prefetch_src(const void *addr)
|
||||
static inline void prefetch_src(const void *addr)
|
||||
{
|
||||
__asm__("ldw 0(" s_space ",%0), %%r0" : : "r" (addr));
|
||||
}
|
||||
|
||||
extern inline void prefetch_dst(const void *addr)
|
||||
static inline void prefetch_dst(const void *addr)
|
||||
{
|
||||
__asm__("ldd 0(" d_space ",%0), %%r0" : : "r" (addr));
|
||||
}
|
||||
|
1
arch/parisc/lib/milli/Makefile
Normal file
1
arch/parisc/lib/milli/Makefile
Normal file
@ -0,0 +1 @@
|
||||
obj-y := dyncall.o divI.o divU.o remI.o remU.o div_const.o mulI.o
|
254
arch/parisc/lib/milli/divI.S
Normal file
254
arch/parisc/lib/milli/divI.S
Normal file
@ -0,0 +1,254 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_divI
|
||||
/* ROUTINES: $$divI, $$divoI
|
||||
|
||||
Single precision divide for signed binary integers.
|
||||
|
||||
The quotient is truncated towards zero.
|
||||
The sign of the quotient is the XOR of the signs of the dividend and
|
||||
divisor.
|
||||
Divide by zero is trapped.
|
||||
Divide of -2**31 by -1 is trapped for $$divoI but not for $$divI.
|
||||
|
||||
INPUT REGISTERS:
|
||||
. arg0 == dividend
|
||||
. arg1 == divisor
|
||||
. mrp == return pc
|
||||
. sr0 == return space when called externally
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
. arg0 = undefined
|
||||
. arg1 = undefined
|
||||
. ret1 = quotient
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
. r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
. Causes a trap under the following conditions:
|
||||
. divisor is zero (traps with ADDIT,= 0,25,0)
|
||||
. dividend==-2**31 and divisor==-1 and routine is $$divoI
|
||||
. (traps with ADDO 26,25,0)
|
||||
. Changes memory at the following places:
|
||||
. NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
. Unwindable.
|
||||
. Suitable for internal or external millicode.
|
||||
. Assumes the special millicode register conventions.
|
||||
|
||||
DISCUSSION:
|
||||
. Branchs to other millicode routines using BE
|
||||
. $$div_# for # being 2,3,4,5,6,7,8,9,10,12,14,15
|
||||
.
|
||||
. For selected divisors, calls a divide by constant routine written by
|
||||
. Karl Pettis. Eligible divisors are 1..15 excluding 11 and 13.
|
||||
.
|
||||
. The only overflow case is -2**31 divided by -1.
|
||||
. Both routines return -2**31 but only $$divoI traps. */
|
||||
|
||||
RDEFINE(temp,r1)
|
||||
RDEFINE(retreg,ret1) /* r29 */
|
||||
RDEFINE(temp1,arg0)
|
||||
SUBSPA_MILLI_DIV
|
||||
ATTR_MILLI
|
||||
.import $$divI_2,millicode
|
||||
.import $$divI_3,millicode
|
||||
.import $$divI_4,millicode
|
||||
.import $$divI_5,millicode
|
||||
.import $$divI_6,millicode
|
||||
.import $$divI_7,millicode
|
||||
.import $$divI_8,millicode
|
||||
.import $$divI_9,millicode
|
||||
.import $$divI_10,millicode
|
||||
.import $$divI_12,millicode
|
||||
.import $$divI_14,millicode
|
||||
.import $$divI_15,millicode
|
||||
.export $$divI,millicode
|
||||
.export $$divoI,millicode
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
GSYM($$divoI)
|
||||
comib,=,n -1,arg1,LREF(negative1) /* when divisor == -1 */
|
||||
GSYM($$divI)
|
||||
ldo -1(arg1),temp /* is there at most one bit set ? */
|
||||
and,<> arg1,temp,r0 /* if not, don't use power of 2 divide */
|
||||
addi,> 0,arg1,r0 /* if divisor > 0, use power of 2 divide */
|
||||
b,n LREF(neg_denom)
|
||||
LSYM(pow2)
|
||||
addi,>= 0,arg0,retreg /* if numerator is negative, add the */
|
||||
add arg0,temp,retreg /* (denominaotr -1) to correct for shifts */
|
||||
extru,= arg1,15,16,temp /* test denominator with 0xffff0000 */
|
||||
extrs retreg,15,16,retreg /* retreg = retreg >> 16 */
|
||||
or arg1,temp,arg1 /* arg1 = arg1 | (arg1 >> 16) */
|
||||
ldi 0xcc,temp1 /* setup 0xcc in temp1 */
|
||||
extru,= arg1,23,8,temp /* test denominator with 0xff00 */
|
||||
extrs retreg,23,24,retreg /* retreg = retreg >> 8 */
|
||||
or arg1,temp,arg1 /* arg1 = arg1 | (arg1 >> 8) */
|
||||
ldi 0xaa,temp /* setup 0xaa in temp */
|
||||
extru,= arg1,27,4,r0 /* test denominator with 0xf0 */
|
||||
extrs retreg,27,28,retreg /* retreg = retreg >> 4 */
|
||||
and,= arg1,temp1,r0 /* test denominator with 0xcc */
|
||||
extrs retreg,29,30,retreg /* retreg = retreg >> 2 */
|
||||
and,= arg1,temp,r0 /* test denominator with 0xaa */
|
||||
extrs retreg,30,31,retreg /* retreg = retreg >> 1 */
|
||||
MILLIRETN
|
||||
LSYM(neg_denom)
|
||||
addi,< 0,arg1,r0 /* if arg1 >= 0, it's not power of 2 */
|
||||
b,n LREF(regular_seq)
|
||||
sub r0,arg1,temp /* make denominator positive */
|
||||
comb,=,n arg1,temp,LREF(regular_seq) /* test against 0x80000000 and 0 */
|
||||
ldo -1(temp),retreg /* is there at most one bit set ? */
|
||||
and,= temp,retreg,r0 /* if so, the denominator is power of 2 */
|
||||
b,n LREF(regular_seq)
|
||||
sub r0,arg0,retreg /* negate numerator */
|
||||
comb,=,n arg0,retreg,LREF(regular_seq) /* test against 0x80000000 */
|
||||
copy retreg,arg0 /* set up arg0, arg1 and temp */
|
||||
copy temp,arg1 /* before branching to pow2 */
|
||||
b LREF(pow2)
|
||||
ldo -1(arg1),temp
|
||||
LSYM(regular_seq)
|
||||
comib,>>=,n 15,arg1,LREF(small_divisor)
|
||||
add,>= 0,arg0,retreg /* move dividend, if retreg < 0, */
|
||||
LSYM(normal)
|
||||
subi 0,retreg,retreg /* make it positive */
|
||||
sub 0,arg1,temp /* clear carry, */
|
||||
/* negate the divisor */
|
||||
ds 0,temp,0 /* set V-bit to the comple- */
|
||||
/* ment of the divisor sign */
|
||||
add retreg,retreg,retreg /* shift msb bit into carry */
|
||||
ds r0,arg1,temp /* 1st divide step, if no carry */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 2nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 3rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 4th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 5th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 6th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 7th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 8th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 9th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 10th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 11th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 12th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 13th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 14th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 15th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 16th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 17th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 18th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 19th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 20th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 21st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 22nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 23rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 24th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 25th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 26th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 27th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 28th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 29th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 30th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 31st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 32nd divide step, */
|
||||
addc retreg,retreg,retreg /* shift last retreg bit into retreg */
|
||||
xor,>= arg0,arg1,0 /* get correct sign of quotient */
|
||||
sub 0,retreg,retreg /* based on operand signs */
|
||||
MILLIRETN
|
||||
nop
|
||||
|
||||
LSYM(small_divisor)
|
||||
|
||||
#if defined(CONFIG_64BIT)
|
||||
/* Clear the upper 32 bits of the arg1 register. We are working with */
|
||||
/* small divisors (and 32-bit integers) We must not be mislead */
|
||||
/* by "1" bits left in the upper 32 bits. */
|
||||
depd %r0,31,32,%r25
|
||||
#endif
|
||||
blr,n arg1,r0
|
||||
nop
|
||||
/* table for divisor == 0,1, ... ,15 */
|
||||
addit,= 0,arg1,r0 /* trap if divisor == 0 */
|
||||
nop
|
||||
MILLIRET /* divisor == 1 */
|
||||
copy arg0,retreg
|
||||
MILLI_BEN($$divI_2) /* divisor == 2 */
|
||||
nop
|
||||
MILLI_BEN($$divI_3) /* divisor == 3 */
|
||||
nop
|
||||
MILLI_BEN($$divI_4) /* divisor == 4 */
|
||||
nop
|
||||
MILLI_BEN($$divI_5) /* divisor == 5 */
|
||||
nop
|
||||
MILLI_BEN($$divI_6) /* divisor == 6 */
|
||||
nop
|
||||
MILLI_BEN($$divI_7) /* divisor == 7 */
|
||||
nop
|
||||
MILLI_BEN($$divI_8) /* divisor == 8 */
|
||||
nop
|
||||
MILLI_BEN($$divI_9) /* divisor == 9 */
|
||||
nop
|
||||
MILLI_BEN($$divI_10) /* divisor == 10 */
|
||||
nop
|
||||
b LREF(normal) /* divisor == 11 */
|
||||
add,>= 0,arg0,retreg
|
||||
MILLI_BEN($$divI_12) /* divisor == 12 */
|
||||
nop
|
||||
b LREF(normal) /* divisor == 13 */
|
||||
add,>= 0,arg0,retreg
|
||||
MILLI_BEN($$divI_14) /* divisor == 14 */
|
||||
nop
|
||||
MILLI_BEN($$divI_15) /* divisor == 15 */
|
||||
nop
|
||||
|
||||
LSYM(negative1)
|
||||
sub 0,arg0,retreg /* result is negation of dividend */
|
||||
MILLIRET
|
||||
addo arg0,arg1,r0 /* trap iff dividend==0x80000000 && divisor==-1 */
|
||||
.exit
|
||||
.procend
|
||||
.end
|
||||
#endif
|
235
arch/parisc/lib/milli/divU.S
Normal file
235
arch/parisc/lib/milli/divU.S
Normal file
@ -0,0 +1,235 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_divU
|
||||
/* ROUTINE: $$divU
|
||||
.
|
||||
. Single precision divide for unsigned integers.
|
||||
.
|
||||
. Quotient is truncated towards zero.
|
||||
. Traps on divide by zero.
|
||||
|
||||
INPUT REGISTERS:
|
||||
. arg0 == dividend
|
||||
. arg1 == divisor
|
||||
. mrp == return pc
|
||||
. sr0 == return space when called externally
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
. arg0 = undefined
|
||||
. arg1 = undefined
|
||||
. ret1 = quotient
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
. r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
. Causes a trap under the following conditions:
|
||||
. divisor is zero
|
||||
. Changes memory at the following places:
|
||||
. NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
. Unwindable.
|
||||
. Does not create a stack frame.
|
||||
. Suitable for internal or external millicode.
|
||||
. Assumes the special millicode register conventions.
|
||||
|
||||
DISCUSSION:
|
||||
. Branchs to other millicode routines using BE:
|
||||
. $$divU_# for 3,5,6,7,9,10,12,14,15
|
||||
.
|
||||
. For selected small divisors calls the special divide by constant
|
||||
. routines written by Karl Pettis. These are: 3,5,6,7,9,10,12,14,15. */
|
||||
|
||||
RDEFINE(temp,r1)
|
||||
RDEFINE(retreg,ret1) /* r29 */
|
||||
RDEFINE(temp1,arg0)
|
||||
SUBSPA_MILLI_DIV
|
||||
ATTR_MILLI
|
||||
.export $$divU,millicode
|
||||
.import $$divU_3,millicode
|
||||
.import $$divU_5,millicode
|
||||
.import $$divU_6,millicode
|
||||
.import $$divU_7,millicode
|
||||
.import $$divU_9,millicode
|
||||
.import $$divU_10,millicode
|
||||
.import $$divU_12,millicode
|
||||
.import $$divU_14,millicode
|
||||
.import $$divU_15,millicode
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
GSYM($$divU)
|
||||
/* The subtract is not nullified since it does no harm and can be used
|
||||
by the two cases that branch back to "normal". */
|
||||
ldo -1(arg1),temp /* is there at most one bit set ? */
|
||||
and,= arg1,temp,r0 /* if so, denominator is power of 2 */
|
||||
b LREF(regular_seq)
|
||||
addit,= 0,arg1,0 /* trap for zero dvr */
|
||||
copy arg0,retreg
|
||||
extru,= arg1,15,16,temp /* test denominator with 0xffff0000 */
|
||||
extru retreg,15,16,retreg /* retreg = retreg >> 16 */
|
||||
or arg1,temp,arg1 /* arg1 = arg1 | (arg1 >> 16) */
|
||||
ldi 0xcc,temp1 /* setup 0xcc in temp1 */
|
||||
extru,= arg1,23,8,temp /* test denominator with 0xff00 */
|
||||
extru retreg,23,24,retreg /* retreg = retreg >> 8 */
|
||||
or arg1,temp,arg1 /* arg1 = arg1 | (arg1 >> 8) */
|
||||
ldi 0xaa,temp /* setup 0xaa in temp */
|
||||
extru,= arg1,27,4,r0 /* test denominator with 0xf0 */
|
||||
extru retreg,27,28,retreg /* retreg = retreg >> 4 */
|
||||
and,= arg1,temp1,r0 /* test denominator with 0xcc */
|
||||
extru retreg,29,30,retreg /* retreg = retreg >> 2 */
|
||||
and,= arg1,temp,r0 /* test denominator with 0xaa */
|
||||
extru retreg,30,31,retreg /* retreg = retreg >> 1 */
|
||||
MILLIRETN
|
||||
nop
|
||||
LSYM(regular_seq)
|
||||
comib,>= 15,arg1,LREF(special_divisor)
|
||||
subi 0,arg1,temp /* clear carry, negate the divisor */
|
||||
ds r0,temp,r0 /* set V-bit to 1 */
|
||||
LSYM(normal)
|
||||
add arg0,arg0,retreg /* shift msb bit into carry */
|
||||
ds r0,arg1,temp /* 1st divide step, if no carry */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 2nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 3rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 4th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 5th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 6th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 7th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 8th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 9th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 10th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 11th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 12th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 13th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 14th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 15th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 16th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 17th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 18th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 19th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 20th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 21st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 22nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 23rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 24th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 25th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 26th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 27th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 28th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 29th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 30th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 31st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds temp,arg1,temp /* 32nd divide step, */
|
||||
MILLIRET
|
||||
addc retreg,retreg,retreg /* shift last retreg bit into retreg */
|
||||
|
||||
/* Handle the cases where divisor is a small constant or has high bit on. */
|
||||
LSYM(special_divisor)
|
||||
/* blr arg1,r0 */
|
||||
/* comib,>,n 0,arg1,LREF(big_divisor) ; nullify previous instruction */
|
||||
|
||||
/* Pratap 8/13/90. The 815 Stirling chip set has a bug that prevents us from
|
||||
generating such a blr, comib sequence. A problem in nullification. So I
|
||||
rewrote this code. */
|
||||
|
||||
#if defined(CONFIG_64BIT)
|
||||
/* Clear the upper 32 bits of the arg1 register. We are working with
|
||||
small divisors (and 32-bit unsigned integers) We must not be mislead
|
||||
by "1" bits left in the upper 32 bits. */
|
||||
depd %r0,31,32,%r25
|
||||
#endif
|
||||
comib,> 0,arg1,LREF(big_divisor)
|
||||
nop
|
||||
blr arg1,r0
|
||||
nop
|
||||
|
||||
LSYM(zero_divisor) /* this label is here to provide external visibility */
|
||||
addit,= 0,arg1,0 /* trap for zero dvr */
|
||||
nop
|
||||
MILLIRET /* divisor == 1 */
|
||||
copy arg0,retreg
|
||||
MILLIRET /* divisor == 2 */
|
||||
extru arg0,30,31,retreg
|
||||
MILLI_BEN($$divU_3) /* divisor == 3 */
|
||||
nop
|
||||
MILLIRET /* divisor == 4 */
|
||||
extru arg0,29,30,retreg
|
||||
MILLI_BEN($$divU_5) /* divisor == 5 */
|
||||
nop
|
||||
MILLI_BEN($$divU_6) /* divisor == 6 */
|
||||
nop
|
||||
MILLI_BEN($$divU_7) /* divisor == 7 */
|
||||
nop
|
||||
MILLIRET /* divisor == 8 */
|
||||
extru arg0,28,29,retreg
|
||||
MILLI_BEN($$divU_9) /* divisor == 9 */
|
||||
nop
|
||||
MILLI_BEN($$divU_10) /* divisor == 10 */
|
||||
nop
|
||||
b LREF(normal) /* divisor == 11 */
|
||||
ds r0,temp,r0 /* set V-bit to 1 */
|
||||
MILLI_BEN($$divU_12) /* divisor == 12 */
|
||||
nop
|
||||
b LREF(normal) /* divisor == 13 */
|
||||
ds r0,temp,r0 /* set V-bit to 1 */
|
||||
MILLI_BEN($$divU_14) /* divisor == 14 */
|
||||
nop
|
||||
MILLI_BEN($$divU_15) /* divisor == 15 */
|
||||
nop
|
||||
|
||||
/* Handle the case where the high bit is on in the divisor.
|
||||
Compute: if( dividend>=divisor) quotient=1; else quotient=0;
|
||||
Note: dividend>==divisor iff dividend-divisor does not borrow
|
||||
and not borrow iff carry. */
|
||||
LSYM(big_divisor)
|
||||
sub arg0,arg1,r0
|
||||
MILLIRET
|
||||
addc r0,r0,retreg
|
||||
.exit
|
||||
.procend
|
||||
.end
|
||||
#endif
|
682
arch/parisc/lib/milli/div_const.S
Normal file
682
arch/parisc/lib/milli/div_const.S
Normal file
@ -0,0 +1,682 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_div_const
|
||||
/* ROUTINE: $$divI_2
|
||||
. $$divI_3 $$divU_3
|
||||
. $$divI_4
|
||||
. $$divI_5 $$divU_5
|
||||
. $$divI_6 $$divU_6
|
||||
. $$divI_7 $$divU_7
|
||||
. $$divI_8
|
||||
. $$divI_9 $$divU_9
|
||||
. $$divI_10 $$divU_10
|
||||
.
|
||||
. $$divI_12 $$divU_12
|
||||
.
|
||||
. $$divI_14 $$divU_14
|
||||
. $$divI_15 $$divU_15
|
||||
. $$divI_16
|
||||
. $$divI_17 $$divU_17
|
||||
.
|
||||
. Divide by selected constants for single precision binary integers.
|
||||
|
||||
INPUT REGISTERS:
|
||||
. arg0 == dividend
|
||||
. mrp == return pc
|
||||
. sr0 == return space when called externally
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
. arg0 = undefined
|
||||
. arg1 = undefined
|
||||
. ret1 = quotient
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
. r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
. Causes a trap under the following conditions: NONE
|
||||
. Changes memory at the following places: NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
. Unwindable.
|
||||
. Does not create a stack frame.
|
||||
. Suitable for internal or external millicode.
|
||||
. Assumes the special millicode register conventions.
|
||||
|
||||
DISCUSSION:
|
||||
. Calls other millicode routines using mrp: NONE
|
||||
. Calls other millicode routines: NONE */
|
||||
|
||||
|
||||
/* TRUNCATED DIVISION BY SMALL INTEGERS
|
||||
|
||||
We are interested in q(x) = floor(x/y), where x >= 0 and y > 0
|
||||
(with y fixed).
|
||||
|
||||
Let a = floor(z/y), for some choice of z. Note that z will be
|
||||
chosen so that division by z is cheap.
|
||||
|
||||
Let r be the remainder(z/y). In other words, r = z - ay.
|
||||
|
||||
Now, our method is to choose a value for b such that
|
||||
|
||||
q'(x) = floor((ax+b)/z)
|
||||
|
||||
is equal to q(x) over as large a range of x as possible. If the
|
||||
two are equal over a sufficiently large range, and if it is easy to
|
||||
form the product (ax), and it is easy to divide by z, then we can
|
||||
perform the division much faster than the general division algorithm.
|
||||
|
||||
So, we want the following to be true:
|
||||
|
||||
. For x in the following range:
|
||||
.
|
||||
. ky <= x < (k+1)y
|
||||
.
|
||||
. implies that
|
||||
.
|
||||
. k <= (ax+b)/z < (k+1)
|
||||
|
||||
We want to determine b such that this is true for all k in the
|
||||
range {0..K} for some maximum K.
|
||||
|
||||
Since (ax+b) is an increasing function of x, we can take each
|
||||
bound separately to determine the "best" value for b.
|
||||
|
||||
(ax+b)/z < (k+1) implies
|
||||
|
||||
(a((k+1)y-1)+b < (k+1)z implies
|
||||
|
||||
b < a + (k+1)(z-ay) implies
|
||||
|
||||
b < a + (k+1)r
|
||||
|
||||
This needs to be true for all k in the range {0..K}. In
|
||||
particular, it is true for k = 0 and this leads to a maximum
|
||||
acceptable value for b.
|
||||
|
||||
b < a+r or b <= a+r-1
|
||||
|
||||
Taking the other bound, we have
|
||||
|
||||
k <= (ax+b)/z implies
|
||||
|
||||
k <= (aky+b)/z implies
|
||||
|
||||
k(z-ay) <= b implies
|
||||
|
||||
kr <= b
|
||||
|
||||
Clearly, the largest range for k will be achieved by maximizing b,
|
||||
when r is not zero. When r is zero, then the simplest choice for b
|
||||
is 0. When r is not 0, set
|
||||
|
||||
. b = a+r-1
|
||||
|
||||
Now, by construction, q'(x) = floor((ax+b)/z) = q(x) = floor(x/y)
|
||||
for all x in the range:
|
||||
|
||||
. 0 <= x < (K+1)y
|
||||
|
||||
We need to determine what K is. Of our two bounds,
|
||||
|
||||
. b < a+(k+1)r is satisfied for all k >= 0, by construction.
|
||||
|
||||
The other bound is
|
||||
|
||||
. kr <= b
|
||||
|
||||
This is always true if r = 0. If r is not 0 (the usual case), then
|
||||
K = floor((a+r-1)/r), is the maximum value for k.
|
||||
|
||||
Therefore, the formula q'(x) = floor((ax+b)/z) yields the correct
|
||||
answer for q(x) = floor(x/y) when x is in the range
|
||||
|
||||
(0,(K+1)y-1) K = floor((a+r-1)/r)
|
||||
|
||||
To be most useful, we want (K+1)y-1 = (max x) >= 2**32-1 so that
|
||||
the formula for q'(x) yields the correct value of q(x) for all x
|
||||
representable by a single word in HPPA.
|
||||
|
||||
We are also constrained in that computing the product (ax), adding
|
||||
b, and dividing by z must all be done quickly, otherwise we will be
|
||||
better off going through the general algorithm using the DS
|
||||
instruction, which uses approximately 70 cycles.
|
||||
|
||||
For each y, there is a choice of z which satisfies the constraints
|
||||
for (K+1)y >= 2**32. We may not, however, be able to satisfy the
|
||||
timing constraints for arbitrary y. It seems that z being equal to
|
||||
a power of 2 or a power of 2 minus 1 is as good as we can do, since
|
||||
it minimizes the time to do division by z. We want the choice of z
|
||||
to also result in a value for (a) that minimizes the computation of
|
||||
the product (ax). This is best achieved if (a) has a regular bit
|
||||
pattern (so the multiplication can be done with shifts and adds).
|
||||
The value of (a) also needs to be less than 2**32 so the product is
|
||||
always guaranteed to fit in 2 words.
|
||||
|
||||
In actual practice, the following should be done:
|
||||
|
||||
1) For negative x, you should take the absolute value and remember
|
||||
. the fact so that the result can be negated. This obviously does
|
||||
. not apply in the unsigned case.
|
||||
2) For even y, you should factor out the power of 2 that divides y
|
||||
. and divide x by it. You can then proceed by dividing by the
|
||||
. odd factor of y.
|
||||
|
||||
Here is a table of some odd values of y, and corresponding choices
|
||||
for z which are "good".
|
||||
|
||||
y z r a (hex) max x (hex)
|
||||
|
||||
3 2**32 1 55555555 100000001
|
||||
5 2**32 1 33333333 100000003
|
||||
7 2**24-1 0 249249 (infinite)
|
||||
9 2**24-1 0 1c71c7 (infinite)
|
||||
11 2**20-1 0 1745d (infinite)
|
||||
13 2**24-1 0 13b13b (infinite)
|
||||
15 2**32 1 11111111 10000000d
|
||||
17 2**32 1 f0f0f0f 10000000f
|
||||
|
||||
If r is 1, then b = a+r-1 = a. This simplifies the computation
|
||||
of (ax+b), since you can compute (x+1)(a) instead. If r is 0,
|
||||
then b = 0 is ok to use which simplifies (ax+b).
|
||||
|
||||
The bit patterns for 55555555, 33333333, and 11111111 are obviously
|
||||
very regular. The bit patterns for the other values of a above are:
|
||||
|
||||
y (hex) (binary)
|
||||
|
||||
7 249249 001001001001001001001001 << regular >>
|
||||
9 1c71c7 000111000111000111000111 << regular >>
|
||||
11 1745d 000000010111010001011101 << irregular >>
|
||||
13 13b13b 000100111011000100111011 << irregular >>
|
||||
|
||||
The bit patterns for (a) corresponding to (y) of 11 and 13 may be
|
||||
too irregular to warrant using this method.
|
||||
|
||||
When z is a power of 2 minus 1, then the division by z is slightly
|
||||
more complicated, involving an iterative solution.
|
||||
|
||||
The code presented here solves division by 1 through 17, except for
|
||||
11 and 13. There are algorithms for both signed and unsigned
|
||||
quantities given.
|
||||
|
||||
TIMINGS (cycles)
|
||||
|
||||
divisor positive negative unsigned
|
||||
|
||||
. 1 2 2 2
|
||||
. 2 4 4 2
|
||||
. 3 19 21 19
|
||||
. 4 4 4 2
|
||||
. 5 18 22 19
|
||||
. 6 19 22 19
|
||||
. 8 4 4 2
|
||||
. 10 18 19 17
|
||||
. 12 18 20 18
|
||||
. 15 16 18 16
|
||||
. 16 4 4 2
|
||||
. 17 16 18 16
|
||||
|
||||
Now, the algorithm for 7, 9, and 14 is an iterative one. That is,
|
||||
a loop body is executed until the tentative quotient is 0. The
|
||||
number of times the loop body is executed varies depending on the
|
||||
dividend, but is never more than two times. If the dividend is
|
||||
less than the divisor, then the loop body is not executed at all.
|
||||
Each iteration adds 4 cycles to the timings.
|
||||
|
||||
divisor positive negative unsigned
|
||||
|
||||
. 7 19+4n 20+4n 20+4n n = number of iterations
|
||||
. 9 21+4n 22+4n 21+4n
|
||||
. 14 21+4n 22+4n 20+4n
|
||||
|
||||
To give an idea of how the number of iterations varies, here is a
|
||||
table of dividend versus number of iterations when dividing by 7.
|
||||
|
||||
smallest largest required
|
||||
dividend dividend iterations
|
||||
|
||||
. 0 6 0
|
||||
. 7 0x6ffffff 1
|
||||
0x1000006 0xffffffff 2
|
||||
|
||||
There is some overlap in the range of numbers requiring 1 and 2
|
||||
iterations. */
|
||||
|
||||
RDEFINE(t2,r1)
|
||||
RDEFINE(x2,arg0) /* r26 */
|
||||
RDEFINE(t1,arg1) /* r25 */
|
||||
RDEFINE(x1,ret1) /* r29 */
|
||||
|
||||
SUBSPA_MILLI_DIV
|
||||
ATTR_MILLI
|
||||
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
/* NONE of these routines require a stack frame
|
||||
ALL of these routines are unwindable from millicode */
|
||||
|
||||
GSYM($$divide_by_constant)
|
||||
.export $$divide_by_constant,millicode
|
||||
/* Provides a "nice" label for the code covered by the unwind descriptor
|
||||
for things like gprof. */
|
||||
|
||||
/* DIVISION BY 2 (shift by 1) */
|
||||
GSYM($$divI_2)
|
||||
.export $$divI_2,millicode
|
||||
comclr,>= arg0,0,0
|
||||
addi 1,arg0,arg0
|
||||
MILLIRET
|
||||
extrs arg0,30,31,ret1
|
||||
|
||||
|
||||
/* DIVISION BY 4 (shift by 2) */
|
||||
GSYM($$divI_4)
|
||||
.export $$divI_4,millicode
|
||||
comclr,>= arg0,0,0
|
||||
addi 3,arg0,arg0
|
||||
MILLIRET
|
||||
extrs arg0,29,30,ret1
|
||||
|
||||
|
||||
/* DIVISION BY 8 (shift by 3) */
|
||||
GSYM($$divI_8)
|
||||
.export $$divI_8,millicode
|
||||
comclr,>= arg0,0,0
|
||||
addi 7,arg0,arg0
|
||||
MILLIRET
|
||||
extrs arg0,28,29,ret1
|
||||
|
||||
/* DIVISION BY 16 (shift by 4) */
|
||||
GSYM($$divI_16)
|
||||
.export $$divI_16,millicode
|
||||
comclr,>= arg0,0,0
|
||||
addi 15,arg0,arg0
|
||||
MILLIRET
|
||||
extrs arg0,27,28,ret1
|
||||
|
||||
/****************************************************************************
|
||||
*
|
||||
* DIVISION BY DIVISORS OF FFFFFFFF, and powers of 2 times these
|
||||
*
|
||||
* includes 3,5,15,17 and also 6,10,12
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/* DIVISION BY 3 (use z = 2**32; a = 55555555) */
|
||||
|
||||
GSYM($$divI_3)
|
||||
.export $$divI_3,millicode
|
||||
comb,<,N x2,0,LREF(neg3)
|
||||
|
||||
addi 1,x2,x2 /* this cannot overflow */
|
||||
extru x2,1,2,x1 /* multiply by 5 to get started */
|
||||
sh2add x2,x2,x2
|
||||
b LREF(pos)
|
||||
addc x1,0,x1
|
||||
|
||||
LSYM(neg3)
|
||||
subi 1,x2,x2 /* this cannot overflow */
|
||||
extru x2,1,2,x1 /* multiply by 5 to get started */
|
||||
sh2add x2,x2,x2
|
||||
b LREF(neg)
|
||||
addc x1,0,x1
|
||||
|
||||
GSYM($$divU_3)
|
||||
.export $$divU_3,millicode
|
||||
addi 1,x2,x2 /* this CAN overflow */
|
||||
addc 0,0,x1
|
||||
shd x1,x2,30,t1 /* multiply by 5 to get started */
|
||||
sh2add x2,x2,x2
|
||||
b LREF(pos)
|
||||
addc x1,t1,x1
|
||||
|
||||
/* DIVISION BY 5 (use z = 2**32; a = 33333333) */
|
||||
|
||||
GSYM($$divI_5)
|
||||
.export $$divI_5,millicode
|
||||
comb,<,N x2,0,LREF(neg5)
|
||||
|
||||
addi 3,x2,t1 /* this cannot overflow */
|
||||
sh1add x2,t1,x2 /* multiply by 3 to get started */
|
||||
b LREF(pos)
|
||||
addc 0,0,x1
|
||||
|
||||
LSYM(neg5)
|
||||
sub 0,x2,x2 /* negate x2 */
|
||||
addi 1,x2,x2 /* this cannot overflow */
|
||||
shd 0,x2,31,x1 /* get top bit (can be 1) */
|
||||
sh1add x2,x2,x2 /* multiply by 3 to get started */
|
||||
b LREF(neg)
|
||||
addc x1,0,x1
|
||||
|
||||
GSYM($$divU_5)
|
||||
.export $$divU_5,millicode
|
||||
addi 1,x2,x2 /* this CAN overflow */
|
||||
addc 0,0,x1
|
||||
shd x1,x2,31,t1 /* multiply by 3 to get started */
|
||||
sh1add x2,x2,x2
|
||||
b LREF(pos)
|
||||
addc t1,x1,x1
|
||||
|
||||
/* DIVISION BY 6 (shift to divide by 2 then divide by 3) */
|
||||
GSYM($$divI_6)
|
||||
.export $$divI_6,millicode
|
||||
comb,<,N x2,0,LREF(neg6)
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
addi 5,x2,t1 /* compute 5*(x2+1) = 5*x2+5 */
|
||||
sh2add x2,t1,x2 /* multiply by 5 to get started */
|
||||
b LREF(pos)
|
||||
addc 0,0,x1
|
||||
|
||||
LSYM(neg6)
|
||||
subi 2,x2,x2 /* negate, divide by 2, and add 1 */
|
||||
/* negation and adding 1 are done */
|
||||
/* at the same time by the SUBI */
|
||||
extru x2,30,31,x2
|
||||
shd 0,x2,30,x1
|
||||
sh2add x2,x2,x2 /* multiply by 5 to get started */
|
||||
b LREF(neg)
|
||||
addc x1,0,x1
|
||||
|
||||
GSYM($$divU_6)
|
||||
.export $$divU_6,millicode
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
addi 1,x2,x2 /* cannot carry */
|
||||
shd 0,x2,30,x1 /* multiply by 5 to get started */
|
||||
sh2add x2,x2,x2
|
||||
b LREF(pos)
|
||||
addc x1,0,x1
|
||||
|
||||
/* DIVISION BY 10 (shift to divide by 2 then divide by 5) */
|
||||
GSYM($$divU_10)
|
||||
.export $$divU_10,millicode
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
addi 3,x2,t1 /* compute 3*(x2+1) = (3*x2)+3 */
|
||||
sh1add x2,t1,x2 /* multiply by 3 to get started */
|
||||
addc 0,0,x1
|
||||
LSYM(pos)
|
||||
shd x1,x2,28,t1 /* multiply by 0x11 */
|
||||
shd x2,0,28,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
LSYM(pos_for_17)
|
||||
shd x1,x2,24,t1 /* multiply by 0x101 */
|
||||
shd x2,0,24,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
|
||||
shd x1,x2,16,t1 /* multiply by 0x10001 */
|
||||
shd x2,0,16,t2
|
||||
add x2,t2,x2
|
||||
MILLIRET
|
||||
addc x1,t1,x1
|
||||
|
||||
GSYM($$divI_10)
|
||||
.export $$divI_10,millicode
|
||||
comb,< x2,0,LREF(neg10)
|
||||
copy 0,x1
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
addib,TR 1,x2,LREF(pos) /* add 1 (cannot overflow) */
|
||||
sh1add x2,x2,x2 /* multiply by 3 to get started */
|
||||
|
||||
LSYM(neg10)
|
||||
subi 2,x2,x2 /* negate, divide by 2, and add 1 */
|
||||
/* negation and adding 1 are done */
|
||||
/* at the same time by the SUBI */
|
||||
extru x2,30,31,x2
|
||||
sh1add x2,x2,x2 /* multiply by 3 to get started */
|
||||
LSYM(neg)
|
||||
shd x1,x2,28,t1 /* multiply by 0x11 */
|
||||
shd x2,0,28,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
LSYM(neg_for_17)
|
||||
shd x1,x2,24,t1 /* multiply by 0x101 */
|
||||
shd x2,0,24,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
|
||||
shd x1,x2,16,t1 /* multiply by 0x10001 */
|
||||
shd x2,0,16,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
MILLIRET
|
||||
sub 0,x1,x1
|
||||
|
||||
/* DIVISION BY 12 (shift to divide by 4 then divide by 3) */
|
||||
GSYM($$divI_12)
|
||||
.export $$divI_12,millicode
|
||||
comb,< x2,0,LREF(neg12)
|
||||
copy 0,x1
|
||||
extru x2,29,30,x2 /* divide by 4 */
|
||||
addib,tr 1,x2,LREF(pos) /* compute 5*(x2+1) = 5*x2+5 */
|
||||
sh2add x2,x2,x2 /* multiply by 5 to get started */
|
||||
|
||||
LSYM(neg12)
|
||||
subi 4,x2,x2 /* negate, divide by 4, and add 1 */
|
||||
/* negation and adding 1 are done */
|
||||
/* at the same time by the SUBI */
|
||||
extru x2,29,30,x2
|
||||
b LREF(neg)
|
||||
sh2add x2,x2,x2 /* multiply by 5 to get started */
|
||||
|
||||
GSYM($$divU_12)
|
||||
.export $$divU_12,millicode
|
||||
extru x2,29,30,x2 /* divide by 4 */
|
||||
addi 5,x2,t1 /* cannot carry */
|
||||
sh2add x2,t1,x2 /* multiply by 5 to get started */
|
||||
b LREF(pos)
|
||||
addc 0,0,x1
|
||||
|
||||
/* DIVISION BY 15 (use z = 2**32; a = 11111111) */
|
||||
GSYM($$divI_15)
|
||||
.export $$divI_15,millicode
|
||||
comb,< x2,0,LREF(neg15)
|
||||
copy 0,x1
|
||||
addib,tr 1,x2,LREF(pos)+4
|
||||
shd x1,x2,28,t1
|
||||
|
||||
LSYM(neg15)
|
||||
b LREF(neg)
|
||||
subi 1,x2,x2
|
||||
|
||||
GSYM($$divU_15)
|
||||
.export $$divU_15,millicode
|
||||
addi 1,x2,x2 /* this CAN overflow */
|
||||
b LREF(pos)
|
||||
addc 0,0,x1
|
||||
|
||||
/* DIVISION BY 17 (use z = 2**32; a = f0f0f0f) */
|
||||
GSYM($$divI_17)
|
||||
.export $$divI_17,millicode
|
||||
comb,<,n x2,0,LREF(neg17)
|
||||
addi 1,x2,x2 /* this cannot overflow */
|
||||
shd 0,x2,28,t1 /* multiply by 0xf to get started */
|
||||
shd x2,0,28,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(pos_for_17)
|
||||
subb t1,0,x1
|
||||
|
||||
LSYM(neg17)
|
||||
subi 1,x2,x2 /* this cannot overflow */
|
||||
shd 0,x2,28,t1 /* multiply by 0xf to get started */
|
||||
shd x2,0,28,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(neg_for_17)
|
||||
subb t1,0,x1
|
||||
|
||||
GSYM($$divU_17)
|
||||
.export $$divU_17,millicode
|
||||
addi 1,x2,x2 /* this CAN overflow */
|
||||
addc 0,0,x1
|
||||
shd x1,x2,28,t1 /* multiply by 0xf to get started */
|
||||
LSYM(u17)
|
||||
shd x2,0,28,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(pos_for_17)
|
||||
subb t1,x1,x1
|
||||
|
||||
|
||||
/* DIVISION BY DIVISORS OF FFFFFF, and powers of 2 times these
|
||||
includes 7,9 and also 14
|
||||
|
||||
|
||||
z = 2**24-1
|
||||
r = z mod x = 0
|
||||
|
||||
so choose b = 0
|
||||
|
||||
Also, in order to divide by z = 2**24-1, we approximate by dividing
|
||||
by (z+1) = 2**24 (which is easy), and then correcting.
|
||||
|
||||
(ax) = (z+1)q' + r
|
||||
. = zq' + (q'+r)
|
||||
|
||||
So to compute (ax)/z, compute q' = (ax)/(z+1) and r = (ax) mod (z+1)
|
||||
Then the true remainder of (ax)/z is (q'+r). Repeat the process
|
||||
with this new remainder, adding the tentative quotients together,
|
||||
until a tentative quotient is 0 (and then we are done). There is
|
||||
one last correction to be done. It is possible that (q'+r) = z.
|
||||
If so, then (q'+r)/(z+1) = 0 and it looks like we are done. But,
|
||||
in fact, we need to add 1 more to the quotient. Now, it turns
|
||||
out that this happens if and only if the original value x is
|
||||
an exact multiple of y. So, to avoid a three instruction test at
|
||||
the end, instead use 1 instruction to add 1 to x at the beginning. */
|
||||
|
||||
/* DIVISION BY 7 (use z = 2**24-1; a = 249249) */
|
||||
GSYM($$divI_7)
|
||||
.export $$divI_7,millicode
|
||||
comb,<,n x2,0,LREF(neg7)
|
||||
LSYM(7)
|
||||
addi 1,x2,x2 /* cannot overflow */
|
||||
shd 0,x2,29,x1
|
||||
sh3add x2,x2,x2
|
||||
addc x1,0,x1
|
||||
LSYM(pos7)
|
||||
shd x1,x2,26,t1
|
||||
shd x2,0,26,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
|
||||
shd x1,x2,20,t1
|
||||
shd x2,0,20,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,t1
|
||||
|
||||
/* computed <t1,x2>. Now divide it by (2**24 - 1) */
|
||||
|
||||
copy 0,x1
|
||||
shd,= t1,x2,24,t1 /* tentative quotient */
|
||||
LSYM(1)
|
||||
addb,tr t1,x1,LREF(2) /* add to previous quotient */
|
||||
extru x2,31,24,x2 /* new remainder (unadjusted) */
|
||||
|
||||
MILLIRETN
|
||||
|
||||
LSYM(2)
|
||||
addb,tr t1,x2,LREF(1) /* adjust remainder */
|
||||
extru,= x2,7,8,t1 /* new quotient */
|
||||
|
||||
LSYM(neg7)
|
||||
subi 1,x2,x2 /* negate x2 and add 1 */
|
||||
LSYM(8)
|
||||
shd 0,x2,29,x1
|
||||
sh3add x2,x2,x2
|
||||
addc x1,0,x1
|
||||
|
||||
LSYM(neg7_shift)
|
||||
shd x1,x2,26,t1
|
||||
shd x2,0,26,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,x1
|
||||
|
||||
shd x1,x2,20,t1
|
||||
shd x2,0,20,t2
|
||||
add x2,t2,x2
|
||||
addc x1,t1,t1
|
||||
|
||||
/* computed <t1,x2>. Now divide it by (2**24 - 1) */
|
||||
|
||||
copy 0,x1
|
||||
shd,= t1,x2,24,t1 /* tentative quotient */
|
||||
LSYM(3)
|
||||
addb,tr t1,x1,LREF(4) /* add to previous quotient */
|
||||
extru x2,31,24,x2 /* new remainder (unadjusted) */
|
||||
|
||||
MILLIRET
|
||||
sub 0,x1,x1 /* negate result */
|
||||
|
||||
LSYM(4)
|
||||
addb,tr t1,x2,LREF(3) /* adjust remainder */
|
||||
extru,= x2,7,8,t1 /* new quotient */
|
||||
|
||||
GSYM($$divU_7)
|
||||
.export $$divU_7,millicode
|
||||
addi 1,x2,x2 /* can carry */
|
||||
addc 0,0,x1
|
||||
shd x1,x2,29,t1
|
||||
sh3add x2,x2,x2
|
||||
b LREF(pos7)
|
||||
addc t1,x1,x1
|
||||
|
||||
/* DIVISION BY 9 (use z = 2**24-1; a = 1c71c7) */
|
||||
GSYM($$divI_9)
|
||||
.export $$divI_9,millicode
|
||||
comb,<,n x2,0,LREF(neg9)
|
||||
addi 1,x2,x2 /* cannot overflow */
|
||||
shd 0,x2,29,t1
|
||||
shd x2,0,29,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(pos7)
|
||||
subb t1,0,x1
|
||||
|
||||
LSYM(neg9)
|
||||
subi 1,x2,x2 /* negate and add 1 */
|
||||
shd 0,x2,29,t1
|
||||
shd x2,0,29,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(neg7_shift)
|
||||
subb t1,0,x1
|
||||
|
||||
GSYM($$divU_9)
|
||||
.export $$divU_9,millicode
|
||||
addi 1,x2,x2 /* can carry */
|
||||
addc 0,0,x1
|
||||
shd x1,x2,29,t1
|
||||
shd x2,0,29,t2
|
||||
sub t2,x2,x2
|
||||
b LREF(pos7)
|
||||
subb t1,x1,x1
|
||||
|
||||
/* DIVISION BY 14 (shift to divide by 2 then divide by 7) */
|
||||
GSYM($$divI_14)
|
||||
.export $$divI_14,millicode
|
||||
comb,<,n x2,0,LREF(neg14)
|
||||
GSYM($$divU_14)
|
||||
.export $$divU_14,millicode
|
||||
b LREF(7) /* go to 7 case */
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
|
||||
LSYM(neg14)
|
||||
subi 2,x2,x2 /* negate (and add 2) */
|
||||
b LREF(8)
|
||||
extru x2,30,31,x2 /* divide by 2 */
|
||||
.exit
|
||||
.procend
|
||||
.end
|
||||
#endif
|
32
arch/parisc/lib/milli/dyncall.S
Normal file
32
arch/parisc/lib/milli/dyncall.S
Normal file
@ -0,0 +1,32 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_dyncall
|
||||
SUBSPA_MILLI
|
||||
ATTR_DATA
|
||||
GSYM($$dyncall)
|
||||
.export $$dyncall,millicode
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
bb,>=,n %r22,30,LREF(1) ; branch if not plabel address
|
||||
depi 0,31,2,%r22 ; clear the two least significant bits
|
||||
ldw 4(%r22),%r19 ; load new LTP value
|
||||
ldw 0(%r22),%r22 ; load address of target
|
||||
LSYM(1)
|
||||
bv %r0(%r22) ; branch to the real target
|
||||
stw %r2,-24(%r30) ; save return address into frame marker
|
||||
.exit
|
||||
.procend
|
||||
#endif
|
2071
arch/parisc/lib/milli/milli.S
Normal file
2071
arch/parisc/lib/milli/milli.S
Normal file
File diff suppressed because it is too large
Load Diff
165
arch/parisc/lib/milli/milli.h
Normal file
165
arch/parisc/lib/milli/milli.h
Normal file
@ -0,0 +1,165 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#ifndef _PA_MILLI_H_
|
||||
#define _PA_MILLI_H_
|
||||
|
||||
#define L_dyncall
|
||||
#define L_divI
|
||||
#define L_divU
|
||||
#define L_remI
|
||||
#define L_remU
|
||||
#define L_div_const
|
||||
#define L_mulI
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
.level 2.0w
|
||||
#endif
|
||||
|
||||
/* Hardware General Registers. */
|
||||
r0: .reg %r0
|
||||
r1: .reg %r1
|
||||
r2: .reg %r2
|
||||
r3: .reg %r3
|
||||
r4: .reg %r4
|
||||
r5: .reg %r5
|
||||
r6: .reg %r6
|
||||
r7: .reg %r7
|
||||
r8: .reg %r8
|
||||
r9: .reg %r9
|
||||
r10: .reg %r10
|
||||
r11: .reg %r11
|
||||
r12: .reg %r12
|
||||
r13: .reg %r13
|
||||
r14: .reg %r14
|
||||
r15: .reg %r15
|
||||
r16: .reg %r16
|
||||
r17: .reg %r17
|
||||
r18: .reg %r18
|
||||
r19: .reg %r19
|
||||
r20: .reg %r20
|
||||
r21: .reg %r21
|
||||
r22: .reg %r22
|
||||
r23: .reg %r23
|
||||
r24: .reg %r24
|
||||
r25: .reg %r25
|
||||
r26: .reg %r26
|
||||
r27: .reg %r27
|
||||
r28: .reg %r28
|
||||
r29: .reg %r29
|
||||
r30: .reg %r30
|
||||
r31: .reg %r31
|
||||
|
||||
/* Hardware Space Registers. */
|
||||
sr0: .reg %sr0
|
||||
sr1: .reg %sr1
|
||||
sr2: .reg %sr2
|
||||
sr3: .reg %sr3
|
||||
sr4: .reg %sr4
|
||||
sr5: .reg %sr5
|
||||
sr6: .reg %sr6
|
||||
sr7: .reg %sr7
|
||||
|
||||
/* Hardware Floating Point Registers. */
|
||||
fr0: .reg %fr0
|
||||
fr1: .reg %fr1
|
||||
fr2: .reg %fr2
|
||||
fr3: .reg %fr3
|
||||
fr4: .reg %fr4
|
||||
fr5: .reg %fr5
|
||||
fr6: .reg %fr6
|
||||
fr7: .reg %fr7
|
||||
fr8: .reg %fr8
|
||||
fr9: .reg %fr9
|
||||
fr10: .reg %fr10
|
||||
fr11: .reg %fr11
|
||||
fr12: .reg %fr12
|
||||
fr13: .reg %fr13
|
||||
fr14: .reg %fr14
|
||||
fr15: .reg %fr15
|
||||
|
||||
/* Hardware Control Registers. */
|
||||
cr11: .reg %cr11
|
||||
sar: .reg %cr11 /* Shift Amount Register */
|
||||
|
||||
/* Software Architecture General Registers. */
|
||||
rp: .reg r2 /* return pointer */
|
||||
#ifdef CONFIG_64BIT
|
||||
mrp: .reg r2 /* millicode return pointer */
|
||||
#else
|
||||
mrp: .reg r31 /* millicode return pointer */
|
||||
#endif
|
||||
ret0: .reg r28 /* return value */
|
||||
ret1: .reg r29 /* return value (high part of double) */
|
||||
sp: .reg r30 /* stack pointer */
|
||||
dp: .reg r27 /* data pointer */
|
||||
arg0: .reg r26 /* argument */
|
||||
arg1: .reg r25 /* argument or high part of double argument */
|
||||
arg2: .reg r24 /* argument */
|
||||
arg3: .reg r23 /* argument or high part of double argument */
|
||||
|
||||
/* Software Architecture Space Registers. */
|
||||
/* sr0 ; return link from BLE */
|
||||
sret: .reg sr1 /* return value */
|
||||
sarg: .reg sr1 /* argument */
|
||||
/* sr4 ; PC SPACE tracker */
|
||||
/* sr5 ; process private data */
|
||||
|
||||
/* Frame Offsets (millicode convention!) Used when calling other
|
||||
millicode routines. Stack unwinding is dependent upon these
|
||||
definitions. */
|
||||
r31_slot: .equ -20 /* "current RP" slot */
|
||||
sr0_slot: .equ -16 /* "static link" slot */
|
||||
#if defined(CONFIG_64BIT)
|
||||
mrp_slot: .equ -16 /* "current RP" slot */
|
||||
psp_slot: .equ -8 /* "previous SP" slot */
|
||||
#else
|
||||
mrp_slot: .equ -20 /* "current RP" slot (replacing "r31_slot") */
|
||||
#endif
|
||||
|
||||
|
||||
#define DEFINE(name,value)name: .EQU value
|
||||
#define RDEFINE(name,value)name: .REG value
|
||||
#ifdef milliext
|
||||
#define MILLI_BE(lbl) BE lbl(sr7,r0)
|
||||
#define MILLI_BEN(lbl) BE,n lbl(sr7,r0)
|
||||
#define MILLI_BLE(lbl) BLE lbl(sr7,r0)
|
||||
#define MILLI_BLEN(lbl) BLE,n lbl(sr7,r0)
|
||||
#define MILLIRETN BE,n 0(sr0,mrp)
|
||||
#define MILLIRET BE 0(sr0,mrp)
|
||||
#define MILLI_RETN BE,n 0(sr0,mrp)
|
||||
#define MILLI_RET BE 0(sr0,mrp)
|
||||
#else
|
||||
#define MILLI_BE(lbl) B lbl
|
||||
#define MILLI_BEN(lbl) B,n lbl
|
||||
#define MILLI_BLE(lbl) BL lbl,mrp
|
||||
#define MILLI_BLEN(lbl) BL,n lbl,mrp
|
||||
#define MILLIRETN BV,n 0(mrp)
|
||||
#define MILLIRET BV 0(mrp)
|
||||
#define MILLI_RETN BV,n 0(mrp)
|
||||
#define MILLI_RET BV 0(mrp)
|
||||
#endif
|
||||
|
||||
#define CAT(a,b) a##b
|
||||
|
||||
#define SUBSPA_MILLI .section .text
|
||||
#define SUBSPA_MILLI_DIV .section .text.div,"ax",@progbits! .align 16
|
||||
#define SUBSPA_MILLI_MUL .section .text.mul,"ax",@progbits! .align 16
|
||||
#define ATTR_MILLI
|
||||
#define SUBSPA_DATA .section .data
|
||||
#define ATTR_DATA
|
||||
#define GLOBAL $global$
|
||||
#define GSYM(sym) !sym:
|
||||
#define LSYM(sym) !CAT(.L,sym:)
|
||||
#define LREF(sym) CAT(.L,sym)
|
||||
|
||||
#endif /*_PA_MILLI_H_*/
|
474
arch/parisc/lib/milli/mulI.S
Normal file
474
arch/parisc/lib/milli/mulI.S
Normal file
@ -0,0 +1,474 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_mulI
|
||||
/* VERSION "@(#)$$mulI $ Revision: 12.4 $ $ Date: 94/03/17 17:18:51 $" */
|
||||
/******************************************************************************
|
||||
This routine is used on PA2.0 processors when gcc -mno-fpregs is used
|
||||
|
||||
ROUTINE: $$mulI
|
||||
|
||||
|
||||
DESCRIPTION:
|
||||
|
||||
$$mulI multiplies two single word integers, giving a single
|
||||
word result.
|
||||
|
||||
|
||||
INPUT REGISTERS:
|
||||
|
||||
arg0 = Operand 1
|
||||
arg1 = Operand 2
|
||||
r31 == return pc
|
||||
sr0 == return space when called externally
|
||||
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
|
||||
arg0 = undefined
|
||||
arg1 = undefined
|
||||
ret1 = result
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
|
||||
r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
|
||||
Causes a trap under the following conditions: NONE
|
||||
Changes memory at the following places: NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
|
||||
Unwindable
|
||||
Does not create a stack frame
|
||||
Is usable for internal or external microcode
|
||||
|
||||
DISCUSSION:
|
||||
|
||||
Calls other millicode routines via mrp: NONE
|
||||
Calls other millicode routines: NONE
|
||||
|
||||
***************************************************************************/
|
||||
|
||||
|
||||
#define a0 %arg0
|
||||
#define a1 %arg1
|
||||
#define t0 %r1
|
||||
#define r %ret1
|
||||
|
||||
#define a0__128a0 zdep a0,24,25,a0
|
||||
#define a0__256a0 zdep a0,23,24,a0
|
||||
#define a1_ne_0_b_l0 comb,<> a1,0,LREF(l0)
|
||||
#define a1_ne_0_b_l1 comb,<> a1,0,LREF(l1)
|
||||
#define a1_ne_0_b_l2 comb,<> a1,0,LREF(l2)
|
||||
#define b_n_ret_t0 b,n LREF(ret_t0)
|
||||
#define b_e_shift b LREF(e_shift)
|
||||
#define b_e_t0ma0 b LREF(e_t0ma0)
|
||||
#define b_e_t0 b LREF(e_t0)
|
||||
#define b_e_t0a0 b LREF(e_t0a0)
|
||||
#define b_e_t02a0 b LREF(e_t02a0)
|
||||
#define b_e_t04a0 b LREF(e_t04a0)
|
||||
#define b_e_2t0 b LREF(e_2t0)
|
||||
#define b_e_2t0a0 b LREF(e_2t0a0)
|
||||
#define b_e_2t04a0 b LREF(e2t04a0)
|
||||
#define b_e_3t0 b LREF(e_3t0)
|
||||
#define b_e_4t0 b LREF(e_4t0)
|
||||
#define b_e_4t0a0 b LREF(e_4t0a0)
|
||||
#define b_e_4t08a0 b LREF(e4t08a0)
|
||||
#define b_e_5t0 b LREF(e_5t0)
|
||||
#define b_e_8t0 b LREF(e_8t0)
|
||||
#define b_e_8t0a0 b LREF(e_8t0a0)
|
||||
#define r__r_a0 add r,a0,r
|
||||
#define r__r_2a0 sh1add a0,r,r
|
||||
#define r__r_4a0 sh2add a0,r,r
|
||||
#define r__r_8a0 sh3add a0,r,r
|
||||
#define r__r_t0 add r,t0,r
|
||||
#define r__r_2t0 sh1add t0,r,r
|
||||
#define r__r_4t0 sh2add t0,r,r
|
||||
#define r__r_8t0 sh3add t0,r,r
|
||||
#define t0__3a0 sh1add a0,a0,t0
|
||||
#define t0__4a0 sh2add a0,0,t0
|
||||
#define t0__5a0 sh2add a0,a0,t0
|
||||
#define t0__8a0 sh3add a0,0,t0
|
||||
#define t0__9a0 sh3add a0,a0,t0
|
||||
#define t0__16a0 zdep a0,27,28,t0
|
||||
#define t0__32a0 zdep a0,26,27,t0
|
||||
#define t0__64a0 zdep a0,25,26,t0
|
||||
#define t0__128a0 zdep a0,24,25,t0
|
||||
#define t0__t0ma0 sub t0,a0,t0
|
||||
#define t0__t0_a0 add t0,a0,t0
|
||||
#define t0__t0_2a0 sh1add a0,t0,t0
|
||||
#define t0__t0_4a0 sh2add a0,t0,t0
|
||||
#define t0__t0_8a0 sh3add a0,t0,t0
|
||||
#define t0__2t0_a0 sh1add t0,a0,t0
|
||||
#define t0__3t0 sh1add t0,t0,t0
|
||||
#define t0__4t0 sh2add t0,0,t0
|
||||
#define t0__4t0_a0 sh2add t0,a0,t0
|
||||
#define t0__5t0 sh2add t0,t0,t0
|
||||
#define t0__8t0 sh3add t0,0,t0
|
||||
#define t0__8t0_a0 sh3add t0,a0,t0
|
||||
#define t0__9t0 sh3add t0,t0,t0
|
||||
#define t0__16t0 zdep t0,27,28,t0
|
||||
#define t0__32t0 zdep t0,26,27,t0
|
||||
#define t0__256a0 zdep a0,23,24,t0
|
||||
|
||||
|
||||
SUBSPA_MILLI
|
||||
ATTR_MILLI
|
||||
.align 16
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.export $$mulI,millicode
|
||||
GSYM($$mulI)
|
||||
combt,<<= a1,a0,LREF(l4) /* swap args if unsigned a1>a0 */
|
||||
copy 0,r /* zero out the result */
|
||||
xor a0,a1,a0 /* swap a0 & a1 using the */
|
||||
xor a0,a1,a1 /* old xor trick */
|
||||
xor a0,a1,a0
|
||||
LSYM(l4)
|
||||
combt,<= 0,a0,LREF(l3) /* if a0>=0 then proceed like unsigned */
|
||||
zdep a1,30,8,t0 /* t0 = (a1&0xff)<<1 ********* */
|
||||
sub,> 0,a1,t0 /* otherwise negate both and */
|
||||
combt,<=,n a0,t0,LREF(l2) /* swap back if |a0|<|a1| */
|
||||
sub 0,a0,a1
|
||||
movb,tr,n t0,a0,LREF(l2) /* 10th inst. */
|
||||
|
||||
LSYM(l0) r__r_t0 /* add in this partial product */
|
||||
LSYM(l1) a0__256a0 /* a0 <<= 8 ****************** */
|
||||
LSYM(l2) zdep a1,30,8,t0 /* t0 = (a1&0xff)<<1 ********* */
|
||||
LSYM(l3) blr t0,0 /* case on these 8 bits ****** */
|
||||
extru a1,23,24,a1 /* a1 >>= 8 ****************** */
|
||||
|
||||
/*16 insts before this. */
|
||||
/* a0 <<= 8 ************************** */
|
||||
LSYM(x0) a1_ne_0_b_l2 ! a0__256a0 ! MILLIRETN ! nop
|
||||
LSYM(x1) a1_ne_0_b_l1 ! r__r_a0 ! MILLIRETN ! nop
|
||||
LSYM(x2) a1_ne_0_b_l1 ! r__r_2a0 ! MILLIRETN ! nop
|
||||
LSYM(x3) a1_ne_0_b_l0 ! t0__3a0 ! MILLIRET ! r__r_t0
|
||||
LSYM(x4) a1_ne_0_b_l1 ! r__r_4a0 ! MILLIRETN ! nop
|
||||
LSYM(x5) a1_ne_0_b_l0 ! t0__5a0 ! MILLIRET ! r__r_t0
|
||||
LSYM(x6) t0__3a0 ! a1_ne_0_b_l1 ! r__r_2t0 ! MILLIRETN
|
||||
LSYM(x7) t0__3a0 ! a1_ne_0_b_l0 ! r__r_4a0 ! b_n_ret_t0
|
||||
LSYM(x8) a1_ne_0_b_l1 ! r__r_8a0 ! MILLIRETN ! nop
|
||||
LSYM(x9) a1_ne_0_b_l0 ! t0__9a0 ! MILLIRET ! r__r_t0
|
||||
LSYM(x10) t0__5a0 ! a1_ne_0_b_l1 ! r__r_2t0 ! MILLIRETN
|
||||
LSYM(x11) t0__3a0 ! a1_ne_0_b_l0 ! r__r_8a0 ! b_n_ret_t0
|
||||
LSYM(x12) t0__3a0 ! a1_ne_0_b_l1 ! r__r_4t0 ! MILLIRETN
|
||||
LSYM(x13) t0__5a0 ! a1_ne_0_b_l0 ! r__r_8a0 ! b_n_ret_t0
|
||||
LSYM(x14) t0__3a0 ! t0__2t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x15) t0__5a0 ! a1_ne_0_b_l0 ! t0__3t0 ! b_n_ret_t0
|
||||
LSYM(x16) t0__16a0 ! a1_ne_0_b_l1 ! r__r_t0 ! MILLIRETN
|
||||
LSYM(x17) t0__9a0 ! a1_ne_0_b_l0 ! t0__t0_8a0 ! b_n_ret_t0
|
||||
LSYM(x18) t0__9a0 ! a1_ne_0_b_l1 ! r__r_2t0 ! MILLIRETN
|
||||
LSYM(x19) t0__9a0 ! a1_ne_0_b_l0 ! t0__2t0_a0 ! b_n_ret_t0
|
||||
LSYM(x20) t0__5a0 ! a1_ne_0_b_l1 ! r__r_4t0 ! MILLIRETN
|
||||
LSYM(x21) t0__5a0 ! a1_ne_0_b_l0 ! t0__4t0_a0 ! b_n_ret_t0
|
||||
LSYM(x22) t0__5a0 ! t0__2t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x23) t0__5a0 ! t0__2t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x24) t0__3a0 ! a1_ne_0_b_l1 ! r__r_8t0 ! MILLIRETN
|
||||
LSYM(x25) t0__5a0 ! a1_ne_0_b_l0 ! t0__5t0 ! b_n_ret_t0
|
||||
LSYM(x26) t0__3a0 ! t0__4t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x27) t0__3a0 ! a1_ne_0_b_l0 ! t0__9t0 ! b_n_ret_t0
|
||||
LSYM(x28) t0__3a0 ! t0__2t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x29) t0__3a0 ! t0__2t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x30) t0__5a0 ! t0__3t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x31) t0__32a0 ! a1_ne_0_b_l0 ! t0__t0ma0 ! b_n_ret_t0
|
||||
LSYM(x32) t0__32a0 ! a1_ne_0_b_l1 ! r__r_t0 ! MILLIRETN
|
||||
LSYM(x33) t0__8a0 ! a1_ne_0_b_l0 ! t0__4t0_a0 ! b_n_ret_t0
|
||||
LSYM(x34) t0__16a0 ! t0__t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x35) t0__9a0 ! t0__3t0 ! b_e_t0 ! t0__t0_8a0
|
||||
LSYM(x36) t0__9a0 ! a1_ne_0_b_l1 ! r__r_4t0 ! MILLIRETN
|
||||
LSYM(x37) t0__9a0 ! a1_ne_0_b_l0 ! t0__4t0_a0 ! b_n_ret_t0
|
||||
LSYM(x38) t0__9a0 ! t0__2t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x39) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x40) t0__5a0 ! a1_ne_0_b_l1 ! r__r_8t0 ! MILLIRETN
|
||||
LSYM(x41) t0__5a0 ! a1_ne_0_b_l0 ! t0__8t0_a0 ! b_n_ret_t0
|
||||
LSYM(x42) t0__5a0 ! t0__4t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x43) t0__5a0 ! t0__4t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x44) t0__5a0 ! t0__2t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x45) t0__9a0 ! a1_ne_0_b_l0 ! t0__5t0 ! b_n_ret_t0
|
||||
LSYM(x46) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__t0_a0
|
||||
LSYM(x47) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__t0_2a0
|
||||
LSYM(x48) t0__3a0 ! a1_ne_0_b_l0 ! t0__16t0 ! b_n_ret_t0
|
||||
LSYM(x49) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__t0_4a0
|
||||
LSYM(x50) t0__5a0 ! t0__5t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x51) t0__9a0 ! t0__t0_8a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x52) t0__3a0 ! t0__4t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x53) t0__3a0 ! t0__4t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x54) t0__9a0 ! t0__3t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x55) t0__9a0 ! t0__3t0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x56) t0__3a0 ! t0__2t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x57) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x58) t0__3a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x59) t0__9a0 ! t0__2t0_a0 ! b_e_t02a0 ! t0__3t0
|
||||
LSYM(x60) t0__5a0 ! t0__3t0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x61) t0__5a0 ! t0__3t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x62) t0__32a0 ! t0__t0ma0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x63) t0__64a0 ! a1_ne_0_b_l0 ! t0__t0ma0 ! b_n_ret_t0
|
||||
LSYM(x64) t0__64a0 ! a1_ne_0_b_l1 ! r__r_t0 ! MILLIRETN
|
||||
LSYM(x65) t0__8a0 ! a1_ne_0_b_l0 ! t0__8t0_a0 ! b_n_ret_t0
|
||||
LSYM(x66) t0__32a0 ! t0__t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x67) t0__8a0 ! t0__4t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x68) t0__8a0 ! t0__2t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x69) t0__8a0 ! t0__2t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x70) t0__64a0 ! t0__t0_4a0 ! b_e_t0 ! t0__t0_2a0
|
||||
LSYM(x71) t0__9a0 ! t0__8t0 ! b_e_t0 ! t0__t0ma0
|
||||
LSYM(x72) t0__9a0 ! a1_ne_0_b_l1 ! r__r_8t0 ! MILLIRETN
|
||||
LSYM(x73) t0__9a0 ! t0__8t0_a0 ! b_e_shift ! r__r_t0
|
||||
LSYM(x74) t0__9a0 ! t0__4t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x75) t0__9a0 ! t0__4t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x76) t0__9a0 ! t0__2t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x77) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x78) t0__9a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x79) t0__16a0 ! t0__5t0 ! b_e_t0 ! t0__t0ma0
|
||||
LSYM(x80) t0__16a0 ! t0__5t0 ! b_e_shift ! r__r_t0
|
||||
LSYM(x81) t0__9a0 ! t0__9t0 ! b_e_shift ! r__r_t0
|
||||
LSYM(x82) t0__5a0 ! t0__8t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x83) t0__5a0 ! t0__8t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x84) t0__5a0 ! t0__4t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x85) t0__8a0 ! t0__2t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x86) t0__5a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x87) t0__9a0 ! t0__9t0 ! b_e_t02a0 ! t0__t0_4a0
|
||||
LSYM(x88) t0__5a0 ! t0__2t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x89) t0__5a0 ! t0__2t0_a0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x90) t0__9a0 ! t0__5t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x91) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x92) t0__5a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__2t0_a0
|
||||
LSYM(x93) t0__32a0 ! t0__t0ma0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x94) t0__9a0 ! t0__5t0 ! b_e_2t0 ! t0__t0_2a0
|
||||
LSYM(x95) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x96) t0__8a0 ! t0__3t0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x97) t0__8a0 ! t0__3t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x98) t0__32a0 ! t0__3t0 ! b_e_t0 ! t0__t0_2a0
|
||||
LSYM(x99) t0__8a0 ! t0__4t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x100) t0__5a0 ! t0__5t0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x101) t0__5a0 ! t0__5t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x102) t0__32a0 ! t0__t0_2a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x103) t0__5a0 ! t0__5t0 ! b_e_t02a0 ! t0__4t0_a0
|
||||
LSYM(x104) t0__3a0 ! t0__4t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x105) t0__5a0 ! t0__4t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x106) t0__3a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x107) t0__9a0 ! t0__t0_4a0 ! b_e_t02a0 ! t0__8t0_a0
|
||||
LSYM(x108) t0__9a0 ! t0__3t0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x109) t0__9a0 ! t0__3t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x110) t0__9a0 ! t0__3t0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x111) t0__9a0 ! t0__4t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x112) t0__3a0 ! t0__2t0_a0 ! b_e_t0 ! t0__16t0
|
||||
LSYM(x113) t0__9a0 ! t0__4t0_a0 ! b_e_t02a0 ! t0__3t0
|
||||
LSYM(x114) t0__9a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__3t0
|
||||
LSYM(x115) t0__9a0 ! t0__2t0_a0 ! b_e_2t0a0 ! t0__3t0
|
||||
LSYM(x116) t0__3a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__4t0_a0
|
||||
LSYM(x117) t0__3a0 ! t0__4t0_a0 ! b_e_t0 ! t0__9t0
|
||||
LSYM(x118) t0__3a0 ! t0__4t0_a0 ! b_e_t0a0 ! t0__9t0
|
||||
LSYM(x119) t0__3a0 ! t0__4t0_a0 ! b_e_t02a0 ! t0__9t0
|
||||
LSYM(x120) t0__5a0 ! t0__3t0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x121) t0__5a0 ! t0__3t0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x122) t0__5a0 ! t0__3t0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x123) t0__5a0 ! t0__8t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x124) t0__32a0 ! t0__t0ma0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x125) t0__5a0 ! t0__5t0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x126) t0__64a0 ! t0__t0ma0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x127) t0__128a0 ! a1_ne_0_b_l0 ! t0__t0ma0 ! b_n_ret_t0
|
||||
LSYM(x128) t0__128a0 ! a1_ne_0_b_l1 ! r__r_t0 ! MILLIRETN
|
||||
LSYM(x129) t0__128a0 ! a1_ne_0_b_l0 ! t0__t0_a0 ! b_n_ret_t0
|
||||
LSYM(x130) t0__64a0 ! t0__t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x131) t0__8a0 ! t0__8t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x132) t0__8a0 ! t0__4t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x133) t0__8a0 ! t0__4t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x134) t0__8a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x135) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x136) t0__8a0 ! t0__2t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x137) t0__8a0 ! t0__2t0_a0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x138) t0__8a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x139) t0__8a0 ! t0__2t0_a0 ! b_e_2t0a0 ! t0__4t0_a0
|
||||
LSYM(x140) t0__3a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__5t0
|
||||
LSYM(x141) t0__8a0 ! t0__2t0_a0 ! b_e_4t0a0 ! t0__2t0_a0
|
||||
LSYM(x142) t0__9a0 ! t0__8t0 ! b_e_2t0 ! t0__t0ma0
|
||||
LSYM(x143) t0__16a0 ! t0__9t0 ! b_e_t0 ! t0__t0ma0
|
||||
LSYM(x144) t0__9a0 ! t0__8t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x145) t0__9a0 ! t0__8t0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x146) t0__9a0 ! t0__8t0_a0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x147) t0__9a0 ! t0__8t0_a0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x148) t0__9a0 ! t0__4t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x149) t0__9a0 ! t0__4t0_a0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x150) t0__9a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x151) t0__9a0 ! t0__4t0_a0 ! b_e_2t0a0 ! t0__2t0_a0
|
||||
LSYM(x152) t0__9a0 ! t0__2t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x153) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x154) t0__9a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x155) t0__32a0 ! t0__t0ma0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x156) t0__9a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__2t0_a0
|
||||
LSYM(x157) t0__32a0 ! t0__t0ma0 ! b_e_t02a0 ! t0__5t0
|
||||
LSYM(x158) t0__16a0 ! t0__5t0 ! b_e_2t0 ! t0__t0ma0
|
||||
LSYM(x159) t0__32a0 ! t0__5t0 ! b_e_t0 ! t0__t0ma0
|
||||
LSYM(x160) t0__5a0 ! t0__4t0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x161) t0__8a0 ! t0__5t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x162) t0__9a0 ! t0__9t0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x163) t0__9a0 ! t0__9t0 ! b_e_t0 ! t0__2t0_a0
|
||||
LSYM(x164) t0__5a0 ! t0__8t0_a0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x165) t0__8a0 ! t0__4t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x166) t0__5a0 ! t0__8t0_a0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x167) t0__5a0 ! t0__8t0_a0 ! b_e_2t0a0 ! t0__2t0_a0
|
||||
LSYM(x168) t0__5a0 ! t0__4t0_a0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x169) t0__5a0 ! t0__4t0_a0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x170) t0__32a0 ! t0__t0_2a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x171) t0__9a0 ! t0__2t0_a0 ! b_e_t0 ! t0__9t0
|
||||
LSYM(x172) t0__5a0 ! t0__4t0_a0 ! b_e_4t0 ! t0__2t0_a0
|
||||
LSYM(x173) t0__9a0 ! t0__2t0_a0 ! b_e_t02a0 ! t0__9t0
|
||||
LSYM(x174) t0__32a0 ! t0__t0_2a0 ! b_e_t04a0 ! t0__5t0
|
||||
LSYM(x175) t0__8a0 ! t0__2t0_a0 ! b_e_5t0 ! t0__2t0_a0
|
||||
LSYM(x176) t0__5a0 ! t0__4t0_a0 ! b_e_8t0 ! t0__t0_a0
|
||||
LSYM(x177) t0__5a0 ! t0__4t0_a0 ! b_e_8t0a0 ! t0__t0_a0
|
||||
LSYM(x178) t0__5a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__8t0_a0
|
||||
LSYM(x179) t0__5a0 ! t0__2t0_a0 ! b_e_2t0a0 ! t0__8t0_a0
|
||||
LSYM(x180) t0__9a0 ! t0__5t0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x181) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x182) t0__9a0 ! t0__5t0 ! b_e_2t0 ! t0__2t0_a0
|
||||
LSYM(x183) t0__9a0 ! t0__5t0 ! b_e_2t0a0 ! t0__2t0_a0
|
||||
LSYM(x184) t0__5a0 ! t0__9t0 ! b_e_4t0 ! t0__t0_a0
|
||||
LSYM(x185) t0__9a0 ! t0__4t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x186) t0__32a0 ! t0__t0ma0 ! b_e_2t0 ! t0__3t0
|
||||
LSYM(x187) t0__9a0 ! t0__4t0_a0 ! b_e_t02a0 ! t0__5t0
|
||||
LSYM(x188) t0__9a0 ! t0__5t0 ! b_e_4t0 ! t0__t0_2a0
|
||||
LSYM(x189) t0__5a0 ! t0__4t0_a0 ! b_e_t0 ! t0__9t0
|
||||
LSYM(x190) t0__9a0 ! t0__2t0_a0 ! b_e_2t0 ! t0__5t0
|
||||
LSYM(x191) t0__64a0 ! t0__3t0 ! b_e_t0 ! t0__t0ma0
|
||||
LSYM(x192) t0__8a0 ! t0__3t0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x193) t0__8a0 ! t0__3t0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x194) t0__8a0 ! t0__3t0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x195) t0__8a0 ! t0__8t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x196) t0__8a0 ! t0__3t0 ! b_e_4t0 ! t0__2t0_a0
|
||||
LSYM(x197) t0__8a0 ! t0__3t0 ! b_e_4t0a0 ! t0__2t0_a0
|
||||
LSYM(x198) t0__64a0 ! t0__t0_2a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x199) t0__8a0 ! t0__4t0_a0 ! b_e_2t0a0 ! t0__3t0
|
||||
LSYM(x200) t0__5a0 ! t0__5t0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x201) t0__5a0 ! t0__5t0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x202) t0__5a0 ! t0__5t0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x203) t0__5a0 ! t0__5t0 ! b_e_2t0a0 ! t0__4t0_a0
|
||||
LSYM(x204) t0__8a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__3t0
|
||||
LSYM(x205) t0__5a0 ! t0__8t0_a0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x206) t0__64a0 ! t0__t0_4a0 ! b_e_t02a0 ! t0__3t0
|
||||
LSYM(x207) t0__8a0 ! t0__2t0_a0 ! b_e_3t0 ! t0__4t0_a0
|
||||
LSYM(x208) t0__5a0 ! t0__5t0 ! b_e_8t0 ! t0__t0_a0
|
||||
LSYM(x209) t0__5a0 ! t0__5t0 ! b_e_8t0a0 ! t0__t0_a0
|
||||
LSYM(x210) t0__5a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__5t0
|
||||
LSYM(x211) t0__5a0 ! t0__4t0_a0 ! b_e_2t0a0 ! t0__5t0
|
||||
LSYM(x212) t0__3a0 ! t0__4t0_a0 ! b_e_4t0 ! t0__4t0_a0
|
||||
LSYM(x213) t0__3a0 ! t0__4t0_a0 ! b_e_4t0a0 ! t0__4t0_a0
|
||||
LSYM(x214) t0__9a0 ! t0__t0_4a0 ! b_e_2t04a0 ! t0__8t0_a0
|
||||
LSYM(x215) t0__5a0 ! t0__4t0_a0 ! b_e_5t0 ! t0__2t0_a0
|
||||
LSYM(x216) t0__9a0 ! t0__3t0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x217) t0__9a0 ! t0__3t0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x218) t0__9a0 ! t0__3t0 ! b_e_2t0 ! t0__4t0_a0
|
||||
LSYM(x219) t0__9a0 ! t0__8t0_a0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x220) t0__3a0 ! t0__9t0 ! b_e_4t0 ! t0__2t0_a0
|
||||
LSYM(x221) t0__3a0 ! t0__9t0 ! b_e_4t0a0 ! t0__2t0_a0
|
||||
LSYM(x222) t0__9a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__3t0
|
||||
LSYM(x223) t0__9a0 ! t0__4t0_a0 ! b_e_2t0a0 ! t0__3t0
|
||||
LSYM(x224) t0__9a0 ! t0__3t0 ! b_e_8t0 ! t0__t0_a0
|
||||
LSYM(x225) t0__9a0 ! t0__5t0 ! b_e_t0 ! t0__5t0
|
||||
LSYM(x226) t0__3a0 ! t0__2t0_a0 ! b_e_t02a0 ! t0__32t0
|
||||
LSYM(x227) t0__9a0 ! t0__5t0 ! b_e_t02a0 ! t0__5t0
|
||||
LSYM(x228) t0__9a0 ! t0__2t0_a0 ! b_e_4t0 ! t0__3t0
|
||||
LSYM(x229) t0__9a0 ! t0__2t0_a0 ! b_e_4t0a0 ! t0__3t0
|
||||
LSYM(x230) t0__9a0 ! t0__5t0 ! b_e_5t0 ! t0__t0_a0
|
||||
LSYM(x231) t0__9a0 ! t0__2t0_a0 ! b_e_3t0 ! t0__4t0_a0
|
||||
LSYM(x232) t0__3a0 ! t0__2t0_a0 ! b_e_8t0 ! t0__4t0_a0
|
||||
LSYM(x233) t0__3a0 ! t0__2t0_a0 ! b_e_8t0a0 ! t0__4t0_a0
|
||||
LSYM(x234) t0__3a0 ! t0__4t0_a0 ! b_e_2t0 ! t0__9t0
|
||||
LSYM(x235) t0__3a0 ! t0__4t0_a0 ! b_e_2t0a0 ! t0__9t0
|
||||
LSYM(x236) t0__9a0 ! t0__2t0_a0 ! b_e_4t08a0 ! t0__3t0
|
||||
LSYM(x237) t0__16a0 ! t0__5t0 ! b_e_3t0 ! t0__t0ma0
|
||||
LSYM(x238) t0__3a0 ! t0__4t0_a0 ! b_e_2t04a0 ! t0__9t0
|
||||
LSYM(x239) t0__16a0 ! t0__5t0 ! b_e_t0ma0 ! t0__3t0
|
||||
LSYM(x240) t0__9a0 ! t0__t0_a0 ! b_e_8t0 ! t0__3t0
|
||||
LSYM(x241) t0__9a0 ! t0__t0_a0 ! b_e_8t0a0 ! t0__3t0
|
||||
LSYM(x242) t0__5a0 ! t0__3t0 ! b_e_2t0 ! t0__8t0_a0
|
||||
LSYM(x243) t0__9a0 ! t0__9t0 ! b_e_t0 ! t0__3t0
|
||||
LSYM(x244) t0__5a0 ! t0__3t0 ! b_e_4t0 ! t0__4t0_a0
|
||||
LSYM(x245) t0__8a0 ! t0__3t0 ! b_e_5t0 ! t0__2t0_a0
|
||||
LSYM(x246) t0__5a0 ! t0__8t0_a0 ! b_e_2t0 ! t0__3t0
|
||||
LSYM(x247) t0__5a0 ! t0__8t0_a0 ! b_e_2t0a0 ! t0__3t0
|
||||
LSYM(x248) t0__32a0 ! t0__t0ma0 ! b_e_shift ! r__r_8t0
|
||||
LSYM(x249) t0__32a0 ! t0__t0ma0 ! b_e_t0 ! t0__8t0_a0
|
||||
LSYM(x250) t0__5a0 ! t0__5t0 ! b_e_2t0 ! t0__5t0
|
||||
LSYM(x251) t0__5a0 ! t0__5t0 ! b_e_2t0a0 ! t0__5t0
|
||||
LSYM(x252) t0__64a0 ! t0__t0ma0 ! b_e_shift ! r__r_4t0
|
||||
LSYM(x253) t0__64a0 ! t0__t0ma0 ! b_e_t0 ! t0__4t0_a0
|
||||
LSYM(x254) t0__128a0 ! t0__t0ma0 ! b_e_shift ! r__r_2t0
|
||||
LSYM(x255) t0__256a0 ! a1_ne_0_b_l0 ! t0__t0ma0 ! b_n_ret_t0
|
||||
/*1040 insts before this. */
|
||||
LSYM(ret_t0) MILLIRET
|
||||
LSYM(e_t0) r__r_t0
|
||||
LSYM(e_shift) a1_ne_0_b_l2
|
||||
a0__256a0 /* a0 <<= 8 *********** */
|
||||
MILLIRETN
|
||||
LSYM(e_t0ma0) a1_ne_0_b_l0
|
||||
t0__t0ma0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_t0a0) a1_ne_0_b_l0
|
||||
t0__t0_a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_t02a0) a1_ne_0_b_l0
|
||||
t0__t0_2a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_t04a0) a1_ne_0_b_l0
|
||||
t0__t0_4a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_2t0) a1_ne_0_b_l1
|
||||
r__r_2t0
|
||||
MILLIRETN
|
||||
LSYM(e_2t0a0) a1_ne_0_b_l0
|
||||
t0__2t0_a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e2t04a0) t0__t0_2a0
|
||||
a1_ne_0_b_l1
|
||||
r__r_2t0
|
||||
MILLIRETN
|
||||
LSYM(e_3t0) a1_ne_0_b_l0
|
||||
t0__3t0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_4t0) a1_ne_0_b_l1
|
||||
r__r_4t0
|
||||
MILLIRETN
|
||||
LSYM(e_4t0a0) a1_ne_0_b_l0
|
||||
t0__4t0_a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e4t08a0) t0__t0_2a0
|
||||
a1_ne_0_b_l1
|
||||
r__r_4t0
|
||||
MILLIRETN
|
||||
LSYM(e_5t0) a1_ne_0_b_l0
|
||||
t0__5t0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
LSYM(e_8t0) a1_ne_0_b_l1
|
||||
r__r_8t0
|
||||
MILLIRETN
|
||||
LSYM(e_8t0a0) a1_ne_0_b_l0
|
||||
t0__8t0_a0
|
||||
MILLIRET
|
||||
r__r_t0
|
||||
|
||||
.procend
|
||||
.end
|
||||
#endif
|
185
arch/parisc/lib/milli/remI.S
Normal file
185
arch/parisc/lib/milli/remI.S
Normal file
@ -0,0 +1,185 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_remI
|
||||
/* ROUTINE: $$remI
|
||||
|
||||
DESCRIPTION:
|
||||
. $$remI returns the remainder of the division of two signed 32-bit
|
||||
. integers. The sign of the remainder is the same as the sign of
|
||||
. the dividend.
|
||||
|
||||
|
||||
INPUT REGISTERS:
|
||||
. arg0 == dividend
|
||||
. arg1 == divisor
|
||||
. mrp == return pc
|
||||
. sr0 == return space when called externally
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
. arg0 = destroyed
|
||||
. arg1 = destroyed
|
||||
. ret1 = remainder
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
. r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
. Causes a trap under the following conditions: DIVIDE BY ZERO
|
||||
. Changes memory at the following places: NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
. Unwindable
|
||||
. Does not create a stack frame
|
||||
. Is usable for internal or external microcode
|
||||
|
||||
DISCUSSION:
|
||||
. Calls other millicode routines via mrp: NONE
|
||||
. Calls other millicode routines: NONE */
|
||||
|
||||
RDEFINE(tmp,r1)
|
||||
RDEFINE(retreg,ret1)
|
||||
|
||||
SUBSPA_MILLI
|
||||
ATTR_MILLI
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
GSYM($$remI)
|
||||
GSYM($$remoI)
|
||||
.export $$remI,MILLICODE
|
||||
.export $$remoI,MILLICODE
|
||||
ldo -1(arg1),tmp /* is there at most one bit set ? */
|
||||
and,<> arg1,tmp,r0 /* if not, don't use power of 2 */
|
||||
addi,> 0,arg1,r0 /* if denominator > 0, use power */
|
||||
/* of 2 */
|
||||
b,n LREF(neg_denom)
|
||||
LSYM(pow2)
|
||||
comb,>,n 0,arg0,LREF(neg_num) /* is numerator < 0 ? */
|
||||
and arg0,tmp,retreg /* get the result */
|
||||
MILLIRETN
|
||||
LSYM(neg_num)
|
||||
subi 0,arg0,arg0 /* negate numerator */
|
||||
and arg0,tmp,retreg /* get the result */
|
||||
subi 0,retreg,retreg /* negate result */
|
||||
MILLIRETN
|
||||
LSYM(neg_denom)
|
||||
addi,< 0,arg1,r0 /* if arg1 >= 0, it's not power */
|
||||
/* of 2 */
|
||||
b,n LREF(regular_seq)
|
||||
sub r0,arg1,tmp /* make denominator positive */
|
||||
comb,=,n arg1,tmp,LREF(regular_seq) /* test against 0x80000000 and 0 */
|
||||
ldo -1(tmp),retreg /* is there at most one bit set ? */
|
||||
and,= tmp,retreg,r0 /* if not, go to regular_seq */
|
||||
b,n LREF(regular_seq)
|
||||
comb,>,n 0,arg0,LREF(neg_num_2) /* if arg0 < 0, negate it */
|
||||
and arg0,retreg,retreg
|
||||
MILLIRETN
|
||||
LSYM(neg_num_2)
|
||||
subi 0,arg0,tmp /* test against 0x80000000 */
|
||||
and tmp,retreg,retreg
|
||||
subi 0,retreg,retreg
|
||||
MILLIRETN
|
||||
LSYM(regular_seq)
|
||||
addit,= 0,arg1,0 /* trap if div by zero */
|
||||
add,>= 0,arg0,retreg /* move dividend, if retreg < 0, */
|
||||
sub 0,retreg,retreg /* make it positive */
|
||||
sub 0,arg1, tmp /* clear carry, */
|
||||
/* negate the divisor */
|
||||
ds 0, tmp,0 /* set V-bit to the comple- */
|
||||
/* ment of the divisor sign */
|
||||
or 0,0, tmp /* clear tmp */
|
||||
add retreg,retreg,retreg /* shift msb bit into carry */
|
||||
ds tmp,arg1, tmp /* 1st divide step, if no carry */
|
||||
/* out, msb of quotient = 0 */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
LSYM(t1)
|
||||
ds tmp,arg1, tmp /* 2nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 3rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 4th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 5th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 6th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 7th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 8th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 9th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 10th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 11th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 12th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 13th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 14th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 15th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 16th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 17th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 18th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 19th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 20th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 21st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 22nd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 23rd divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 24th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 25th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 26th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 27th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 28th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 29th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 30th divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 31st divide step */
|
||||
addc retreg,retreg,retreg /* shift retreg with/into carry */
|
||||
ds tmp,arg1, tmp /* 32nd divide step, */
|
||||
addc retreg,retreg,retreg /* shift last bit into retreg */
|
||||
movb,>=,n tmp,retreg,LREF(finish) /* branch if pos. tmp */
|
||||
add,< arg1,0,0 /* if arg1 > 0, add arg1 */
|
||||
add,tr tmp,arg1,retreg /* for correcting remainder tmp */
|
||||
sub tmp,arg1,retreg /* else add absolute value arg1 */
|
||||
LSYM(finish)
|
||||
add,>= arg0,0,0 /* set sign of remainder */
|
||||
sub 0,retreg,retreg /* to sign of dividend */
|
||||
MILLIRET
|
||||
nop
|
||||
.exit
|
||||
.procend
|
||||
#ifdef milliext
|
||||
.origin 0x00000200
|
||||
#endif
|
||||
.end
|
||||
#endif
|
148
arch/parisc/lib/milli/remU.S
Normal file
148
arch/parisc/lib/milli/remU.S
Normal file
@ -0,0 +1,148 @@
|
||||
/* 32 and 64-bit millicode, original author Hewlett-Packard
|
||||
adapted for gcc by Paul Bame <bame@debian.org>
|
||||
and Alan Modra <alan@linuxcare.com.au>.
|
||||
|
||||
Copyright 2001, 2002, 2003 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of GCC and is released under the terms of
|
||||
of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 2, or (at your option) any later version.
|
||||
See the file COPYING in the top-level GCC source directory for a copy
|
||||
of the license. */
|
||||
|
||||
#include "milli.h"
|
||||
|
||||
#ifdef L_remU
|
||||
/* ROUTINE: $$remU
|
||||
. Single precision divide for remainder with unsigned binary integers.
|
||||
.
|
||||
. The remainder must be dividend-(dividend/divisor)*divisor.
|
||||
. Divide by zero is trapped.
|
||||
|
||||
INPUT REGISTERS:
|
||||
. arg0 == dividend
|
||||
. arg1 == divisor
|
||||
. mrp == return pc
|
||||
. sr0 == return space when called externally
|
||||
|
||||
OUTPUT REGISTERS:
|
||||
. arg0 = undefined
|
||||
. arg1 = undefined
|
||||
. ret1 = remainder
|
||||
|
||||
OTHER REGISTERS AFFECTED:
|
||||
. r1 = undefined
|
||||
|
||||
SIDE EFFECTS:
|
||||
. Causes a trap under the following conditions: DIVIDE BY ZERO
|
||||
. Changes memory at the following places: NONE
|
||||
|
||||
PERMISSIBLE CONTEXT:
|
||||
. Unwindable.
|
||||
. Does not create a stack frame.
|
||||
. Suitable for internal or external millicode.
|
||||
. Assumes the special millicode register conventions.
|
||||
|
||||
DISCUSSION:
|
||||
. Calls other millicode routines using mrp: NONE
|
||||
. Calls other millicode routines: NONE */
|
||||
|
||||
|
||||
RDEFINE(temp,r1)
|
||||
RDEFINE(rmndr,ret1) /* r29 */
|
||||
SUBSPA_MILLI
|
||||
ATTR_MILLI
|
||||
.export $$remU,millicode
|
||||
.proc
|
||||
.callinfo millicode
|
||||
.entry
|
||||
GSYM($$remU)
|
||||
ldo -1(arg1),temp /* is there at most one bit set ? */
|
||||
and,= arg1,temp,r0 /* if not, don't use power of 2 */
|
||||
b LREF(regular_seq)
|
||||
addit,= 0,arg1,r0 /* trap on div by zero */
|
||||
and arg0,temp,rmndr /* get the result for power of 2 */
|
||||
MILLIRETN
|
||||
LSYM(regular_seq)
|
||||
comib,>=,n 0,arg1,LREF(special_case)
|
||||
subi 0,arg1,rmndr /* clear carry, negate the divisor */
|
||||
ds r0,rmndr,r0 /* set V-bit to 1 */
|
||||
add arg0,arg0,temp /* shift msb bit into carry */
|
||||
ds r0,arg1,rmndr /* 1st divide step, if no carry */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 2nd divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 3rd divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 4th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 5th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 6th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 7th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 8th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 9th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 10th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 11th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 12th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 13th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 14th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 15th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 16th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 17th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 18th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 19th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 20th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 21st divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 22nd divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 23rd divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 24th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 25th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 26th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 27th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 28th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 29th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 30th divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 31st divide step */
|
||||
addc temp,temp,temp /* shift temp with/into carry */
|
||||
ds rmndr,arg1,rmndr /* 32nd divide step, */
|
||||
comiclr,<= 0,rmndr,r0
|
||||
add rmndr,arg1,rmndr /* correction */
|
||||
MILLIRETN
|
||||
nop
|
||||
|
||||
/* Putting >= on the last DS and deleting COMICLR does not work! */
|
||||
LSYM(special_case)
|
||||
sub,>>= arg0,arg1,rmndr
|
||||
copy arg0,rmndr
|
||||
MILLIRETN
|
||||
nop
|
||||
.exit
|
||||
.procend
|
||||
.end
|
||||
#endif
|
@ -607,7 +607,7 @@ void show_mem(void)
|
||||
|
||||
printk("Zone list for zone %d on node %d: ", j, i);
|
||||
for (k = 0; zl->zones[k] != NULL; k++)
|
||||
printk("[%ld/%s] ", zone_to_nid(zl->zones[k]), zl->zones[k]->name);
|
||||
printk("[%d/%s] ", zone_to_nid(zl->zones[k]), zl->zones[k]->name);
|
||||
printk("\n");
|
||||
}
|
||||
}
|
||||
|
@ -556,44 +556,6 @@ lba_bios_init(void)
|
||||
|
||||
#ifdef CONFIG_64BIT
|
||||
|
||||
/*
|
||||
** Determine if a device is already configured.
|
||||
** If so, reserve it resources.
|
||||
**
|
||||
** Read PCI cfg command register and see if I/O or MMIO is enabled.
|
||||
** PAT has to enable the devices it's using.
|
||||
**
|
||||
** Note: resources are fixed up before we try to claim them.
|
||||
*/
|
||||
static void
|
||||
lba_claim_dev_resources(struct pci_dev *dev)
|
||||
{
|
||||
u16 cmd;
|
||||
int i, srch_flags;
|
||||
|
||||
(void) pci_read_config_word(dev, PCI_COMMAND, &cmd);
|
||||
|
||||
srch_flags = (cmd & PCI_COMMAND_IO) ? IORESOURCE_IO : 0;
|
||||
if (cmd & PCI_COMMAND_MEMORY)
|
||||
srch_flags |= IORESOURCE_MEM;
|
||||
|
||||
if (!srch_flags)
|
||||
return;
|
||||
|
||||
for (i = 0; i <= PCI_ROM_RESOURCE; i++) {
|
||||
if (dev->resource[i].flags & srch_flags) {
|
||||
pci_claim_resource(dev, i);
|
||||
DBG(" claimed %s %d [%lx,%lx]/%lx\n",
|
||||
pci_name(dev), i,
|
||||
dev->resource[i].start,
|
||||
dev->resource[i].end,
|
||||
dev->resource[i].flags
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* truncate_pat_collision: Deal with overlaps or outright collisions
|
||||
* between PAT PDC reported ranges.
|
||||
@ -653,7 +615,6 @@ truncate_pat_collision(struct resource *root, struct resource *new)
|
||||
}
|
||||
|
||||
#else
|
||||
#define lba_claim_dev_resources(dev) do { } while (0)
|
||||
#define truncate_pat_collision(r,n) (0)
|
||||
#endif
|
||||
|
||||
@ -684,8 +645,12 @@ lba_fixup_bus(struct pci_bus *bus)
|
||||
** pci_alloc_primary_bus() mangles this.
|
||||
*/
|
||||
if (bus->self) {
|
||||
int i;
|
||||
/* PCI-PCI Bridge */
|
||||
pci_read_bridge_bases(bus);
|
||||
for (i = PCI_BRIDGE_RESOURCES; i < PCI_NUM_RESOURCES; i++) {
|
||||
pci_claim_resource(bus->self, i);
|
||||
}
|
||||
} else {
|
||||
/* Host-PCI Bridge */
|
||||
int err, i;
|
||||
@ -803,6 +768,9 @@ lba_fixup_bus(struct pci_bus *bus)
|
||||
DBG("lba_fixup_bus() WTF? 0x%lx [%lx/%lx] XXX",
|
||||
res->flags, res->start, res->end);
|
||||
}
|
||||
if ((i != PCI_ROM_RESOURCE) ||
|
||||
(res->flags & IORESOURCE_ROM_ENABLE))
|
||||
pci_claim_resource(dev, i);
|
||||
}
|
||||
|
||||
#ifdef FBB_SUPPORT
|
||||
@ -814,11 +782,6 @@ lba_fixup_bus(struct pci_bus *bus)
|
||||
bus->bridge_ctl &= ~(status & PCI_STATUS_FAST_BACK);
|
||||
#endif
|
||||
|
||||
if (is_pdc_pat()) {
|
||||
/* Claim resources for PDC's devices */
|
||||
lba_claim_dev_resources(dev);
|
||||
}
|
||||
|
||||
/*
|
||||
** P2PB's have no IRQs. ignore them.
|
||||
*/
|
||||
|
@ -282,6 +282,7 @@ pdcspath_hwpath_write(struct pdcspath_entry *entry, const char *buf, size_t coun
|
||||
unsigned short i;
|
||||
char in[count+1], *temp;
|
||||
struct device *dev;
|
||||
int ret;
|
||||
|
||||
if (!entry || !buf || !count)
|
||||
return -EINVAL;
|
||||
@ -333,7 +334,9 @@ pdcspath_hwpath_write(struct pdcspath_entry *entry, const char *buf, size_t coun
|
||||
|
||||
/* Update the symlink to the real device */
|
||||
sysfs_remove_link(&entry->kobj, "device");
|
||||
sysfs_create_link(&entry->kobj, &entry->dev->kobj, "device");
|
||||
ret = sysfs_create_link(&entry->kobj, &entry->dev->kobj, "device");
|
||||
WARN_ON(ret);
|
||||
|
||||
write_unlock(&entry->rw_lock);
|
||||
|
||||
printk(KERN_INFO PDCS_PREFIX ": changed \"%s\" path to \"%s\"\n",
|
||||
@ -1003,8 +1006,10 @@ pdcs_register_pathentries(void)
|
||||
entry->ready = 2;
|
||||
|
||||
/* Add a nice symlink to the real device */
|
||||
if (entry->dev)
|
||||
sysfs_create_link(&entry->kobj, &entry->dev->kobj, "device");
|
||||
if (entry->dev) {
|
||||
err = sysfs_create_link(&entry->kobj, &entry->dev->kobj, "device");
|
||||
WARN_ON(err);
|
||||
}
|
||||
|
||||
write_unlock(&entry->rw_lock);
|
||||
}
|
||||
|
@ -1909,8 +1909,8 @@ sba_driver_callback(struct parisc_device *dev)
|
||||
global_ioc_cnt *= 2;
|
||||
}
|
||||
|
||||
printk(KERN_INFO "%s found %s at 0x%lx\n",
|
||||
MODULE_NAME, version, dev->hpa.start);
|
||||
printk(KERN_INFO "%s found %s at 0x%llx\n",
|
||||
MODULE_NAME, version, (unsigned long long)dev->hpa.start);
|
||||
|
||||
sba_dev = kzalloc(sizeof(struct sba_device), GFP_KERNEL);
|
||||
if (!sba_dev) {
|
||||
|
@ -155,6 +155,7 @@ superio_init(struct pci_dev *pcidev)
|
||||
struct superio_device *sio = &sio_dev;
|
||||
struct pci_dev *pdev = sio->lio_pdev;
|
||||
u16 word;
|
||||
int ret;
|
||||
|
||||
if (sio->suckyio_irq_enabled)
|
||||
return;
|
||||
@ -200,7 +201,8 @@ superio_init(struct pci_dev *pcidev)
|
||||
pci_write_config_word (pdev, PCI_COMMAND, word);
|
||||
|
||||
pci_set_master (pdev);
|
||||
pci_enable_device(pdev);
|
||||
ret = pci_enable_device(pdev);
|
||||
BUG_ON(ret < 0); /* not too much we can do about this... */
|
||||
|
||||
/*
|
||||
* Next project is programming the onboard interrupt controllers.
|
||||
|
@ -1 +1,3 @@
|
||||
include include/asm-generic/Kbuild.asm
|
||||
|
||||
unifdef-y += pdc.h
|
||||
|
@ -138,7 +138,7 @@ extern void __iomem * __ioremap(unsigned long offset, unsigned long size, unsign
|
||||
/* Most machines react poorly to I/O-space being cacheable... Instead let's
|
||||
* define ioremap() in terms of ioremap_nocache().
|
||||
*/
|
||||
extern inline void __iomem * ioremap(unsigned long offset, unsigned long size)
|
||||
static inline void __iomem * ioremap(unsigned long offset, unsigned long size)
|
||||
{
|
||||
return __ioremap(offset, size, _PAGE_NO_CACHE);
|
||||
}
|
||||
|
@ -3,6 +3,8 @@
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
#include <linux/const.h>
|
||||
|
||||
#if defined(CONFIG_PARISC_PAGE_SIZE_4KB)
|
||||
# define PAGE_SHIFT 12
|
||||
#elif defined(CONFIG_PARISC_PAGE_SIZE_16KB)
|
||||
@ -12,7 +14,7 @@
|
||||
#else
|
||||
# error "unknown default kernel page size"
|
||||
#endif
|
||||
#define PAGE_SIZE (1UL << PAGE_SHIFT)
|
||||
#define PAGE_SIZE (_AC(1,UL) << PAGE_SHIFT)
|
||||
#define PAGE_MASK (~(PAGE_SIZE-1))
|
||||
|
||||
|
||||
|
@ -207,7 +207,7 @@ extern struct pci_bios_ops *pci_bios;
|
||||
extern void pcibios_register_hba(struct pci_hba_data *);
|
||||
extern void pcibios_set_master(struct pci_dev *);
|
||||
#else
|
||||
extern inline void pcibios_register_hba(struct pci_hba_data *x)
|
||||
static inline void pcibios_register_hba(struct pci_hba_data *x)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
@ -1,7 +1,6 @@
|
||||
#ifndef _PARISC_PDC_H
|
||||
#define _PARISC_PDC_H
|
||||
|
||||
|
||||
/*
|
||||
* PDC return values ...
|
||||
* All PDC calls return a subset of these errors.
|
||||
@ -20,7 +19,6 @@
|
||||
#define PDC_BUS_POW_WARN -12 /* Call could not complete in allowed power budget */
|
||||
#define PDC_NOT_NARROW -17 /* Narrow mode not supported */
|
||||
|
||||
|
||||
/*
|
||||
* PDC entry points...
|
||||
*/
|
||||
@ -50,6 +48,12 @@
|
||||
#define PDC_MODEL_DISPEC 5 /* disable specific option */
|
||||
#define PDC_MODEL_CPU_ID 6 /* returns cpu-id (only newer machines!) */
|
||||
#define PDC_MODEL_CAPABILITIES 7 /* returns OS32/OS64-flags */
|
||||
/* Values for PDC_MODEL_CAPABILITIES non-equivalent virtual aliasing support */
|
||||
#define PDC_MODEL_IOPDIR_FDC (1 << 2)
|
||||
#define PDC_MODEL_NVA_MASK (3 << 4)
|
||||
#define PDC_MODEL_NVA_SUPPORTED (0 << 4)
|
||||
#define PDC_MODEL_NVA_SLOW (1 << 4)
|
||||
#define PDC_MODEL_NVA_UNSUPPORTED (3 << 4)
|
||||
#define PDC_MODEL_GET_BOOT__OP 8 /* returns boot test options */
|
||||
#define PDC_MODEL_SET_BOOT__OP 9 /* set boot test options */
|
||||
|
||||
@ -91,7 +95,7 @@
|
||||
#define PDC_TOD 9 /* time-of-day clock (TOD) */
|
||||
#define PDC_TOD_READ 0 /* read TOD */
|
||||
#define PDC_TOD_WRITE 1 /* write TOD */
|
||||
#define PDC_TOD_ITIMER 2 /* calibrate Interval Timer (CR16) */
|
||||
|
||||
|
||||
#define PDC_STABLE 10 /* stable storage (sprockets) */
|
||||
#define PDC_STABLE_READ 0
|
||||
@ -143,15 +147,6 @@
|
||||
#define PDC_MEM_RET_PDT_FULL -11
|
||||
#define PDC_MEM_RET_INVALID_PHYSICAL_LOCATION ~0ULL
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
typedef struct {
|
||||
unsigned long long baseAddr;
|
||||
unsigned int pages;
|
||||
unsigned int reserved;
|
||||
} MemAddrTable_t;
|
||||
#endif
|
||||
|
||||
|
||||
#define PDC_PSW 21 /* Get/Set default System Mask */
|
||||
#define PDC_PSW_MASK 0 /* Return mask */
|
||||
#define PDC_PSW_GET_DEFAULTS 1 /* Return defaults */
|
||||
@ -274,6 +269,43 @@ typedef struct {
|
||||
#define PDC_LINK_PCI_ENTRY_POINTS 0 /* list (Arg1) = 0 */
|
||||
#define PDC_LINK_USB_ENTRY_POINTS 1 /* list (Arg1) = 1 */
|
||||
|
||||
/* cl_class
|
||||
* page 3-33 of IO-Firmware ARS
|
||||
* IODC ENTRY_INIT(Search first) RET[1]
|
||||
*/
|
||||
#define CL_NULL 0 /* invalid */
|
||||
#define CL_RANDOM 1 /* random access (as disk) */
|
||||
#define CL_SEQU 2 /* sequential access (as tape) */
|
||||
#define CL_DUPLEX 7 /* full-duplex point-to-point (RS-232, Net) */
|
||||
#define CL_KEYBD 8 /* half-duplex console (HIL Keyboard) */
|
||||
#define CL_DISPL 9 /* half-duplex console (display) */
|
||||
#define CL_FC 10 /* FiberChannel access media */
|
||||
|
||||
/* IODC ENTRY_INIT() */
|
||||
#define ENTRY_INIT_SRCH_FRST 2
|
||||
#define ENTRY_INIT_SRCH_NEXT 3
|
||||
#define ENTRY_INIT_MOD_DEV 4
|
||||
#define ENTRY_INIT_DEV 5
|
||||
#define ENTRY_INIT_MOD 6
|
||||
#define ENTRY_INIT_MSG 9
|
||||
|
||||
/* IODC ENTRY_IO() */
|
||||
#define ENTRY_IO_BOOTIN 0
|
||||
#define ENTRY_IO_BOOTOUT 1
|
||||
#define ENTRY_IO_CIN 2
|
||||
#define ENTRY_IO_COUT 3
|
||||
#define ENTRY_IO_CLOSE 4
|
||||
#define ENTRY_IO_GETMSG 9
|
||||
#define ENTRY_IO_BBLOCK_IN 16
|
||||
#define ENTRY_IO_BBLOCK_OUT 17
|
||||
|
||||
/* IODC ENTRY_SPA() */
|
||||
|
||||
/* IODC ENTRY_CONFIG() */
|
||||
|
||||
/* IODC ENTRY_TEST() */
|
||||
|
||||
/* IODC ENTRY_TLB() */
|
||||
|
||||
/* constants for OS (NVM...) */
|
||||
#define OS_ID_NONE 0 /* Undefined OS ID */
|
||||
@ -295,7 +327,13 @@ typedef struct {
|
||||
#define OSTAT_RUN 6
|
||||
#define OSTAT_ON 7
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
/* Page Zero constant offsets used by the HPMC handler */
|
||||
#define BOOT_CONSOLE_HPA_OFFSET 0x3c0
|
||||
#define BOOT_CONSOLE_SPA_OFFSET 0x3c4
|
||||
#define BOOT_CONSOLE_PATH_OFFSET 0x3a8
|
||||
|
||||
#if !defined(__ASSEMBLY__)
|
||||
#ifdef __KERNEL__
|
||||
|
||||
#include <linux/types.h>
|
||||
|
||||
@ -331,14 +369,6 @@ struct pdc_model { /* for PDC_MODEL */
|
||||
unsigned long curr_key;
|
||||
};
|
||||
|
||||
/* Values for PDC_MODEL_CAPABILITIES non-equivalent virtual aliasing support */
|
||||
|
||||
#define PDC_MODEL_IOPDIR_FDC (1 << 2) /* see sba_iommu.c */
|
||||
#define PDC_MODEL_NVA_MASK (3 << 4)
|
||||
#define PDC_MODEL_NVA_SUPPORTED (0 << 4)
|
||||
#define PDC_MODEL_NVA_SLOW (1 << 4)
|
||||
#define PDC_MODEL_NVA_UNSUPPORTED (3 << 4)
|
||||
|
||||
struct pdc_cache_cf { /* for PDC_CACHE (I/D-caches) */
|
||||
unsigned long
|
||||
#ifdef CONFIG_64BIT
|
||||
@ -558,156 +588,6 @@ struct pdc_hpmc_pim_20 { /* PDC_PIM */
|
||||
__u64 fr[32];
|
||||
};
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
/* flags of the device_path (see below) */
|
||||
#define PF_AUTOBOOT 0x80
|
||||
#define PF_AUTOSEARCH 0x40
|
||||
#define PF_TIMER 0x0F
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
|
||||
struct device_path { /* page 1-69 */
|
||||
unsigned char flags; /* flags see above! */
|
||||
unsigned char bc[6]; /* bus converter routing info */
|
||||
unsigned char mod;
|
||||
unsigned int layers[6];/* device-specific layer-info */
|
||||
} __attribute__((aligned(8))) ;
|
||||
|
||||
struct pz_device {
|
||||
struct device_path dp; /* see above */
|
||||
/* struct iomod *hpa; */
|
||||
unsigned int hpa; /* HPA base address */
|
||||
/* char *spa; */
|
||||
unsigned int spa; /* SPA base address */
|
||||
/* int (*iodc_io)(struct iomod*, ...); */
|
||||
unsigned int iodc_io; /* device entry point */
|
||||
short pad; /* reserved */
|
||||
unsigned short cl_class;/* see below */
|
||||
} __attribute__((aligned(8))) ;
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
/* cl_class
|
||||
* page 3-33 of IO-Firmware ARS
|
||||
* IODC ENTRY_INIT(Search first) RET[1]
|
||||
*/
|
||||
#define CL_NULL 0 /* invalid */
|
||||
#define CL_RANDOM 1 /* random access (as disk) */
|
||||
#define CL_SEQU 2 /* sequential access (as tape) */
|
||||
#define CL_DUPLEX 7 /* full-duplex point-to-point (RS-232, Net) */
|
||||
#define CL_KEYBD 8 /* half-duplex console (HIL Keyboard) */
|
||||
#define CL_DISPL 9 /* half-duplex console (display) */
|
||||
#define CL_FC 10 /* FiberChannel access media */
|
||||
|
||||
#if 0
|
||||
/* FIXME: DEVCLASS_* duplicates CL_* (above). Delete DEVCLASS_*? */
|
||||
#define DEVCLASS_RANDOM 1
|
||||
#define DEVCLASS_SEQU 2
|
||||
#define DEVCLASS_DUPLEX 7
|
||||
#define DEVCLASS_KEYBD 8
|
||||
#define DEVCLASS_DISP 9
|
||||
#endif
|
||||
|
||||
/* IODC ENTRY_INIT() */
|
||||
#define ENTRY_INIT_SRCH_FRST 2
|
||||
#define ENTRY_INIT_SRCH_NEXT 3
|
||||
#define ENTRY_INIT_MOD_DEV 4
|
||||
#define ENTRY_INIT_DEV 5
|
||||
#define ENTRY_INIT_MOD 6
|
||||
#define ENTRY_INIT_MSG 9
|
||||
|
||||
/* IODC ENTRY_IO() */
|
||||
#define ENTRY_IO_BOOTIN 0
|
||||
#define ENTRY_IO_BOOTOUT 1
|
||||
#define ENTRY_IO_CIN 2
|
||||
#define ENTRY_IO_COUT 3
|
||||
#define ENTRY_IO_CLOSE 4
|
||||
#define ENTRY_IO_GETMSG 9
|
||||
#define ENTRY_IO_BBLOCK_IN 16
|
||||
#define ENTRY_IO_BBLOCK_OUT 17
|
||||
|
||||
/* IODC ENTRY_SPA() */
|
||||
|
||||
/* IODC ENTRY_CONFIG() */
|
||||
|
||||
/* IODC ENTRY_TEST() */
|
||||
|
||||
/* IODC ENTRY_TLB() */
|
||||
|
||||
|
||||
/* DEFINITION OF THE ZERO-PAGE (PAG0) */
|
||||
/* based on work by Jason Eckhardt (jason@equator.com) */
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
|
||||
#define PAGE0 ((struct zeropage *)__PAGE_OFFSET)
|
||||
|
||||
struct zeropage {
|
||||
/* [0x000] initialize vectors (VEC) */
|
||||
unsigned int vec_special; /* must be zero */
|
||||
/* int (*vec_pow_fail)(void);*/
|
||||
unsigned int vec_pow_fail; /* power failure handler */
|
||||
/* int (*vec_toc)(void); */
|
||||
unsigned int vec_toc;
|
||||
unsigned int vec_toclen;
|
||||
/* int (*vec_rendz)(void); */
|
||||
unsigned int vec_rendz;
|
||||
int vec_pow_fail_flen;
|
||||
int vec_pad[10];
|
||||
|
||||
/* [0x040] reserved processor dependent */
|
||||
int pad0[112];
|
||||
|
||||
/* [0x200] reserved */
|
||||
int pad1[84];
|
||||
|
||||
/* [0x350] memory configuration (MC) */
|
||||
int memc_cont; /* contiguous mem size (bytes) */
|
||||
int memc_phsize; /* physical memory size */
|
||||
int memc_adsize; /* additional mem size, bytes of SPA space used by PDC */
|
||||
unsigned int mem_pdc_hi; /* used for 64-bit */
|
||||
|
||||
/* [0x360] various parameters for the boot-CPU */
|
||||
/* unsigned int *mem_booterr[8]; */
|
||||
unsigned int mem_booterr[8]; /* ptr to boot errors */
|
||||
unsigned int mem_free; /* first location, where OS can be loaded */
|
||||
/* struct iomod *mem_hpa; */
|
||||
unsigned int mem_hpa; /* HPA of the boot-CPU */
|
||||
/* int (*mem_pdc)(int, ...); */
|
||||
unsigned int mem_pdc; /* PDC entry point */
|
||||
unsigned int mem_10msec; /* number of clock ticks in 10msec */
|
||||
|
||||
/* [0x390] initial memory module (IMM) */
|
||||
/* struct iomod *imm_hpa; */
|
||||
unsigned int imm_hpa; /* HPA of the IMM */
|
||||
int imm_soft_boot; /* 0 = was hard boot, 1 = was soft boot */
|
||||
unsigned int imm_spa_size; /* SPA size of the IMM in bytes */
|
||||
unsigned int imm_max_mem; /* bytes of mem in IMM */
|
||||
|
||||
/* [0x3A0] boot console, display device and keyboard */
|
||||
struct pz_device mem_cons; /* description of console device */
|
||||
struct pz_device mem_boot; /* description of boot device */
|
||||
struct pz_device mem_kbd; /* description of keyboard device */
|
||||
|
||||
/* [0x430] reserved */
|
||||
int pad430[116];
|
||||
|
||||
/* [0x600] processor dependent */
|
||||
__u32 pad600[1];
|
||||
__u32 proc_sti; /* pointer to STI ROM */
|
||||
__u32 pad608[126];
|
||||
};
|
||||
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
/* Page Zero constant offsets used by the HPMC handler */
|
||||
|
||||
#define BOOT_CONSOLE_HPA_OFFSET 0x3c0
|
||||
#define BOOT_CONSOLE_SPA_OFFSET 0x3c4
|
||||
#define BOOT_CONSOLE_PATH_OFFSET 0x3a8
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
void pdc_console_init(void); /* in pdc_console.c */
|
||||
void pdc_console_restart(void);
|
||||
|
||||
@ -724,7 +604,7 @@ int pdc_iodc_read(unsigned long *actcnt, unsigned long hpa, unsigned int index,
|
||||
void *iodc_data, unsigned int iodc_data_size);
|
||||
int pdc_system_map_find_mods(struct pdc_system_map_mod_info *pdc_mod_info,
|
||||
struct pdc_module_path *mod_path, long mod_index);
|
||||
int pdc_system_map_find_addrs(struct pdc_system_map_addr_info *pdc_addr_info,
|
||||
int pdc_system_map_find_addrs(struct pdc_system_map_addr_info *pdc_addr_info,
|
||||
long mod_index, long addr_index);
|
||||
int pdc_model_info(struct pdc_model *model);
|
||||
int pdc_model_sysmodel(char *name);
|
||||
@ -786,6 +666,94 @@ static inline char * os_id_to_string(u16 os_id) {
|
||||
default: return "Unknown";
|
||||
}
|
||||
}
|
||||
#endif /* __ASSEMBLY__ */
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#define PAGE0 ((struct zeropage *)__PAGE_OFFSET)
|
||||
|
||||
/* DEFINITION OF THE ZERO-PAGE (PAG0) */
|
||||
/* based on work by Jason Eckhardt (jason@equator.com) */
|
||||
|
||||
/* flags of the device_path */
|
||||
#define PF_AUTOBOOT 0x80
|
||||
#define PF_AUTOSEARCH 0x40
|
||||
#define PF_TIMER 0x0F
|
||||
|
||||
struct device_path { /* page 1-69 */
|
||||
unsigned char flags; /* flags see above! */
|
||||
unsigned char bc[6]; /* bus converter routing info */
|
||||
unsigned char mod;
|
||||
unsigned int layers[6];/* device-specific layer-info */
|
||||
} __attribute__((aligned(8))) ;
|
||||
|
||||
struct pz_device {
|
||||
struct device_path dp; /* see above */
|
||||
/* struct iomod *hpa; */
|
||||
unsigned int hpa; /* HPA base address */
|
||||
/* char *spa; */
|
||||
unsigned int spa; /* SPA base address */
|
||||
/* int (*iodc_io)(struct iomod*, ...); */
|
||||
unsigned int iodc_io; /* device entry point */
|
||||
short pad; /* reserved */
|
||||
unsigned short cl_class;/* see below */
|
||||
} __attribute__((aligned(8))) ;
|
||||
|
||||
struct zeropage {
|
||||
/* [0x000] initialize vectors (VEC) */
|
||||
unsigned int vec_special; /* must be zero */
|
||||
/* int (*vec_pow_fail)(void);*/
|
||||
unsigned int vec_pow_fail; /* power failure handler */
|
||||
/* int (*vec_toc)(void); */
|
||||
unsigned int vec_toc;
|
||||
unsigned int vec_toclen;
|
||||
/* int (*vec_rendz)(void); */
|
||||
unsigned int vec_rendz;
|
||||
int vec_pow_fail_flen;
|
||||
int vec_pad[10];
|
||||
|
||||
/* [0x040] reserved processor dependent */
|
||||
int pad0[112];
|
||||
|
||||
/* [0x200] reserved */
|
||||
int pad1[84];
|
||||
|
||||
/* [0x350] memory configuration (MC) */
|
||||
int memc_cont; /* contiguous mem size (bytes) */
|
||||
int memc_phsize; /* physical memory size */
|
||||
int memc_adsize; /* additional mem size, bytes of SPA space used by PDC */
|
||||
unsigned int mem_pdc_hi; /* used for 64-bit */
|
||||
|
||||
/* [0x360] various parameters for the boot-CPU */
|
||||
/* unsigned int *mem_booterr[8]; */
|
||||
unsigned int mem_booterr[8]; /* ptr to boot errors */
|
||||
unsigned int mem_free; /* first location, where OS can be loaded */
|
||||
/* struct iomod *mem_hpa; */
|
||||
unsigned int mem_hpa; /* HPA of the boot-CPU */
|
||||
/* int (*mem_pdc)(int, ...); */
|
||||
unsigned int mem_pdc; /* PDC entry point */
|
||||
unsigned int mem_10msec; /* number of clock ticks in 10msec */
|
||||
|
||||
/* [0x390] initial memory module (IMM) */
|
||||
/* struct iomod *imm_hpa; */
|
||||
unsigned int imm_hpa; /* HPA of the IMM */
|
||||
int imm_soft_boot; /* 0 = was hard boot, 1 = was soft boot */
|
||||
unsigned int imm_spa_size; /* SPA size of the IMM in bytes */
|
||||
unsigned int imm_max_mem; /* bytes of mem in IMM */
|
||||
|
||||
/* [0x3A0] boot console, display device and keyboard */
|
||||
struct pz_device mem_cons; /* description of console device */
|
||||
struct pz_device mem_boot; /* description of boot device */
|
||||
struct pz_device mem_kbd; /* description of keyboard device */
|
||||
|
||||
/* [0x430] reserved */
|
||||
int pad430[116];
|
||||
|
||||
/* [0x600] processor dependent */
|
||||
__u32 pad600[1];
|
||||
__u32 proc_sti; /* pointer to STI ROM */
|
||||
__u32 pad608[126];
|
||||
};
|
||||
|
||||
#endif /* !defined(__ASSEMBLY__) */
|
||||
|
||||
#endif /* _PARISC_PDC_H */
|
||||
|
@ -49,14 +49,6 @@
|
||||
#define pgd_ERROR(e) \
|
||||
printk("%s:%d: bad pgd %08lx.\n", __FILE__, __LINE__, (unsigned long)pgd_val(e))
|
||||
|
||||
/* Note: If you change ISTACK_SIZE, you need to change the corresponding
|
||||
* values in vmlinux.lds and vmlinux64.lds (init_istack section). Also,
|
||||
* the "order" and size need to agree.
|
||||
*/
|
||||
|
||||
#define ISTACK_SIZE 32768 /* Interrupt Stack Size */
|
||||
#define ISTACK_ORDER 3
|
||||
|
||||
/* This is the size of the initially mapped kernel memory */
|
||||
#ifdef CONFIG_64BIT
|
||||
#define KERNEL_INITIAL_ORDER 24 /* 0 to 1<<24 = 16MB */
|
||||
@ -325,27 +317,27 @@ static inline void pgd_clear(pgd_t *pgd) {
|
||||
* setup: the pgd is never bad, and a pmd always exists (as it's folded
|
||||
* into the pgd entry)
|
||||
*/
|
||||
extern inline int pgd_none(pgd_t pgd) { return 0; }
|
||||
extern inline int pgd_bad(pgd_t pgd) { return 0; }
|
||||
extern inline int pgd_present(pgd_t pgd) { return 1; }
|
||||
extern inline void pgd_clear(pgd_t * pgdp) { }
|
||||
static inline int pgd_none(pgd_t pgd) { return 0; }
|
||||
static inline int pgd_bad(pgd_t pgd) { return 0; }
|
||||
static inline int pgd_present(pgd_t pgd) { return 1; }
|
||||
static inline void pgd_clear(pgd_t * pgdp) { }
|
||||
#endif
|
||||
|
||||
/*
|
||||
* The following only work if pte_present() is true.
|
||||
* Undefined behaviour if not..
|
||||
*/
|
||||
extern inline int pte_dirty(pte_t pte) { return pte_val(pte) & _PAGE_DIRTY; }
|
||||
extern inline int pte_young(pte_t pte) { return pte_val(pte) & _PAGE_ACCESSED; }
|
||||
extern inline int pte_write(pte_t pte) { return pte_val(pte) & _PAGE_WRITE; }
|
||||
extern inline int pte_file(pte_t pte) { return pte_val(pte) & _PAGE_FILE; }
|
||||
static inline int pte_dirty(pte_t pte) { return pte_val(pte) & _PAGE_DIRTY; }
|
||||
static inline int pte_young(pte_t pte) { return pte_val(pte) & _PAGE_ACCESSED; }
|
||||
static inline int pte_write(pte_t pte) { return pte_val(pte) & _PAGE_WRITE; }
|
||||
static inline int pte_file(pte_t pte) { return pte_val(pte) & _PAGE_FILE; }
|
||||
|
||||
extern inline pte_t pte_mkclean(pte_t pte) { pte_val(pte) &= ~_PAGE_DIRTY; return pte; }
|
||||
extern inline pte_t pte_mkold(pte_t pte) { pte_val(pte) &= ~_PAGE_ACCESSED; return pte; }
|
||||
extern inline pte_t pte_wrprotect(pte_t pte) { pte_val(pte) &= ~_PAGE_WRITE; return pte; }
|
||||
extern inline pte_t pte_mkdirty(pte_t pte) { pte_val(pte) |= _PAGE_DIRTY; return pte; }
|
||||
extern inline pte_t pte_mkyoung(pte_t pte) { pte_val(pte) |= _PAGE_ACCESSED; return pte; }
|
||||
extern inline pte_t pte_mkwrite(pte_t pte) { pte_val(pte) |= _PAGE_WRITE; return pte; }
|
||||
static inline pte_t pte_mkclean(pte_t pte) { pte_val(pte) &= ~_PAGE_DIRTY; return pte; }
|
||||
static inline pte_t pte_mkold(pte_t pte) { pte_val(pte) &= ~_PAGE_ACCESSED; return pte; }
|
||||
static inline pte_t pte_wrprotect(pte_t pte) { pte_val(pte) &= ~_PAGE_WRITE; return pte; }
|
||||
static inline pte_t pte_mkdirty(pte_t pte) { pte_val(pte) |= _PAGE_DIRTY; return pte; }
|
||||
static inline pte_t pte_mkyoung(pte_t pte) { pte_val(pte) |= _PAGE_ACCESSED; return pte; }
|
||||
static inline pte_t pte_mkwrite(pte_t pte) { pte_val(pte) |= _PAGE_WRITE; return pte; }
|
||||
|
||||
/*
|
||||
* Conversion functions: convert a page and protection to a page entry,
|
||||
@ -369,7 +361,7 @@ static inline pte_t pfn_pte(unsigned long pfn, pgprot_t pgprot)
|
||||
return pte;
|
||||
}
|
||||
|
||||
extern inline pte_t pte_modify(pte_t pte, pgprot_t newprot)
|
||||
static inline pte_t pte_modify(pte_t pte, pgprot_t newprot)
|
||||
{ pte_val(pte) = (pte_val(pte) & _PAGE_CHG_MASK) | pgprot_val(newprot); return pte; }
|
||||
|
||||
/* Permanent address of a page. On parisc we don't have highmem. */
|
||||
|
@ -19,7 +19,7 @@
|
||||
#ifdef CONFIG_PREFETCH
|
||||
|
||||
#define ARCH_HAS_PREFETCH
|
||||
extern inline void prefetch(const void *addr)
|
||||
static inline void prefetch(const void *addr)
|
||||
{
|
||||
__asm__("ldw 0(%0), %%r0" : : "r" (addr));
|
||||
}
|
||||
@ -27,7 +27,7 @@ extern inline void prefetch(const void *addr)
|
||||
/* LDD is a PA2.0 addition. */
|
||||
#ifdef CONFIG_PA20
|
||||
#define ARCH_HAS_PREFETCHW
|
||||
extern inline void prefetchw(const void *addr)
|
||||
static inline void prefetchw(const void *addr)
|
||||
{
|
||||
__asm__("ldd 0(%0), %%r0" : : "r" (addr));
|
||||
}
|
||||
|
@ -50,10 +50,10 @@ static inline unsigned int get_rtc_time(struct rtc_time *wtime)
|
||||
long int days, rem, y;
|
||||
const unsigned short int *ip;
|
||||
|
||||
if(pdc_tod_read(&tod_data) < 0)
|
||||
memset(wtime, 0, sizeof(*wtime));
|
||||
if (pdc_tod_read(&tod_data) < 0)
|
||||
return RTC_24H | RTC_BATT_BAD;
|
||||
|
||||
|
||||
// most of the remainder of this function is:
|
||||
// Copyright (C) 1991, 1993, 1997, 1998 Free Software Foundation, Inc.
|
||||
// This was originally a part of the GNU C Library.
|
||||
|
@ -54,7 +54,7 @@ struct semaphore {
|
||||
|
||||
#define DECLARE_MUTEX(name) __DECLARE_SEMAPHORE_GENERIC(name,1)
|
||||
|
||||
extern inline void sema_init (struct semaphore *sem, int val)
|
||||
static inline void sema_init (struct semaphore *sem, int val)
|
||||
{
|
||||
*sem = (struct semaphore)__SEMAPHORE_INITIALIZER((*sem),val);
|
||||
}
|
||||
@ -82,7 +82,7 @@ asmlinkage void __up(struct semaphore * sem);
|
||||
* interrupts while we're messing with the semaphore. Sorry.
|
||||
*/
|
||||
|
||||
extern __inline__ void down(struct semaphore * sem)
|
||||
static inline void down(struct semaphore * sem)
|
||||
{
|
||||
might_sleep();
|
||||
spin_lock_irq(&sem->sentry);
|
||||
@ -94,7 +94,7 @@ extern __inline__ void down(struct semaphore * sem)
|
||||
spin_unlock_irq(&sem->sentry);
|
||||
}
|
||||
|
||||
extern __inline__ int down_interruptible(struct semaphore * sem)
|
||||
static inline int down_interruptible(struct semaphore * sem)
|
||||
{
|
||||
int ret = 0;
|
||||
might_sleep();
|
||||
@ -112,7 +112,7 @@ extern __inline__ int down_interruptible(struct semaphore * sem)
|
||||
* down_trylock returns 0 on success, 1 if we failed to get the lock.
|
||||
* May not sleep, but must preserve irq state
|
||||
*/
|
||||
extern __inline__ int down_trylock(struct semaphore * sem)
|
||||
static inline int down_trylock(struct semaphore * sem)
|
||||
{
|
||||
unsigned long flags;
|
||||
int count;
|
||||
@ -129,7 +129,7 @@ extern __inline__ int down_trylock(struct semaphore * sem)
|
||||
* Note! This is subtle. We jump to wake people up only if
|
||||
* the semaphore was negative (== somebody was waiting on it).
|
||||
*/
|
||||
extern __inline__ void up(struct semaphore * sem)
|
||||
static inline void up(struct semaphore * sem)
|
||||
{
|
||||
unsigned long flags;
|
||||
|
||||
|
@ -797,8 +797,9 @@
|
||||
#define __NR_signalfd (__NR_Linux + 302)
|
||||
#define __NR_timerfd (__NR_Linux + 303)
|
||||
#define __NR_eventfd (__NR_Linux + 304)
|
||||
#define __NR_fallocate (__NR_Linux + 305)
|
||||
|
||||
#define __NR_Linux_syscalls (__NR_eventfd + 1)
|
||||
#define __NR_Linux_syscalls (__NR_fallocate + 1)
|
||||
|
||||
|
||||
#define __IGNORE_select /* newselect */
|
||||
|
@ -13,6 +13,7 @@
|
||||
# Random bits by Matt Mackall <mpm@selenic.com>
|
||||
# M68k port by Geert Uytterhoeven and Andreas Schwab
|
||||
# AVR32 port by Haavard Skinnemoen <hskinnemoen@atmel.com>
|
||||
# PARISC port by Kyle McMartin <kyle@parisc-linux.org>
|
||||
#
|
||||
# Usage:
|
||||
# objdump -d vmlinux | scripts/checkstack.pl [arch]
|
||||
@ -61,6 +62,8 @@ my (@stack, $re, $x, $xs);
|
||||
} elsif ($arch eq 'mips') {
|
||||
#88003254: 27bdffe0 addiu sp,sp,-32
|
||||
$re = qr/.*addiu.*sp,sp,-(([0-9]{2}|[3-9])[0-9]{2})/o;
|
||||
} elsif ($arch eq 'parisc' || $arch eq 'parisc64') {
|
||||
$re = qr/.*ldo ($x{1,8})\(sp\),sp/o;
|
||||
} elsif ($arch eq 'ppc') {
|
||||
#c00029f4: 94 21 ff 30 stwu r1,-208(r1)
|
||||
$re = qr/.*stwu.*r1,-($x{1,8})\(r1\)/o;
|
||||
|
Loading…
x
Reference in New Issue
Block a user