Go to file
Andre Simoes Dias Vieira 28a7b5df3b aarch64: Implement ACLE Data Intrinsics
This patch adds support for the ACLE Data Intrinsics to the AArch64 port.

gcc/ChangeLog:

2022-07-25  Andre Vieira  <andre.simoesdiasvieira@arm.com>

	* config/aarch64/aarch64.md (rbit<mode>2): Rename this ...
	(@aarch64_rbit<mode>): ... to this and change it in...
	(ffs<mode>2,ctz<mode>2): ... here.
	(@aarch64_rev16<mode>): New.
	* config/aarch64/aarch64-builtins.cc: (aarch64_builtins):
	Define the following enum AARCH64_REV16, AARCH64_REV16L,
	AARCH64_REV16LL, AARCH64_RBIT, AARCH64_RBITL, AARCH64_RBITLL.
	(aarch64_init_data_intrinsics): New.
	(aarch64_general_init_builtins): Add call to
	aarch64_init_data_intrinsics.
	(aarch64_expand_builtin_data_intrinsic): New.
	(aarch64_general_expand_builtin): Add call to
	aarch64_expand_builtin_data_intrinsic.
	* config/aarch64/arm_acle.h (__clz, __clzl, __clzll, __cls, __clsl,
	__clsll, __rbit, __rbitl, __rbitll, __rev, __revl, __revll, __rev16,
	__rev16l, __rev16ll, __ror, __rorl, __rorll, __revsh): New.

gcc/testsuite/ChangeLog:

2022-07-25  Andre Vieira  <andre.simoesdiasvieira@arm.com>

	* gcc.target/aarch64/acle/data-intrinsics.c: New test.

(cherry picked from commit eb966d393d)
2022-08-11 16:18:08 +01:00
c++tools Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
config Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
contrib Daily bump. 2022-05-07 00:18:53 +00:00
fixincludes Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
gcc aarch64: Implement ACLE Data Intrinsics 2022-08-11 16:18:08 +01:00
gnattools Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
gotools Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
include Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
INSTALL
intl Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libada Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libatomic Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libbacktrace Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libcc1 Daily bump. 2022-07-03 00:19:11 +00:00
libcody Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libcpp Daily bump. 2022-08-02 00:19:17 +00:00
libdecnumber Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libffi Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libgcc Daily bump. 2022-05-17 00:18:54 +00:00
libgfortran Daily bump. 2022-08-04 00:19:28 +00:00
libgo libgo: don't include <linux/fs.h> when building gen-sysinfo.go 2022-07-21 13:39:43 +02:00
libgomp Daily bump. 2022-08-02 00:19:17 +00:00
libiberty Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libitm Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libobjc Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
liboffloadmic Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libphobos Daily bump. 2022-07-27 00:19:35 +00:00
libquadmath Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libsanitizer libsanitizer: cherry-pick 9cf13067cb5088626ba7 from upstream 2022-07-21 13:38:10 +02:00
libssp Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
libstdc++-v3 Daily bump. 2022-08-06 00:19:27 +00:00
libvtv Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
lto-plugin Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
maintainer-scripts Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
zlib Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
.dir-locals.el
.gitattributes
.gitignore
ABOUT-NLS
ar-lib
ChangeLog Update ChangeLog and version files for release 2022-05-06 07:07:53 +00:00
ChangeLog.jit
ChangeLog.tree-ssa Merge tree-ssa-20020619-branch into mainline. 2004-05-13 02:41:07 -04:00
compile
config-ml.in
config.guess
config.rpath
config.sub
configure
configure.ac
COPYING
COPYING3
COPYING3.LIB
COPYING.LIB
COPYING.RUNTIME
depcomp
install-sh
libtool-ldflags
libtool.m4
lt~obsolete.m4
ltgcc.m4 libtool.m4: Update to libtool 2.2.6. 2008-09-26 16:21:02 +00:00
ltmain.sh
ltoptions.m4
ltsugar.m4
ltversion.m4
MAINTAINERS
Makefile.def
Makefile.in
Makefile.tpl
missing
mkdep
mkinstalldirs
move-if-change
multilib.am
README
symlink-tree
test-driver
ylwrap

This directory contains the GNU Compiler Collection (GCC).

The GNU Compiler Collection is free software.  See the files whose
names start with COPYING for copying permission.  The manuals, and
some of the runtime libraries, are under different terms; see the
individual source files for details.

The directory INSTALL contains copies of the installation information
as HTML and plain text.  The source of this information is
gcc/doc/install.texi.  The installation information includes details
of what is included in the GCC sources and what files GCC installs.

See the file gcc/doc/gcc.texi (together with other files that it
includes) for usage and porting information.  An online readable
version of the manual is in the files gcc/doc/gcc.info*.

See http://gcc.gnu.org/bugs/ for how to report bugs usefully.

Copyright years on GCC source files may be listed using range
notation, e.g., 1987-2012, indicating that every year in the range,
inclusive, is a copyrightable year that could otherwise be listed
individually.