Michael Meissner 5e8a1cfaff Add support for 1,024 bit dense math registers.
This patch is a prelimianry patch to add the full 1,024 bit dense math register
(DMRs) for -mcpu=future.  The MMA 512-bit accumulators map onto the top of the
DMR register.

This patch only adds the new 1,024 bit register support.  It does not add
support for any instructions that need 1,024 bit registers instead of 512 bit
registers.

I used the new mode 'TDOmode' to be the opaque mode used for 1,024 bit
registers.  The 'wD' constraint added in previous patches is used for these
registers.  I added support to do load and store of DMRs via the VSX registers,
since there are no load/store dense math instructions.  I added the new keyword
'__dm1024' to create 1,024 bit types that can be loaded into dense math
registers.

The patches have been tested on both little and big endian systems.  Can I check
it into the master branch?

This is version 4 of the patches.  The previous patches were:

 * https://gcc.gnu.org/pipermail/gcc-patches/2026-February/707452.html
 * https://gcc.gnu.org/pipermail/gcc-patches/2026-February/707453.html
 * https://gcc.gnu.org/pipermail/gcc-patches/2026-February/707454.html
 * https://gcc.gnu.org/pipermail/gcc-patches/2026-February/707455.html
 * https://gcc.gnu.org/pipermail/gcc-patches/2026-February/707456.html

gcc/

2026-02-20   Michael Meissner  <meissner@linux.ibm.com>

	* config/rs6000/mma.md (UNSPEC_DM_INSERT512_UPPER): New unspec.
	(UNSPEC_DM_INSERT512_LOWER): Likewise.
	(UNSPEC_DM_EXTRACT512): Likewise.
	(UNSPEC_DM_RELOAD_FROM_MEMORY): Likewise.
	(UNSPEC_DM_RELOAD_TO_MEMORY): Likewise.
	(movtdo): New define_expand and define_insn_and_split to implement 1,024
	bit dense math registers.
	(movtdo_insert512_upper): New insn.
	(movtdo_insert512_lower): Likewise.
	(movtdo_extract512): Likewise.
	(reload_tdo_from_memory): Likewise.
	(reload_tdo_to_memory): Likewise.
	* config/rs6000/rs6000-builtin.cc (rs6000_type_string): Add dense math
	register support.
	(rs6000_init_builtins): Add support for __dm1024 keyword.
	* config/rs6000/rs6000-call.cc (rs6000_return_in_memory): Add support
	for TDOmode.
	(rs6000_function_arg): Likewise.
	* config/rs6000/rs6000-modes.def (TDOmode): New mode.
	* config/rs6000/rs6000.cc (rs6000_hard_regno_nregs_internal): Add
	support for TDOmode.
	(rs6000_hard_regno_mode_ok_uncached): Likewise.
	(rs6000_hard_regno_mode_ok): Likewise.
	(rs6000_modes_tieable_p): Likewise.
	(rs6000_debug_reg_global): Likewise.
	(rs6000_setup_reg_addr_masks): Likewise.
	(rs6000_init_hard_regno_mode_ok): Add support for TDOmode.  Setup reload
	hooks for dense math TDO reload mode.
	(reg_offset_addressing_ok_p): Add support for TDOmode.
	(rs6000_emit_move): Likewise.
	(rs6000_secondary_reload_simple_move): Likewise.
	(rs6000_preferred_reload_class): Likewise.
	(rs6000_mangle_type): Add mangling for __dm1024 type.
	(rs6000_dense_math_register_move_cost): Add support for TDOmode.
	(rs6000_split_multireg_move): Likewise.
	(rs6000_invalid_conversion): Likewise.
	* config/rs6000/rs6000.h (VECTOR_ALIGNMENT_P): Add TDOmode.
	(enum rs6000_builtin_type_index): Add dense math register type nodes.
	(dm1024_type_node): Likewise.
	(ptr_dm1024_type_node): Likewise.

gcc/testsuite/

2026-02-20   Michael Meissner  <meissner@linux.ibm.com>

	* gcc.target/powerpc/dm-1024bit.c: New test.
2026-02-20 23:36:32 -05:00
2026-02-05 00:16:28 +00:00
2026-02-06 00:16:39 +00:00
2026-02-06 00:16:39 +00:00
2026-01-31 00:16:35 +00:00
2026-01-31 00:16:35 +00:00
2026-01-30 00:16:31 +00:00
2026-01-31 00:16:35 +00:00
2026-02-13 00:16:32 +00:00
2026-02-13 00:16:32 +00:00
2026-02-13 00:16:32 +00:00
2026-02-13 00:16:32 +00:00
2026-02-06 00:16:39 +00:00
2026-02-06 00:16:39 +00:00

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.
Description
No description provided
Readme 2.7 GiB
Languages
C++ 30.7%
C 30.1%
Ada 14.4%
D 6.1%
Go 5.7%
Other 12.5%