diff options
author | liuhongt <hongtao.liu@intel.com> | 2023-11-27 13:35:41 +0800 |
---|---|---|
committer | liuhongt <hongtao.liu@intel.com> | 2023-12-05 10:40:59 +0800 |
commit | b1cb2d993cc1148281fb4922a7ae26a4ae9ecf6f (patch) | |
tree | 850b553431ec1942a20914c81e0ebfecbb09bf09 /gcc/tree-pass.h | |
parent | 48cf8d0773fee2f7acf2b9778c7af7e344de07e6 (diff) | |
download | gcc-b1cb2d993cc1148281fb4922a7ae26a4ae9ecf6f.zip gcc-b1cb2d993cc1148281fb4922a7ae26a4ae9ecf6f.tar.gz gcc-b1cb2d993cc1148281fb4922a7ae26a4ae9ecf6f.tar.bz2 |
Take register pressure into account for vec_construct/scalar_to_vec when the components are not loaded from memory.
For vec_contruct, the components must be live at the same time if
they're not loaded from memory, when the number of those components
exceeds available registers, spill happens. Try to account that with a
rough estimation.
??? Ideally, we should have an overall estimation of register pressure
if we know the live range of all variables.
gcc/ChangeLog:
* config/i386/i386.cc (ix86_vector_costs::add_stmt_cost):
Count sse_reg/gpr_regs for components not loaded from memory.
(ix86_vector_costs:ix86_vector_costs): New constructor.
(ix86_vector_costs::m_num_gpr_needed[3]): New private memeber.
(ix86_vector_costs::m_num_sse_needed[3]): Ditto.
(ix86_vector_costs::finish_cost): Estimate overall register
pressure cost.
(ix86_vector_costs::ix86_vect_estimate_reg_pressure): New
function.
Diffstat (limited to 'gcc/tree-pass.h')
0 files changed, 0 insertions, 0 deletions