+2025-08-26 liuhongt <hongtao.liu@intel.com>
+
+ * config/i386/i386.cc (ix86_vector_costs::ix86_vector_costs):
+ Addd new memeber m_num_reduc, m_prefer_unroll.
+ (ix86_vector_costs::add_stmt_cost): Set m_prefer_unroll and
+ m_num_reduc
+ (ix86_vector_costs::finish_cost): Determine
+ m_suggested_unroll_vector with consideration of
+ reduc_lat_mult_thr, m_num_reduction and
+ ix86_vect_unroll_limit.
+ * config/i386/i386.h (enum ix86_reduc_unroll_factor): New
+ enum.
+ (processor_costs): Add reduc_lat_mult_thr and
+ vect_unroll_limit.
+ * config/i386/x86-tune-costs.h: Initialize
+ reduc_lat_mult_thr and vect_unroll_limit.
+ * config/i386/i386.opt: Add -param=ix86-vect-unroll-limit.
+
+2025-08-26 Paul-Antoine Arras <parras@baylibre.com>
+
+ * config/riscv/autovec-opt.md (*vfrdiv_vf_<mode>): Add new pattern to
+ combine vec_duplicate + vfdiv.vv into vfrdiv.vf.
+ * config/riscv/vector.md (@pred_<optab><mode>_reverse_scalar): Allow VLS
+ modes.
+
+2025-08-26 Tamar Christina <tamar.christina@arm.com>
+
+ PR target/121290
+ * config/aarch64/aarch64.cc
+ (class aarch64_vector_costs ): Add m_loop_fully_scalar_dup.
+ (aarch64_vector_costs::add_stmt_cost): Detect invariant inner loops.
+ (adjust_body_cost): Adjust final costing if m_loop_fully_scalar_dup.
+
+2025-08-26 Paul-Antoine Arras <parras@baylibre.com>
+
+ * config/riscv/autovec-opt.md (*vfmul_vf_<mode>): Add new pattern to
+ combine vec_duplicate + vfmul.vv into vfmul.vf.
+ * config/riscv/vector.md (@pred_<optab><mode>_scalar): Allow VLS modes.
+
+2025-08-26 Jeff Law <jlaw@ventanamicro.com>
+
+ * config/riscv/riscv.cc (riscv_arg_partial_bytes): Remove name
+ from unused parameter.
+
+2025-08-26 Richard Biener <rguenther@suse.de>
+
+ * tree-vectorizer.h (vect_reduc_type): Get SLP node as argument.
+ * config/aarch64/aarch64.cc (aarch64_sve_in_loop_reduction_latency):
+ Take SLO node as argument and adjust.
+ (aarch64_in_loop_reduction_latency): Likewise.
+ (aarch64_detect_vector_stmt_subtype): Adjust.
+ (aarch64_vector_costs::count_ops): Likewise. Treat reductions
+ during scalar costing as single-cycle.
+
+2025-08-26 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/121659
+ * tree-vect-slp.cc (vect_build_slp_tree_1): Do not allow
+ matching up comparison operators by swapping if that would
+ disturb STMT_VINFO_REDUC_IDX. Make sure to only
+ actually mark operands for swapping when there was a
+ mismatch and we're not processing the first stmt.
+
+2025-08-26 Richard Biener <rguenther@suse.de>
+
+ * tree-vect-stmts.cc (vectorizable_store): Access lanes_ifn
+ only when VMAT_LOAD_STORE_LANES.
+ (vectorizable_load): Likewise.
+
+2025-08-26 Richard Biener <rguenther@suse.de>
+
+ * tree-vectorizer.h (stmt_vec_info_::reduc_vectype_in): Remove.
+ (STMT_VINFO_REDUC_VECTYPE_IN): Likewise.
+ * tree-vect-loop.cc (vect_is_emulated_mixed_dot_prod): Get
+ at the input vectype via the SLP node child.
+ (vectorizable_lane_reducing): Likewise.
+ (vect_transform_reduction): Likewise.
+ (vectorizable_reduction): Do not set STMT_VINFO_REDUC_VECTYPE_IN.
+
+2025-08-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/121658
+ * config/i386/sse.md (<insn><mode>3 any_shift): Use const0_rtx
+ instead of GEN_INT (0).
+ (cond_<insn><mode> any_shift): Likewise. Formatting fix.
+ (<insn><mode>3 any_rotate): Use register_operand predicate instead of
+ general_operand for match_operand 1. Use const0_rtx instead of
+ GEN_INT (0).
+ (<insn>v16qi3 any_rotate): Use force_reg on operands[1]. Formatting
+ fix.
+ * config/i386/i386.cc (ix86_shift_rotate_cost): Comment formatting
+ fixes.
+
2025-08-26 Pan Li <pan2.li@intel.com>
* config/riscv/vector.md (@pred_mul_plus_vx_<mode>): Add new pattern to
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ PR middle-end/118839
+ * c-parser.cc (c_finish_omp_declare_variant): Error if variant
+ is the same as base.
+
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ * c-parser.cc (c_finish_omp_declare_variant): Rework diagnostic
+ code. Do not record variant if there are errors. Make check for
+ a missing "match" clause unconditional.
+
2025-08-21 Andrew Pinski <andrew.pinski@oss.qualcomm.com>
PR c/121478
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ PR middle-end/118839
+ * decl.cc (omp_declare_variant_finalize_one): Error if variant
+ is the same as base.
+
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ * parser.cc (cp_finish_omp_declare_variant): Structure diagnostic
+ code similarly to C front end. Make check for a missing "match"
+ clause unconditional.
+
2025-08-25 Jakub Jelinek <jakub@redhat.com>
* pt.cc (finish_expansion_stmt): Implement C++ CWG3048
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ PR middle-end/118839
+ * trans-openmp.cc (gfc_trans_omp_declare_variant): Error if variant
+ is the same as base.
+
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ * openmp.cc (gfc_match_omp_declare_variant): Make check for a
+ missing "match" clause unconditional.
+
2025-08-21 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/121627
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ PR middle-end/118839
+ * gcc.dg/gomp/declare-variant-3.c: New.
+ * gfortran.dg/gomp/declare-variant-22.f90: New.
+
+2025-08-26 Sandra Loosemore <sloosemore@baylibre.com>
+
+ * c-c++-common/gomp/append-args-1.c: Adjust expected output.
+ * g++.dg/gomp/adjust-args-1.C: Likewise.
+ * g++.dg/gomp/adjust-args-3.C: Likewise.
+ * gcc.dg/gomp/adjust-args-1.c: Likewise:
+ * gcc.dg/gomp/append-args-1.c: Likewise.
+ * gcc.dg/gomp/unprototyped-variant.c: New.
+ * gfortran.dg/gomp/adjust-args-1.f90: Adjust expected output.
+ * gfortran.dg/gomp/append_args-1.f90: Likewise.
+
+2025-08-26 Jeff Law <jlaw@ventanamicro.com>
+
+ * gcc.target/riscv/arch-25.c: Use wildcards to simplify/eliminate
+ dg-error directives.
+ * gcc.target/riscv/arch-ss-2.c: Similarly.
+ * gcc.target/riscv/arch-zilsd-2.c: Similarly.
+ * gcc.target/riscv/arch-zilsd-3.c: Similarly.
+
+2025-08-26 David Faust <david.faust@oracle.com>
+
+ PR debug/121411
+ * gcc.dg/debug/ctf/ctf-array-7.c: Restrict to lp64,llp64
+ targets.
+
+2025-08-26 Torbjörn SVENSSON <torbjorn.svensson@foss.st.com>
+
+ * gcc.target/arm/unsigned-extend-2.c: Disable sched2 and sched3
+ and update function body to match.
+
+2025-08-26 liuhongt <hongtao.liu@intel.com>
+
+ * gcc.target/i386/vect_unroll-1.c: New test.
+ * gcc.target/i386/vect_unroll-2.c: New test.
+ * gcc.target/i386/vect_unroll-3.c: New test.
+ * gcc.target/i386/vect_unroll-4.c: New test.
+ * gcc.target/i386/vect_unroll-5.c: New test.
+ * gcc.target/i386/vect_unroll-6.c: New file.
+
+2025-08-26 Paul-Antoine Arras <parras@baylibre.com>
+
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f16.c: Add vfrdiv.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_binop.h: Add support for reverse
+ variants.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_binop_data.h: Add data for
+ reverse variants.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfrdiv-run-1-f16.c: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfrdiv-run-1-f32.c: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfrdiv-run-1-f64.c: New test.
+
+2025-08-26 Tamar Christina <tamar.christina@arm.com>
+
+ PR target/121290
+ * gcc.target/aarch64/pr121290.c: New test.
+
+2025-08-26 Paul-Antoine Arras <parras@baylibre.com>
+
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f16.c: Add vfmul.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-1-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-2-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-3-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f16.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f32.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf-4-f64.c: Likewise.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_binop.h: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_binop_data.h: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_binop_run.h: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfmul-run-1-f16.c: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfmul-run-1-f32.c: New test.
+ * gcc.target/riscv/rvv/autovec/vx_vf/vf_vfmul-run-1-f64.c: New test.
+ * gcc.target/riscv/rvv/autovec/vls/floating-point-mul-2.c: Adjust scan
+ dump.
+ * gcc.target/riscv/rvv/autovec/vls/floating-point-mul-3.c: Likewise.
+
+2025-08-26 Richard Earnshaw <rearnsha@arm.com>
+
+ * gcc.target/arm/bics_3.c: Add some additional tests that
+ cannot be folded to a bit manipulation.
+
+2025-08-26 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/121659
+ * gcc.dg/vect/pr121659.c: New testcase.
+
+2025-08-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/121658
+ * gcc.target/i386/pr121658.c: New test.
+
2025-08-26 Pan Li <pan2.li@intel.com>
* gcc.target/riscv/rvv/autovec/vx_vf/vx-1-u16.c: Add asm check
+2025-08-26 Patrick Palka <ppalka@redhat.com>
+
+ * include/std/ranges (__detail::_CachedPosition): Remove
+ additional size constraint on the offset-based partial
+ specialization.
+
+2025-08-26 Tomasz Kamiński <tkaminsk@redhat.com>
+
+ PR libstdc++/90192
+ * include/bits/stl_vector.h (vector<T>::_M_fill_append): Declare.
+ (vector<T>::fill): Use _M_fill_append instead of _M_fill_insert.
+ * include/bits/vector.tcc (vector<T>::_M_fill_append): Define
+ (vector<T>::_M_fill_insert): Delegate to _M_fill_append when
+ elements are appended.
+ * testsuite/23_containers/vector/modifiers/moveable.cc: Updated
+ copycount for inserting at the end (appending).
+ * testsuite/23_containers/vector/modifiers/resize.cc: New test.
+ * testsuite/backward/hash_set/check_construct_destroy.cc: Updated
+ copycount, the hash_set constructor uses insert to fill buckets
+ with nullptrs.
+
+2025-08-26 Tomasz Kamiński <tkaminsk@redhat.com>
+
+ * include/bits/move.h (std::__like_impl, std::__like_t): Make
+ available in c++11.
+ * include/std/functional (std::_Indexed_bound_arg)
+ (std::_Bound_arg_storage, std::__make_bound_args): Define.
+ (std::_Bind_front, std::_Bind_back): Use _Bound_arg_storage.
+ * testsuite/20_util/function_objects/bind_back/1.cc: Expand
+ test to cover cases of 0, 1, many bound args.
+ * testsuite/20_util/function_objects/bind_back/111327.cc: Likewise.
+ * testsuite/20_util/function_objects/bind_front/1.cc: Likewise.
+ * testsuite/20_util/function_objects/bind_front/111327.cc: Likewise.
+
+2025-08-26 Tomasz Kamiński <tkaminsk@redhat.com>
+
+ * include/std/stop_token (__variant::_Never_valueless_alt): Declare.
+ (__variant::_Never_valueless_alt<std::stop_token>)
+ (__variant::_Never_valueless_alt<std::stop_source>): Define.
+ * include/std/thread: (__variant::_Never_valueless_alt): Declare.
+ (__variant::_Never_valueless_alt<std::jthread>): Define.
+
2025-08-21 Jonathan Wakely <jwakely@redhat.com>
PR libstdc++/121496