OSDN Git Service

2005-07-25 Andrew Pinski <pinskia@physics.uc.edu>
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
index afaf918..2217142 100644 (file)
@@ -1,5 +1,323 @@
+2005-07-25  Andrew Pinski  <pinskia@physics.uc.edu>
+
+       * tree-ssa-reassoc.c (reassociate_expr): Allow scaler floating point
+       types when flag_unsafe_math_optimizations is true.
+
+2005-07-25  Mark Mitchell  <mark@codesourcery.com>
+
+       * gcc.c (option_map): Add --sysroot.
+       (process_command): Handle --sysroot.
+       (display_help): Document it.
+       * doc/cppopts.tex (-isysroot): Document.
+       * doc/invoke.texi (--sysroot): Document.
+       * doc/install.texi (--with-build-sysroot): Document.
+
+       * Makefile.in (inhibit_libc): New variable.
+       (INHIBIT_LIBC_CFLAGS): Likewise.
+       (LIBGCC2_CFLAGS): Include
+       $(INHIBIT_LIBC_CFLAGS).
+       (CRTSTUFF_CFLAGS): Include $(INHIBIT_LIBC_CFLAGS).
+       ($(T)crtbegin.o): Do not use @inhibit_libc@.
+       ($(T)crtend.o): Likewise.
+       ($(T)crtbeginS.o): Do not use @inhibit_libc@.
+       ($(T)crtendS.o): Likewise.
+       ($(T)crtbeginT.o): Do not use @inhibit_libc@.
+       ($(T)crtendT.o): Likewise.
+       (stmp-fixinc): Do not complain about missing headers if
+       inhibit_libc.
+       * configure.ac (inhibit_libc): Set it to true/false.
+       (--with-build-sysroot): New option.  Use it to set
+       SYSTEM_HEADER_DIR. 
+       * configure: Regenerated.
+
+2005-07-25  Manfred Hollstein  <mh@suse.com>
+
+       * calls.c (store_one_arg): Fix unsigned comparison warning.
+
+2005-07-25  Serge Belyshev  <belyshev@depni.sinp.msu.ru>
+
+       PR other/22337
+       * ggc-zone.c (ggc_alloc_zone_stat): Do not use CHUNK_OVERHEAD.
+       (ggc_print_statistics): Initialize variable before use.
+
+2005-07-25  Richard Guenther  <rguenther@suse.de>
+
+       * tree-dfa.c (mark_new_vars_to_rename): Protect against
+       calling with a PHI_NODE argument.
+
+       * tree-flow-inline.h (overlap_subvar): Protect against
+       possible overflow.
+
+2005-07-25  Paolo Bonzini  <bonzini@gnu.org>
+
+       * aclocal.m4 (gcc_AC_CHECK_TOOL): Add /bin to default directory.
+       * configure: Regenerate.
+
+2005-07-25  Ira Rosen  <irar@il.ibm.com>
+
+       * expr.c (highest_pow2_factor): Make extern.
+       * tree-data-ref.c (ptr_decl_may_alias_p): New function.
+       (ptr_ptr_may_alias_p, may_alias_p, record_ptr_differ_p,
+       record_array_differ_p, array_ptr_differ_p): Likewise.
+       (base_object_differ_p): Rename (from array_base_name_differ_p). Support
+       additional cases. Call the above functions.
+       (base_addr_differ_p): Moved from tree-vect-analyze.c. Call
+       base_object_differ_p when there are two base objects. Otherwise, compare
+       base address and offset. Call may_alias_p.
+       (dump_data_reference): Use a correct field name.
+       (analyze_array): Make static. Initialize new data-ref fields.
+       (analyze_indirect_ref): New function.
+       (init_data_ref): Initialize new data-ref fields.   
+       (strip_conversion): Moved from tree-vect-analyze.c. 
+       (analyze_offset_expr, get_ptr_offset, address_analysis,
+       object_analysis): Likewise.
+       (analyze_offset): New function.
+       (create_data_ref): Likewise.
+       (initialize_data_dependence_relation): Call base_addr_differ_p. Compare
+       dimensions for ARRAY_REFs only.
+       (build_classic_dist_vector): Make static.
+       (access_functions_are_affine_or_constant_p): Call macro to get the
+       address of access functions.
+       (compute_all_dependences): Add new parameter
+       compute_self_and_read_read_dependences. Compute self and read-read  
+       dependences if it is true.
+       (find_data_references_in_loop): Call create_data_ref. Initialize new
+       data-ref fields.
+       (compute_data_dependences_for_loop): Add new parameter
+       compute_self_and_read_read_dependences. Remove parameter nb_loops,
+       compute nb_loops. Call compute_all_dependences,
+       build_classic_dist_vector and build_classic_dir_vector with correct
+       parameters.
+       (analyze_all_data_dependences): Call compute_data_dependences_for_loop
+       with correct parameters. Compare dimensions for ARRAY_REFs only.
+       (free_data_refs): Call macro to free access functions.
+       * tree-data-ref.h (struct first_location_in_loop): New structure. Move
+       fields from stmt_vinfo.
+       (struct base_object_info): New structure.
+       (struct data_reference): Move fields to base_object_info. Add fields   
+       first_location and object_info for above structures. Move fields from
+       stmt_info: memtag, ptr_info, subvars, misalignment. Add new field
+       aligned_to.  Add macros to access the new fields.
+       Update functions declarations.
+       * tree-flow.h (is_aliased_with): Declare.
+       * tree-loop-linear.c (linear_transform_loops): Call
+       compute_data_dependences_for_loop with correct parameters.
+       * tree-ssa-alias.c (is_aliased_with): New function.
+       * tree-vect-analyze.c (vect_get_ptr_offset): Remove.
+       (vect_analyze_offset_expr, vect_base_addr_differ_p): Likewise.
+       (vect_analyze_data_ref_dependence): Get ddr. Remove call to
+       vect_base_addr_differ_p, compute_subscript_distance and
+       build_classic_dist_vector. Add printings. Check absolute value of
+       distance.
+       (vect_analyze_data_ref_dependences): Go through ddrs instead of
+       data-refs.
+       (vect_compute_data_ref_alignment): Get the fields of data-ref instead of
+       stmt. Check aligned_to. Check if the base is aligned. Remove conversion
+       to bytes. Add printing.
+       (vect_compute_data_refs_alignment): Go through loads and stores in one
+       loop.
+       (vect_enhance_data_refs_alignment, vect_analyze_data_refs_alignment,
+       vect_analyze_data_ref_access): Likewise.
+       (vect_analyze_pointer_ref_access): Remove.
+       (vect_address_analysis, vect_object_analysis): Likewise.
+       (vect_analyze_data_refs): Call compute_data_dependences_for_loop to find
+       and analyze data-refs in the loop.
+       * tree-vect-transform.c (vect_create_addr_base_for_vector_ref): Get the
+       fields of data-ref instead of stmt. Add init to the offset from the
+       base.
+       (vect_create_data_ref_ptr): Get the fields of data-ref instead of stmt.
+       (vect_update_init_of_dr): Likewise.
+       (vect_update_inits_of_drs): Go through loads and stores in one loop.
+       * tree-vectorizer.c (new_stmt_vec_info): Remove initialization of
+       removed fields.
+       (new_loop_vec_info): Initialize new fields.
+       (destroy_loop_vec_info): Free new fields.
+       (vect_strip_conversion): Remove.
+       * tree-vectorizer.h (enum verbosity_levels): Add new verbosity level.
+       (struct _loop_vec_info): Unify data_ref_writes and data_ref_reads into
+       datarefs. Add new field ddrs. 
+       Add macros for the new fields access.
+       (struct _stmt_vec_info): Remove: base_address, initial_offset, step,
+       base_aligned_p, misalignment, memtag, ptr_info and subvars.
+       Remove their macros.
+       * tree.h (highest_pow2_factor): Declare.
+
+2005-07-25  Jakub Jelinek  <jakub@redhat.com>
+
+       * calls.c (store_one_arg): Check for sibling call MEM arguments
+       from already clobbered incoming argument area.
+
+2005-07-24  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-common.c (check_missing_format_attribute): New.
+       * c-common.h (check_missing_format_attribute): Likewise.
+       * c-typeck.c (convert_for_assignment): Use it.
+
+2005-07-24  Andreas Schwab  <schwab@suse.de>
+
+       * config/m68k/m68k.md ("extendqidi2"): When source is an address
+       register use a word move.  Correct operand of ext.w in 68000 code.
+
+2005-07-23  Mark Mitchell  <mark@codesourcery.com>
+
+       * dwarf2out.c (gen_variable_die): Treat un-emitted COMDAT
+       variables as declarations, rather than definitions.
+
+2005-07-24  Ira Rosen  <irar@il.ibm.com>
+
+        PR tree-optimization/22526
+        * tree-vectorizer.c (slpeel_tree_peel_loop_to_edge): Match the type
+        of the zero node.
+
+2005-07-24  Francois-Xavier Coudert  <coudert@clipper.ens.fr>
+
+       * builtins.def: Add DEF_EXT_C99RES_BUILTIN to define builtins
+       that C99 reserve for future use. Use it to define clog10,
+       clog10f and clog10l.
+
+2005-07-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * Makefile.in (STRICT2_WARN): Add -Wmissing-format-attribute.
+       * configure.ac: Check for -Wmissing-format-attribute.
+       
+       * configure: Regenerate.
+
+2005-07-23  Richard Henderson  <rth@redhat.com>
+
+       PR tree-optimization/22623
+       * tree-complex.c (set_component_ssa_name): Use replace_ssa_name_symbol.
+
+2005-07-23  Giovanni Bajo  <giovannibajo@libero.it>
+
+       PR target/22577
+       * config/pa/pa.c (reloc_needed): Updated for VECs inside CONSTRUCTOR.
+
+2005-07-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * Makefile.in (C_TREE_H): Update dependencies.
+       * c-tree.h: Include toplev.h.
+       * diagnostic.h (diagnostic_set_info): Add format attribute.
+       * rtl-error.c (diagnostic_for_asm): Likewise.
+
+2005-07-23  Chao-ying Fu  <fu@mips.com>
+
+       * config/mips/mips-dsp.md: New file.
+       * config/mips/mips-modes.def (V4QI, V2HI, CCDSP): New modes.
+       * config/mips/mips.c (mips_function_type): Add types for DSP builtin
+       functions.
+       (mips_builtin_type): Add MIPS_BUILTIN_DIRECT_NO_TARGET and
+       MIPS_BUILTIN_BPOSGE32.
+       (mips_expand_builtin_direct): Add one parameter to indicate that
+       builtin functions need to return a value.
+       (mips_expand_builtin_bposge): New for expanding "bposge" builtin
+       functions.
+       (mips_regno_to_class): Add classes for 12 new DSP registers.
+       (mips_subword): Change to check four HI registers.
+       (mips_output_move): Output move to and from 6 new DSP accumulators.
+       (override_options): Make sure -mdsp and -mips16 are not used together.
+       Map 'A' to DSP_ACC_REGS and 'a' to ACC_REGS.  Enable DSP accumulators
+       for machine modes.
+       (mips_conditional_register_usage): Disable 6 new DSP accumulators
+       when !TARGET_DSP.
+       (print_operand): Add 'q' for printing DSP accumulators.
+       (mips_cannot_change_mode_class): Check ACC_REGS.
+       (mips_secondary_reload_class): Check ACC_REGS.
+       (mips_vector_mode_supported_p): Enable V2HI and V4QI when TARGET_DSP.
+       (mips_register_move_cost): Check ACC_REGS.
+       (CODE_FOR_mips_addq_ph, CODE_FOR_mips_addu_qb, CODE_FOR_mips_subq_ph)
+       (CODE_FOR_mips_subu_qb): New code-aliasing macros.
+       (DIRECT_NO_TARGET_BUILTIN, BPOSGE_BUILTIN): New macros.
+       (dsp_bdesc): New array.
+       (bdesc_arrays): Add DSP builtin function table.
+       (mips_prepare_builtin_arg): Check predicate again after
+       copy_to_mode_reg.
+       (mips_expand_builtin): Add one more parameter to
+       mips_expand_builtin_direct. Expand MIPS_BUILTIN_DIRECT_NO_TARGET and
+       MIPS_BUILTIN_BPOSGE32.
+       (mips_init_builtins): Initialize new function types.
+       (mips_expand_builtin_direct): Check if builtin functions need to
+       return a value and pass operands properly.
+       (mips_expand_builtin_bposge): New function.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Add __mips_dsp.
+       (ASM_SPEC): Map -mdsp to -mdsp in GAS.
+       (FIRST_PSEUDO_REGISTER): Increase to 188.
+       (FIXED_REGISTERS, CALL_USED_REGISTERS, CALL_REALLY_USED_REGISTERS):
+       Update for 12 new DSP registers.
+       (DSP_ACC_REG_FIRST, DSP_ACC_REG_LAST, DSP_ACC_REG_NUM, AC1HI_REGNUM)
+       (AC1LO_REGNUM, AC2HI_REGNUM, AC2LO_REGNUM, AC3HI_REGNUM, AC3LO_REGNUM):
+       (DSP_ACC_REG_P, ACC_REG_P, ACC_HI_REG_P): New macros.
+       (reg_class): Add DSP_ACC_REGS and ACC_REGS.
+       (REG_CLASS_NAMES): Add names for DSP_ACC_REGS and ACC_REGS.
+       (REG_CLASS_CONTENTS): Update for DSP_ACC_REGS, ACC_REGS and ALL_REGS.
+       (REG_ALLOC_ORDER): Update for 12 new DSP registers.
+       (mips_char_to_class): Add 'A' for DSP_ACC_REGS and 'a' for ACC_REGS.
+       (UIMM6_OPERAND, IMM10_OPERAND): New macros.
+       (EXTRA_CONSTRAINT_Y): Add YA and YB extra constraints.
+       (REGISTER_NAMES): Add names for 12 new DSP registers.
+       * config/mips/mips.md: Include mips-dsp.md.
+       (UNSPEC_ADDQ, UNSPEC_ADDQ_S, UNSPEC_SUBQ, UNSPEC_SUBQ_S, UNSPEC_ADDSC)
+       (UNSPEC_ADDWC, UNSPEC_MODSUB, UNSPEC_RADDU_W_QB, UNSPEC_ABSQ_S)
+       (UNSPEC_PRECRQ_QB_PH, UNSPEC_PRECRQ_PH_W, UNSPEC_PRECRQ_RS_PH_W)
+       (UNSPEC_PRECRQU_S_QB_PH, UNSPEC_PRECEQ_W_PHL, UNSPEC_PRECEQ_W_PHR)
+       (UNSPEC_PRECEQU_PH_QBL, UNSPEC_PRECEQU_PH_QBR, UNSPEC_PRECEQU_PH_QBLA)
+       (UNSPEC_PRECEQU_PH_QBRA, UNSPEC_PRECEU_PH_QBL, UNSPEC_PRECEU_PH_QBR)
+       (UNSPEC_PRECEU_PH_QBLA, UNSPEC_PRECEU_PH_QBRA, UNSPEC_SHLL)
+       (UNSPEC_SHLL_S, UNSPEC_SHRL_QB, UNSPEC_SHRA_PH, UNSPEC_SHRA_R)
+       (UNSPEC_MULEU_S_PH_QBL, UNSPEC_MULEU_S_PH_QBR, UNSPEC_MULQ_RS_PH)
+       (UNSPEC_MULEQ_S_W_PHL, UNSPEC_MULEQ_S_W_PHR, UNSPEC_DPAU_H_QBL)
+       (UNSPEC_DPAU_H_QBR, UNSPEC_DPSU_H_QBL, UNSPEC_DPSU_H_QBR)
+       (UNSPEC_DPAQ_S_W_PH, UNSPEC_DPSQ_S_W_PH, UNSPEC_MULSAQ_S_W_PH)
+       (UNSPEC_DPAQ_SA_L_W, UNSPEC_DPSQ_SA_L_W, UNSPEC_MAQ_S_W_PHL)
+       (UNSPEC_MAQ_S_W_PHR, UNSPEC_MAQ_SA_W_PHL, UNSPEC_MAQ_SA_W_PHR)
+       (UNSPEC_BITREV, UNSPEC_INSV, UNSPEC_REPL_QB, UNSPEC_REPL_PH)
+       (UNSPEC_CMP_EQ, UNSPEC_CMP_LT, UNSPEC_CMP_LE, UNSPEC_CMPGU_EQ_QB)
+       (UNSPEC_CMPGU_LT_QB, UNSPEC_CMPGU_LE_QB, UNSPEC_PICK, UNSPEC_PACKRL_PH)
+       (UNSPEC_EXTR_W, UNSPEC_EXTR_R_W, UNSPEC_EXTR_RS_W, UNSPEC_EXTR_S_H)
+       (UNSPEC_EXTP, UNSPEC_EXTPDP, UNSPEC_SHILO, UNSPEC_MTHLIP, UNSPEC_WRDSP)
+       (UNSPEC_RDDSP): New constants.
+       (*movdi_32bit): Change 'x' to 'a' for ACC_REGS.
+       (*movsi_internal): Change 'x' to 'a' for ACC_REGS.  Add an
+       A<-d alternative.
+       * config/mips/mips.opt (-mdsp): New option.
+       * config/mips/predicates.md (const_uimm6_operand, const_imm10_operand)
+       (reg_imm10_operand): New predicates.
+       * doc/extend.texi (MIPS DSP Built-in Functions): New section.
+       * doc/invoke.texi (-mdsp): Document new option.
+
+2005-07-22  DJ Delorie  <dj@redhat.com>
+
+       * c-objc-common.c (c_cannot_inline_tree_fn): Add warning control
+       to warning calls.
+       * tree-inline.c (inlinable_function_p): Likewise.
+
+2005-07-22  Mark Mitchell  <mark@codesourcery.com>
+
+       PR debug/21828
+       * toplev.c (check_global_declarations): Do not mark undefined
+       variables as DECL_IGNORED_P.
+       * varasm.c (first_global_object_name): GTY it.
+       (weak_global_object_name): Likewise.
+       (notice_global_symbol): Use ggc_strdup, not xstrdup, when creating
+       a string to go into {weak,first}_global_object_name.
+
+2005-07-22  DJ Delorie  <dj@redhat.com>
+
+       * c-format.c (check_function_format): Change warning control
+       option from OPT_Wattribute to OPT_Wmissing_format_attribute.
+
+2005-07-22  Diego Novillo  <dnovillo@redhat.com>
+
+       * tree-ssa-alias.c (count_ptr_derefs): Do not consider
+       &PTR->FLD a dereference of PTR.
+       * tree-ssa-structalias.c (update_alias_info): Consider &PTR->FLD
+       a potential dereference of PTR.
+
 2005-07-22  J"orn Rennecke <joern.rennecke@st.com>
 
+       PR rtl-optimization/20370
+       * ifcvt.c (dead_or_predicable): Before calling propagate_block,
+       call allocate_reg_info if necessary.
+
        PR rtl-optimization/21848
        * calls.c (emit_library_call_value_1): For const functions, add
        USEs of the stack slots to CALL_INSN_FUNCTION_USAGE.