Add support for ARC to newlib
newlib/ChangeLog: 2015-11-12 Anton Kolesov <Anton.Kolesov@synopsys.com> * configure.host: Add ARC support. * libc/include/machine/setjmp.h: Likewise. * libc/machine/configure: Likewise. * libc/machine/configure.in: Likewise. * libc/machine/arc/Makefile.am: Likewise. * libc/machine/arc/Makefile.in: Likewise. * libc/machine/arc/aclocal.m4: Likewise. * libc/machine/arc/asm.h: Likewise. * libc/machine/arc/configure: Likewise. * libc/machine/arc/configure.in: Likewise. * libc/machine/arc/memcmp-bs-norm.S: Likewise. * libc/machine/arc/memcmp-stub.c: Likewise. * libc/machine/arc/memcmp.S: Likewise. * libc/machine/arc/memcpy-archs.S: Likewise. * libc/machine/arc/memcpy-bs.S: Likewise. * libc/machine/arc/memcpy-stub.c: Likewise. * libc/machine/arc/memcpy.S: Likewise. * libc/machine/arc/memset-archs.S: Likewise. * libc/machine/arc/memset-bs.S: Likewise. * libc/machine/arc/memset-stub.c: Likewise. * libc/machine/arc/memset.S: Likewise. * libc/machine/arc/setjmp.S: Likewise. * libc/machine/arc/strchr-bs-norm.S: Likewise. * libc/machine/arc/strchr-bs.S: Likewise. * libc/machine/arc/strchr-stub.c: Likewise. * libc/machine/arc/strchr.S: Likewise. * libc/machine/arc/strcmp-archs.S: Likewise. * libc/machine/arc/strcmp-stub.c: Likewise. * libc/machine/arc/strcmp.S: Likewise. * libc/machine/arc/strcpy-bs-arc600.S: Likewise. * libc/machine/arc/strcpy-bs.S: Likewise. * libc/machine/arc/strcpy-stub.c: Likewise. * libc/machine/arc/strcpy.S: Likewise. * libc/machine/arc/strlen-bs-norm.S: Likewise. * libc/machine/arc/strlen-bs.S: Likewise. * libc/machine/arc/strlen-stub.c: Likewise. * libc/machine/arc/strlen.S: Likewise. * libc/machine/arc/strncpy-bs.S: Likewise. * libc/machine/arc/strncpy-stub.c: Likewise. * libc/machine/arc/strncpy.S: Likewise.
This commit is contained in:
parent
acdfcb0a0a
commit
c0a99f0293
|
@ -1,3 +1,46 @@
|
||||||
|
2015-11-12 Anton Kolesov <Anton.Kolesov@synopsys.com>
|
||||||
|
|
||||||
|
* configure.host: Add ARC support.
|
||||||
|
* libc/include/machine/setjmp.h: Likewise.
|
||||||
|
* libc/machine/configure: Likewise.
|
||||||
|
* libc/machine/configure.in: Likewise.
|
||||||
|
* libc/machine/arc/Makefile.am: Likewise.
|
||||||
|
* libc/machine/arc/Makefile.in: Likewise.
|
||||||
|
* libc/machine/arc/aclocal.m4: Likewise.
|
||||||
|
* libc/machine/arc/asm.h: Likewise.
|
||||||
|
* libc/machine/arc/configure: Likewise.
|
||||||
|
* libc/machine/arc/configure.in: Likewise.
|
||||||
|
* libc/machine/arc/memcmp-bs-norm.S: Likewise.
|
||||||
|
* libc/machine/arc/memcmp-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/memcmp.S: Likewise.
|
||||||
|
* libc/machine/arc/memcpy-archs.S: Likewise.
|
||||||
|
* libc/machine/arc/memcpy-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/memcpy-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/memcpy.S: Likewise.
|
||||||
|
* libc/machine/arc/memset-archs.S: Likewise.
|
||||||
|
* libc/machine/arc/memset-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/memset-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/memset.S: Likewise.
|
||||||
|
* libc/machine/arc/setjmp.S: Likewise.
|
||||||
|
* libc/machine/arc/strchr-bs-norm.S: Likewise.
|
||||||
|
* libc/machine/arc/strchr-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/strchr-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/strchr.S: Likewise.
|
||||||
|
* libc/machine/arc/strcmp-archs.S: Likewise.
|
||||||
|
* libc/machine/arc/strcmp-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/strcmp.S: Likewise.
|
||||||
|
* libc/machine/arc/strcpy-bs-arc600.S: Likewise.
|
||||||
|
* libc/machine/arc/strcpy-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/strcpy-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/strcpy.S: Likewise.
|
||||||
|
* libc/machine/arc/strlen-bs-norm.S: Likewise.
|
||||||
|
* libc/machine/arc/strlen-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/strlen-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/strlen.S: Likewise.
|
||||||
|
* libc/machine/arc/strncpy-bs.S: Likewise.
|
||||||
|
* libc/machine/arc/strncpy-stub.c: Likewise.
|
||||||
|
* libc/machine/arc/strncpy.S: Likewise.
|
||||||
|
|
||||||
2015-11-12 Anton Kolesov <Anton.Kolesov@synopsys.com>
|
2015-11-12 Anton Kolesov <Anton.Kolesov@synopsys.com>
|
||||||
|
|
||||||
* configure.host: Remove ARC system.
|
* configure.host: Remove ARC system.
|
||||||
|
|
|
@ -100,8 +100,8 @@ case "${host_cpu}" in
|
||||||
machine_dir=aarch64
|
machine_dir=aarch64
|
||||||
libm_machine_dir=aarch64
|
libm_machine_dir=aarch64
|
||||||
;;
|
;;
|
||||||
arc)
|
arc*)
|
||||||
machine_dir=
|
machine_dir=arc
|
||||||
;;
|
;;
|
||||||
arm*)
|
arm*)
|
||||||
machine_dir=arm
|
machine_dir=arm
|
||||||
|
@ -611,8 +611,9 @@ case "${host}" in
|
||||||
default_newlib_io_long_long="yes"
|
default_newlib_io_long_long="yes"
|
||||||
syscall_dir=syscalls
|
syscall_dir=syscalls
|
||||||
;;
|
;;
|
||||||
arc-*-*)
|
arc*-*-*)
|
||||||
syscall_dir=syscalls
|
syscall_dir=syscalls
|
||||||
|
default_newlib_io_long_long="yes"
|
||||||
;;
|
;;
|
||||||
arm*-*-pe)
|
arm*-*-pe)
|
||||||
syscall_dir=syscalls
|
syscall_dir=syscalls
|
||||||
|
@ -631,9 +632,6 @@ case "${host}" in
|
||||||
newlib_cflags="${newlib_cflags} -DARM_RDI_MONITOR"
|
newlib_cflags="${newlib_cflags} -DARM_RDI_MONITOR"
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
arc*)
|
|
||||||
newlib_cflags="${newlib_cflags} -DREENTRANT_SYSCALLS_PROVIDED"
|
|
||||||
;;
|
|
||||||
avr*)
|
avr*)
|
||||||
newlib_cflags="${newlib_cflags} -DNO_EXEC -DSMALL_MEMORY -DMISSING_SYSCALL_NAMES"
|
newlib_cflags="${newlib_cflags} -DNO_EXEC -DSMALL_MEMORY -DMISSING_SYSCALL_NAMES"
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -262,6 +262,10 @@ _BEGIN_STD_C
|
||||||
#define _JBLEN 16
|
#define _JBLEN 16
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __arc__
|
||||||
|
#define _JBLEN 25 /* r13-r30,blink,lp_count,lp_start,lp_end,mlo,mhi,status32 */
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __MMIX__
|
#ifdef __MMIX__
|
||||||
/* Using a layout compatible with GCC's built-in. */
|
/* Using a layout compatible with GCC's built-in. */
|
||||||
#define _JBLEN 5
|
#define _JBLEN 5
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
## Process this file with automake to generate Makefile.in
|
||||||
|
|
||||||
|
AUTOMAKE_OPTIONS = cygnus
|
||||||
|
|
||||||
|
INCLUDES = $(NEWLIB_CFLAGS) $(CROSS_CFLAGS) $(TARGET_CFLAGS)
|
||||||
|
|
||||||
|
noinst_LIBRARIES = lib.a
|
||||||
|
|
||||||
|
lib_a_SOURCES = \
|
||||||
|
memcmp.S \
|
||||||
|
memcmp-bs-norm.S \
|
||||||
|
memcmp-stub.c \
|
||||||
|
memcpy.S \
|
||||||
|
memcpy-archs.S \
|
||||||
|
memcpy-bs.S \
|
||||||
|
memcpy-stub.c \
|
||||||
|
memset.S \
|
||||||
|
memset-archs.S \
|
||||||
|
memset-bs.S \
|
||||||
|
memset-stub.c \
|
||||||
|
setjmp.S \
|
||||||
|
strchr.S \
|
||||||
|
strchr-bs.S \
|
||||||
|
strchr-bs-norm.S \
|
||||||
|
strchr-stub.c \
|
||||||
|
strcmp.S \
|
||||||
|
strcmp-archs.S \
|
||||||
|
strcmp-stub.c \
|
||||||
|
strcpy.S \
|
||||||
|
strcpy-bs.S \
|
||||||
|
strcpy-bs-arc600.S \
|
||||||
|
strcpy-stub.c \
|
||||||
|
strlen.S \
|
||||||
|
strlen-bs.S \
|
||||||
|
strlen-bs-norm.S \
|
||||||
|
strlen-stub.c \
|
||||||
|
strncpy.S \
|
||||||
|
strncpy-stub.c \
|
||||||
|
strncpy-bs.S
|
||||||
|
|
||||||
|
lib_a_CCASFLAGS=$(AM_CCASFLAGS)
|
||||||
|
lib_a_CFLAGS = $(AM_CFLAGS)
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I ../../..
|
||||||
|
CONFIG_STATUS_DEPENDENCIES = $(newlib_basedir)/configure.host
|
||||||
|
|
||||||
|
pdf:
|
||||||
|
install-pdf:
|
|
@ -0,0 +1,637 @@
|
||||||
|
# Makefile.in generated by automake 1.11.1 from Makefile.am.
|
||||||
|
# @configure_input@
|
||||||
|
|
||||||
|
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
|
# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation,
|
||||||
|
# Inc.
|
||||||
|
# This Makefile.in is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
||||||
|
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE.
|
||||||
|
|
||||||
|
@SET_MAKE@
|
||||||
|
|
||||||
|
VPATH = @srcdir@
|
||||||
|
pkgdatadir = $(datadir)/@PACKAGE@
|
||||||
|
pkgincludedir = $(includedir)/@PACKAGE@
|
||||||
|
pkglibdir = $(libdir)/@PACKAGE@
|
||||||
|
pkglibexecdir = $(libexecdir)/@PACKAGE@
|
||||||
|
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
||||||
|
install_sh_DATA = $(install_sh) -c -m 644
|
||||||
|
install_sh_PROGRAM = $(install_sh) -c
|
||||||
|
install_sh_SCRIPT = $(install_sh) -c
|
||||||
|
INSTALL_HEADER = $(INSTALL_DATA)
|
||||||
|
transform = $(program_transform_name)
|
||||||
|
NORMAL_INSTALL = :
|
||||||
|
PRE_INSTALL = :
|
||||||
|
POST_INSTALL = :
|
||||||
|
NORMAL_UNINSTALL = :
|
||||||
|
PRE_UNINSTALL = :
|
||||||
|
POST_UNINSTALL = :
|
||||||
|
build_triplet = @build@
|
||||||
|
host_triplet = @host@
|
||||||
|
subdir = .
|
||||||
|
DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am \
|
||||||
|
$(top_srcdir)/configure $(am__configure_deps) \
|
||||||
|
$(srcdir)/../../../../mkinstalldirs
|
||||||
|
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
||||||
|
am__aclocal_m4_deps = $(top_srcdir)/../../../acinclude.m4 \
|
||||||
|
$(top_srcdir)/configure.in
|
||||||
|
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
||||||
|
$(ACLOCAL_M4)
|
||||||
|
am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
|
||||||
|
configure.lineno config.status.lineno
|
||||||
|
mkinstalldirs = $(SHELL) $(top_srcdir)/../../../../mkinstalldirs
|
||||||
|
CONFIG_CLEAN_FILES =
|
||||||
|
CONFIG_CLEAN_VPATH_FILES =
|
||||||
|
LIBRARIES = $(noinst_LIBRARIES)
|
||||||
|
ARFLAGS = cru
|
||||||
|
lib_a_AR = $(AR) $(ARFLAGS)
|
||||||
|
lib_a_LIBADD =
|
||||||
|
am_lib_a_OBJECTS = lib_a-memcmp.$(OBJEXT) \
|
||||||
|
lib_a-memcmp-bs-norm.$(OBJEXT) lib_a-memcmp-stub.$(OBJEXT) \
|
||||||
|
lib_a-memcpy.$(OBJEXT) lib_a-memcpy-archs.$(OBJEXT) \
|
||||||
|
lib_a-memcpy-bs.$(OBJEXT) lib_a-memcpy-stub.$(OBJEXT) \
|
||||||
|
lib_a-memset.$(OBJEXT) lib_a-memset-archs.$(OBJEXT) \
|
||||||
|
lib_a-memset-bs.$(OBJEXT) lib_a-memset-stub.$(OBJEXT) \
|
||||||
|
lib_a-setjmp.$(OBJEXT) lib_a-strchr.$(OBJEXT) \
|
||||||
|
lib_a-strchr-bs.$(OBJEXT) lib_a-strchr-bs-norm.$(OBJEXT) \
|
||||||
|
lib_a-strchr-stub.$(OBJEXT) lib_a-strcmp.$(OBJEXT) \
|
||||||
|
lib_a-strcmp-archs.$(OBJEXT) lib_a-strcmp-stub.$(OBJEXT) \
|
||||||
|
lib_a-strcpy.$(OBJEXT) lib_a-strcpy-bs.$(OBJEXT) \
|
||||||
|
lib_a-strcpy-bs-arc600.$(OBJEXT) lib_a-strcpy-stub.$(OBJEXT) \
|
||||||
|
lib_a-strlen.$(OBJEXT) lib_a-strlen-bs.$(OBJEXT) \
|
||||||
|
lib_a-strlen-bs-norm.$(OBJEXT) lib_a-strlen-stub.$(OBJEXT) \
|
||||||
|
lib_a-strncpy.$(OBJEXT) lib_a-strncpy-stub.$(OBJEXT) \
|
||||||
|
lib_a-strncpy-bs.$(OBJEXT)
|
||||||
|
lib_a_OBJECTS = $(am_lib_a_OBJECTS)
|
||||||
|
DEFAULT_INCLUDES = -I.@am__isrc@
|
||||||
|
depcomp =
|
||||||
|
am__depfiles_maybe =
|
||||||
|
CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
|
||||||
|
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS)
|
||||||
|
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
||||||
|
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||||
|
CCLD = $(CC)
|
||||||
|
LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
|
||||||
|
SOURCES = $(lib_a_SOURCES)
|
||||||
|
ETAGS = etags
|
||||||
|
CTAGS = ctags
|
||||||
|
ACLOCAL = @ACLOCAL@
|
||||||
|
AMTAR = @AMTAR@
|
||||||
|
AR = @AR@
|
||||||
|
AS = @AS@
|
||||||
|
AUTOCONF = @AUTOCONF@
|
||||||
|
AUTOHEADER = @AUTOHEADER@
|
||||||
|
AUTOMAKE = @AUTOMAKE@
|
||||||
|
AWK = @AWK@
|
||||||
|
CC = @CC@
|
||||||
|
CCAS = @CCAS@
|
||||||
|
CCASFLAGS = @CCASFLAGS@
|
||||||
|
CCDEPMODE = @CCDEPMODE@
|
||||||
|
CYGPATH_W = @CYGPATH_W@
|
||||||
|
DEFS = @DEFS@
|
||||||
|
DEPDIR = @DEPDIR@
|
||||||
|
ECHO_C = @ECHO_C@
|
||||||
|
ECHO_N = @ECHO_N@
|
||||||
|
ECHO_T = @ECHO_T@
|
||||||
|
INSTALL = @INSTALL@
|
||||||
|
INSTALL_DATA = @INSTALL_DATA@
|
||||||
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||||
|
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||||
|
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
||||||
|
LDFLAGS = @LDFLAGS@
|
||||||
|
LIBOBJS = @LIBOBJS@
|
||||||
|
LIBS = @LIBS@
|
||||||
|
LTLIBOBJS = @LTLIBOBJS@
|
||||||
|
MAINT = @MAINT@
|
||||||
|
MAKEINFO = @MAKEINFO@
|
||||||
|
MKDIR_P = @MKDIR_P@
|
||||||
|
NEWLIB_CFLAGS = @NEWLIB_CFLAGS@
|
||||||
|
NO_INCLUDE_LIST = @NO_INCLUDE_LIST@
|
||||||
|
OBJEXT = @OBJEXT@
|
||||||
|
PACKAGE = @PACKAGE@
|
||||||
|
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
||||||
|
PACKAGE_NAME = @PACKAGE_NAME@
|
||||||
|
PACKAGE_STRING = @PACKAGE_STRING@
|
||||||
|
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
||||||
|
PACKAGE_URL = @PACKAGE_URL@
|
||||||
|
PACKAGE_VERSION = @PACKAGE_VERSION@
|
||||||
|
PATH_SEPARATOR = @PATH_SEPARATOR@
|
||||||
|
RANLIB = @RANLIB@
|
||||||
|
READELF = @READELF@
|
||||||
|
SET_MAKE = @SET_MAKE@
|
||||||
|
SHELL = @SHELL@
|
||||||
|
STRIP = @STRIP@
|
||||||
|
VERSION = @VERSION@
|
||||||
|
abs_builddir = @abs_builddir@
|
||||||
|
abs_srcdir = @abs_srcdir@
|
||||||
|
abs_top_builddir = @abs_top_builddir@
|
||||||
|
abs_top_srcdir = @abs_top_srcdir@
|
||||||
|
aext = @aext@
|
||||||
|
am__include = @am__include@
|
||||||
|
am__leading_dot = @am__leading_dot@
|
||||||
|
am__quote = @am__quote@
|
||||||
|
am__tar = @am__tar@
|
||||||
|
am__untar = @am__untar@
|
||||||
|
bindir = @bindir@
|
||||||
|
build = @build@
|
||||||
|
build_alias = @build_alias@
|
||||||
|
build_cpu = @build_cpu@
|
||||||
|
build_os = @build_os@
|
||||||
|
build_vendor = @build_vendor@
|
||||||
|
builddir = @builddir@
|
||||||
|
datadir = @datadir@
|
||||||
|
datarootdir = @datarootdir@
|
||||||
|
docdir = @docdir@
|
||||||
|
dvidir = @dvidir@
|
||||||
|
exec_prefix = @exec_prefix@
|
||||||
|
host = @host@
|
||||||
|
host_alias = @host_alias@
|
||||||
|
host_cpu = @host_cpu@
|
||||||
|
host_os = @host_os@
|
||||||
|
host_vendor = @host_vendor@
|
||||||
|
htmldir = @htmldir@
|
||||||
|
includedir = @includedir@
|
||||||
|
infodir = @infodir@
|
||||||
|
install_sh = @install_sh@
|
||||||
|
libdir = @libdir@
|
||||||
|
libexecdir = @libexecdir@
|
||||||
|
libm_machine_dir = @libm_machine_dir@
|
||||||
|
localedir = @localedir@
|
||||||
|
localstatedir = @localstatedir@
|
||||||
|
lpfx = @lpfx@
|
||||||
|
machine_dir = @machine_dir@
|
||||||
|
mandir = @mandir@
|
||||||
|
mkdir_p = @mkdir_p@
|
||||||
|
newlib_basedir = @newlib_basedir@
|
||||||
|
oext = @oext@
|
||||||
|
oldincludedir = @oldincludedir@
|
||||||
|
pdfdir = @pdfdir@
|
||||||
|
prefix = @prefix@
|
||||||
|
program_transform_name = @program_transform_name@
|
||||||
|
psdir = @psdir@
|
||||||
|
sbindir = @sbindir@
|
||||||
|
sharedstatedir = @sharedstatedir@
|
||||||
|
srcdir = @srcdir@
|
||||||
|
sys_dir = @sys_dir@
|
||||||
|
sysconfdir = @sysconfdir@
|
||||||
|
target_alias = @target_alias@
|
||||||
|
top_build_prefix = @top_build_prefix@
|
||||||
|
top_builddir = @top_builddir@
|
||||||
|
top_srcdir = @top_srcdir@
|
||||||
|
AUTOMAKE_OPTIONS = cygnus
|
||||||
|
INCLUDES = $(NEWLIB_CFLAGS) $(CROSS_CFLAGS) $(TARGET_CFLAGS)
|
||||||
|
noinst_LIBRARIES = lib.a
|
||||||
|
lib_a_SOURCES = \
|
||||||
|
memcmp.S \
|
||||||
|
memcmp-bs-norm.S \
|
||||||
|
memcmp-stub.c \
|
||||||
|
memcpy.S \
|
||||||
|
memcpy-archs.S \
|
||||||
|
memcpy-bs.S \
|
||||||
|
memcpy-stub.c \
|
||||||
|
memset.S \
|
||||||
|
memset-archs.S \
|
||||||
|
memset-bs.S \
|
||||||
|
memset-stub.c \
|
||||||
|
setjmp.S \
|
||||||
|
strchr.S \
|
||||||
|
strchr-bs.S \
|
||||||
|
strchr-bs-norm.S \
|
||||||
|
strchr-stub.c \
|
||||||
|
strcmp.S \
|
||||||
|
strcmp-archs.S \
|
||||||
|
strcmp-stub.c \
|
||||||
|
strcpy.S \
|
||||||
|
strcpy-bs.S \
|
||||||
|
strcpy-bs-arc600.S \
|
||||||
|
strcpy-stub.c \
|
||||||
|
strlen.S \
|
||||||
|
strlen-bs.S \
|
||||||
|
strlen-bs-norm.S \
|
||||||
|
strlen-stub.c \
|
||||||
|
strncpy.S \
|
||||||
|
strncpy-stub.c \
|
||||||
|
strncpy-bs.S
|
||||||
|
|
||||||
|
lib_a_CCASFLAGS = $(AM_CCASFLAGS)
|
||||||
|
lib_a_CFLAGS = $(AM_CFLAGS)
|
||||||
|
ACLOCAL_AMFLAGS = -I ../../..
|
||||||
|
CONFIG_STATUS_DEPENDENCIES = $(newlib_basedir)/configure.host
|
||||||
|
all: all-am
|
||||||
|
|
||||||
|
.SUFFIXES:
|
||||||
|
.SUFFIXES: .S .c .o .obj
|
||||||
|
am--refresh:
|
||||||
|
@:
|
||||||
|
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
|
||||||
|
@for dep in $?; do \
|
||||||
|
case '$(am__configure_deps)' in \
|
||||||
|
*$$dep*) \
|
||||||
|
echo ' cd $(srcdir) && $(AUTOMAKE) --cygnus'; \
|
||||||
|
$(am__cd) $(srcdir) && $(AUTOMAKE) --cygnus \
|
||||||
|
&& exit 0; \
|
||||||
|
exit 1;; \
|
||||||
|
esac; \
|
||||||
|
done; \
|
||||||
|
echo ' cd $(top_srcdir) && $(AUTOMAKE) --cygnus Makefile'; \
|
||||||
|
$(am__cd) $(top_srcdir) && \
|
||||||
|
$(AUTOMAKE) --cygnus Makefile
|
||||||
|
.PRECIOUS: Makefile
|
||||||
|
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
|
@case '$?' in \
|
||||||
|
*config.status*) \
|
||||||
|
echo ' $(SHELL) ./config.status'; \
|
||||||
|
$(SHELL) ./config.status;; \
|
||||||
|
*) \
|
||||||
|
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
|
||||||
|
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
|
||||||
|
esac;
|
||||||
|
|
||||||
|
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||||
|
$(SHELL) ./config.status --recheck
|
||||||
|
|
||||||
|
$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
|
||||||
|
$(am__cd) $(srcdir) && $(AUTOCONF)
|
||||||
|
$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
|
||||||
|
$(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
|
||||||
|
$(am__aclocal_m4_deps):
|
||||||
|
|
||||||
|
clean-noinstLIBRARIES:
|
||||||
|
-test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES)
|
||||||
|
lib.a: $(lib_a_OBJECTS) $(lib_a_DEPENDENCIES)
|
||||||
|
-rm -f lib.a
|
||||||
|
$(lib_a_AR) lib.a $(lib_a_OBJECTS) $(lib_a_LIBADD)
|
||||||
|
$(RANLIB) lib.a
|
||||||
|
|
||||||
|
mostlyclean-compile:
|
||||||
|
-rm -f *.$(OBJEXT)
|
||||||
|
|
||||||
|
distclean-compile:
|
||||||
|
-rm -f *.tab.c
|
||||||
|
|
||||||
|
.S.o:
|
||||||
|
$(CPPASCOMPILE) -c -o $@ $<
|
||||||
|
|
||||||
|
.S.obj:
|
||||||
|
$(CPPASCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
|
||||||
|
|
||||||
|
lib_a-memcmp.o: memcmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcmp.o `test -f 'memcmp.S' || echo '$(srcdir)/'`memcmp.S
|
||||||
|
|
||||||
|
lib_a-memcmp.obj: memcmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcmp.obj `if test -f 'memcmp.S'; then $(CYGPATH_W) 'memcmp.S'; else $(CYGPATH_W) '$(srcdir)/memcmp.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memcmp-bs-norm.o: memcmp-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcmp-bs-norm.o `test -f 'memcmp-bs-norm.S' || echo '$(srcdir)/'`memcmp-bs-norm.S
|
||||||
|
|
||||||
|
lib_a-memcmp-bs-norm.obj: memcmp-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcmp-bs-norm.obj `if test -f 'memcmp-bs-norm.S'; then $(CYGPATH_W) 'memcmp-bs-norm.S'; else $(CYGPATH_W) '$(srcdir)/memcmp-bs-norm.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memcpy.o: memcpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy.o `test -f 'memcpy.S' || echo '$(srcdir)/'`memcpy.S
|
||||||
|
|
||||||
|
lib_a-memcpy.obj: memcpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy.obj `if test -f 'memcpy.S'; then $(CYGPATH_W) 'memcpy.S'; else $(CYGPATH_W) '$(srcdir)/memcpy.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memcpy-archs.o: memcpy-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy-archs.o `test -f 'memcpy-archs.S' || echo '$(srcdir)/'`memcpy-archs.S
|
||||||
|
|
||||||
|
lib_a-memcpy-archs.obj: memcpy-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy-archs.obj `if test -f 'memcpy-archs.S'; then $(CYGPATH_W) 'memcpy-archs.S'; else $(CYGPATH_W) '$(srcdir)/memcpy-archs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memcpy-bs.o: memcpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy-bs.o `test -f 'memcpy-bs.S' || echo '$(srcdir)/'`memcpy-bs.S
|
||||||
|
|
||||||
|
lib_a-memcpy-bs.obj: memcpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memcpy-bs.obj `if test -f 'memcpy-bs.S'; then $(CYGPATH_W) 'memcpy-bs.S'; else $(CYGPATH_W) '$(srcdir)/memcpy-bs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memset.o: memset.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset.o `test -f 'memset.S' || echo '$(srcdir)/'`memset.S
|
||||||
|
|
||||||
|
lib_a-memset.obj: memset.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset.obj `if test -f 'memset.S'; then $(CYGPATH_W) 'memset.S'; else $(CYGPATH_W) '$(srcdir)/memset.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memset-archs.o: memset-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset-archs.o `test -f 'memset-archs.S' || echo '$(srcdir)/'`memset-archs.S
|
||||||
|
|
||||||
|
lib_a-memset-archs.obj: memset-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset-archs.obj `if test -f 'memset-archs.S'; then $(CYGPATH_W) 'memset-archs.S'; else $(CYGPATH_W) '$(srcdir)/memset-archs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-memset-bs.o: memset-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset-bs.o `test -f 'memset-bs.S' || echo '$(srcdir)/'`memset-bs.S
|
||||||
|
|
||||||
|
lib_a-memset-bs.obj: memset-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-memset-bs.obj `if test -f 'memset-bs.S'; then $(CYGPATH_W) 'memset-bs.S'; else $(CYGPATH_W) '$(srcdir)/memset-bs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-setjmp.o: setjmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-setjmp.o `test -f 'setjmp.S' || echo '$(srcdir)/'`setjmp.S
|
||||||
|
|
||||||
|
lib_a-setjmp.obj: setjmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-setjmp.obj `if test -f 'setjmp.S'; then $(CYGPATH_W) 'setjmp.S'; else $(CYGPATH_W) '$(srcdir)/setjmp.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strchr.o: strchr.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr.o `test -f 'strchr.S' || echo '$(srcdir)/'`strchr.S
|
||||||
|
|
||||||
|
lib_a-strchr.obj: strchr.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr.obj `if test -f 'strchr.S'; then $(CYGPATH_W) 'strchr.S'; else $(CYGPATH_W) '$(srcdir)/strchr.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strchr-bs.o: strchr-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr-bs.o `test -f 'strchr-bs.S' || echo '$(srcdir)/'`strchr-bs.S
|
||||||
|
|
||||||
|
lib_a-strchr-bs.obj: strchr-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr-bs.obj `if test -f 'strchr-bs.S'; then $(CYGPATH_W) 'strchr-bs.S'; else $(CYGPATH_W) '$(srcdir)/strchr-bs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strchr-bs-norm.o: strchr-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr-bs-norm.o `test -f 'strchr-bs-norm.S' || echo '$(srcdir)/'`strchr-bs-norm.S
|
||||||
|
|
||||||
|
lib_a-strchr-bs-norm.obj: strchr-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strchr-bs-norm.obj `if test -f 'strchr-bs-norm.S'; then $(CYGPATH_W) 'strchr-bs-norm.S'; else $(CYGPATH_W) '$(srcdir)/strchr-bs-norm.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strcmp.o: strcmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcmp.o `test -f 'strcmp.S' || echo '$(srcdir)/'`strcmp.S
|
||||||
|
|
||||||
|
lib_a-strcmp.obj: strcmp.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcmp.obj `if test -f 'strcmp.S'; then $(CYGPATH_W) 'strcmp.S'; else $(CYGPATH_W) '$(srcdir)/strcmp.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strcmp-archs.o: strcmp-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcmp-archs.o `test -f 'strcmp-archs.S' || echo '$(srcdir)/'`strcmp-archs.S
|
||||||
|
|
||||||
|
lib_a-strcmp-archs.obj: strcmp-archs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcmp-archs.obj `if test -f 'strcmp-archs.S'; then $(CYGPATH_W) 'strcmp-archs.S'; else $(CYGPATH_W) '$(srcdir)/strcmp-archs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strcpy.o: strcpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy.o `test -f 'strcpy.S' || echo '$(srcdir)/'`strcpy.S
|
||||||
|
|
||||||
|
lib_a-strcpy.obj: strcpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy.obj `if test -f 'strcpy.S'; then $(CYGPATH_W) 'strcpy.S'; else $(CYGPATH_W) '$(srcdir)/strcpy.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strcpy-bs.o: strcpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy-bs.o `test -f 'strcpy-bs.S' || echo '$(srcdir)/'`strcpy-bs.S
|
||||||
|
|
||||||
|
lib_a-strcpy-bs.obj: strcpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy-bs.obj `if test -f 'strcpy-bs.S'; then $(CYGPATH_W) 'strcpy-bs.S'; else $(CYGPATH_W) '$(srcdir)/strcpy-bs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strcpy-bs-arc600.o: strcpy-bs-arc600.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy-bs-arc600.o `test -f 'strcpy-bs-arc600.S' || echo '$(srcdir)/'`strcpy-bs-arc600.S
|
||||||
|
|
||||||
|
lib_a-strcpy-bs-arc600.obj: strcpy-bs-arc600.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strcpy-bs-arc600.obj `if test -f 'strcpy-bs-arc600.S'; then $(CYGPATH_W) 'strcpy-bs-arc600.S'; else $(CYGPATH_W) '$(srcdir)/strcpy-bs-arc600.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strlen.o: strlen.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen.o `test -f 'strlen.S' || echo '$(srcdir)/'`strlen.S
|
||||||
|
|
||||||
|
lib_a-strlen.obj: strlen.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen.obj `if test -f 'strlen.S'; then $(CYGPATH_W) 'strlen.S'; else $(CYGPATH_W) '$(srcdir)/strlen.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strlen-bs.o: strlen-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen-bs.o `test -f 'strlen-bs.S' || echo '$(srcdir)/'`strlen-bs.S
|
||||||
|
|
||||||
|
lib_a-strlen-bs.obj: strlen-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen-bs.obj `if test -f 'strlen-bs.S'; then $(CYGPATH_W) 'strlen-bs.S'; else $(CYGPATH_W) '$(srcdir)/strlen-bs.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strlen-bs-norm.o: strlen-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen-bs-norm.o `test -f 'strlen-bs-norm.S' || echo '$(srcdir)/'`strlen-bs-norm.S
|
||||||
|
|
||||||
|
lib_a-strlen-bs-norm.obj: strlen-bs-norm.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strlen-bs-norm.obj `if test -f 'strlen-bs-norm.S'; then $(CYGPATH_W) 'strlen-bs-norm.S'; else $(CYGPATH_W) '$(srcdir)/strlen-bs-norm.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strncpy.o: strncpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strncpy.o `test -f 'strncpy.S' || echo '$(srcdir)/'`strncpy.S
|
||||||
|
|
||||||
|
lib_a-strncpy.obj: strncpy.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strncpy.obj `if test -f 'strncpy.S'; then $(CYGPATH_W) 'strncpy.S'; else $(CYGPATH_W) '$(srcdir)/strncpy.S'; fi`
|
||||||
|
|
||||||
|
lib_a-strncpy-bs.o: strncpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strncpy-bs.o `test -f 'strncpy-bs.S' || echo '$(srcdir)/'`strncpy-bs.S
|
||||||
|
|
||||||
|
lib_a-strncpy-bs.obj: strncpy-bs.S
|
||||||
|
$(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CCASFLAGS) $(CCASFLAGS) -c -o lib_a-strncpy-bs.obj `if test -f 'strncpy-bs.S'; then $(CYGPATH_W) 'strncpy-bs.S'; else $(CYGPATH_W) '$(srcdir)/strncpy-bs.S'; fi`
|
||||||
|
|
||||||
|
.c.o:
|
||||||
|
$(COMPILE) -c $<
|
||||||
|
|
||||||
|
.c.obj:
|
||||||
|
$(COMPILE) -c `$(CYGPATH_W) '$<'`
|
||||||
|
|
||||||
|
lib_a-memcmp-stub.o: memcmp-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memcmp-stub.o `test -f 'memcmp-stub.c' || echo '$(srcdir)/'`memcmp-stub.c
|
||||||
|
|
||||||
|
lib_a-memcmp-stub.obj: memcmp-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memcmp-stub.obj `if test -f 'memcmp-stub.c'; then $(CYGPATH_W) 'memcmp-stub.c'; else $(CYGPATH_W) '$(srcdir)/memcmp-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-memcpy-stub.o: memcpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memcpy-stub.o `test -f 'memcpy-stub.c' || echo '$(srcdir)/'`memcpy-stub.c
|
||||||
|
|
||||||
|
lib_a-memcpy-stub.obj: memcpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memcpy-stub.obj `if test -f 'memcpy-stub.c'; then $(CYGPATH_W) 'memcpy-stub.c'; else $(CYGPATH_W) '$(srcdir)/memcpy-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-memset-stub.o: memset-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memset-stub.o `test -f 'memset-stub.c' || echo '$(srcdir)/'`memset-stub.c
|
||||||
|
|
||||||
|
lib_a-memset-stub.obj: memset-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-memset-stub.obj `if test -f 'memset-stub.c'; then $(CYGPATH_W) 'memset-stub.c'; else $(CYGPATH_W) '$(srcdir)/memset-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-strchr-stub.o: strchr-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strchr-stub.o `test -f 'strchr-stub.c' || echo '$(srcdir)/'`strchr-stub.c
|
||||||
|
|
||||||
|
lib_a-strchr-stub.obj: strchr-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strchr-stub.obj `if test -f 'strchr-stub.c'; then $(CYGPATH_W) 'strchr-stub.c'; else $(CYGPATH_W) '$(srcdir)/strchr-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-strcmp-stub.o: strcmp-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strcmp-stub.o `test -f 'strcmp-stub.c' || echo '$(srcdir)/'`strcmp-stub.c
|
||||||
|
|
||||||
|
lib_a-strcmp-stub.obj: strcmp-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strcmp-stub.obj `if test -f 'strcmp-stub.c'; then $(CYGPATH_W) 'strcmp-stub.c'; else $(CYGPATH_W) '$(srcdir)/strcmp-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-strcpy-stub.o: strcpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strcpy-stub.o `test -f 'strcpy-stub.c' || echo '$(srcdir)/'`strcpy-stub.c
|
||||||
|
|
||||||
|
lib_a-strcpy-stub.obj: strcpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strcpy-stub.obj `if test -f 'strcpy-stub.c'; then $(CYGPATH_W) 'strcpy-stub.c'; else $(CYGPATH_W) '$(srcdir)/strcpy-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-strlen-stub.o: strlen-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strlen-stub.o `test -f 'strlen-stub.c' || echo '$(srcdir)/'`strlen-stub.c
|
||||||
|
|
||||||
|
lib_a-strlen-stub.obj: strlen-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strlen-stub.obj `if test -f 'strlen-stub.c'; then $(CYGPATH_W) 'strlen-stub.c'; else $(CYGPATH_W) '$(srcdir)/strlen-stub.c'; fi`
|
||||||
|
|
||||||
|
lib_a-strncpy-stub.o: strncpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strncpy-stub.o `test -f 'strncpy-stub.c' || echo '$(srcdir)/'`strncpy-stub.c
|
||||||
|
|
||||||
|
lib_a-strncpy-stub.obj: strncpy-stub.c
|
||||||
|
$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(lib_a_CFLAGS) $(CFLAGS) -c -o lib_a-strncpy-stub.obj `if test -f 'strncpy-stub.c'; then $(CYGPATH_W) 'strncpy-stub.c'; else $(CYGPATH_W) '$(srcdir)/strncpy-stub.c'; fi`
|
||||||
|
|
||||||
|
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
mkid -fID $$unique
|
||||||
|
tags: TAGS
|
||||||
|
|
||||||
|
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
set x; \
|
||||||
|
here=`pwd`; \
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
shift; \
|
||||||
|
if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
|
||||||
|
test -n "$$unique" || unique=$$empty_fix; \
|
||||||
|
if test $$# -gt 0; then \
|
||||||
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
"$$@" $$unique; \
|
||||||
|
else \
|
||||||
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
$$unique; \
|
||||||
|
fi; \
|
||||||
|
fi
|
||||||
|
ctags: CTAGS
|
||||||
|
CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
test -z "$(CTAGS_ARGS)$$unique" \
|
||||||
|
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
||||||
|
$$unique
|
||||||
|
|
||||||
|
GTAGS:
|
||||||
|
here=`$(am__cd) $(top_builddir) && pwd` \
|
||||||
|
&& $(am__cd) $(top_srcdir) \
|
||||||
|
&& gtags -i $(GTAGS_ARGS) "$$here"
|
||||||
|
|
||||||
|
distclean-tags:
|
||||||
|
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
||||||
|
check-am:
|
||||||
|
check: check-am
|
||||||
|
all-am: Makefile $(LIBRARIES)
|
||||||
|
installdirs:
|
||||||
|
install: install-am
|
||||||
|
install-exec: install-exec-am
|
||||||
|
install-data: install-data-am
|
||||||
|
uninstall: uninstall-am
|
||||||
|
|
||||||
|
install-am: all-am
|
||||||
|
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
||||||
|
|
||||||
|
installcheck: installcheck-am
|
||||||
|
install-strip:
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||||
|
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||||
|
`test -z '$(STRIP)' || \
|
||||||
|
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
||||||
|
mostlyclean-generic:
|
||||||
|
|
||||||
|
clean-generic:
|
||||||
|
|
||||||
|
distclean-generic:
|
||||||
|
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
||||||
|
-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
|
||||||
|
|
||||||
|
maintainer-clean-generic:
|
||||||
|
@echo "This command is intended for maintainers to use"
|
||||||
|
@echo "it deletes files that may require special tools to rebuild."
|
||||||
|
clean: clean-am
|
||||||
|
|
||||||
|
clean-am: clean-generic clean-noinstLIBRARIES mostlyclean-am
|
||||||
|
|
||||||
|
distclean: distclean-am
|
||||||
|
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||||
|
-rm -f Makefile
|
||||||
|
distclean-am: clean-am distclean-compile distclean-generic \
|
||||||
|
distclean-tags
|
||||||
|
|
||||||
|
dvi: dvi-am
|
||||||
|
|
||||||
|
dvi-am:
|
||||||
|
|
||||||
|
html: html-am
|
||||||
|
|
||||||
|
html-am:
|
||||||
|
|
||||||
|
info: info-am
|
||||||
|
|
||||||
|
info-am:
|
||||||
|
|
||||||
|
install-data-am:
|
||||||
|
|
||||||
|
install-dvi: install-dvi-am
|
||||||
|
|
||||||
|
install-dvi-am:
|
||||||
|
|
||||||
|
install-exec-am:
|
||||||
|
|
||||||
|
install-html: install-html-am
|
||||||
|
|
||||||
|
install-html-am:
|
||||||
|
|
||||||
|
install-info: install-info-am
|
||||||
|
|
||||||
|
install-info-am:
|
||||||
|
|
||||||
|
install-man:
|
||||||
|
|
||||||
|
install-pdf-am:
|
||||||
|
|
||||||
|
install-ps: install-ps-am
|
||||||
|
|
||||||
|
install-ps-am:
|
||||||
|
|
||||||
|
installcheck-am:
|
||||||
|
|
||||||
|
maintainer-clean: maintainer-clean-am
|
||||||
|
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||||
|
-rm -rf $(top_srcdir)/autom4te.cache
|
||||||
|
-rm -f Makefile
|
||||||
|
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||||
|
|
||||||
|
mostlyclean: mostlyclean-am
|
||||||
|
|
||||||
|
mostlyclean-am: mostlyclean-compile mostlyclean-generic
|
||||||
|
|
||||||
|
pdf-am:
|
||||||
|
|
||||||
|
ps: ps-am
|
||||||
|
|
||||||
|
ps-am:
|
||||||
|
|
||||||
|
uninstall-am:
|
||||||
|
|
||||||
|
.MAKE: install-am install-strip
|
||||||
|
|
||||||
|
.PHONY: CTAGS GTAGS all all-am am--refresh check check-am clean \
|
||||||
|
clean-generic clean-noinstLIBRARIES ctags distclean \
|
||||||
|
distclean-compile distclean-generic distclean-tags dvi dvi-am \
|
||||||
|
html html-am info info-am install install-am install-data \
|
||||||
|
install-data-am install-dvi install-dvi-am install-exec \
|
||||||
|
install-exec-am install-html install-html-am install-info \
|
||||||
|
install-info-am install-man install-pdf install-pdf-am \
|
||||||
|
install-ps install-ps-am install-strip installcheck \
|
||||||
|
installcheck-am installdirs maintainer-clean \
|
||||||
|
maintainer-clean-generic mostlyclean mostlyclean-compile \
|
||||||
|
mostlyclean-generic pdf pdf-am ps ps-am tags uninstall \
|
||||||
|
uninstall-am
|
||||||
|
|
||||||
|
|
||||||
|
pdf:
|
||||||
|
install-pdf:
|
||||||
|
|
||||||
|
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
||||||
|
# Otherwise a system limit (for SysV at least) may be exceeded.
|
||||||
|
.NOEXPORT:
|
|
@ -0,0 +1,992 @@
|
||||||
|
# generated automatically by aclocal 1.11.1 -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
||||||
|
# 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
||||||
|
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE.
|
||||||
|
|
||||||
|
m4_ifndef([AC_AUTOCONF_VERSION],
|
||||||
|
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
||||||
|
m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.64],,
|
||||||
|
[m4_warning([this file was generated for autoconf 2.64.
|
||||||
|
You have another version of autoconf. It may work, but is not guaranteed to.
|
||||||
|
If you have problems, you may need to regenerate the build system entirely.
|
||||||
|
To do so, use the procedure documented by the package, typically `autoreconf'.])])
|
||||||
|
|
||||||
|
# Copyright (C) 2002, 2003, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# AM_AUTOMAKE_VERSION(VERSION)
|
||||||
|
# ----------------------------
|
||||||
|
# Automake X.Y traces this macro to ensure aclocal.m4 has been
|
||||||
|
# generated from the m4 files accompanying Automake X.Y.
|
||||||
|
# (This private macro should not be called outside this file.)
|
||||||
|
AC_DEFUN([AM_AUTOMAKE_VERSION],
|
||||||
|
[am__api_version='1.11'
|
||||||
|
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
|
||||||
|
dnl require some minimum version. Point them to the right macro.
|
||||||
|
m4_if([$1], [1.11.1], [],
|
||||||
|
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
# _AM_AUTOCONF_VERSION(VERSION)
|
||||||
|
# -----------------------------
|
||||||
|
# aclocal traces this macro to find the Autoconf version.
|
||||||
|
# This is a private macro too. Using m4_define simplifies
|
||||||
|
# the logic in aclocal, which can simply ignore this definition.
|
||||||
|
m4_define([_AM_AUTOCONF_VERSION], [])
|
||||||
|
|
||||||
|
# AM_SET_CURRENT_AUTOMAKE_VERSION
|
||||||
|
# -------------------------------
|
||||||
|
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
|
||||||
|
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
|
||||||
|
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
|
||||||
|
[AM_AUTOMAKE_VERSION([1.11.1])dnl
|
||||||
|
m4_ifndef([AC_AUTOCONF_VERSION],
|
||||||
|
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
||||||
|
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
|
||||||
|
|
||||||
|
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
|
||||||
|
# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to
|
||||||
|
# `$srcdir', `$srcdir/..', or `$srcdir/../..'.
|
||||||
|
#
|
||||||
|
# Of course, Automake must honor this variable whenever it calls a
|
||||||
|
# tool from the auxiliary directory. The problem is that $srcdir (and
|
||||||
|
# therefore $ac_aux_dir as well) can be either absolute or relative,
|
||||||
|
# depending on how configure is run. This is pretty annoying, since
|
||||||
|
# it makes $ac_aux_dir quite unusable in subdirectories: in the top
|
||||||
|
# source directory, any form will work fine, but in subdirectories a
|
||||||
|
# relative path needs to be adjusted first.
|
||||||
|
#
|
||||||
|
# $ac_aux_dir/missing
|
||||||
|
# fails when called from a subdirectory if $ac_aux_dir is relative
|
||||||
|
# $top_srcdir/$ac_aux_dir/missing
|
||||||
|
# fails if $ac_aux_dir is absolute,
|
||||||
|
# fails when called from a subdirectory in a VPATH build with
|
||||||
|
# a relative $ac_aux_dir
|
||||||
|
#
|
||||||
|
# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
|
||||||
|
# are both prefixed by $srcdir. In an in-source build this is usually
|
||||||
|
# harmless because $srcdir is `.', but things will broke when you
|
||||||
|
# start a VPATH build or use an absolute $srcdir.
|
||||||
|
#
|
||||||
|
# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
|
||||||
|
# iff we strip the leading $srcdir from $ac_aux_dir. That would be:
|
||||||
|
# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
|
||||||
|
# and then we would define $MISSING as
|
||||||
|
# MISSING="\${SHELL} $am_aux_dir/missing"
|
||||||
|
# This will work as long as MISSING is not called from configure, because
|
||||||
|
# unfortunately $(top_srcdir) has no meaning in configure.
|
||||||
|
# However there are other variables, like CC, which are often used in
|
||||||
|
# configure, and could therefore not use this "fixed" $ac_aux_dir.
|
||||||
|
#
|
||||||
|
# Another solution, used here, is to always expand $ac_aux_dir to an
|
||||||
|
# absolute PATH. The drawback is that using absolute paths prevent a
|
||||||
|
# configured tree to be moved without reconfiguration.
|
||||||
|
|
||||||
|
AC_DEFUN([AM_AUX_DIR_EXPAND],
|
||||||
|
[dnl Rely on autoconf to set up CDPATH properly.
|
||||||
|
AC_PREREQ([2.50])dnl
|
||||||
|
# expand $ac_aux_dir to an absolute path
|
||||||
|
am_aux_dir=`cd $ac_aux_dir && pwd`
|
||||||
|
])
|
||||||
|
|
||||||
|
# AM_CONDITIONAL -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005, 2006, 2008
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 9
|
||||||
|
|
||||||
|
# AM_CONDITIONAL(NAME, SHELL-CONDITION)
|
||||||
|
# -------------------------------------
|
||||||
|
# Define a conditional.
|
||||||
|
AC_DEFUN([AM_CONDITIONAL],
|
||||||
|
[AC_PREREQ(2.52)dnl
|
||||||
|
ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])],
|
||||||
|
[$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
|
||||||
|
AC_SUBST([$1_TRUE])dnl
|
||||||
|
AC_SUBST([$1_FALSE])dnl
|
||||||
|
_AM_SUBST_NOTMAKE([$1_TRUE])dnl
|
||||||
|
_AM_SUBST_NOTMAKE([$1_FALSE])dnl
|
||||||
|
m4_define([_AM_COND_VALUE_$1], [$2])dnl
|
||||||
|
if $2; then
|
||||||
|
$1_TRUE=
|
||||||
|
$1_FALSE='#'
|
||||||
|
else
|
||||||
|
$1_TRUE='#'
|
||||||
|
$1_FALSE=
|
||||||
|
fi
|
||||||
|
AC_CONFIG_COMMANDS_PRE(
|
||||||
|
[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
|
||||||
|
AC_MSG_ERROR([[conditional "$1" was never defined.
|
||||||
|
Usually this means the macro was only invoked conditionally.]])
|
||||||
|
fi])])
|
||||||
|
|
||||||
|
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 10
|
||||||
|
|
||||||
|
# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
|
||||||
|
# written in clear, in which case automake, when reading aclocal.m4,
|
||||||
|
# will think it sees a *use*, and therefore will trigger all it's
|
||||||
|
# C support machinery. Also note that it means that autoscan, seeing
|
||||||
|
# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
|
||||||
|
|
||||||
|
|
||||||
|
# _AM_DEPENDENCIES(NAME)
|
||||||
|
# ----------------------
|
||||||
|
# See how the compiler implements dependency checking.
|
||||||
|
# NAME is "CC", "CXX", "GCJ", or "OBJC".
|
||||||
|
# We try a few techniques and use that to set a single cache variable.
|
||||||
|
#
|
||||||
|
# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
|
||||||
|
# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
|
||||||
|
# dependency, and given that the user is not expected to run this macro,
|
||||||
|
# just rely on AC_PROG_CC.
|
||||||
|
AC_DEFUN([_AM_DEPENDENCIES],
|
||||||
|
[AC_REQUIRE([AM_SET_DEPDIR])dnl
|
||||||
|
AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
|
||||||
|
AC_REQUIRE([AM_MAKE_INCLUDE])dnl
|
||||||
|
AC_REQUIRE([AM_DEP_TRACK])dnl
|
||||||
|
|
||||||
|
ifelse([$1], CC, [depcc="$CC" am_compiler_list=],
|
||||||
|
[$1], CXX, [depcc="$CXX" am_compiler_list=],
|
||||||
|
[$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
|
||||||
|
[$1], UPC, [depcc="$UPC" am_compiler_list=],
|
||||||
|
[$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'],
|
||||||
|
[depcc="$$1" am_compiler_list=])
|
||||||
|
|
||||||
|
AC_CACHE_CHECK([dependency style of $depcc],
|
||||||
|
[am_cv_$1_dependencies_compiler_type],
|
||||||
|
[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
|
||||||
|
# We make a subdir and do the tests there. Otherwise we can end up
|
||||||
|
# making bogus files that we don't know about and never remove. For
|
||||||
|
# instance it was reported that on HP-UX the gcc test will end up
|
||||||
|
# making a dummy file named `D' -- because `-MD' means `put the output
|
||||||
|
# in D'.
|
||||||
|
mkdir conftest.dir
|
||||||
|
# Copy depcomp to subdir because otherwise we won't find it if we're
|
||||||
|
# using a relative directory.
|
||||||
|
cp "$am_depcomp" conftest.dir
|
||||||
|
cd conftest.dir
|
||||||
|
# We will build objects and dependencies in a subdirectory because
|
||||||
|
# it helps to detect inapplicable dependency modes. For instance
|
||||||
|
# both Tru64's cc and ICC support -MD to output dependencies as a
|
||||||
|
# side effect of compilation, but ICC will put the dependencies in
|
||||||
|
# the current directory while Tru64 will put them in the object
|
||||||
|
# directory.
|
||||||
|
mkdir sub
|
||||||
|
|
||||||
|
am_cv_$1_dependencies_compiler_type=none
|
||||||
|
if test "$am_compiler_list" = ""; then
|
||||||
|
am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
|
||||||
|
fi
|
||||||
|
am__universal=false
|
||||||
|
m4_case([$1], [CC],
|
||||||
|
[case " $depcc " in #(
|
||||||
|
*\ -arch\ *\ -arch\ *) am__universal=true ;;
|
||||||
|
esac],
|
||||||
|
[CXX],
|
||||||
|
[case " $depcc " in #(
|
||||||
|
*\ -arch\ *\ -arch\ *) am__universal=true ;;
|
||||||
|
esac])
|
||||||
|
|
||||||
|
for depmode in $am_compiler_list; do
|
||||||
|
# Setup a source with many dependencies, because some compilers
|
||||||
|
# like to wrap large dependency lists on column 80 (with \), and
|
||||||
|
# we should not choose a depcomp mode which is confused by this.
|
||||||
|
#
|
||||||
|
# We need to recreate these files for each test, as the compiler may
|
||||||
|
# overwrite some of them when testing with obscure command lines.
|
||||||
|
# This happens at least with the AIX C compiler.
|
||||||
|
: > sub/conftest.c
|
||||||
|
for i in 1 2 3 4 5 6; do
|
||||||
|
echo '#include "conftst'$i'.h"' >> sub/conftest.c
|
||||||
|
# Using `: > sub/conftst$i.h' creates only sub/conftst1.h with
|
||||||
|
# Solaris 8's {/usr,}/bin/sh.
|
||||||
|
touch sub/conftst$i.h
|
||||||
|
done
|
||||||
|
echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
|
||||||
|
|
||||||
|
# We check with `-c' and `-o' for the sake of the "dashmstdout"
|
||||||
|
# mode. It turns out that the SunPro C++ compiler does not properly
|
||||||
|
# handle `-M -o', and we need to detect this. Also, some Intel
|
||||||
|
# versions had trouble with output in subdirs
|
||||||
|
am__obj=sub/conftest.${OBJEXT-o}
|
||||||
|
am__minus_obj="-o $am__obj"
|
||||||
|
case $depmode in
|
||||||
|
gcc)
|
||||||
|
# This depmode causes a compiler race in universal mode.
|
||||||
|
test "$am__universal" = false || continue
|
||||||
|
;;
|
||||||
|
nosideeffect)
|
||||||
|
# after this tag, mechanisms are not by side-effect, so they'll
|
||||||
|
# only be used when explicitly requested
|
||||||
|
if test "x$enable_dependency_tracking" = xyes; then
|
||||||
|
continue
|
||||||
|
else
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
msvisualcpp | msvcmsys)
|
||||||
|
# This compiler won't grok `-c -o', but also, the minuso test has
|
||||||
|
# not run yet. These depmodes are late enough in the game, and
|
||||||
|
# so weak that their functioning should not be impacted.
|
||||||
|
am__obj=conftest.${OBJEXT-o}
|
||||||
|
am__minus_obj=
|
||||||
|
;;
|
||||||
|
none) break ;;
|
||||||
|
esac
|
||||||
|
if depmode=$depmode \
|
||||||
|
source=sub/conftest.c object=$am__obj \
|
||||||
|
depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
|
||||||
|
$SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \
|
||||||
|
>/dev/null 2>conftest.err &&
|
||||||
|
grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 &&
|
||||||
|
grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
|
||||||
|
grep $am__obj sub/conftest.Po > /dev/null 2>&1 &&
|
||||||
|
${MAKE-make} -s -f confmf > /dev/null 2>&1; then
|
||||||
|
# icc doesn't choke on unknown options, it will just issue warnings
|
||||||
|
# or remarks (even with -Werror). So we grep stderr for any message
|
||||||
|
# that says an option was ignored or not supported.
|
||||||
|
# When given -MP, icc 7.0 and 7.1 complain thusly:
|
||||||
|
# icc: Command line warning: ignoring option '-M'; no argument required
|
||||||
|
# The diagnosis changed in icc 8.0:
|
||||||
|
# icc: Command line remark: option '-MP' not supported
|
||||||
|
if (grep 'ignoring option' conftest.err ||
|
||||||
|
grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
|
||||||
|
am_cv_$1_dependencies_compiler_type=$depmode
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
rm -rf conftest.dir
|
||||||
|
else
|
||||||
|
am_cv_$1_dependencies_compiler_type=none
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
|
||||||
|
AM_CONDITIONAL([am__fastdep$1], [
|
||||||
|
test "x$enable_dependency_tracking" != xno \
|
||||||
|
&& test "$am_cv_$1_dependencies_compiler_type" = gcc3])
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
# AM_SET_DEPDIR
|
||||||
|
# -------------
|
||||||
|
# Choose a directory name for dependency files.
|
||||||
|
# This macro is AC_REQUIREd in _AM_DEPENDENCIES
|
||||||
|
AC_DEFUN([AM_SET_DEPDIR],
|
||||||
|
[AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
||||||
|
AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
# AM_DEP_TRACK
|
||||||
|
# ------------
|
||||||
|
AC_DEFUN([AM_DEP_TRACK],
|
||||||
|
[AC_ARG_ENABLE(dependency-tracking,
|
||||||
|
[ --disable-dependency-tracking speeds up one-time build
|
||||||
|
--enable-dependency-tracking do not reject slow dependency extractors])
|
||||||
|
if test "x$enable_dependency_tracking" != xno; then
|
||||||
|
am_depcomp="$ac_aux_dir/depcomp"
|
||||||
|
AMDEPBACKSLASH='\'
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
|
||||||
|
AC_SUBST([AMDEPBACKSLASH])dnl
|
||||||
|
_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
# Generate code to set up dependency tracking. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2008
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
#serial 5
|
||||||
|
|
||||||
|
# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||||
|
# ------------------------------
|
||||||
|
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||||
|
[{
|
||||||
|
# Autoconf 2.62 quotes --file arguments for eval, but not when files
|
||||||
|
# are listed without --file. Let's play safe and only enable the eval
|
||||||
|
# if we detect the quoting.
|
||||||
|
case $CONFIG_FILES in
|
||||||
|
*\'*) eval set x "$CONFIG_FILES" ;;
|
||||||
|
*) set x $CONFIG_FILES ;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
for mf
|
||||||
|
do
|
||||||
|
# Strip MF so we end up with the name of the file.
|
||||||
|
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
||||||
|
# Check whether this is an Automake generated Makefile or not.
|
||||||
|
# We used to match only the files named `Makefile.in', but
|
||||||
|
# some people rename them; so instead we look at the file content.
|
||||||
|
# Grep'ing the first line is not enough: some people post-process
|
||||||
|
# each Makefile.in and add a new line on top of each file to say so.
|
||||||
|
# Grep'ing the whole file is not good either: AIX grep has a line
|
||||||
|
# limit of 2048, but all sed's we know have understand at least 4000.
|
||||||
|
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
||||||
|
dirpart=`AS_DIRNAME("$mf")`
|
||||||
|
else
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
# Extract the definition of DEPDIR, am__include, and am__quote
|
||||||
|
# from the Makefile without running `make'.
|
||||||
|
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
||||||
|
test -z "$DEPDIR" && continue
|
||||||
|
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
||||||
|
test -z "am__include" && continue
|
||||||
|
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
||||||
|
# When using ansi2knr, U may be empty or an underscore; expand it
|
||||||
|
U=`sed -n 's/^U = //p' < "$mf"`
|
||||||
|
# Find all dependency output files, they are included files with
|
||||||
|
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
||||||
|
# simplest approach to changing $(DEPDIR) to its actual value in the
|
||||||
|
# expansion.
|
||||||
|
for file in `sed -n "
|
||||||
|
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
||||||
|
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
|
||||||
|
# Make sure the directory exists.
|
||||||
|
test -f "$dirpart/$file" && continue
|
||||||
|
fdir=`AS_DIRNAME(["$file"])`
|
||||||
|
AS_MKDIR_P([$dirpart/$fdir])
|
||||||
|
# echo "creating $dirpart/$file"
|
||||||
|
echo '# dummy' > "$dirpart/$file"
|
||||||
|
done
|
||||||
|
done
|
||||||
|
}
|
||||||
|
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||||
|
|
||||||
|
|
||||||
|
# AM_OUTPUT_DEPENDENCY_COMMANDS
|
||||||
|
# -----------------------------
|
||||||
|
# This macro should only be invoked once -- use via AC_REQUIRE.
|
||||||
|
#
|
||||||
|
# This code is only required when automatic dependency tracking
|
||||||
|
# is enabled. FIXME. This creates each `.P' file that we will
|
||||||
|
# need in order to bootstrap the dependency handling code.
|
||||||
|
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||||
|
[AC_CONFIG_COMMANDS([depfiles],
|
||||||
|
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
|
||||||
|
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
|
||||||
|
])
|
||||||
|
|
||||||
|
# Do all the work for Automake. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
||||||
|
# 2005, 2006, 2008, 2009 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 16
|
||||||
|
|
||||||
|
# This macro actually does too much. Some checks are only needed if
|
||||||
|
# your package does certain things. But this isn't really a big deal.
|
||||||
|
|
||||||
|
# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
|
||||||
|
# AM_INIT_AUTOMAKE([OPTIONS])
|
||||||
|
# -----------------------------------------------
|
||||||
|
# The call with PACKAGE and VERSION arguments is the old style
|
||||||
|
# call (pre autoconf-2.50), which is being phased out. PACKAGE
|
||||||
|
# and VERSION should now be passed to AC_INIT and removed from
|
||||||
|
# the call to AM_INIT_AUTOMAKE.
|
||||||
|
# We support both call styles for the transition. After
|
||||||
|
# the next Automake release, Autoconf can make the AC_INIT
|
||||||
|
# arguments mandatory, and then we can depend on a new Autoconf
|
||||||
|
# release and drop the old call support.
|
||||||
|
AC_DEFUN([AM_INIT_AUTOMAKE],
|
||||||
|
[AC_PREREQ([2.62])dnl
|
||||||
|
dnl Autoconf wants to disallow AM_ names. We explicitly allow
|
||||||
|
dnl the ones we care about.
|
||||||
|
m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
|
||||||
|
AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
|
||||||
|
AC_REQUIRE([AC_PROG_INSTALL])dnl
|
||||||
|
if test "`cd $srcdir && pwd`" != "`pwd`"; then
|
||||||
|
# Use -I$(srcdir) only when $(srcdir) != ., so that make's output
|
||||||
|
# is not polluted with repeated "-I."
|
||||||
|
AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl
|
||||||
|
# test to see if srcdir already configured
|
||||||
|
if test -f $srcdir/config.status; then
|
||||||
|
AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# test whether we have cygpath
|
||||||
|
if test -z "$CYGPATH_W"; then
|
||||||
|
if (cygpath --version) >/dev/null 2>/dev/null; then
|
||||||
|
CYGPATH_W='cygpath -w'
|
||||||
|
else
|
||||||
|
CYGPATH_W=echo
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
AC_SUBST([CYGPATH_W])
|
||||||
|
|
||||||
|
# Define the identity of the package.
|
||||||
|
dnl Distinguish between old-style and new-style calls.
|
||||||
|
m4_ifval([$2],
|
||||||
|
[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
|
||||||
|
AC_SUBST([PACKAGE], [$1])dnl
|
||||||
|
AC_SUBST([VERSION], [$2])],
|
||||||
|
[_AM_SET_OPTIONS([$1])dnl
|
||||||
|
dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT.
|
||||||
|
m4_if(m4_ifdef([AC_PACKAGE_NAME], 1)m4_ifdef([AC_PACKAGE_VERSION], 1), 11,,
|
||||||
|
[m4_fatal([AC_INIT should be called with package and version arguments])])dnl
|
||||||
|
AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl
|
||||||
|
AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl
|
||||||
|
|
||||||
|
_AM_IF_OPTION([no-define],,
|
||||||
|
[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
|
||||||
|
AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl
|
||||||
|
|
||||||
|
# Some tools Automake needs.
|
||||||
|
AC_REQUIRE([AM_SANITY_CHECK])dnl
|
||||||
|
AC_REQUIRE([AC_ARG_PROGRAM])dnl
|
||||||
|
AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version})
|
||||||
|
AM_MISSING_PROG(AUTOCONF, autoconf)
|
||||||
|
AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version})
|
||||||
|
AM_MISSING_PROG(AUTOHEADER, autoheader)
|
||||||
|
AM_MISSING_PROG(MAKEINFO, makeinfo)
|
||||||
|
AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
|
||||||
|
AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
|
||||||
|
AC_REQUIRE([AM_PROG_MKDIR_P])dnl
|
||||||
|
# We need awk for the "check" target. The system "awk" is bad on
|
||||||
|
# some platforms.
|
||||||
|
AC_REQUIRE([AC_PROG_AWK])dnl
|
||||||
|
AC_REQUIRE([AC_PROG_MAKE_SET])dnl
|
||||||
|
AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
||||||
|
_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])],
|
||||||
|
[_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])],
|
||||||
|
[_AM_PROG_TAR([v7])])])
|
||||||
|
_AM_IF_OPTION([no-dependencies],,
|
||||||
|
[AC_PROVIDE_IFELSE([AC_PROG_CC],
|
||||||
|
[_AM_DEPENDENCIES(CC)],
|
||||||
|
[define([AC_PROG_CC],
|
||||||
|
defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl
|
||||||
|
AC_PROVIDE_IFELSE([AC_PROG_CXX],
|
||||||
|
[_AM_DEPENDENCIES(CXX)],
|
||||||
|
[define([AC_PROG_CXX],
|
||||||
|
defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl
|
||||||
|
AC_PROVIDE_IFELSE([AC_PROG_OBJC],
|
||||||
|
[_AM_DEPENDENCIES(OBJC)],
|
||||||
|
[define([AC_PROG_OBJC],
|
||||||
|
defn([AC_PROG_OBJC])[_AM_DEPENDENCIES(OBJC)])])dnl
|
||||||
|
])
|
||||||
|
_AM_IF_OPTION([silent-rules], [AC_REQUIRE([AM_SILENT_RULES])])dnl
|
||||||
|
dnl The `parallel-tests' driver may need to know about EXEEXT, so add the
|
||||||
|
dnl `am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This macro
|
||||||
|
dnl is hooked onto _AC_COMPILER_EXEEXT early, see below.
|
||||||
|
AC_CONFIG_COMMANDS_PRE(dnl
|
||||||
|
[m4_provide_if([_AM_COMPILER_EXEEXT],
|
||||||
|
[AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl Hook into `_AC_COMPILER_EXEEXT' early to learn its expansion. Do not
|
||||||
|
dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further
|
||||||
|
dnl mangled by Autoconf and run in a shell conditional statement.
|
||||||
|
m4_define([_AC_COMPILER_EXEEXT],
|
||||||
|
m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])])
|
||||||
|
|
||||||
|
|
||||||
|
# When config.status generates a header, we must update the stamp-h file.
|
||||||
|
# This file resides in the same directory as the config header
|
||||||
|
# that is generated. The stamp files are numbered to have different names.
|
||||||
|
|
||||||
|
# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the
|
||||||
|
# loop where config.status creates the headers, so we can generate
|
||||||
|
# our stamp files there.
|
||||||
|
AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK],
|
||||||
|
[# Compute $1's index in $config_headers.
|
||||||
|
_am_arg=$1
|
||||||
|
_am_stamp_count=1
|
||||||
|
for _am_header in $config_headers :; do
|
||||||
|
case $_am_header in
|
||||||
|
$_am_arg | $_am_arg:* )
|
||||||
|
break ;;
|
||||||
|
* )
|
||||||
|
_am_stamp_count=`expr $_am_stamp_count + 1` ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
|
||||||
|
|
||||||
|
# Copyright (C) 2001, 2003, 2005, 2008 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# AM_PROG_INSTALL_SH
|
||||||
|
# ------------------
|
||||||
|
# Define $install_sh.
|
||||||
|
AC_DEFUN([AM_PROG_INSTALL_SH],
|
||||||
|
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
||||||
|
if test x"${install_sh}" != xset; then
|
||||||
|
case $am_aux_dir in
|
||||||
|
*\ * | *\ *)
|
||||||
|
install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;;
|
||||||
|
*)
|
||||||
|
install_sh="\${SHELL} $am_aux_dir/install-sh"
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
AC_SUBST(install_sh)])
|
||||||
|
|
||||||
|
# Copyright (C) 2003, 2005 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 2
|
||||||
|
|
||||||
|
# Check whether the underlying file-system supports filenames
|
||||||
|
# with a leading dot. For instance MS-DOS doesn't.
|
||||||
|
AC_DEFUN([AM_SET_LEADING_DOT],
|
||||||
|
[rm -rf .tst 2>/dev/null
|
||||||
|
mkdir .tst 2>/dev/null
|
||||||
|
if test -d .tst; then
|
||||||
|
am__leading_dot=.
|
||||||
|
else
|
||||||
|
am__leading_dot=_
|
||||||
|
fi
|
||||||
|
rmdir .tst 2>/dev/null
|
||||||
|
AC_SUBST([am__leading_dot])])
|
||||||
|
|
||||||
|
# Add --enable-maintainer-mode option to configure. -*- Autoconf -*-
|
||||||
|
# From Jim Meyering
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1998, 2000, 2001, 2002, 2003, 2004, 2005, 2008
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 5
|
||||||
|
|
||||||
|
# AM_MAINTAINER_MODE([DEFAULT-MODE])
|
||||||
|
# ----------------------------------
|
||||||
|
# Control maintainer-specific portions of Makefiles.
|
||||||
|
# Default is to disable them, unless `enable' is passed literally.
|
||||||
|
# For symmetry, `disable' may be passed as well. Anyway, the user
|
||||||
|
# can override the default with the --enable/--disable switch.
|
||||||
|
AC_DEFUN([AM_MAINTAINER_MODE],
|
||||||
|
[m4_case(m4_default([$1], [disable]),
|
||||||
|
[enable], [m4_define([am_maintainer_other], [disable])],
|
||||||
|
[disable], [m4_define([am_maintainer_other], [enable])],
|
||||||
|
[m4_define([am_maintainer_other], [enable])
|
||||||
|
m4_warn([syntax], [unexpected argument to AM@&t@_MAINTAINER_MODE: $1])])
|
||||||
|
AC_MSG_CHECKING([whether to am_maintainer_other maintainer-specific portions of Makefiles])
|
||||||
|
dnl maintainer-mode's default is 'disable' unless 'enable' is passed
|
||||||
|
AC_ARG_ENABLE([maintainer-mode],
|
||||||
|
[ --][am_maintainer_other][-maintainer-mode am_maintainer_other make rules and dependencies not useful
|
||||||
|
(and sometimes confusing) to the casual installer],
|
||||||
|
[USE_MAINTAINER_MODE=$enableval],
|
||||||
|
[USE_MAINTAINER_MODE=]m4_if(am_maintainer_other, [enable], [no], [yes]))
|
||||||
|
AC_MSG_RESULT([$USE_MAINTAINER_MODE])
|
||||||
|
AM_CONDITIONAL([MAINTAINER_MODE], [test $USE_MAINTAINER_MODE = yes])
|
||||||
|
MAINT=$MAINTAINER_MODE_TRUE
|
||||||
|
AC_SUBST([MAINT])dnl
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
AU_DEFUN([jm_MAINTAINER_MODE], [AM_MAINTAINER_MODE])
|
||||||
|
|
||||||
|
# Check to see how 'make' treats includes. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 2001, 2002, 2003, 2005, 2009 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 4
|
||||||
|
|
||||||
|
# AM_MAKE_INCLUDE()
|
||||||
|
# -----------------
|
||||||
|
# Check to see how make treats includes.
|
||||||
|
AC_DEFUN([AM_MAKE_INCLUDE],
|
||||||
|
[am_make=${MAKE-make}
|
||||||
|
cat > confinc << 'END'
|
||||||
|
am__doit:
|
||||||
|
@echo this is the am__doit target
|
||||||
|
.PHONY: am__doit
|
||||||
|
END
|
||||||
|
# If we don't find an include directive, just comment out the code.
|
||||||
|
AC_MSG_CHECKING([for style of include used by $am_make])
|
||||||
|
am__include="#"
|
||||||
|
am__quote=
|
||||||
|
_am_result=none
|
||||||
|
# First try GNU make style include.
|
||||||
|
echo "include confinc" > confmf
|
||||||
|
# Ignore all kinds of additional output from `make'.
|
||||||
|
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||||
|
*the\ am__doit\ target*)
|
||||||
|
am__include=include
|
||||||
|
am__quote=
|
||||||
|
_am_result=GNU
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
# Now try BSD make style include.
|
||||||
|
if test "$am__include" = "#"; then
|
||||||
|
echo '.include "confinc"' > confmf
|
||||||
|
case `$am_make -s -f confmf 2> /dev/null` in #(
|
||||||
|
*the\ am__doit\ target*)
|
||||||
|
am__include=.include
|
||||||
|
am__quote="\""
|
||||||
|
_am_result=BSD
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
AC_SUBST([am__include])
|
||||||
|
AC_SUBST([am__quote])
|
||||||
|
AC_MSG_RESULT([$_am_result])
|
||||||
|
rm -f confinc confmf
|
||||||
|
])
|
||||||
|
|
||||||
|
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2004, 2005, 2008
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 6
|
||||||
|
|
||||||
|
# AM_MISSING_PROG(NAME, PROGRAM)
|
||||||
|
# ------------------------------
|
||||||
|
AC_DEFUN([AM_MISSING_PROG],
|
||||||
|
[AC_REQUIRE([AM_MISSING_HAS_RUN])
|
||||||
|
$1=${$1-"${am_missing_run}$2"}
|
||||||
|
AC_SUBST($1)])
|
||||||
|
|
||||||
|
|
||||||
|
# AM_MISSING_HAS_RUN
|
||||||
|
# ------------------
|
||||||
|
# Define MISSING if not defined so far and test if it supports --run.
|
||||||
|
# If it does, set am_missing_run to use it, otherwise, to nothing.
|
||||||
|
AC_DEFUN([AM_MISSING_HAS_RUN],
|
||||||
|
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
||||||
|
AC_REQUIRE_AUX_FILE([missing])dnl
|
||||||
|
if test x"${MISSING+set}" != xset; then
|
||||||
|
case $am_aux_dir in
|
||||||
|
*\ * | *\ *)
|
||||||
|
MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;;
|
||||||
|
*)
|
||||||
|
MISSING="\${SHELL} $am_aux_dir/missing" ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
# Use eval to expand $SHELL
|
||||||
|
if eval "$MISSING --run true"; then
|
||||||
|
am_missing_run="$MISSING --run "
|
||||||
|
else
|
||||||
|
am_missing_run=
|
||||||
|
AC_MSG_WARN([`missing' script is too old or missing])
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
# Copyright (C) 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# AM_PROG_MKDIR_P
|
||||||
|
# ---------------
|
||||||
|
# Check for `mkdir -p'.
|
||||||
|
AC_DEFUN([AM_PROG_MKDIR_P],
|
||||||
|
[AC_PREREQ([2.60])dnl
|
||||||
|
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
|
||||||
|
dnl Automake 1.8 to 1.9.6 used to define mkdir_p. We now use MKDIR_P,
|
||||||
|
dnl while keeping a definition of mkdir_p for backward compatibility.
|
||||||
|
dnl @MKDIR_P@ is magic: AC_OUTPUT adjusts its value for each Makefile.
|
||||||
|
dnl However we cannot define mkdir_p as $(MKDIR_P) for the sake of
|
||||||
|
dnl Makefile.ins that do not define MKDIR_P, so we do our own
|
||||||
|
dnl adjustment using top_builddir (which is defined more often than
|
||||||
|
dnl MKDIR_P).
|
||||||
|
AC_SUBST([mkdir_p], ["$MKDIR_P"])dnl
|
||||||
|
case $mkdir_p in
|
||||||
|
[[\\/$]]* | ?:[[\\/]]*) ;;
|
||||||
|
*/*) mkdir_p="\$(top_builddir)/$mkdir_p" ;;
|
||||||
|
esac
|
||||||
|
])
|
||||||
|
|
||||||
|
# Helper functions for option handling. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 2001, 2002, 2003, 2005, 2008 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 4
|
||||||
|
|
||||||
|
# _AM_MANGLE_OPTION(NAME)
|
||||||
|
# -----------------------
|
||||||
|
AC_DEFUN([_AM_MANGLE_OPTION],
|
||||||
|
[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
|
||||||
|
|
||||||
|
# _AM_SET_OPTION(NAME)
|
||||||
|
# ------------------------------
|
||||||
|
# Set option NAME. Presently that only means defining a flag for this option.
|
||||||
|
AC_DEFUN([_AM_SET_OPTION],
|
||||||
|
[m4_define(_AM_MANGLE_OPTION([$1]), 1)])
|
||||||
|
|
||||||
|
# _AM_SET_OPTIONS(OPTIONS)
|
||||||
|
# ----------------------------------
|
||||||
|
# OPTIONS is a space-separated list of Automake options.
|
||||||
|
AC_DEFUN([_AM_SET_OPTIONS],
|
||||||
|
[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
|
||||||
|
|
||||||
|
# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
|
||||||
|
# -------------------------------------------
|
||||||
|
# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
|
||||||
|
AC_DEFUN([_AM_IF_OPTION],
|
||||||
|
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
|
||||||
|
|
||||||
|
# Check to make sure that the build environment is sane. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005, 2008
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 5
|
||||||
|
|
||||||
|
# AM_SANITY_CHECK
|
||||||
|
# ---------------
|
||||||
|
AC_DEFUN([AM_SANITY_CHECK],
|
||||||
|
[AC_MSG_CHECKING([whether build environment is sane])
|
||||||
|
# Just in case
|
||||||
|
sleep 1
|
||||||
|
echo timestamp > conftest.file
|
||||||
|
# Reject unsafe characters in $srcdir or the absolute working directory
|
||||||
|
# name. Accept space and tab only in the latter.
|
||||||
|
am_lf='
|
||||||
|
'
|
||||||
|
case `pwd` in
|
||||||
|
*[[\\\"\#\$\&\'\`$am_lf]]*)
|
||||||
|
AC_MSG_ERROR([unsafe absolute working directory name]);;
|
||||||
|
esac
|
||||||
|
case $srcdir in
|
||||||
|
*[[\\\"\#\$\&\'\`$am_lf\ \ ]]*)
|
||||||
|
AC_MSG_ERROR([unsafe srcdir value: `$srcdir']);;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Do `set' in a subshell so we don't clobber the current shell's
|
||||||
|
# arguments. Must try -L first in case configure is actually a
|
||||||
|
# symlink; some systems play weird games with the mod time of symlinks
|
||||||
|
# (eg FreeBSD returns the mod time of the symlink's containing
|
||||||
|
# directory).
|
||||||
|
if (
|
||||||
|
set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null`
|
||||||
|
if test "$[*]" = "X"; then
|
||||||
|
# -L didn't work.
|
||||||
|
set X `ls -t "$srcdir/configure" conftest.file`
|
||||||
|
fi
|
||||||
|
rm -f conftest.file
|
||||||
|
if test "$[*]" != "X $srcdir/configure conftest.file" \
|
||||||
|
&& test "$[*]" != "X conftest.file $srcdir/configure"; then
|
||||||
|
|
||||||
|
# If neither matched, then we have a broken ls. This can happen
|
||||||
|
# if, for instance, CONFIG_SHELL is bash and it inherits a
|
||||||
|
# broken ls alias from the environment. This has actually
|
||||||
|
# happened. Such a system could not be considered "sane".
|
||||||
|
AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
|
||||||
|
alias in your environment])
|
||||||
|
fi
|
||||||
|
|
||||||
|
test "$[2]" = conftest.file
|
||||||
|
)
|
||||||
|
then
|
||||||
|
# Ok.
|
||||||
|
:
|
||||||
|
else
|
||||||
|
AC_MSG_ERROR([newly created file is older than distributed files!
|
||||||
|
Check your system clock])
|
||||||
|
fi
|
||||||
|
AC_MSG_RESULT(yes)])
|
||||||
|
|
||||||
|
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# AM_PROG_INSTALL_STRIP
|
||||||
|
# ---------------------
|
||||||
|
# One issue with vendor `install' (even GNU) is that you can't
|
||||||
|
# specify the program used to strip binaries. This is especially
|
||||||
|
# annoying in cross-compiling environments, where the build's strip
|
||||||
|
# is unlikely to handle the host's binaries.
|
||||||
|
# Fortunately install-sh will honor a STRIPPROG variable, so we
|
||||||
|
# always use install-sh in `make install-strip', and initialize
|
||||||
|
# STRIPPROG with the value of the STRIP variable (set by the user).
|
||||||
|
AC_DEFUN([AM_PROG_INSTALL_STRIP],
|
||||||
|
[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
|
||||||
|
# Installed binaries are usually stripped using `strip' when the user
|
||||||
|
# run `make install-strip'. However `strip' might not be the right
|
||||||
|
# tool to use in cross-compilation environments, therefore Automake
|
||||||
|
# will honor the `STRIP' environment variable to overrule this program.
|
||||||
|
dnl Don't test for $cross_compiling = yes, because it might be `maybe'.
|
||||||
|
if test "$cross_compiling" != no; then
|
||||||
|
AC_CHECK_TOOL([STRIP], [strip], :)
|
||||||
|
fi
|
||||||
|
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
|
||||||
|
AC_SUBST([INSTALL_STRIP_PROGRAM])])
|
||||||
|
|
||||||
|
# Copyright (C) 2006, 2008 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 2
|
||||||
|
|
||||||
|
# _AM_SUBST_NOTMAKE(VARIABLE)
|
||||||
|
# ---------------------------
|
||||||
|
# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in.
|
||||||
|
# This macro is traced by Automake.
|
||||||
|
AC_DEFUN([_AM_SUBST_NOTMAKE])
|
||||||
|
|
||||||
|
# AM_SUBST_NOTMAKE(VARIABLE)
|
||||||
|
# ---------------------------
|
||||||
|
# Public sister of _AM_SUBST_NOTMAKE.
|
||||||
|
AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
|
||||||
|
|
||||||
|
# Check how to create a tarball. -*- Autoconf -*-
|
||||||
|
|
||||||
|
# Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 2
|
||||||
|
|
||||||
|
# _AM_PROG_TAR(FORMAT)
|
||||||
|
# --------------------
|
||||||
|
# Check how to create a tarball in format FORMAT.
|
||||||
|
# FORMAT should be one of `v7', `ustar', or `pax'.
|
||||||
|
#
|
||||||
|
# Substitute a variable $(am__tar) that is a command
|
||||||
|
# writing to stdout a FORMAT-tarball containing the directory
|
||||||
|
# $tardir.
|
||||||
|
# tardir=directory && $(am__tar) > result.tar
|
||||||
|
#
|
||||||
|
# Substitute a variable $(am__untar) that extract such
|
||||||
|
# a tarball read from stdin.
|
||||||
|
# $(am__untar) < result.tar
|
||||||
|
AC_DEFUN([_AM_PROG_TAR],
|
||||||
|
[# Always define AMTAR for backward compatibility.
|
||||||
|
AM_MISSING_PROG([AMTAR], [tar])
|
||||||
|
m4_if([$1], [v7],
|
||||||
|
[am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'],
|
||||||
|
[m4_case([$1], [ustar],, [pax],,
|
||||||
|
[m4_fatal([Unknown tar format])])
|
||||||
|
AC_MSG_CHECKING([how to create a $1 tar archive])
|
||||||
|
# Loop over all known methods to create a tar archive until one works.
|
||||||
|
_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none'
|
||||||
|
_am_tools=${am_cv_prog_tar_$1-$_am_tools}
|
||||||
|
# Do not fold the above two line into one, because Tru64 sh and
|
||||||
|
# Solaris sh will not grok spaces in the rhs of `-'.
|
||||||
|
for _am_tool in $_am_tools
|
||||||
|
do
|
||||||
|
case $_am_tool in
|
||||||
|
gnutar)
|
||||||
|
for _am_tar in tar gnutar gtar;
|
||||||
|
do
|
||||||
|
AM_RUN_LOG([$_am_tar --version]) && break
|
||||||
|
done
|
||||||
|
am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"'
|
||||||
|
am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"'
|
||||||
|
am__untar="$_am_tar -xf -"
|
||||||
|
;;
|
||||||
|
plaintar)
|
||||||
|
# Must skip GNU tar: if it does not support --format= it doesn't create
|
||||||
|
# ustar tarball either.
|
||||||
|
(tar --version) >/dev/null 2>&1 && continue
|
||||||
|
am__tar='tar chf - "$$tardir"'
|
||||||
|
am__tar_='tar chf - "$tardir"'
|
||||||
|
am__untar='tar xf -'
|
||||||
|
;;
|
||||||
|
pax)
|
||||||
|
am__tar='pax -L -x $1 -w "$$tardir"'
|
||||||
|
am__tar_='pax -L -x $1 -w "$tardir"'
|
||||||
|
am__untar='pax -r'
|
||||||
|
;;
|
||||||
|
cpio)
|
||||||
|
am__tar='find "$$tardir" -print | cpio -o -H $1 -L'
|
||||||
|
am__tar_='find "$tardir" -print | cpio -o -H $1 -L'
|
||||||
|
am__untar='cpio -i -H $1 -d'
|
||||||
|
;;
|
||||||
|
none)
|
||||||
|
am__tar=false
|
||||||
|
am__tar_=false
|
||||||
|
am__untar=false
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# If the value was cached, stop now. We just wanted to have am__tar
|
||||||
|
# and am__untar set.
|
||||||
|
test -n "${am_cv_prog_tar_$1}" && break
|
||||||
|
|
||||||
|
# tar/untar a dummy directory, and stop if the command works
|
||||||
|
rm -rf conftest.dir
|
||||||
|
mkdir conftest.dir
|
||||||
|
echo GrepMe > conftest.dir/file
|
||||||
|
AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar])
|
||||||
|
rm -rf conftest.dir
|
||||||
|
if test -s conftest.tar; then
|
||||||
|
AM_RUN_LOG([$am__untar <conftest.tar])
|
||||||
|
grep GrepMe conftest.dir/file >/dev/null 2>&1 && break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
rm -rf conftest.dir
|
||||||
|
|
||||||
|
AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool])
|
||||||
|
AC_MSG_RESULT([$am_cv_prog_tar_$1])])
|
||||||
|
AC_SUBST([am__tar])
|
||||||
|
AC_SUBST([am__untar])
|
||||||
|
]) # _AM_PROG_TAR
|
||||||
|
|
||||||
|
m4_include([../../../acinclude.m4])
|
|
@ -0,0 +1,64 @@
|
||||||
|
#ifndef ARC_NEWLIB_ASM_H
|
||||||
|
#define ARC_NEWLIB_ASM_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#define _ENTRY(name) \
|
||||||
|
.text ` .balign 4 ` .globl name ` name:
|
||||||
|
#define FUNC(name) .type name,@function
|
||||||
|
#define ENDFUNC0(name) .Lfe_##name: .size name,.Lfe_##name-name
|
||||||
|
#define ENDFUNC(name) ENDFUNC0 (name)
|
||||||
|
#define ENTRY(name) _ENTRY (name) ` FUNC (name)
|
||||||
|
|
||||||
|
#define add_l add
|
||||||
|
#define bcc_l bcc
|
||||||
|
#define bclr_l bclr
|
||||||
|
#define beq_l beq
|
||||||
|
#define bic_l bic
|
||||||
|
#define b_l b
|
||||||
|
#define bne_l bne
|
||||||
|
#define breq_l breq
|
||||||
|
#define brne_l brne
|
||||||
|
#define j_l j
|
||||||
|
#define ldb_l ldb
|
||||||
|
#define ld_l ld
|
||||||
|
#define mov_l mov
|
||||||
|
#define or_l or
|
||||||
|
#define st_l st
|
||||||
|
#define stb_l stb
|
||||||
|
#define sub_l sub
|
||||||
|
#define tst_l tst
|
||||||
|
#define extb_l extb
|
||||||
|
|
||||||
|
#define bcc_s bhs_s
|
||||||
|
|
||||||
|
#endif /* ARC_NEWLIB_ASM_H */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,13 @@
|
||||||
|
dnl This is the newlib/libc/machine/arc configure.in file.
|
||||||
|
dnl Process this file with autoconf to produce a configure script.
|
||||||
|
|
||||||
|
AC_PREREQ(2.59)
|
||||||
|
AC_INIT([newlib],[NEWLIB_VERSION])
|
||||||
|
AC_CONFIG_SRCDIR([Makefile.am])
|
||||||
|
|
||||||
|
dnl Can't be done in NEWLIB_CONFIGURE because that confuses automake.
|
||||||
|
AC_CONFIG_AUX_DIR(../../../..)
|
||||||
|
|
||||||
|
NEWLIB_CONFIGURE(../../..)
|
||||||
|
|
||||||
|
AC_OUTPUT(Makefile)
|
|
@ -0,0 +1,223 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memcmp.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if !defined (__ARC601__) && defined (__ARC_NORM__) && defined (__Xbarrel_shifter)
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
#define WORD2 r2
|
||||||
|
#define SHIFT r3
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
#define WORD2 r3
|
||||||
|
#define SHIFT r2
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ENTRY (memcmp)
|
||||||
|
or r12,r0,r1
|
||||||
|
asl_s r12,r12,30
|
||||||
|
#if defined (__ARC700__) || defined (__EM__) || defined (__HS__)
|
||||||
|
sub_l r3,r2,1
|
||||||
|
brls r2,r12,.Lbytewise
|
||||||
|
#else
|
||||||
|
brls.d r2,r12,.Lbytewise
|
||||||
|
sub_s r3,r2,1
|
||||||
|
#endif
|
||||||
|
ld r4,[r0,0]
|
||||||
|
ld r5,[r1,0]
|
||||||
|
lsr.f lp_count,r3,3
|
||||||
|
#ifdef __EM__
|
||||||
|
/* A branch can't be the last instruction in a zero overhead loop.
|
||||||
|
So we move the branch to the start of the loop, duplicate it
|
||||||
|
after the end, and set up r12 so that the branch isn't taken
|
||||||
|
initially. */
|
||||||
|
mov_s r12,WORD2
|
||||||
|
lpne .Loop_end
|
||||||
|
brne WORD2,r12,.Lodd
|
||||||
|
ld WORD2,[r0,4]
|
||||||
|
#else
|
||||||
|
lpne .Loop_end
|
||||||
|
ld_s WORD2,[r0,4]
|
||||||
|
#endif
|
||||||
|
ld_s r12,[r1,4]
|
||||||
|
brne r4,r5,.Leven
|
||||||
|
ld.a r4,[r0,8]
|
||||||
|
ld.a r5,[r1,8]
|
||||||
|
#ifdef __EM__
|
||||||
|
.Loop_end:
|
||||||
|
brne WORD2,r12,.Lodd
|
||||||
|
#else
|
||||||
|
brne WORD2,r12,.Lodd
|
||||||
|
#ifdef __HS__
|
||||||
|
nop
|
||||||
|
#endif
|
||||||
|
.Loop_end:
|
||||||
|
#endif
|
||||||
|
asl_s SHIFT,SHIFT,3
|
||||||
|
bcc_s .Last_cmp
|
||||||
|
brne r4,r5,.Leven
|
||||||
|
ld r4,[r0,4]
|
||||||
|
ld r5,[r1,4]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
#if defined (__ARC700__) || defined (__EM__) || defined (__HS__)
|
||||||
|
nop_s
|
||||||
|
; one more load latency cycle
|
||||||
|
.Last_cmp:
|
||||||
|
xor r0,r4,r5
|
||||||
|
bset r0,r0,SHIFT
|
||||||
|
sub_s r1,r0,1
|
||||||
|
bic_s r1,r1,r0
|
||||||
|
norm r1,r1
|
||||||
|
b.d .Leven_cmp
|
||||||
|
and r1,r1,24
|
||||||
|
.Leven:
|
||||||
|
xor r0,r4,r5
|
||||||
|
sub_s r1,r0,1
|
||||||
|
bic_s r1,r1,r0
|
||||||
|
norm r1,r1
|
||||||
|
; slow track insn
|
||||||
|
and r1,r1,24
|
||||||
|
.Leven_cmp:
|
||||||
|
asl r2,r4,r1
|
||||||
|
asl r12,r5,r1
|
||||||
|
lsr_s r2,r2,1
|
||||||
|
lsr_s r12,r12,1
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r2,r12
|
||||||
|
.balign 4
|
||||||
|
.Lodd:
|
||||||
|
xor r0,WORD2,r12
|
||||||
|
sub_s r1,r0,1
|
||||||
|
bic_s r1,r1,r0
|
||||||
|
norm r1,r1
|
||||||
|
; slow track insn
|
||||||
|
and r1,r1,24
|
||||||
|
asl_s r2,r2,r1
|
||||||
|
asl_s r12,r12,r1
|
||||||
|
lsr_s r2,r2,1
|
||||||
|
lsr_s r12,r12,1
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r2,r12
|
||||||
|
#else /* !__ARC700__ */
|
||||||
|
.balign 4
|
||||||
|
.Last_cmp:
|
||||||
|
xor r0,r4,r5
|
||||||
|
b.d .Leven_cmp
|
||||||
|
bset r0,r0,SHIFT
|
||||||
|
.Lodd:
|
||||||
|
mov_s r4,WORD2
|
||||||
|
mov_s r5,r12
|
||||||
|
.Leven:
|
||||||
|
xor r0,r4,r5
|
||||||
|
.Leven_cmp:
|
||||||
|
mov_s r1,0x80808080
|
||||||
|
; uses long immediate
|
||||||
|
sub_s r12,r0,1
|
||||||
|
bic_s r0,r0,r12
|
||||||
|
sub r0,r1,r0
|
||||||
|
xor_s r0,r0,r1
|
||||||
|
and r1,r5,r0
|
||||||
|
and r0,r4,r0
|
||||||
|
xor.f 0,r0,r1
|
||||||
|
sub_s r0,r0,r1
|
||||||
|
j_s.d [blink]
|
||||||
|
mov.mi r0,r1
|
||||||
|
#endif /* !__ARC700__ */
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
.Last_cmp:
|
||||||
|
neg_s SHIFT,SHIFT
|
||||||
|
lsr r4,r4,SHIFT
|
||||||
|
lsr r5,r5,SHIFT
|
||||||
|
; slow track insn
|
||||||
|
.Leven:
|
||||||
|
sub.f r0,r4,r5
|
||||||
|
mov.ne r0,1
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.cs r0,r0,31
|
||||||
|
.Lodd:
|
||||||
|
cmp_s WORD2,r12
|
||||||
|
#if defined (__ARC700__) || defined (__EM__) || defined (__HS__)
|
||||||
|
mov_s r0,1
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.cs r0,r0,31
|
||||||
|
#else /* !__ARC700__ */
|
||||||
|
j_s.d [blink]
|
||||||
|
rrc r0,2
|
||||||
|
#endif /* !__ARC700__ */
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
.balign 4
|
||||||
|
.Lbytewise:
|
||||||
|
breq r2,0,.Lnil
|
||||||
|
ldb r4,[r0,0]
|
||||||
|
ldb r5,[r1,0]
|
||||||
|
lsr.f lp_count,r3
|
||||||
|
#ifdef __EM__
|
||||||
|
mov r12,r3
|
||||||
|
lpne .Lbyte_end
|
||||||
|
brne r3,r12,.Lbyte_odd
|
||||||
|
#else
|
||||||
|
lpne .Lbyte_end
|
||||||
|
#endif
|
||||||
|
ldb_s r3,[r0,1]
|
||||||
|
ldb_l r12,[r1,1]
|
||||||
|
brne r4,r5,.Lbyte_even
|
||||||
|
ldb.a r4,[r0,2]
|
||||||
|
ldb.a r5,[r1,2]
|
||||||
|
#ifdef __EM__
|
||||||
|
.Lbyte_end:
|
||||||
|
brne r3,r12,.Lbyte_odd
|
||||||
|
#else
|
||||||
|
brne r3,r12,.Lbyte_odd
|
||||||
|
#ifdef __HS__
|
||||||
|
nop
|
||||||
|
#endif
|
||||||
|
.Lbyte_end:
|
||||||
|
#endif
|
||||||
|
bcc_l .Lbyte_even
|
||||||
|
brne r4,r5,.Lbyte_even
|
||||||
|
ldb_s r3,[r0,1]
|
||||||
|
ldb_s r12,[r1,1]
|
||||||
|
.Lbyte_odd:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r3,r12
|
||||||
|
.Lbyte_even:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r4,r5
|
||||||
|
.Lnil:
|
||||||
|
j_s.d [blink]
|
||||||
|
mov_l r0,0
|
||||||
|
ENDFUNC (memcmp)
|
||||||
|
#endif /* !__ARC601__ && __ARC_NORM__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/memcmp.c"
|
||||||
|
#else
|
||||||
|
/* See memcmp-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,153 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memcmp.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || !defined (__ARC_NORM__) || !defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
/* Addresses are unsigned, and at 0 is the vector table, so it's OK to assume
|
||||||
|
that we can subtract 8 from a source end address without underflow. */
|
||||||
|
|
||||||
|
ENTRY (memcmp)
|
||||||
|
or r12,r0,r1
|
||||||
|
tst r12,3
|
||||||
|
breq r2,0,.Lnil
|
||||||
|
add_s r3,r0,r2
|
||||||
|
|
||||||
|
/* This algorithm for big endian targets sometimes works incorrectly
|
||||||
|
when sources are aligned. To be precise the last step is omitted.
|
||||||
|
Just use a simple bytewise variant until the algorithm is reviewed
|
||||||
|
and fixed. */
|
||||||
|
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
bne_s .Lbytewise
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
b_s .Lbytewise
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
sub r6,r3,8
|
||||||
|
ld r4,[r0,0]
|
||||||
|
ld r5,[r1,0]
|
||||||
|
2:
|
||||||
|
brhs r0,r6,.Loop_end
|
||||||
|
ld_s r3,[r0,4]
|
||||||
|
ld_s r12,[r1,4]
|
||||||
|
brne r4,r5,.Leven
|
||||||
|
ld.a r4,[r0,8]
|
||||||
|
breq.d r3,r12,2b
|
||||||
|
ld.a r5,[r1,8]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
mov_s r4,r3
|
||||||
|
b.d .Lodd
|
||||||
|
mov_s r5,r12
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
cmp_s r3,r12
|
||||||
|
j_s.d [blink]
|
||||||
|
rrc r0,2
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Loop_end:
|
||||||
|
sub r3,r0,r6
|
||||||
|
brhs r3,4,.Last_cmp
|
||||||
|
brne r4,r5,.Leven
|
||||||
|
ld r4,[r0,4]
|
||||||
|
ld r5,[r1,4]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
.balign 4
|
||||||
|
.Last_cmp:
|
||||||
|
mov_l r0,24
|
||||||
|
add3 r2,r0,r2
|
||||||
|
xor r0,r4,r5
|
||||||
|
b.d .Leven_cmp
|
||||||
|
bset r0,r0,r2
|
||||||
|
.Lodd:
|
||||||
|
.Leven:
|
||||||
|
xor r0,r4,r5
|
||||||
|
.Leven_cmp:
|
||||||
|
mov_s r1,0x80808080
|
||||||
|
; uses long immediate
|
||||||
|
sub_s r12,r0,1
|
||||||
|
bic_s r0,r0,r12
|
||||||
|
sub r0,r1,r0
|
||||||
|
xor_s r0,r0,r1
|
||||||
|
and r1,r5,r0
|
||||||
|
and r0,r4,r0
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
.Last_cmp:
|
||||||
|
mov_s r3,0
|
||||||
|
sub3 r2,r3,r2
|
||||||
|
sub_s r3,r3,1
|
||||||
|
bclr r3,r3,r2
|
||||||
|
add_l r3,r3,1
|
||||||
|
and r0,r4,r3
|
||||||
|
and r1,r5,r3
|
||||||
|
.Leven:
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
xor.f 0,r0,r1
|
||||||
|
sub_s r0,r0,r1
|
||||||
|
j_s.d [blink]
|
||||||
|
mov.mi r0,r1
|
||||||
|
.balign 4
|
||||||
|
.Lbytewise:
|
||||||
|
ldb r4,[r0,0]
|
||||||
|
ldb r5,[r1,0]
|
||||||
|
sub r6,r3,2
|
||||||
|
3:
|
||||||
|
brhs r0,r6,.Lbyte_end
|
||||||
|
ldb_s r3,[r0,1]
|
||||||
|
ldb_s r12,[r1,1]
|
||||||
|
brne r4,r5,.Lbyte_even
|
||||||
|
ldb.a r4,[r0,2]
|
||||||
|
breq.d r3,r12,3b
|
||||||
|
ldb.a r5,[r1,2]
|
||||||
|
.Lbyte_odd:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r3,r12
|
||||||
|
.balign 4
|
||||||
|
.Lbyte_end:
|
||||||
|
bbit1 r2,0,.Lbyte_even
|
||||||
|
brne r4,r5,.Lbyte_even
|
||||||
|
ldb r4,[r0,1]
|
||||||
|
ldb r5,[r1,1]
|
||||||
|
.Lbyte_even:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r4,r5
|
||||||
|
.Lnil:
|
||||||
|
j_s.d [blink]
|
||||||
|
mov_s r0,0
|
||||||
|
ENDFUNC (memcmp)
|
||||||
|
#endif /* __ARC601__ || !__ARC_NORM__ || !__Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,268 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__HS__)
|
||||||
|
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
# define SHIFT_1(RX,RY,IMM) asl RX, RY, IMM ; <<
|
||||||
|
# define SHIFT_2(RX,RY,IMM) lsr RX, RY, IMM ; >>
|
||||||
|
# define MERGE_1(RX,RY,IMM) asl RX, RY, IMM
|
||||||
|
# define MERGE_2(RX,RY,IMM)
|
||||||
|
# define EXTRACT_1(RX,RY,IMM) and RX, RY, 0xFFFF
|
||||||
|
# define EXTRACT_2(RX,RY,IMM) lsr RX, RY, IMM
|
||||||
|
#else
|
||||||
|
# define SHIFT_1(RX,RY,IMM) lsr RX, RY, IMM ; >>
|
||||||
|
# define SHIFT_2(RX,RY,IMM) asl RX, RY, IMM ; <<
|
||||||
|
# define MERGE_1(RX,RY,IMM) asl RX, RY, IMM ; <<
|
||||||
|
# define MERGE_2(RX,RY,IMM) asl RX, RY, IMM ; <<
|
||||||
|
# define EXTRACT_1(RX,RY,IMM) lsr RX, RY, IMM
|
||||||
|
# define EXTRACT_2(RX,RY,IMM) lsr RX, RY, 0x08
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __LL64__
|
||||||
|
# define PREFETCH_READ(RX) prefetch [RX, 56]
|
||||||
|
# define PREFETCH_WRITE(RX) prefetchw [RX, 64]
|
||||||
|
# define LOADX(DST,RX) ldd.ab DST, [RX, 8]
|
||||||
|
# define STOREX(SRC,RX) std.ab SRC, [RX, 8]
|
||||||
|
# define ZOLSHFT 5
|
||||||
|
# define ZOLAND 0x1F
|
||||||
|
#else
|
||||||
|
# define PREFETCH_READ(RX) prefetch [RX, 28]
|
||||||
|
# define PREFETCH_WRITE(RX) prefetchw [RX, 32]
|
||||||
|
# define LOADX(DST,RX) ld.ab DST, [RX, 4]
|
||||||
|
# define STOREX(SRC,RX) st.ab SRC, [RX, 4]
|
||||||
|
# define ZOLSHFT 4
|
||||||
|
# define ZOLAND 0xF
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ENTRY (memcpy)
|
||||||
|
prefetch [r1] ; Prefetch the read location
|
||||||
|
prefetchw [r0] ; Prefetch the write location
|
||||||
|
mov.f 0, r2
|
||||||
|
; if size is zero
|
||||||
|
jz.d [blink]
|
||||||
|
mov r3, r0 ; don't clobber ret val
|
||||||
|
|
||||||
|
; if size <= 8
|
||||||
|
cmp r2, 8
|
||||||
|
bls.d @.Lsmallchunk
|
||||||
|
mov.f lp_count, r2
|
||||||
|
|
||||||
|
and.f r4, r0, 0x03
|
||||||
|
rsub lp_count, r4, 4
|
||||||
|
lpnz @.Laligndestination
|
||||||
|
; LOOP BEGIN
|
||||||
|
ldb.ab r5, [r1,1]
|
||||||
|
sub r2, r2, 1
|
||||||
|
stb.ab r5, [r3,1]
|
||||||
|
.Laligndestination:
|
||||||
|
|
||||||
|
; Check the alignment of the source
|
||||||
|
and.f r4, r1, 0x03
|
||||||
|
bnz.d @.Lsourceunaligned
|
||||||
|
|
||||||
|
; CASE 0: Both source and destination are 32bit aligned
|
||||||
|
; Convert len to Dwords, unfold x4
|
||||||
|
lsr.f lp_count, r2, ZOLSHFT
|
||||||
|
lpnz @.Lcopy32_64bytes
|
||||||
|
; LOOP START
|
||||||
|
LOADX (r6, r1)
|
||||||
|
PREFETCH_READ (r1)
|
||||||
|
PREFETCH_WRITE (r3)
|
||||||
|
LOADX (r8, r1)
|
||||||
|
LOADX (r10, r1)
|
||||||
|
LOADX (r4, r1)
|
||||||
|
STOREX (r6, r3)
|
||||||
|
STOREX (r8, r3)
|
||||||
|
STOREX (r10, r3)
|
||||||
|
STOREX (r4, r3)
|
||||||
|
.Lcopy32_64bytes:
|
||||||
|
|
||||||
|
and.f lp_count, r2, ZOLAND ;Last remaining 31 bytes
|
||||||
|
.Lsmallchunk:
|
||||||
|
lpnz @.Lcopyremainingbytes
|
||||||
|
; LOOP START
|
||||||
|
ldb.ab r5, [r1,1]
|
||||||
|
stb.ab r5, [r3,1]
|
||||||
|
.Lcopyremainingbytes:
|
||||||
|
|
||||||
|
j [blink]
|
||||||
|
; END CASE 0
|
||||||
|
|
||||||
|
.Lsourceunaligned:
|
||||||
|
cmp r4, 2
|
||||||
|
beq.d @.LunalignedOffby2
|
||||||
|
sub r2, r2, 1
|
||||||
|
|
||||||
|
bhi.d @.LunalignedOffby3
|
||||||
|
ldb.ab r5, [r1, 1]
|
||||||
|
|
||||||
|
; CASE 1: The source is unaligned, off by 1
|
||||||
|
; Hence I need to read 1 byte for a 16bit alignment
|
||||||
|
; and 2bytes to reach 32bit alignment
|
||||||
|
ldh.ab r6, [r1, 2]
|
||||||
|
sub r2, r2, 2
|
||||||
|
; Convert to words, unfold x2
|
||||||
|
lsr.f lp_count, r2, 3
|
||||||
|
MERGE_1 (r6, r6, 8)
|
||||||
|
MERGE_2 (r5, r5, 24)
|
||||||
|
or r5, r5, r6
|
||||||
|
|
||||||
|
; Both src and dst are aligned
|
||||||
|
lpnz @.Lcopy8bytes_1
|
||||||
|
; LOOP START
|
||||||
|
ld.ab r6, [r1, 4]
|
||||||
|
prefetch [r1, 28] ;Prefetch the next read location
|
||||||
|
ld.ab r8, [r1,4]
|
||||||
|
prefetchw [r3, 32] ;Prefetch the next write location
|
||||||
|
|
||||||
|
SHIFT_1 (r7, r6, 24)
|
||||||
|
or r7, r7, r5
|
||||||
|
SHIFT_2 (r5, r6, 8)
|
||||||
|
|
||||||
|
SHIFT_1 (r9, r8, 24)
|
||||||
|
or r9, r9, r5
|
||||||
|
SHIFT_2 (r5, r8, 8)
|
||||||
|
|
||||||
|
st.ab r7, [r3, 4]
|
||||||
|
st.ab r9, [r3, 4]
|
||||||
|
.Lcopy8bytes_1:
|
||||||
|
|
||||||
|
; Write back the remaining 16bits
|
||||||
|
EXTRACT_1 (r6, r5, 16)
|
||||||
|
sth.ab r6, [r3, 2]
|
||||||
|
; Write back the remaining 8bits
|
||||||
|
EXTRACT_2 (r5, r5, 16)
|
||||||
|
stb.ab r5, [r3, 1]
|
||||||
|
|
||||||
|
and.f lp_count, r2, 0x07 ;Last 8bytes
|
||||||
|
lpnz @.Lcopybytewise_1
|
||||||
|
; LOOP START
|
||||||
|
ldb.ab r6, [r1,1]
|
||||||
|
stb.ab r6, [r3,1]
|
||||||
|
.Lcopybytewise_1:
|
||||||
|
j [blink]
|
||||||
|
|
||||||
|
.LunalignedOffby2:
|
||||||
|
; CASE 2: The source is unaligned, off by 2
|
||||||
|
ldh.ab r5, [r1, 2]
|
||||||
|
sub r2, r2, 1
|
||||||
|
|
||||||
|
; Both src and dst are aligned
|
||||||
|
; Convert to words, unfold x2
|
||||||
|
lsr.f lp_count, r2, 3
|
||||||
|
#ifdef __BIG_ENDIAN__
|
||||||
|
asl.nz r5, r5, 16
|
||||||
|
#endif
|
||||||
|
lpnz @.Lcopy8bytes_2
|
||||||
|
; LOOP START
|
||||||
|
ld.ab r6, [r1, 4]
|
||||||
|
prefetch [r1, 28] ;Prefetch the next read location
|
||||||
|
ld.ab r8, [r1,4]
|
||||||
|
prefetchw [r3, 32] ;Prefetch the next write location
|
||||||
|
|
||||||
|
SHIFT_1 (r7, r6, 16)
|
||||||
|
or r7, r7, r5
|
||||||
|
SHIFT_2 (r5, r6, 16)
|
||||||
|
|
||||||
|
SHIFT_1 (r9, r8, 16)
|
||||||
|
or r9, r9, r5
|
||||||
|
SHIFT_2 (r5, r8, 16)
|
||||||
|
|
||||||
|
st.ab r7, [r3, 4]
|
||||||
|
st.ab r9, [r3, 4]
|
||||||
|
.Lcopy8bytes_2:
|
||||||
|
|
||||||
|
#ifdef __BIG_ENDIAN__
|
||||||
|
lsr.nz r5, r5, 16
|
||||||
|
#endif
|
||||||
|
sth.ab r5, [r3, 2]
|
||||||
|
|
||||||
|
and.f lp_count, r2, 0x07 ;Last 8bytes
|
||||||
|
lpnz @.Lcopybytewise_2
|
||||||
|
; LOOP START
|
||||||
|
ldb.ab r6, [r1,1]
|
||||||
|
stb.ab r6, [r3,1]
|
||||||
|
.Lcopybytewise_2:
|
||||||
|
j [blink]
|
||||||
|
|
||||||
|
.LunalignedOffby3:
|
||||||
|
; CASE 3: The source is unaligned, off by 3
|
||||||
|
; Hence, I need to read 1byte for achieve the 32bit alignment
|
||||||
|
|
||||||
|
; Both src and dst are aligned
|
||||||
|
; Convert to words, unfold x2
|
||||||
|
lsr.f lp_count, r2, 3
|
||||||
|
#ifdef __BIG_ENDIAN__
|
||||||
|
asl.ne r5, r5, 24
|
||||||
|
#endif
|
||||||
|
lpnz @.Lcopy8bytes_3
|
||||||
|
; LOOP START
|
||||||
|
ld.ab r6, [r1, 4]
|
||||||
|
prefetch [r1, 28] ;Prefetch the next read location
|
||||||
|
ld.ab r8, [r1,4]
|
||||||
|
prefetchw [r3, 32] ;Prefetch the next write location
|
||||||
|
|
||||||
|
SHIFT_1 (r7, r6, 8)
|
||||||
|
or r7, r7, r5
|
||||||
|
SHIFT_2 (r5, r6, 24)
|
||||||
|
|
||||||
|
SHIFT_1 (r9, r8, 8)
|
||||||
|
or r9, r9, r5
|
||||||
|
SHIFT_2 (r5, r8, 24)
|
||||||
|
|
||||||
|
st.ab r7, [r3, 4]
|
||||||
|
st.ab r9, [r3, 4]
|
||||||
|
.Lcopy8bytes_3:
|
||||||
|
|
||||||
|
#ifdef __BIG_ENDIAN__
|
||||||
|
lsr.nz r5, r5, 24
|
||||||
|
#endif
|
||||||
|
stb.ab r5, [r3, 1]
|
||||||
|
|
||||||
|
and.f lp_count, r2, 0x07 ;Last 8bytes
|
||||||
|
lpnz @.Lcopybytewise_3
|
||||||
|
; LOOP START
|
||||||
|
ldb.ab r6, [r1,1]
|
||||||
|
stb.ab r6, [r3,1]
|
||||||
|
.Lcopybytewise_3:
|
||||||
|
j [blink]
|
||||||
|
|
||||||
|
ENDFUNC (memcpy)
|
||||||
|
#endif /* __HS__ */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,103 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if !defined (__ARC601__) && !defined (__HS__) && defined (__Xbarrel_shifter)
|
||||||
|
/* Mostly optimized for ARC700, but not bad for ARC600 either. */
|
||||||
|
/* This memcpy implementation does not support objects of 1GB or larger -
|
||||||
|
the check for alignment does not work then. */
|
||||||
|
/* We assume that most sources and destinations are aligned, and
|
||||||
|
that also lengths are mostly a multiple of four, although to a lesser
|
||||||
|
extent. */
|
||||||
|
ENTRY (memcpy)
|
||||||
|
or r3,r0,r1
|
||||||
|
asl_s r3,r3,30
|
||||||
|
mov_s r5,r0
|
||||||
|
brls.d r2,r3,.Lcopy_bytewise
|
||||||
|
sub.f r3,r2,1
|
||||||
|
ld_s r12,[r1,0]
|
||||||
|
asr.f lp_count,r3,3
|
||||||
|
bbit0.d r3,2,.Lnox4
|
||||||
|
bmsk_s r2,r2,1
|
||||||
|
st.ab r12,[r5,4]
|
||||||
|
ld.a r12,[r1,4]
|
||||||
|
.Lnox4:
|
||||||
|
lppnz .Lendloop
|
||||||
|
ld_s r3,[r1,4]
|
||||||
|
st.ab r12,[r5,4]
|
||||||
|
ld.a r12,[r1,8]
|
||||||
|
st.ab r3,[r5,4]
|
||||||
|
.Lendloop:
|
||||||
|
breq_l r2,0,.Last_store
|
||||||
|
ld r3,[r5,0]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
add3 r2,-1,r2
|
||||||
|
; uses long immediate
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
bmsk r12,r12,r2
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
sub3 r2,31,r2
|
||||||
|
; uses long immediate
|
||||||
|
xor_s r3,r3,r12
|
||||||
|
bmsk r3,r3,r2
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
.Last_store:
|
||||||
|
j_s.d [blink]
|
||||||
|
st r12,[r5,0]
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lcopy_bytewise:
|
||||||
|
jcs [blink]
|
||||||
|
ldb_s r12,[r1,0]
|
||||||
|
lsr.f lp_count,r3
|
||||||
|
bcc_s .Lnox1
|
||||||
|
stb.ab r12,[r5,1]
|
||||||
|
ldb.a r12,[r1,1]
|
||||||
|
.Lnox1:
|
||||||
|
lppnz .Lendbloop
|
||||||
|
ldb_s r3,[r1,1]
|
||||||
|
stb.ab r12,[r5,1]
|
||||||
|
ldb.a r12,[r1,2]
|
||||||
|
stb.ab r3,[r5,1]
|
||||||
|
.Lendbloop:
|
||||||
|
j_s.d [blink]
|
||||||
|
stb r12,[r5,0]
|
||||||
|
ENDFUNC (memcpy)
|
||||||
|
#endif /* !__ARC601__ && !__HS__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/memcpy.c"
|
||||||
|
#else
|
||||||
|
/* See memcpy-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,109 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || (!defined (__Xbarrel_shifter) && !defined (__HS__))
|
||||||
|
/* Adapted from memcpy-bs.S. */
|
||||||
|
/* We assume that most sources and destinations are aligned, and
|
||||||
|
that also lengths are mostly a multiple of four, although to a lesser
|
||||||
|
extent. */
|
||||||
|
ENTRY (memcpy)
|
||||||
|
or r3,r0,r1
|
||||||
|
bmsk.f 0,r3,1
|
||||||
|
breq_s r2,0,.Lnil
|
||||||
|
mov_s r5,r0
|
||||||
|
bne.d .Lcopy_bytewise
|
||||||
|
add r6,r0,r2
|
||||||
|
sub_s r3,r2,1
|
||||||
|
ld_s r12,[r1,0]
|
||||||
|
bbit0.d r3,2,.Lnox4
|
||||||
|
sub r6,r6,8
|
||||||
|
st.ab r12,[r5,4]
|
||||||
|
ld.a r12,[r1,4]
|
||||||
|
.Lnox4:
|
||||||
|
brlo r2,9,.Lendloop
|
||||||
|
.Lnox4a:
|
||||||
|
ld_s r3,[r1,4]
|
||||||
|
st.ab r12,[r5,8]
|
||||||
|
ld.a r12,[r1,8]
|
||||||
|
brlo.d r5,r6,.Lnox4a
|
||||||
|
st r3,[r5,-4]
|
||||||
|
.Lendloop:
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
ld r3,[r5,0]
|
||||||
|
add3 r2,-1,r2
|
||||||
|
; uses long immediate
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
bmsk r12,r12,r2
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
bmsk_s r2,r2,1
|
||||||
|
breq_s r2,0,.Last_store
|
||||||
|
ld r3,[r5,0]
|
||||||
|
sub3 r2,31,r2
|
||||||
|
; uses long immediate
|
||||||
|
xor_s r3,r3,r12
|
||||||
|
bmsk r3,r3,r2
|
||||||
|
xor_s r12,r12,r3
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
.Last_store:
|
||||||
|
j_s.d [blink]
|
||||||
|
st r12,[r5,0]
|
||||||
|
|
||||||
|
.Lnil:
|
||||||
|
j_s [blink]
|
||||||
|
.balign 4
|
||||||
|
.Lcopy_bytewise:
|
||||||
|
ldb_s r12,[r1,0]
|
||||||
|
bbit1.d r2,0,.Lnox1
|
||||||
|
sub r6,r6,2
|
||||||
|
stb.ab r12,[r5,1]
|
||||||
|
ldb.a r12,[r1,1]
|
||||||
|
.Lnox1:
|
||||||
|
brlo r2,3,.Lendbloop
|
||||||
|
.Lnox1a:
|
||||||
|
ldb_s r3,[r1,1]
|
||||||
|
stb.ab r12,[r5,2]
|
||||||
|
ldb.a r12,[r1,2]
|
||||||
|
brlo.d r5,r6,.Lnox1a
|
||||||
|
stb r3,[r5,-1]
|
||||||
|
.Lendbloop:
|
||||||
|
j_s.d [blink]
|
||||||
|
stb r12,[r5,0]
|
||||||
|
ENDFUNC (memcpy)
|
||||||
|
#endif /* __ARC601__ || (!__Xbarrel_shifter && !__HS__) */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,146 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memset.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#ifdef __HS__
|
||||||
|
|
||||||
|
#ifdef USE_PREFETCH
|
||||||
|
#define PREWRITE(A,B) prefetchw [(A),(B)]
|
||||||
|
#else
|
||||||
|
#define PREWRITE(A,B) prealloc [(A),(B)]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ENTRY (memset)
|
||||||
|
prefetchw [r0] ; Prefetch the write location
|
||||||
|
mov.f 0, r2
|
||||||
|
; if size is zero
|
||||||
|
jz.d [blink]
|
||||||
|
mov r3, r0 ; don't clobber ret val
|
||||||
|
|
||||||
|
; if length < 8
|
||||||
|
brls.d.nt r2, 8, .Lsmallchunk
|
||||||
|
mov.f lp_count,r2
|
||||||
|
|
||||||
|
and.f r4, r0, 0x03
|
||||||
|
rsub lp_count, r4, 4
|
||||||
|
lpnz @.Laligndestination
|
||||||
|
; LOOP BEGIN
|
||||||
|
stb.ab r1, [r3,1]
|
||||||
|
sub r2, r2, 1
|
||||||
|
.Laligndestination:
|
||||||
|
|
||||||
|
; Destination is aligned
|
||||||
|
and r1, r1, 0xFF
|
||||||
|
asl r4, r1, 8
|
||||||
|
or r4, r4, r1
|
||||||
|
asl r5, r4, 16
|
||||||
|
or r5, r5, r4
|
||||||
|
mov r4, r5
|
||||||
|
|
||||||
|
sub3 lp_count, r2, 8
|
||||||
|
cmp r2, 64
|
||||||
|
bmsk.hi r2, r2, 5
|
||||||
|
mov.ls lp_count, 0
|
||||||
|
add3.hi r2, r2, 8
|
||||||
|
|
||||||
|
; Convert len to Dwords, unfold x8
|
||||||
|
lsr.f lp_count, lp_count, 6
|
||||||
|
lpnz @.Lset64bytes
|
||||||
|
; LOOP START
|
||||||
|
PREWRITE (r3, 64) ;Prefetch the next write location
|
||||||
|
#ifdef __LL64__
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
#else
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
#endif
|
||||||
|
.Lset64bytes:
|
||||||
|
|
||||||
|
lsr.f lp_count, r2, 5 ;Last remaining max 124 bytes
|
||||||
|
lpnz .Lset32bytes
|
||||||
|
; LOOP START
|
||||||
|
prefetchw [r3, 32] ;Prefetch the next write location
|
||||||
|
#ifdef __LL64__
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
std.ab r4, [r3, 8]
|
||||||
|
#else
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
st.ab r4, [r3, 4]
|
||||||
|
#endif
|
||||||
|
.Lset32bytes:
|
||||||
|
|
||||||
|
and.f lp_count, r2, 0x1F ;Last remaining 31 bytes
|
||||||
|
.Lsmallchunk:
|
||||||
|
lpnz .Lcopy3bytes
|
||||||
|
; LOOP START
|
||||||
|
stb.ab r1, [r3, 1]
|
||||||
|
.Lcopy3bytes:
|
||||||
|
|
||||||
|
j [blink]
|
||||||
|
|
||||||
|
ENDFUNC (memset)
|
||||||
|
#endif /* __HS__ */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,154 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memset.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* ARC HS has it's own implementation of memset, yet we want this function
|
||||||
|
still to be compiled under "__dummy_memset" disguise, because strncpy
|
||||||
|
function uses __strncpy_bzero as a second entry point into memset. Would be
|
||||||
|
better to add __strncpy_bzero label to memset for ARC HS though, and even
|
||||||
|
better would be to avoid a second entry point into function. ARC HS always
|
||||||
|
has barrel-shifter, so this implementation will be always used for this
|
||||||
|
purpose. */
|
||||||
|
#if !defined (__ARC601__) && defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
/* To deal with alignment/loop issues, SMALL must be at least 2. */
|
||||||
|
#define SMALL 7
|
||||||
|
|
||||||
|
.global __strncpy_bzero
|
||||||
|
.hidden __strncpy_bzero
|
||||||
|
/* __strncpy_bzero provides the following interface to strncpy:
|
||||||
|
r0: return value
|
||||||
|
r2: zeroing length
|
||||||
|
r3: zeroing start address
|
||||||
|
No attempt is made here for __strncpy_memset to speed up aligned
|
||||||
|
cases, because the copying of a string presumably leaves start address
|
||||||
|
and length alignment for the zeroing randomly distributed. */
|
||||||
|
|
||||||
|
#ifdef __HS__
|
||||||
|
ENTRY (__dummy_memset)
|
||||||
|
#else
|
||||||
|
ENTRY (memset)
|
||||||
|
#endif
|
||||||
|
#if !defined (__ARC700__) && !defined (__EM__)
|
||||||
|
#undef SMALL
|
||||||
|
#define SMALL 8 /* Even faster if aligned. */
|
||||||
|
brls.d r2,SMALL,.Ltiny
|
||||||
|
#endif
|
||||||
|
mov_s r3,r0
|
||||||
|
or r12,r0,r2
|
||||||
|
bmsk.f r12,r12,1
|
||||||
|
extb_s r1,r1
|
||||||
|
asl r12,r1,8
|
||||||
|
beq.d .Laligned
|
||||||
|
or_s r1,r1,r12
|
||||||
|
#if defined (__ARC700__) || defined (__EM__)
|
||||||
|
brls r2,SMALL,.Ltiny
|
||||||
|
#endif
|
||||||
|
.Lnot_tiny:
|
||||||
|
add_s r12,r2,r0
|
||||||
|
stb r1,[r12,-1]
|
||||||
|
bclr_l r12,r12,0
|
||||||
|
stw r1,[r12,-2]
|
||||||
|
bmsk.f r12,r3,1
|
||||||
|
add_s r2,r2,r12
|
||||||
|
sub.ne r2,r2,4
|
||||||
|
stb.ab r1,[r3,1]
|
||||||
|
bclr_s r3,r3,0
|
||||||
|
stw.ab r1,[r3,2]
|
||||||
|
bclr_s r3,r3,1
|
||||||
|
.Laligned: ; This code address should be aligned for speed.
|
||||||
|
#if defined (__ARC700__) || defined (__EM__)
|
||||||
|
asl r12,r1,16
|
||||||
|
lsr.f lp_count,r2,2
|
||||||
|
or_s r1,r1,r12
|
||||||
|
lpne .Loop_end
|
||||||
|
st.ab r1,[r3,4]
|
||||||
|
.Loop_end:
|
||||||
|
j_s [blink]
|
||||||
|
#else /* !__ARC700 */
|
||||||
|
lsr.f lp_count,r2,3
|
||||||
|
asl r12,r1,16
|
||||||
|
or_s r1,r1,r12
|
||||||
|
lpne .Loop_end
|
||||||
|
st.ab r1,[r3,4]
|
||||||
|
st.ab r1,[r3,4]
|
||||||
|
.Loop_end:
|
||||||
|
jcc [blink]
|
||||||
|
j_s.d [blink]
|
||||||
|
st_s r1,[r3]
|
||||||
|
#endif /* !__ARC700 */
|
||||||
|
|
||||||
|
#if defined (__ARC700__) || defined (__EM__)
|
||||||
|
.balign 4
|
||||||
|
__strncpy_bzero:
|
||||||
|
brhi.d r2,17,.Lnot_tiny
|
||||||
|
mov_l r1,0
|
||||||
|
.Ltiny:
|
||||||
|
mov.f lp_count,r2
|
||||||
|
lpne .Ltiny_end
|
||||||
|
stb.ab r1,[r3,1]
|
||||||
|
.Ltiny_end:
|
||||||
|
j_s [blink]
|
||||||
|
#else /* !__ARC700__ */
|
||||||
|
#if SMALL > 8
|
||||||
|
FIXME
|
||||||
|
#endif
|
||||||
|
.balign 4
|
||||||
|
__strncpy_bzero:
|
||||||
|
brhi.d r2,8,.Lnot_tiny
|
||||||
|
mov_s r1,0
|
||||||
|
.Ltiny:
|
||||||
|
sub_s r2,r2,11
|
||||||
|
sub1 r12,pcl,r2
|
||||||
|
j_s [r12]
|
||||||
|
stb_s r1,[r3,7]
|
||||||
|
stb_s r1,[r3,6]
|
||||||
|
stb_s r1,[r3,5]
|
||||||
|
stb_s r1,[r3,4]
|
||||||
|
stb_s r1,[r3,3]
|
||||||
|
stb_s r1,[r3,2]
|
||||||
|
stb_s r1,[r3,1]
|
||||||
|
stb_s r1,[r3]
|
||||||
|
j_s [blink]
|
||||||
|
#endif /* !__ARC700 */
|
||||||
|
#ifdef __HS__
|
||||||
|
ENDFUNC (__dummy_memset)
|
||||||
|
#else
|
||||||
|
ENDFUNC (memset)
|
||||||
|
#endif
|
||||||
|
#endif /* !__ARC601__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/memset.c"
|
||||||
|
#else
|
||||||
|
/* See memset-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,109 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/memset.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || (!defined (__Xbarrel_shifter) && !defined (__HS__))
|
||||||
|
|
||||||
|
/* To deal with alignment/loop issues, SMALL must be at least 2. */
|
||||||
|
#define SMALL 8 /* Even faster if aligned. */
|
||||||
|
|
||||||
|
.global __strncpy_bzero
|
||||||
|
.hidden __strncpy_bzero
|
||||||
|
/* __strncpy_bzero provides the following interface to strncpy:
|
||||||
|
r0: return value
|
||||||
|
r2: zeroing length
|
||||||
|
r3: zeroing start address
|
||||||
|
No attempt is made here for __strncpy_memset to speed up aligned
|
||||||
|
cases, because the copying of a string presumably leaves start address
|
||||||
|
and length alignment for the zeroing randomly distributed. */
|
||||||
|
|
||||||
|
ENTRY (memset)
|
||||||
|
brls.d r2,SMALL,.Ltiny
|
||||||
|
mov_s r3,r0
|
||||||
|
or r12,r0,r2
|
||||||
|
bmsk.f r12,r12,1
|
||||||
|
breq_s r1,0,.Lbzero
|
||||||
|
mov r4,0
|
||||||
|
stb.a r1,[sp,-4]
|
||||||
|
stb r1,[sp,1]
|
||||||
|
stb r1,[sp,2]
|
||||||
|
stb r1,[sp,3]
|
||||||
|
ld.ab r1,[sp,4]
|
||||||
|
.Lbzero:
|
||||||
|
beq.d .Laligned
|
||||||
|
.Lbzero2:
|
||||||
|
add r6,r2,r3
|
||||||
|
.Lnot_tiny:
|
||||||
|
stb r1,[r6,-1]
|
||||||
|
bclr r12,r6,0
|
||||||
|
stw r1,[r12,-2]
|
||||||
|
stb.ab r1,[r3,1]
|
||||||
|
bclr_s r3,r3,0
|
||||||
|
stw.ab r1,[r3,2]
|
||||||
|
bclr_s r3,r3,1
|
||||||
|
.Laligned: ; This code address should be aligned for speed.
|
||||||
|
sub r6,r6,8
|
||||||
|
brlo.d r6,r3,.Loop_end
|
||||||
|
sub r6,r6,8
|
||||||
|
3:
|
||||||
|
st_l r1,[r3,4]
|
||||||
|
brhs.d r6,r3,3b
|
||||||
|
st.ab r1,[r3,8]
|
||||||
|
.Loop_end:
|
||||||
|
bic r12,r6,3
|
||||||
|
j_s.d [blink]
|
||||||
|
st_s r1,[r12,12]
|
||||||
|
.balign 4
|
||||||
|
__strncpy_bzero:
|
||||||
|
brhi.d r2,8,.Lbzero2
|
||||||
|
mov_s r1,0
|
||||||
|
.Ltiny:
|
||||||
|
sub_s r2,r2,11
|
||||||
|
sub1 r12,pcl,r2
|
||||||
|
j_s [r12]
|
||||||
|
stb_s r1,[r3,7]
|
||||||
|
stb_s r1,[r3,6]
|
||||||
|
stb_s r1,[r3,5]
|
||||||
|
stb_s r1,[r3,4]
|
||||||
|
stb_s r1,[r3,3]
|
||||||
|
stb_s r1,[r3,2]
|
||||||
|
stb_s r1,[r3,1]
|
||||||
|
stb_s r1,[r3]
|
||||||
|
j_s [blink]
|
||||||
|
ENDFUNC (memset)
|
||||||
|
#endif /* __ARC601__ || (!__Xbarrel_shifter && !__HS__) */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,165 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* ABI interface file
|
||||||
|
these are the stack mappings for the registers
|
||||||
|
as stored in the ABI for ARC */
|
||||||
|
|
||||||
|
.file "setjmp.S"
|
||||||
|
|
||||||
|
ABIr13 = 0
|
||||||
|
ABIr14 = ABIr13 + 4
|
||||||
|
ABIr15 = ABIr14 + 4
|
||||||
|
ABIr16 = ABIr15 + 4
|
||||||
|
ABIr17 = ABIr16 + 4
|
||||||
|
ABIr18 = ABIr17 + 4
|
||||||
|
ABIr19 = ABIr18 + 4
|
||||||
|
ABIr20 = ABIr19 + 4
|
||||||
|
ABIr21 = ABIr20 + 4
|
||||||
|
ABIr22 = ABIr21 + 4
|
||||||
|
ABIr23 = ABIr22 + 4
|
||||||
|
ABIr24 = ABIr23 + 4
|
||||||
|
ABIr25 = ABIr24 + 4
|
||||||
|
ABIr26 = ABIr25 + 4
|
||||||
|
ABIr27 = ABIr26 + 4
|
||||||
|
ABIr28 = ABIr27 + 4
|
||||||
|
ABIr29 = ABIr28 + 4
|
||||||
|
ABIr30 = ABIr29 + 4
|
||||||
|
ABIr31 = ABIr30 + 4
|
||||||
|
ABIlpc = ABIr31 + 4
|
||||||
|
ABIlps = ABIlpc + 4
|
||||||
|
ABIlpe = ABIlps + 4
|
||||||
|
|
||||||
|
ABIflg = ABIlpe + 4
|
||||||
|
ABImlo = ABIflg + 4
|
||||||
|
ABImhi = ABImlo + 4
|
||||||
|
|
||||||
|
.text
|
||||||
|
.align 4
|
||||||
|
.global setjmp
|
||||||
|
.type setjmp,@function
|
||||||
|
setjmp:
|
||||||
|
st r13, [r0, ABIr13]
|
||||||
|
st r14, [r0, ABIr14]
|
||||||
|
st r15, [r0, ABIr15]
|
||||||
|
st r16, [r0, ABIr16]
|
||||||
|
st r17, [r0, ABIr17]
|
||||||
|
st r18, [r0, ABIr18]
|
||||||
|
st r19, [r0, ABIr19]
|
||||||
|
st r20, [r0, ABIr20]
|
||||||
|
st r21, [r0, ABIr21]
|
||||||
|
st r22, [r0, ABIr22]
|
||||||
|
st r23, [r0, ABIr23]
|
||||||
|
st r24, [r0, ABIr24]
|
||||||
|
st r25, [r0, ABIr25]
|
||||||
|
st r26, [r0, ABIr26]
|
||||||
|
st r27, [r0, ABIr27]
|
||||||
|
st r28, [r0, ABIr28]
|
||||||
|
st r29, [r0, ABIr29]
|
||||||
|
st r30, [r0, ABIr30]
|
||||||
|
st blink, [r0, ABIr31]
|
||||||
|
st lp_count, [r0, ABIlpc]
|
||||||
|
|
||||||
|
lr r2, [lp_start]
|
||||||
|
lr r3, [lp_end]
|
||||||
|
st r2, [r0, ABIlps]
|
||||||
|
st r3, [r0, ABIlpe]
|
||||||
|
|
||||||
|
#if (!defined (__A7__) && !defined (__EM__) && !defined (__HS__))
|
||||||
|
; Till the configure changes are decided, and implemented, the code working on
|
||||||
|
; mlo/mhi and using mul64 should be disabled.
|
||||||
|
; st mlo, [r0, ABImlo]
|
||||||
|
; st mhi, [r0, ABImhi]
|
||||||
|
lr r2, [status32]
|
||||||
|
st r2, [r0, ABIflg]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
j.d [blink]
|
||||||
|
mov r0,0
|
||||||
|
.Lfe1:
|
||||||
|
.size setjmp,.Lfe1-setjmp
|
||||||
|
|
||||||
|
.align 4
|
||||||
|
.global longjmp
|
||||||
|
.type longjmp,@function
|
||||||
|
longjmp:
|
||||||
|
|
||||||
|
; load registers
|
||||||
|
ld r13, [r0, ABIr13]
|
||||||
|
ld r14, [r0, ABIr14]
|
||||||
|
ld r15, [r0, ABIr15]
|
||||||
|
ld r16, [r0, ABIr16]
|
||||||
|
ld r17, [r0, ABIr17]
|
||||||
|
ld r18, [r0, ABIr18]
|
||||||
|
ld r19, [r0, ABIr19]
|
||||||
|
ld r20, [r0, ABIr20]
|
||||||
|
ld r21, [r0, ABIr21]
|
||||||
|
ld r22, [r0, ABIr22]
|
||||||
|
ld r23, [r0, ABIr23]
|
||||||
|
ld r24, [r0, ABIr24]
|
||||||
|
ld r25, [r0, ABIr25]
|
||||||
|
ld r26, [r0, ABIr26]
|
||||||
|
ld r27, [r0, ABIr27]
|
||||||
|
ld r28, [r0, ABIr28]
|
||||||
|
|
||||||
|
ld r3, [r0, ABIr29]
|
||||||
|
mov r29, r3
|
||||||
|
|
||||||
|
ld r3, [r0, ABIr30]
|
||||||
|
mov r30, r3
|
||||||
|
|
||||||
|
ld blink, [r0, ABIr31]
|
||||||
|
|
||||||
|
ld r3, [r0, ABIlpc]
|
||||||
|
mov lp_count, r3
|
||||||
|
|
||||||
|
ld r2, [r0, ABIlps]
|
||||||
|
ld r3, [r0, ABIlpe]
|
||||||
|
sr r2, [lp_start]
|
||||||
|
sr r3, [lp_end]
|
||||||
|
|
||||||
|
#if (!defined (__A7__) && !defined (__EM__) && !defined (__HS__))
|
||||||
|
ld r2, [r0, ABImlo]
|
||||||
|
ld r3, [r0, ABImhi]
|
||||||
|
; We do not support restoring of mulhi and mlo registers, yet.
|
||||||
|
|
||||||
|
; mulu64 0,r2,1 ; restores mlo
|
||||||
|
; mov 0,mlo ; force multiply to finish
|
||||||
|
; sr r3, [mulhi]
|
||||||
|
ld r2, [r0, ABIflg]
|
||||||
|
flag r2 ; restore "status32" register
|
||||||
|
#endif
|
||||||
|
|
||||||
|
mov.f r1, r1 ; to avoid return 0 from longjmp
|
||||||
|
mov.eq r1, 1
|
||||||
|
j.d [blink]
|
||||||
|
mov r0,r1
|
||||||
|
.Lfe2:
|
||||||
|
.size longjmp,.Lfe2-longjmp
|
|
@ -0,0 +1,165 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strchr.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
/* ARC700 has a relatively long pipeline and branch prediction, so we want
|
||||||
|
to avoid branches that are hard to predict. On the other hand, the
|
||||||
|
presence of the norm instruction makes it easier to operate on whole
|
||||||
|
words branch-free. */
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if (defined (__ARC700__) || defined (__EM__) || defined (__HS__)) \
|
||||||
|
&& defined (__ARC_NORM__) && defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
ENTRY (strchr)
|
||||||
|
extb_s r1,r1
|
||||||
|
asl r5,r1,8
|
||||||
|
bmsk r2,r0,1
|
||||||
|
or r5,r5,r1
|
||||||
|
mov_s r3,0x01010101
|
||||||
|
breq.d r2,r0,.Laligned
|
||||||
|
asl r4,r5,16
|
||||||
|
sub_s r0,r0,r2
|
||||||
|
asl r7,r2,3
|
||||||
|
ld_s r2,[r0]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
asl r7,r3,r7
|
||||||
|
#else
|
||||||
|
lsr r7,r3,r7
|
||||||
|
#endif
|
||||||
|
or r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
sub r12,r2,r7
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
brne.d r12,0,.Lfound0_ua
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
and r7,r12,r4
|
||||||
|
breq r7,0,.Loop ; For speed, we want this branch to be unaligned.
|
||||||
|
b_l .Lfound_char ; Likewise this one.
|
||||||
|
#else
|
||||||
|
and r12,r12,r4
|
||||||
|
breq_l r12,0,.Loop ; For speed, we want this branch to be unaligned.
|
||||||
|
lsr_s r12,r12,7
|
||||||
|
bic r2,r7,r6
|
||||||
|
b.d .Lfound_char_b
|
||||||
|
and_s r2,r2,r12
|
||||||
|
#endif
|
||||||
|
; /* We require this code address to be unaligned for speed... */
|
||||||
|
.Laligned:
|
||||||
|
ld_s r2,[r0]
|
||||||
|
or r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
; /* ... so that this code address is aligned, for itself and ... */
|
||||||
|
.Loop:
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
brne.d r12,0,.Lfound0
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r3
|
||||||
|
bic r12,r12,r6
|
||||||
|
and r7,r12,r4
|
||||||
|
breq r7,0,.Loop /* ... so that this branch is unaligned. */
|
||||||
|
; Found searched-for character. r0 has already advanced to next word.
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
/* We only need the information about the first matching byte
|
||||||
|
(i.e. the least significant matching byte) to be exact,
|
||||||
|
hence there is no problem with carry effects. */
|
||||||
|
.Lfound_char:
|
||||||
|
sub r3,r7,1
|
||||||
|
bic r3,r3,r7
|
||||||
|
norm r2,r3
|
||||||
|
sub_s r0,r0,1
|
||||||
|
asr_s r2,r2,3
|
||||||
|
j_l.d [blink]
|
||||||
|
sub_s r0,r0,r2
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_l r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
sub r3,r6,r3
|
||||||
|
bic r3,r3,r6
|
||||||
|
and r2,r3,r4
|
||||||
|
or_s r12,r12,r2
|
||||||
|
sub_s r3,r12,1
|
||||||
|
bic_s r3,r3,r12
|
||||||
|
norm r3,r3
|
||||||
|
add_s r0,r0,3
|
||||||
|
asr_s r12,r3,3
|
||||||
|
asl.f 0,r2,r3
|
||||||
|
sub_s r0,r0,r12
|
||||||
|
j_s.d [blink]
|
||||||
|
mov.pl r0,0
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
.Lfound_char:
|
||||||
|
lsr r7,r7,7
|
||||||
|
|
||||||
|
bic r2,r7,r6
|
||||||
|
.Lfound_char_b:
|
||||||
|
norm r2,r2
|
||||||
|
sub_s r0,r0,4
|
||||||
|
asr_s r2,r2,3
|
||||||
|
j_l.d [blink]
|
||||||
|
add_s r0,r0,r2
|
||||||
|
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_s r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
asl_s r2,r2,7
|
||||||
|
or r7,r6,r4
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
sub r2,r7,r3
|
||||||
|
or r2,r2,r6
|
||||||
|
bic r12,r2,r12
|
||||||
|
bic.f r3,r4,r12
|
||||||
|
norm r3,r3
|
||||||
|
|
||||||
|
add.pl r3,r3,1
|
||||||
|
asr_s r12,r3,3
|
||||||
|
asl.f 0,r2,r3
|
||||||
|
add_s r0,r0,r12
|
||||||
|
j_s.d [blink]
|
||||||
|
mov.mi r0,0
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
ENDFUNC (strchr)
|
||||||
|
#endif /* (__ARC700__ || __EM__ || __HS__) && __ARC_NORM__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,200 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strchr.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* In order to search for a zero in a W, we calculate
|
||||||
|
X := (W - 0x01010101) & ~W & 0x80808080;
|
||||||
|
In the little endian case:
|
||||||
|
If no byte in W is zero, X will be zero; otherwise, the least significant
|
||||||
|
byte of X which is nonzero indicates the least significant byte of W that
|
||||||
|
is zero.
|
||||||
|
In the big endian case:
|
||||||
|
X will be zero iff no byte in W is zero.
|
||||||
|
If X is nonzero, to find out which is the most significant zero byte
|
||||||
|
in W, we calculate:
|
||||||
|
Y := ~(((W | 0x80808080) - 0x01010101) | W) & 0x80808080;
|
||||||
|
Each byte in Y is 0x80 if the the corresponding byte in
|
||||||
|
W is zero, otherwise that byte of Y is 0. */
|
||||||
|
|
||||||
|
#if defined (__Xbarrel_shifter) && \
|
||||||
|
(defined (__ARC600__) || (!defined (__ARC_NORM__) && !defined (__ARC601__)))
|
||||||
|
ENTRY (strchr)
|
||||||
|
bmsk.f r2,r0,1
|
||||||
|
mov_s r3,0x01010101
|
||||||
|
extb_s r1,r1
|
||||||
|
asl r5,r1,8
|
||||||
|
or r5,r5,r1
|
||||||
|
beq.d .Laligned
|
||||||
|
asl r4,r5,16
|
||||||
|
sub_s r0,r0,r2
|
||||||
|
asl_s r2,r2,3
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
asl r7,r3,r2
|
||||||
|
#else
|
||||||
|
lsr r7,r3,r2
|
||||||
|
#endif
|
||||||
|
ld_s r2,[r0]
|
||||||
|
or r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
sub r12,r2,r7
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
|
||||||
|
brne.d r12,0,.Lfound0_ua
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
and.f r7,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
b.d .Lfound_char_ua
|
||||||
|
btst r7,7
|
||||||
|
#else
|
||||||
|
and.f r8,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
bic r12,r7,r6
|
||||||
|
asl_s r12,r12,7
|
||||||
|
and.f r2,r8,r12
|
||||||
|
b.d .Lfound_char_ua
|
||||||
|
sub_s r0,r0,4
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Laligned:
|
||||||
|
ld_s r2,[r0]
|
||||||
|
or r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
.Loop:
|
||||||
|
|
||||||
|
brne.d r12,0,.Lfound0
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r3
|
||||||
|
bic r12,r12,r6
|
||||||
|
and.f r7,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
; Found searched-for character. r0 has already advanced to next word.
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
/* We only need the information about the first matching byte
|
||||||
|
(i.e. the least significant matching byte) to be exact,
|
||||||
|
hence there is no problem with carry effects. */
|
||||||
|
.Lfound_char:
|
||||||
|
btst r7,7
|
||||||
|
.Lfound_char_ua:
|
||||||
|
sub_s r0,r0,4
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r7,15
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r7,23
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_l r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
sub r2,r6,r3
|
||||||
|
bic r2,r2,r6
|
||||||
|
and r2,r2,r4
|
||||||
|
or r3,r12,r2
|
||||||
|
sub_s r12,r3,1
|
||||||
|
xor_s r3,r3,r12
|
||||||
|
tst_s r2,r3
|
||||||
|
lsr r2,r3,31
|
||||||
|
lsr r12,r3,16
|
||||||
|
jeq.d [blink]
|
||||||
|
mov.eq r0,0
|
||||||
|
lsr r3,r3,8
|
||||||
|
sub_s r2,r2,r12
|
||||||
|
sub_s r2,r2,r3
|
||||||
|
bmsk_s r2,r2,1
|
||||||
|
j_s.d [blink]
|
||||||
|
add_s r0,r0,r2
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
.Lfound_char:
|
||||||
|
asl r6,r6,7
|
||||||
|
sub_s r0,r0,4
|
||||||
|
bic.f r2,r7,r6
|
||||||
|
.Lfound_char_ua:
|
||||||
|
add.pl r0,r0,1
|
||||||
|
jmi.d [blink]
|
||||||
|
btst_s r2,23
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,15
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
|
||||||
|
; N.B. if we searched for a char zero and found it in the MSB,
|
||||||
|
; and ignored matches are identical, we will take the early exit
|
||||||
|
; like for an ordinary found zero - except for the extra stalls at jhi -
|
||||||
|
; but still compute the right result.
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_s r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
asl_s r2,r2,7
|
||||||
|
or r7,r6,r4
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
sub r2,r7,r3
|
||||||
|
or r2,r2,r6
|
||||||
|
bic r2,r4,r2
|
||||||
|
cmp r12,r2
|
||||||
|
mov.hi r0,0
|
||||||
|
btst.ls r2,31
|
||||||
|
jhi.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,23
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,15
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
ENDFUNC (strchr)
|
||||||
|
#endif /* __Xbarrel_shifter && (__ARC600__ || (!__ARC_NORM__ && !__ARC601__)) */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/strchr.c"
|
||||||
|
#else
|
||||||
|
/* See strchr-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,208 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strchr.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* In order to search for a zero in a W, we calculate
|
||||||
|
X := (W - 0x01010101) & ~W & 0x80808080;
|
||||||
|
In the little endian case:
|
||||||
|
If no byte in W is zero, X will be zero; otherwise, the least significant
|
||||||
|
byte of X which is nonzero indicates the least significant byte of W that
|
||||||
|
is zero.
|
||||||
|
In the big endian case:
|
||||||
|
X will be zero iff no byte in W is zero.
|
||||||
|
If X is nonzero, to find out which is the most significant zero byte
|
||||||
|
in W, we calculate:
|
||||||
|
Y := ~(((W | 0x80808080) - 0x01010101) | W) & 0x80808080;
|
||||||
|
Each byte in Y is 0x80 if the the corresponding byte in
|
||||||
|
W is zero, otherwise that byte of Y is 0. */
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || !defined (__Xbarrel_shifter)
|
||||||
|
ENTRY (strchr)
|
||||||
|
bmsk.f r2,r0,1
|
||||||
|
mov_s r3,0x01010101
|
||||||
|
extb_s r1,r1
|
||||||
|
mov r8,0
|
||||||
|
add3 r5,r8,r1
|
||||||
|
add3 r5,r8,r5
|
||||||
|
add2 r5,r1,r5
|
||||||
|
add3 r4,r8,r5
|
||||||
|
add3 r4,r8,r4
|
||||||
|
add3 r4,r8,r4
|
||||||
|
add3 r4,r8,r4
|
||||||
|
beq.d .Laligned
|
||||||
|
add3 r4,r8,r4
|
||||||
|
sub_s r0,r0,r2
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
add3.f r2,-1,r2
|
||||||
|
bmsk r7,r3,r2
|
||||||
|
rsub.pl r7,r7,r3
|
||||||
|
#else
|
||||||
|
mov_s r12,31
|
||||||
|
sub3 r2,r12,r2
|
||||||
|
bmsk r7,r3,r2
|
||||||
|
#endif
|
||||||
|
ld_s r2,[r0]
|
||||||
|
add1 r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
sub r12,r2,r7
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
|
||||||
|
brne.d r12,0,.Lfound0_ua
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
and.f r7,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
b.d .Lfound_char_ua
|
||||||
|
btst r7,7
|
||||||
|
#else
|
||||||
|
and.f r8,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
bic r12,r7,r6
|
||||||
|
bic r2,r3,r12
|
||||||
|
sub1 r2,r3,r2
|
||||||
|
sub_s r0,r0,4
|
||||||
|
b.d .Lfound_char_ua
|
||||||
|
bic.f r2,r8,r2
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Laligned:
|
||||||
|
ld_s r2,[r0]
|
||||||
|
add1 r5,r5,r4
|
||||||
|
ror r4,r3
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
and r12,r12,r4
|
||||||
|
.Loop:
|
||||||
|
|
||||||
|
brne.d r12,0,.Lfound0
|
||||||
|
xor r6,r2,r5
|
||||||
|
ld.a r2,[r0,4]
|
||||||
|
sub r12,r6,r3
|
||||||
|
bic r12,r12,r6
|
||||||
|
and.f r7,r12,r4
|
||||||
|
sub r12,r2,r3
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
beq.d .Loop
|
||||||
|
and r12,r12,r4
|
||||||
|
; Found searched-for character. r0 has already advanced to next word.
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
/* We only need the information about the first matching byte
|
||||||
|
(i.e. the least significant matching byte) to be exact,
|
||||||
|
hence there is no problem with carry effects. */
|
||||||
|
.Lfound_char:
|
||||||
|
btst r7,7
|
||||||
|
.Lfound_char_ua:
|
||||||
|
sub_s r0,r0,4
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r7,15
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r7,23
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_l r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
sub r2,r6,r3
|
||||||
|
bic r2,r2,r6
|
||||||
|
and r2,r2,r4
|
||||||
|
or r3,r12,r2
|
||||||
|
sub_s r12,r3,1
|
||||||
|
xor_s r3,r3,r12
|
||||||
|
cmp 0xffff,r3
|
||||||
|
; cmp uses limm ; ARC600 would do: asl.f 0,r3,9
|
||||||
|
tst_s r2,r3
|
||||||
|
mov.eq r0,0
|
||||||
|
add.mi r0,r0,1
|
||||||
|
btst.ne r3,15
|
||||||
|
j_s.d [blink]
|
||||||
|
adc.ne r0,r0,1
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
.Lfound_char:
|
||||||
|
and r2,r6,r3
|
||||||
|
sub1 r2,r3,r2
|
||||||
|
sub_s r0,r0,4
|
||||||
|
bic.f r2,r7,r2
|
||||||
|
.Lfound_char_ua:
|
||||||
|
add.pl r0,r0,1
|
||||||
|
jmi.d [blink]
|
||||||
|
btst_s r2,23
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,15
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
|
||||||
|
; N.B. if we searched for a char zero and found it in the MSB,
|
||||||
|
; and ignored matches are identical, we will take the early exit
|
||||||
|
; like for an ordinary found zero - except for the extra stalls at jhi -
|
||||||
|
; but still compute the right result.
|
||||||
|
.Lfound0_ua:
|
||||||
|
mov_s r3,r7
|
||||||
|
.Lfound0:
|
||||||
|
and_s r2,r2,r3
|
||||||
|
sub1 r2,r3,r2
|
||||||
|
or r7,r6,r4
|
||||||
|
bic_s r12,r12,r2
|
||||||
|
sub r2,r7,r3
|
||||||
|
or r2,r2,r6
|
||||||
|
bic r2,r4,r2
|
||||||
|
cmp_s r12,r2
|
||||||
|
mov.hi r0,0
|
||||||
|
btst.ls r2,31
|
||||||
|
jhi.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,23
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r2,15
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
ENDFUNC (strchr)
|
||||||
|
#endif /* __ARC601__ || !__Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,109 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strcmp.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#ifdef __HS__
|
||||||
|
ENTRY (strcmp)
|
||||||
|
or r2, r0, r1
|
||||||
|
bmsk_s r2, r2, 1
|
||||||
|
brne r2, 0, @.Lcharloop
|
||||||
|
|
||||||
|
; s1 and s2 are word aligned
|
||||||
|
ld.ab r2, [r0, 4]
|
||||||
|
|
||||||
|
mov_s r12, 0x01010101
|
||||||
|
ror r11, r12
|
||||||
|
.align 4
|
||||||
|
.LwordLoop:
|
||||||
|
ld.ab r3, [r1, 4]
|
||||||
|
; Detect NULL char in str1
|
||||||
|
sub r4, r2, r12
|
||||||
|
ld.ab r5, [r0, 4]
|
||||||
|
bic r4, r4, r2
|
||||||
|
and r4, r4, r11
|
||||||
|
brne.d.nt r4, 0, .LfoundNULL
|
||||||
|
; Check if the read locations are the same
|
||||||
|
cmp r2, r3
|
||||||
|
beq.d .LwordLoop
|
||||||
|
mov.eq r2, r5
|
||||||
|
|
||||||
|
; A match is found, spot it out
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
swape r3, r3
|
||||||
|
mov_s r0, 1
|
||||||
|
swape r2, r2
|
||||||
|
#else
|
||||||
|
mov_s r0, 1
|
||||||
|
#endif
|
||||||
|
cmp_s r2, r3
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.lo r0, r0, 31
|
||||||
|
|
||||||
|
.align 4
|
||||||
|
.LfoundNULL:
|
||||||
|
#ifdef __BIG_ENDIAN__
|
||||||
|
swape r4, r4
|
||||||
|
swape r2, r2
|
||||||
|
swape r3, r3
|
||||||
|
#endif
|
||||||
|
; Find null byte
|
||||||
|
ffs r0, r4
|
||||||
|
bmsk r2, r2, r0
|
||||||
|
bmsk r3, r3, r0
|
||||||
|
swape r2, r2
|
||||||
|
swape r3, r3
|
||||||
|
; make the return value
|
||||||
|
sub.f r0, r2, r3
|
||||||
|
mov.hi r0, 1
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.lo r0, r0, 31
|
||||||
|
|
||||||
|
.align 4
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r2, [r0, 1]
|
||||||
|
ldb.ab r3, [r1, 1]
|
||||||
|
nop
|
||||||
|
breq r2, 0, .Lcmpend
|
||||||
|
breq r2, r3, .Lcharloop
|
||||||
|
|
||||||
|
.align 4
|
||||||
|
.Lcmpend:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0, r2, r3
|
||||||
|
ENDFUNC (strcmp)
|
||||||
|
#endif /* __HS__ */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/strcmp.c"
|
||||||
|
#else
|
||||||
|
/* See strcmp-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,133 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strcmp.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* This is optimized primarily for the ARC700.
|
||||||
|
It would be possible to speed up the loops by one cycle / word
|
||||||
|
respective one cycle / byte by forcing double source 1 alignment, unrolling
|
||||||
|
by a factor of two, and speculatively loading the second word / byte of
|
||||||
|
source 1; however, that would increase the overhead for loop setup / finish,
|
||||||
|
and strcmp might often terminate early. */
|
||||||
|
#ifndef __HS__
|
||||||
|
|
||||||
|
ENTRY (strcmp)
|
||||||
|
or r2,r0,r1
|
||||||
|
bmsk_s r2,r2,1
|
||||||
|
brne_l r2,0,.Lcharloop
|
||||||
|
mov_s r12,0x01010101
|
||||||
|
ror r5,r12
|
||||||
|
.Lwordloop:
|
||||||
|
ld.ab r2,[r0,4]
|
||||||
|
ld.ab r3,[r1,4]
|
||||||
|
nop_s
|
||||||
|
sub r4,r2,r12
|
||||||
|
bic r4,r4,r2
|
||||||
|
and r4,r4,r5
|
||||||
|
brne_l r4,0,.Lfound0
|
||||||
|
breq r2,r3,.Lwordloop
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
xor r0,r2,r3 ; mask for difference
|
||||||
|
sub_s r1,r0,1
|
||||||
|
bic_s r0,r0,r1 ; mask for least significant difference bit
|
||||||
|
sub r1,r5,r0
|
||||||
|
xor r0,r5,r1 ; mask for least significant difference byte
|
||||||
|
and_s r2,r2,r0
|
||||||
|
and_s r3,r3,r0
|
||||||
|
#endif /* LITTLE ENDIAN */
|
||||||
|
cmp_s r2,r3
|
||||||
|
mov_s r0,1
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.lo r0,r0,31
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
.Lfound0:
|
||||||
|
xor r0,r2,r3 ; mask for difference
|
||||||
|
or r0,r0,r4 ; or in zero indicator
|
||||||
|
sub_s r1,r0,1
|
||||||
|
bic_s r0,r0,r1 ; mask for least significant difference bit
|
||||||
|
sub r1,r5,r0
|
||||||
|
xor r0,r5,r1 ; mask for least significant difference byte
|
||||||
|
and_s r2,r2,r0
|
||||||
|
and_s r3,r3,r0
|
||||||
|
sub.f r0,r2,r3
|
||||||
|
mov.hi r0,1
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.lo r0,r0,31
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
/* The zero-detection above can mis-detect 0x01 bytes as zeroes
|
||||||
|
because of carry-propagateion from a lower significant zero byte.
|
||||||
|
We can compensate for this by checking that bit0 is zero.
|
||||||
|
This compensation is not necessary in the step where we
|
||||||
|
get a low estimate for r2, because in any affected bytes
|
||||||
|
we already have 0x00 or 0x01, which will remain unchanged
|
||||||
|
when bit 7 is cleared. */
|
||||||
|
.balign 4
|
||||||
|
.Lfound0:
|
||||||
|
#ifndef __ARC601__
|
||||||
|
lsr r0,r4,8
|
||||||
|
lsr_s r1,r2
|
||||||
|
bic_s r2,r2,r0 ; get low estimate for r2 and get ...
|
||||||
|
bic_s r0,r0,r1 ; <this is the adjusted mask for zeros>
|
||||||
|
or_s r3,r3,r0 ; ... high estimate r3 so that r2 > r3 will ...
|
||||||
|
cmp_s r3,r2 ; ... be independent of trailing garbage
|
||||||
|
or_s r2,r2,r0 ; likewise for r3 > r2
|
||||||
|
bic_s r3,r3,r0
|
||||||
|
rlc r0,0 ; r0 := r2 > r3 ? 1 : 0
|
||||||
|
cmp_s r2,r3
|
||||||
|
j_s.d [blink]
|
||||||
|
bset.lo r0,r0,31
|
||||||
|
#else /* __ARC601__ */
|
||||||
|
/* Fall through to .Lcharloop. */
|
||||||
|
sub_s r0,r0,4
|
||||||
|
sub_s r1,r1,4
|
||||||
|
#endif /* __ARC601__ */
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r2,[r0,1]
|
||||||
|
ldb.ab r3,[r1,1]
|
||||||
|
nop_s
|
||||||
|
breq_l r2,0,.Lcmpend
|
||||||
|
breq r2,r3,.Lcharloop
|
||||||
|
.Lcmpend:
|
||||||
|
j_s.d [blink]
|
||||||
|
sub r0,r2,r3
|
||||||
|
ENDFUNC (strcmp)
|
||||||
|
#endif /* !__HS__ */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,120 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__ARC600__) && defined (__Xbarrel_shifter)
|
||||||
|
/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
|
||||||
|
If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
|
||||||
|
it 8 byte aligned. Thus, we can do a little read-ahead, without
|
||||||
|
dereferencing a cache line that we should not touch.
|
||||||
|
Note that short and long instructions have been scheduled to avoid
|
||||||
|
branch stalls.
|
||||||
|
This version is optimized for the ARC600 pipeline. */
|
||||||
|
|
||||||
|
ENTRY (strcpy)
|
||||||
|
or r2,r0,r1
|
||||||
|
bmsk.f 0,r2,1
|
||||||
|
mov r8,0x01010101
|
||||||
|
bne.d .Lcharloop
|
||||||
|
mov_s r10,r0
|
||||||
|
ld_l r3,[r1,0]
|
||||||
|
bbit0.d r1,2,.Loop_setup
|
||||||
|
ror r12,r8
|
||||||
|
sub r2,r3,r8
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
and_s r2,r2,r12
|
||||||
|
brne_s r2,0,.Lr3z
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
.Loop_setup:
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
|
||||||
|
sub r2,r3,r8
|
||||||
|
and.f r2,r2,r12
|
||||||
|
sub r5,r4,r8
|
||||||
|
and.eq.f r5,r5,r12
|
||||||
|
b.d .Loop_start
|
||||||
|
mov_s r6,r3
|
||||||
|
.balign 4
|
||||||
|
.Loop:
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
st r4,[r10,4]
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
sub r2,r3,r8
|
||||||
|
and.f r2,r2,r12
|
||||||
|
sub r5,r4,r8
|
||||||
|
and.eq.f r5,r5,r12
|
||||||
|
st.ab r6,[r10,8]
|
||||||
|
mov r6,r3
|
||||||
|
.Loop_start:
|
||||||
|
beq.d .Loop
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
brne.d r2,0,.Lr3z
|
||||||
|
and r5,r5,r12
|
||||||
|
bic r5,r5,r4
|
||||||
|
breq.d r5,0,.Loop
|
||||||
|
mov_s r3,r4
|
||||||
|
st.ab r6,[r10,4]
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
.Lr3z: bmsk.f r1,r3,7
|
||||||
|
.Lr3z_loop:
|
||||||
|
lsr_s r3,r3,8
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
bne.d .Lr3z_loop
|
||||||
|
bmsk.f r1,r3,7
|
||||||
|
j_s [blink]
|
||||||
|
#else
|
||||||
|
.Lr3z: lsr.f r1,r3,24
|
||||||
|
.Lr3z_loop:
|
||||||
|
asl_s r3,r3,8
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
bne.d .Lr3z_loop
|
||||||
|
lsr.f r1,r3,24
|
||||||
|
j_s [blink]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r3,[r1,1]
|
||||||
|
|
||||||
|
|
||||||
|
brne.d r3,0,.Lcharloop
|
||||||
|
stb.ab r3,[r10,1]
|
||||||
|
j [blink]
|
||||||
|
ENDFUNC (strcpy)
|
||||||
|
#endif /* __ARC600__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,103 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if (defined (__ARC700__) || defined (__EM__) || defined (__HS__)) \
|
||||||
|
&& defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
|
||||||
|
If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
|
||||||
|
it 8 byte aligned. Thus, we can do a little read-ahead, without
|
||||||
|
dereferencing a cache line that we should not touch.
|
||||||
|
Note that short and long instructions have been scheduled to avoid
|
||||||
|
branch stalls.
|
||||||
|
The beq_s to r3z could be made unaligned & long to avoid a stall
|
||||||
|
there, but the it is not likely to be taken often, and it
|
||||||
|
would also be likey to cost an unaligned mispredict at the next call. */
|
||||||
|
|
||||||
|
ENTRY (strcpy)
|
||||||
|
or r2,r0,r1
|
||||||
|
bmsk_s r2,r2,1
|
||||||
|
brne.d r2,0,charloop
|
||||||
|
mov_s r10,r0
|
||||||
|
ld_s r3,[r1,0]
|
||||||
|
mov r8,0x01010101
|
||||||
|
bbit0.d r1,2,loop_start
|
||||||
|
ror r12,r8
|
||||||
|
sub r2,r3,r8
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
tst_s r2,r12
|
||||||
|
bne_l r3z
|
||||||
|
mov_s r4,r3
|
||||||
|
.balign 4
|
||||||
|
loop:
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
st.ab r4,[r10,4]
|
||||||
|
loop_start:
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
sub r2,r3,r8
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
tst_l r2,r12
|
||||||
|
bne_l r3z
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
sub r2,r4,r8
|
||||||
|
bic r2,r2,r4
|
||||||
|
tst_l r2,r12
|
||||||
|
beq_l loop
|
||||||
|
mov_s r3,r4
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
r3z: bmsk.f r1,r3,7
|
||||||
|
lsr_s r3,r3,8
|
||||||
|
#else
|
||||||
|
r3z: lsr.f r1,r3,24
|
||||||
|
asl_s r3,r3,8
|
||||||
|
#endif
|
||||||
|
bne.d r3z
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
j_s [blink]
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
charloop:
|
||||||
|
ldb.ab r3,[r1,1]
|
||||||
|
|
||||||
|
|
||||||
|
brne.d r3,0,charloop
|
||||||
|
stb.ab r3,[r10,1]
|
||||||
|
j [blink]
|
||||||
|
ENDFUNC (strcpy)
|
||||||
|
#endif /* (__ARC700__ || __EM__ || __HS__) && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/strcpy.c"
|
||||||
|
#else
|
||||||
|
/* See strcpy-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,90 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strcpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || !defined (__Xbarrel_shifter)
|
||||||
|
/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
|
||||||
|
If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
|
||||||
|
it 8 byte aligned. Thus, we can do a little read-ahead, without
|
||||||
|
dereferencing a cache line that we should not touch.
|
||||||
|
This version is a compromise between speed for the 601 pipeline and code
|
||||||
|
size. */
|
||||||
|
|
||||||
|
ENTRY (strcpy)
|
||||||
|
or r2,r0,r1
|
||||||
|
bmsk.f 0,r2,1
|
||||||
|
mov r8,0x01010101
|
||||||
|
bne.d .Lcharloop
|
||||||
|
mov_s r10,r0
|
||||||
|
ld_s r3,[r1]
|
||||||
|
bbit0.d r1,2,.Loop_start
|
||||||
|
ror r12,r8
|
||||||
|
sub r2,r3,r8
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
and_s r2,r2,r12
|
||||||
|
brne_s r2,0,.Lr3z
|
||||||
|
mov r4,r3
|
||||||
|
sub_s r1,r1,4
|
||||||
|
.balign 4
|
||||||
|
.Loop:
|
||||||
|
ld.a r3,[r1,8]
|
||||||
|
st.ab r4,[r10,4]
|
||||||
|
.Loop_start:
|
||||||
|
ld r4,[r1,4]
|
||||||
|
sub r2,r3,r8
|
||||||
|
bic_s r2,r2,r3
|
||||||
|
tst_s r2,r12
|
||||||
|
sub r5,r4,r8
|
||||||
|
bic r5,r5,r4
|
||||||
|
bne_s .Lr3z
|
||||||
|
and r5,r5,r12
|
||||||
|
breq.d r5,0,.Loop
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
|
||||||
|
;mov_s r3,r4
|
||||||
|
add_s r1,r1,4
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lr3z:
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r3,[r1,1]
|
||||||
|
brne.d r3,0,.Lcharloop
|
||||||
|
stb.ab r3,[r10,1]
|
||||||
|
j_s [blink]
|
||||||
|
ENDFUNC (strcpy)
|
||||||
|
#endif /* __ARC601__ || !__Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,115 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strlen.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
#if (defined (__ARC700__) || defined (__EM__) || defined (__HS__)) \
|
||||||
|
&& defined (__ARC_NORM__) && defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
ENTRY (strlen)
|
||||||
|
or r3,r0,7
|
||||||
|
ld r2,[r3,-7]
|
||||||
|
ld.a r6,[r3,-3]
|
||||||
|
mov r4,0x01010101
|
||||||
|
; uses long immediate
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
asl_s r1,r0,3
|
||||||
|
btst_s r0,2
|
||||||
|
asl r7,r4,r1
|
||||||
|
ror r5,r4
|
||||||
|
sub r1,r2,r7
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
mov.eq r7,r4
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
ror r5,r4
|
||||||
|
btst_s r0,2
|
||||||
|
mov_s r1,31
|
||||||
|
sub3 r7,r1,r0
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
bmsk r1,r1,r7
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
bmsk.ne r12,r12,r7
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.Loop:
|
||||||
|
ld_s r2,[r3,4]
|
||||||
|
ld.a r6,[r3,8]
|
||||||
|
; stall for load result
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
or_l r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
breq_l r12,0,.Loop
|
||||||
|
.Lend:
|
||||||
|
and.f r1,r1,r5
|
||||||
|
sub.ne r3,r3,4
|
||||||
|
mov.eq r1,r12
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
sub_s r2,r1,1
|
||||||
|
bic_s r2,r2,r1
|
||||||
|
norm r1,r2
|
||||||
|
sub_s r0,r0,3
|
||||||
|
lsr_s r1,r1,3
|
||||||
|
sub r0,r3,r0
|
||||||
|
j_s.d [blink]
|
||||||
|
sub_l r0,r0,r1
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
lsr_s r1,r1,7
|
||||||
|
mov.eq r2,r6
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
norm r1,r1
|
||||||
|
sub r0,r3,r0
|
||||||
|
lsr_s r1,r1,3
|
||||||
|
j_s.d [blink]
|
||||||
|
add_l r0,r0,r1
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
.Learly_end:
|
||||||
|
b.d .Lend
|
||||||
|
sub_s.ne r1,r1,r1
|
||||||
|
ENDFUNC (strlen)
|
||||||
|
#endif /* (__ARC700__ || __EM__ || __HS__) && __ARC_NORM__ && _Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,122 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strlen.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if (defined (__ARC600__) || !defined (__ARC_NORM__)) && !defined (__ARC601__) \
|
||||||
|
&& defined (__Xbarrel_shifter)
|
||||||
|
/* This code is optimized for the ARC600 pipeline. */
|
||||||
|
|
||||||
|
ENTRY (strlen)
|
||||||
|
or r3,r0,7
|
||||||
|
ld r2,[r3,-7]
|
||||||
|
ld.a r6,[r3,-3]
|
||||||
|
mov r4,0x01010101
|
||||||
|
; uses long immediate
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
asl_s r1,r0,3
|
||||||
|
btst_s r0,2
|
||||||
|
asl r7,r4,r1
|
||||||
|
ror r5,r4
|
||||||
|
sub r1,r2,r7
|
||||||
|
bic_l r1,r1,r2
|
||||||
|
mov.eq r7,r4
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
ror r5,r4
|
||||||
|
btst_s r0,2
|
||||||
|
mov_s r1,31
|
||||||
|
sub3 r7,r1,r0
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_l r1,r1,r2
|
||||||
|
bmsk r1,r1,r7
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
bmsk.ne r12,r12,r7
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.Loop:
|
||||||
|
ld_s r2,[r3,4]
|
||||||
|
ld.a r6,[r3,8]
|
||||||
|
; stall for load result
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
or_s r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
breq_s r12,0,.Loop
|
||||||
|
.Lend:
|
||||||
|
and.f r1,r1,r5
|
||||||
|
sub.ne r3,r3,4
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
mov.eq r1,r12
|
||||||
|
asr.f 0,r1,8
|
||||||
|
bmsk.f 0,r1,15
|
||||||
|
sub r0,r3,r0
|
||||||
|
add.cc r0,r0,1
|
||||||
|
jne.d [blink]
|
||||||
|
asl.f 0,r1,9
|
||||||
|
j_s.d [blink]
|
||||||
|
sbc r0,r0,-2
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
mov.eq r2,r6
|
||||||
|
asl_s r2,r2,7
|
||||||
|
mov.eq r1,r12
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
asr.f 0,r1,16
|
||||||
|
sub r0,r3,r0
|
||||||
|
add.pl r0,r0,1
|
||||||
|
jne.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
j_s.d [blink]
|
||||||
|
add.cc r0,r0,1
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Learly_end:
|
||||||
|
b.d .Lend
|
||||||
|
sub_s.ne r1,r1,r1
|
||||||
|
ENDFUNC (strlen)
|
||||||
|
#endif /* (__ARC600__ || !__ARC_NORM__) && !__ARC601__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/strlen.c"
|
||||||
|
#else
|
||||||
|
/* See strlen-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,165 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strlen.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
#if defined(__ARC601__) || !defined (__Xbarrel_shifter)
|
||||||
|
/* This code is optimized for the ARC601 pipeline without barrel shifter. */
|
||||||
|
|
||||||
|
ENTRY (strlen)
|
||||||
|
or r3,r0,7
|
||||||
|
ld r2,[r3,-7]
|
||||||
|
ld.a r6,[r3,-3]
|
||||||
|
mov r4,0x01010101
|
||||||
|
; uses long immediate
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
bmsk.f 0,r0,1
|
||||||
|
mov_s r1,31
|
||||||
|
add3_s r1,r1,r0
|
||||||
|
bmsk r7,r4,r1
|
||||||
|
xor.ne r7,r7,r4
|
||||||
|
btst_s r0,2
|
||||||
|
ror r5,r4
|
||||||
|
sub r1,r2,r7
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
mov.eq r7,r4
|
||||||
|
sub r12,r6,r7
|
||||||
|
bic r12,r12,r6
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
add.f r1,r4,30 ; r1 mod 31 := -1; clear carry
|
||||||
|
ror r5,r4
|
||||||
|
sub3 r7,r1,r0
|
||||||
|
btst_s r0,2
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
bmsk r1,r1,r7
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
bmsk.ne r12,r12,r7
|
||||||
|
or.eq r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
brne r12,0,.Learly_end
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
.Loop:
|
||||||
|
ld_s r2,[r3,4]
|
||||||
|
ld.a r6,[r3,8]
|
||||||
|
; stall for load result
|
||||||
|
sub r1,r2,r4
|
||||||
|
bic_s r1,r1,r2
|
||||||
|
sub r12,r6,r4
|
||||||
|
bic r12,r12,r6
|
||||||
|
or_s r12,r12,r1
|
||||||
|
and r12,r12,r5
|
||||||
|
breq_s r12,0,.Loop
|
||||||
|
.Lend:
|
||||||
|
and.f r1,r1,r5
|
||||||
|
sub.ne r3,r3,4
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
mov.eq r1,r12
|
||||||
|
btst_s r1,7
|
||||||
|
sub r0,r3,r0
|
||||||
|
add.eq r0,r0,1
|
||||||
|
bmsk.f 0,r1,15
|
||||||
|
add.eq r0,r0,1
|
||||||
|
bmsk.f 0,r1,23
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
#else /* BIG ENDIAN */
|
||||||
|
#ifdef __OPTIMIZE_SIZE__
|
||||||
|
1: ldb_s r1,[r3]
|
||||||
|
breq_s r1,0,0f
|
||||||
|
ldb.a r1,[r3,1]
|
||||||
|
breq_s r1,0,0f
|
||||||
|
ldb.a r1,[r3,1]
|
||||||
|
breq_s r1,0,0f
|
||||||
|
add_s r3,r3,1
|
||||||
|
0: j_s.d [blink]
|
||||||
|
sub r0,r3,r0
|
||||||
|
|
||||||
|
#define SPECIAL_EARLY_END
|
||||||
|
.Learly_end:
|
||||||
|
mov_s r3,r0
|
||||||
|
b_s 1b
|
||||||
|
#elif 0 /* Need more information about pipeline to assess if this is faster. */
|
||||||
|
mov.eq r2,r6
|
||||||
|
and r2,r2,r5
|
||||||
|
sub1 r2,r4,r2
|
||||||
|
mov.eq r1,r12
|
||||||
|
bic.f r1,r1,r2
|
||||||
|
sub r0,r3,r0
|
||||||
|
add.pl r0,r0,1
|
||||||
|
btst.pl r1,23
|
||||||
|
add.eq r0,r0,1
|
||||||
|
btst.eq r1,15
|
||||||
|
j_s.d [blink]
|
||||||
|
add.eq r0,r0,1
|
||||||
|
#else /* !__OPTIMIZE_SIZE__ */
|
||||||
|
/* Need carry clear here. */
|
||||||
|
mov.eq r2,r6
|
||||||
|
1: bmsk r1,r2,23
|
||||||
|
breq r1,r2,0f
|
||||||
|
bmsk r2,r1,15
|
||||||
|
breq.d r1,r2,0f
|
||||||
|
add_s r3,r3,1
|
||||||
|
cmp r2,0x100
|
||||||
|
add_s r3,r3,2
|
||||||
|
0: j_s.d [blink]
|
||||||
|
sbc r0,r3,r0
|
||||||
|
|
||||||
|
#define SPECIAL_EARLY_END
|
||||||
|
.Learly_end:
|
||||||
|
sub_s.ne r1,r1,r1
|
||||||
|
mov_s r12,0
|
||||||
|
bset r12,r12,r7
|
||||||
|
sub1 r2,r2,r12
|
||||||
|
b.d .Lend
|
||||||
|
sub1.ne r6,r6,r12
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ */
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
|
||||||
|
#ifndef SPECIAL_EARLY_END
|
||||||
|
.balign 4
|
||||||
|
.Learly_end:
|
||||||
|
b.d .Lend
|
||||||
|
sub_s.ne r1,r1,r1
|
||||||
|
#endif /* !SPECIAL_EARLY_END */
|
||||||
|
ENDFUNC (strlen)
|
||||||
|
#endif /* __ARC601__ || !__Xbarrel_shifter*/
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,171 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strncpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
|
||||||
|
If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
|
||||||
|
it 8 byte aligned. Thus, we can do a little read-ahead, without
|
||||||
|
dereferencing a cache line that we should not touch.
|
||||||
|
Note that short and long instructions have been scheduled to avoid
|
||||||
|
branch stalls.
|
||||||
|
The beq_s to r3z could be made unaligned & long to avoid a stall
|
||||||
|
there, but the it is not likely to be taken often, and it
|
||||||
|
would also be likey to cost an unaligned mispredict at the next call. */
|
||||||
|
|
||||||
|
#if !defined (__ARC601__) && defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
#if defined (__ARC700___) || defined (__EM__) || defined (__HS__)
|
||||||
|
#define BRand(a,b,l) tst a,b ` bne_l l
|
||||||
|
#else
|
||||||
|
#define BRand(a,b,l) and a,a,b ` brne_s a,0,l
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ENTRY (strncpy)
|
||||||
|
cmp_s r2,8
|
||||||
|
or r12,r0,r1
|
||||||
|
bmsk.cc.f r12,r12,1
|
||||||
|
brne.d r12,0,.Lbytewise
|
||||||
|
mov_s r10,r0
|
||||||
|
ld_s r3,[r1,0]
|
||||||
|
mov r8,0x01010101
|
||||||
|
sub lp_count,r2,1
|
||||||
|
bbit0.d r1,2,.Loop_start
|
||||||
|
ror r11,r8
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_l r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z)
|
||||||
|
mov_s r4,r3
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
sub lp_count,lp_count,4
|
||||||
|
st.ab r4,[r10,4]
|
||||||
|
.balign 4
|
||||||
|
.Loop_start:
|
||||||
|
lsr.f lp_count,lp_count,3
|
||||||
|
lpne .Loop_end
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_s r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z)
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
sub r12,r4,r8
|
||||||
|
bic r12,r12,r4
|
||||||
|
BRand (r12,r11,.Lr4z)
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
st.ab r4,[r10,4]
|
||||||
|
.Loop_end:
|
||||||
|
bcc_s .Lastword
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_s r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z)
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
mov_s r3,r4
|
||||||
|
.Lastword:
|
||||||
|
and.f lp_count,r2,3
|
||||||
|
mov.eq lp_count,4
|
||||||
|
lp .Last_byte_end
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
bmsk.f r1,r3,7
|
||||||
|
lsr.ne r3,r3,8
|
||||||
|
#else
|
||||||
|
lsr.f r1,r3,24
|
||||||
|
asl.ne r3,r3,8
|
||||||
|
#endif
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
.Last_byte_end:
|
||||||
|
j_s [blink]
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lr4z:
|
||||||
|
mov_l r3,r4
|
||||||
|
.Lr3z:
|
||||||
|
#if defined (__ARC700__) || defined (__EM__) || defined (__HS__)
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
bmsk.f r1,r3,7
|
||||||
|
lsr_s r3,r3,8
|
||||||
|
#else
|
||||||
|
lsr.f r1,r3,24
|
||||||
|
asl_s r3,r3,8
|
||||||
|
#endif
|
||||||
|
bne.d .Lr3z
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
#else /* ! __ARC700__ */
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
bmsk.f r1,r3,7
|
||||||
|
.Lr3z_loop:
|
||||||
|
lsr_s r3,r3,8
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
bne.d .Lr3z_loop
|
||||||
|
bmsk.f r1,r3,7
|
||||||
|
#else
|
||||||
|
lsr.f r1,r3,24
|
||||||
|
.Lr3z_loop:
|
||||||
|
asl_s r3,r3,8
|
||||||
|
stb.ab r1,[r10,1]
|
||||||
|
bne.d .Lr3z_loop
|
||||||
|
lsr.f r1,r3,24
|
||||||
|
#endif /* ENDIAN */
|
||||||
|
#endif /* ! __ARC700__ */
|
||||||
|
.Lzero_rest:
|
||||||
|
; __strncpy_bzero requires:
|
||||||
|
; return value in r0
|
||||||
|
; zeroing length in r2
|
||||||
|
; zeroing start address in r3
|
||||||
|
mov_s r3,r10
|
||||||
|
add_s r2,r2,r0
|
||||||
|
b.d __strncpy_bzero
|
||||||
|
sub_s r2,r2,r3
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lbytewise:
|
||||||
|
sub.f r2,r2,1
|
||||||
|
mov_l r3,r0
|
||||||
|
jcs [blink]
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r12,[r1,1]
|
||||||
|
beq.d .Last_byte
|
||||||
|
sub.f r2,r2,1
|
||||||
|
brne.d r12,0,.Lcharloop
|
||||||
|
stb.ab r12,[r3,1]
|
||||||
|
b.d __strncpy_bzero
|
||||||
|
stb.ab r12,[r3,1]
|
||||||
|
.Last_byte:
|
||||||
|
j_s.d [blink]
|
||||||
|
stb_l r12,[r3]
|
||||||
|
ENDFUNC (strncpy)
|
||||||
|
#endif /* !__ARC601__ && __Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (__OPTIMIZE_SIZE__) || defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
# include "../../string/strncpy.c"
|
||||||
|
#else
|
||||||
|
/* See strncpy-*.S. */
|
||||||
|
#endif
|
|
@ -0,0 +1,134 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2015, Synopsys, Inc. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1) Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2) Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3) Neither the name of the Synopsys, Inc., nor the names of its contributors
|
||||||
|
may be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This implementation is optimized for performance. For code size a generic
|
||||||
|
implementation of this function from newlib/libc/string/strncpy.c will be
|
||||||
|
used. */
|
||||||
|
#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
|
||||||
|
/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
|
||||||
|
If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
|
||||||
|
it 8 byte aligned. Thus, we can do a little read-ahead, without
|
||||||
|
dereferencing a cache line that we should not touch. */
|
||||||
|
|
||||||
|
#if defined (__ARC601__) || !defined (__Xbarrel_shifter)
|
||||||
|
|
||||||
|
#define BRand(a,b,l) and a,a,b ` brne_s a,0,l
|
||||||
|
|
||||||
|
ENTRY (strncpy)
|
||||||
|
cmp_s r2,8
|
||||||
|
or r12,r0,r1
|
||||||
|
bmsk.cc.f r12,r12,1
|
||||||
|
brne.d r12,0,.Lbytewise
|
||||||
|
mov_s r10,r0
|
||||||
|
ld_s r3,[r1,0]
|
||||||
|
mov r8,0x01010101
|
||||||
|
add r6,r0,r2
|
||||||
|
sub r6,r6,8
|
||||||
|
bbit0.d r1,2,.Loop_start
|
||||||
|
ror r11,r8
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_l r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z)
|
||||||
|
mov_s r4,r3
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
st.ab r4,[r10,4]
|
||||||
|
.balign 4
|
||||||
|
.Loop_start:
|
||||||
|
brhs r10,r6,.Loop_end
|
||||||
|
1:
|
||||||
|
ld.a r4,[r1,4]
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_s r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z2)
|
||||||
|
st.ab r3,[r10,8]
|
||||||
|
sub r12,r4,r8
|
||||||
|
bic r12,r12,r4
|
||||||
|
BRand (r12,r11,.Lr4z)
|
||||||
|
ld.a r3,[r1,4]
|
||||||
|
brlo.d r10,r6,1b
|
||||||
|
st r4,[r10,-4]
|
||||||
|
.Loop_end:
|
||||||
|
add r6,r6,4
|
||||||
|
brhs r10,r6,.Lastword
|
||||||
|
sub r12,r3,r8
|
||||||
|
bic_s r12,r12,r3
|
||||||
|
BRand (r12,r11,.Lr3z)
|
||||||
|
add_s r1,r1,4
|
||||||
|
st.ab r3,[r10,4]
|
||||||
|
.Lastword:
|
||||||
|
sub_s r2,r2,1
|
||||||
|
b.d .Lstart_charloop
|
||||||
|
bmsk.f r2,r2,1
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
nop_s
|
||||||
|
.Lr3z2: sub_s r1,r1,4
|
||||||
|
.Lr4z:
|
||||||
|
.Lr3z:
|
||||||
|
.balign 4
|
||||||
|
.Lr3z_loop:
|
||||||
|
ldb.ab r3,[r1,1]
|
||||||
|
brne.d r3,0,.Lr3z_loop
|
||||||
|
stb.ab r3,[r10,1]
|
||||||
|
|
||||||
|
.Lzero_rest:
|
||||||
|
; __strncpy_bzero requires:
|
||||||
|
; return value in r0
|
||||||
|
; zeroing length in r2
|
||||||
|
; zeroing start address in r3
|
||||||
|
mov_s r3,r10
|
||||||
|
add_s r2,r2,r0
|
||||||
|
b.d __strncpy_bzero
|
||||||
|
sub_s r2,r2,r3
|
||||||
|
|
||||||
|
.balign 4
|
||||||
|
.Lbytewise:
|
||||||
|
sub.f r2,r2,1
|
||||||
|
jcs [blink]
|
||||||
|
.Lstart_charloop:
|
||||||
|
mov_s r3,r10
|
||||||
|
.Lcharloop:
|
||||||
|
ldb.ab r12,[r1,1]
|
||||||
|
beq.d .Last_byte
|
||||||
|
sub.f r2,r2,1
|
||||||
|
brne.d r12,0,.Lcharloop
|
||||||
|
stb.ab r12,[r3,1]
|
||||||
|
b.d __strncpy_bzero
|
||||||
|
stb.ab r12,[r3,1]
|
||||||
|
.Last_byte:
|
||||||
|
j_s.d [blink]
|
||||||
|
stb_s r12,[r3]
|
||||||
|
ENDFUNC (strncpy)
|
||||||
|
#endif /* __ARC601__ || !__Xbarrel_shifter */
|
||||||
|
|
||||||
|
#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */
|
|
@ -786,6 +786,7 @@ CPPFLAGS
|
||||||
CPP'
|
CPP'
|
||||||
ac_subdirs_all='a29k
|
ac_subdirs_all='a29k
|
||||||
aarch64
|
aarch64
|
||||||
|
arc
|
||||||
arm
|
arm
|
||||||
bfin
|
bfin
|
||||||
cr16
|
cr16
|
||||||
|
@ -11833,6 +11834,8 @@ if test -n "${machine_dir}"; then
|
||||||
subdirs="$subdirs a29k"
|
subdirs="$subdirs a29k"
|
||||||
;;
|
;;
|
||||||
aarch64) subdirs="$subdirs aarch64"
|
aarch64) subdirs="$subdirs aarch64"
|
||||||
|
;;
|
||||||
|
arc) subdirs="$subdirs arc"
|
||||||
;;
|
;;
|
||||||
arm) subdirs="$subdirs arm"
|
arm) subdirs="$subdirs arm"
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -25,6 +25,7 @@ if test -n "${machine_dir}"; then
|
||||||
case ${machine_dir} in
|
case ${machine_dir} in
|
||||||
a29k) AC_CONFIG_SUBDIRS(a29k) ;;
|
a29k) AC_CONFIG_SUBDIRS(a29k) ;;
|
||||||
aarch64) AC_CONFIG_SUBDIRS(aarch64) ;;
|
aarch64) AC_CONFIG_SUBDIRS(aarch64) ;;
|
||||||
|
arc) AC_CONFIG_SUBDIRS(arc) ;;
|
||||||
arm) AC_CONFIG_SUBDIRS(arm) ;;
|
arm) AC_CONFIG_SUBDIRS(arm) ;;
|
||||||
bfin) AC_CONFIG_SUBDIRS(bfin) ;;
|
bfin) AC_CONFIG_SUBDIRS(bfin) ;;
|
||||||
cr16) AC_CONFIG_SUBDIRS(cr16) ;;
|
cr16) AC_CONFIG_SUBDIRS(cr16) ;;
|
||||||
|
|
Loading…
Reference in New Issue