- 14 Aug, 2000 1 commit
-
-
law authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35678 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 11 Aug, 2000 1 commit
-
-
law authored
(emit_a_rotate): Likewise. (h8300_adjust_insn_length): Add support for the rotate insns. * h8300.md (rotlqi3): New. (*rotlqi3_1): Likewise. (rotlhi3): Likewise. (*rotlhi3_1): Likewise. (rotlhi3): Likewise. (*rotlhi3_1): Likewise. * h8300-proto.h: Add prototypes for expand_a_rotate and emit_a_rotate. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35616 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 08 Aug, 2000 1 commit
-
-
law authored
* h8300.h: Likewise. * h8300.md: Likewise. (movsi_h8300hs): Fix formatting of the resulting assembly code. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35575 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 01 Aug, 2000 1 commit
-
-
law authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35397 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 31 Jul, 2000 1 commit
-
-
law authored
(emit_a_shift): Rearrange code to improve readability. * h8300.md (movsi_h8300hs): Rearrange code to improve readability. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35375 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 20 Jul, 2000 1 commit
-
-
law authored
* h8300.h (OK_FOR_T): New. (EXTRA_CONSTRAINT): Support OK_FOR_T. * h8300.md: Use inc/dec.[wl] for increment/decrement by 1 and 2 in HI and SI modes. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35155 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 17 Jul, 2000 1 commit
-
-
law authored
(movsi_h8300hs): Output a tab after stmac instead of a space. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@35085 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 18 May, 2000 2 commits
-
-
rth authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@33986 138bc75d-0d04-0410-961f-82ee72b054a4
-
rth authored
(small_power_of_two): Likewise; use exact_log2. (adds_subs_operand, one_insn_adds_subs_operand): Remove. (output_adds_subs): Remove. (two_insn_adds_subs_operand): New. (split_adds_subs): New. * config/h8300/h8300-protos.h: Update. * config/h8300/h8300.h (CONST_OK_FOR_J): Cast to uns HOST_WIDE_INT. (CONST_OK_FOR_L): Match strict adds operands. (CONST_OK_FOR_N): Match struct subs operands. * config/h8300/h8300.md (adds_subs insns): Remove. (addhi patterns): Output adds/subs directly. (addsi_h8300h): Likewise. (addhi/addsi splitters): New. Decompose two_insn_adds_subs_operand. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@33985 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 26 Feb, 2000 1 commit
-
-
law authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@32194 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 14 Jan, 2000 1 commit
-
-
ghazi authored
* h8300.c: Include tm_p.h. Add static prototypes. Fix compile time warnings. * h8300.h: Move prototypes to h8300-protos.h. Fix compile time warnings. * h8300.md: Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@31426 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 16 Dec, 1999 1 commit
-
-
law authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@30969 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 22 Mar, 1999 1 commit
-
-
vmakarov authored
* config/h8300/h8300.md (adjust_length): New attribute. (modhi3+1, andsi3+1, iorsi3+1, extzv+1, extzv+2): Change insn default value of attribute "adjust_length" onto "no". * config/h8300/h8300.c (h8300_adjust_insn_length): Use 0 if the shift is negative. * final.c (shorten_branches): Check insn length after its adjusting. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@25895 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 12 Feb, 1999 1 commit
-
-
law authored
* h8300.md (zero_extendhisi2 H8/300 variant): Correctly handle extending a CONST_INT. * h8300.md (peephole for combining memrefs): Delete incorrect peephole. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@25168 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 01 Jul, 1998 1 commit
-
-
raeburn authored
* h8300.md (branch_true, branch_false): Use %= with a prefix instead of %L for local branch labels. Prevents emitting of "tl###" labels that are not assembler-temporary and thus confuse gdb. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@20881 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 06 May, 1997 1 commit
-
-
law authored
(shift_one, shift_two): Set CC_NO_CARRY as needed. Remove references to CC_OVERFLOW_0. (emit_a_shift): Similarly. * h8300.h (CC_OVERFLOW_0): Remove. * h8300.md: Use set_zn and set_znv for cc0 tracking. (bCC): Restore the comparison is CC_OVERFLOW_UNUSABLE is set and the comparison needs the overflow bits. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@14020 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 26 Sep, 1996 1 commit
-
-
law authored
(ARG_POINTER_REGNUM): Likewise. (FIXED_REGISTERS): Add entry for MAC register. (CALL_USED_REGISTERS< REG_ALLOC_ORDER): Likewise. (HARD_REGNO_NREGS): Handle MAC register. (HARD_REGNO_MODE_OK< REGNO_OK_FOR_BASE_P): LIkewise. (REGISTER_NAMES): Likewise. (enum reg_class): New MAC_REGS register class. (REG_CLASS_CONTENTS, REGNO_REG_CLASS): Corresponding changes. (REG_CLASS_FROM_LETTER): LIkewise. (REGISTER_MOVE_COST): Make copies to/from the MAC register expenseive. (CONDITIONAL_REGISTER_USAGE): Define. * h8300/h8300.md (movsi_h8300hs): Renamed from movsi_h8300h. Handle moves to/from the MAC register. (mac): Two new patterns to use the mac instruction. * h8300/h8300.c (notice_update_cc): Fix CC_SET case. (restore_compare_p): Remove unused function. * h8300/h8300.md: Handle "set" vs "set_zn_c0" correctly. (bCC patterns): No longer need to call restore_compare_p. * h8300/h8300.c (get_shift_alg): Fix HImode ASHIFTRT by 13 or 14 bits. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@12848 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 08 Jul, 1996 1 commit
-
-
law authored
* h8300/h8300.c (h8300_init_once): Handle the H8/S (treat it like the H8/300H). (dosize, adds_subs_operand, one_insn_adds_subs_operand): Likewise. (output_adds_subs, const_costs, print_operand): Likewise. (output_simode_bld, h8300_adjust_insn_length): Likewise. (push_order, pop_order): Reverse. (function_prologue): Try to use ldm.l and stm.l insns on the H8/S. Minor cleanups. (function_epilogue): Likewise. (asm_file_start): Emit ".h8300s" when compiling for the H8/S. * h8300/h8300.h (CPP_SPEC): Handle the H8/S. (TARGET_H8300S): New target. (TARGET_SWITCHES): Add "-ms" and "-mno-s". (BITS_PER_WORD): Handle the H8/S (treat it like the H8/300H). (UNITS_PER_WORD, POINTER_SIZE, PARM_BOUNDARY): Likewise. (BIGGEST_ALIGNMENT, BIGGEST_FIELD_ALIGNMENT): Likewise. (INITIALIZE_TRAMPOLINE, MOVE_MAX, Pmode): Likewise. * h8300/h8300.md: Handle H8/S just like H8/300H throughout the entire file. * h8300/t-h8300 (MULTILIB_OPTIONS): Build "-ms" libraries too. (MULTILIB_DIRNAMES): Put H8/S libraries in "h8300s" directory. * h8300/lib1funcs.asm: Emit ".h8300s" pseudo-op when generating h8300s object files. Otherwise treat the H8/S just like the H8/300H. * ginclude/stdarg.h: Handle the H8/S. * ginclude/varargs.h: Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@12410 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 23 May, 1996 1 commit
-
-
law authored
on the H8/300H. * h8300.md: Use "m" rather than "o" constraint everywhere appropriate. Cleanup use of "i" and "n" constraints. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@12081 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 22 May, 1996 1 commit
-
-
law authored
(mod patterns): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@12072 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 08 May, 1996 1 commit
-
-
law authored
(bit_memory_operand): New function. (print_operand): Append ":16" to a memory reference to the tiny data area. (h8300_tiny_data_p): New function. (h8300_valid_machine_decl_attribute): Accept "tiny_data". Fix typo. (h8300_encode_label): New function. (h8300_adjust_insn_length): References to the tiny data section are two bytes shorter than normal accesses on the H8/300H. * h8300/h8300.h (OK_FOR_U): Fix thinko. (ENCODE_SECTION_INFO): Encode info for tiny data variables. (STRIP_NAME_ENCODING): Define. * h8300/h8300.md (movqi insn): Fix length for a constant load. (movstrictqi): Likewise. (movhi, movstricthi): Likewise. (memory btst patterns): Add register to the constraints to keep reload happy. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11955 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 07 May, 1996 1 commit
-
-
law authored
is a valid U operand if SYMBOL_REF_FLAG is set on the SYMBOL_REF. * h8300/h8300.md (memory btst patterns): New patterns. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11954 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 01 May, 1996 2 commits
-
-
law authored
shifts by small constant values. * h8300/h8300.md: Refine comments. Remove names from many patterns which don't need them. (compare insns): Don't underestimate lengths. (andqi3 expander): Remove constrains. (andhi3): Don't underestimate length. (andsi3): Don't underestimate length. Improve code when upper or lower half of destination is being cleared. (indirect_jump_h8300, indirect_jump_h8300h): Simplify. (shift insns): Remove useless "I" constraint. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11912 138bc75d-0d04-0410-961f-82ee72b054a4
-
law authored
all references. (bcs insns): Delete. No longer needed. (setcc from bitfield): Rewrite to use zero_extract. Provide QImode, HImode and SImode variants. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11910 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 30 Apr, 1996 1 commit
-
-
law authored
(h8300_adjust_insn_length): New function. * h8300/h8300.h (ADJUST_INSN_LENGTH): Define. * h8300/h8300.md: Remove obsolete comments. (move patterns): Tweak constraints. (tst patterns): Use "register_operand" for predicate. (adds pattern): Use one_insn_adds_subs_operand to get length computation correct. (subs pattern): Similarly. (movstrhi): Remove unused expander. (fancy*, pxor, and-not patterns): Remove. No longer needed. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11907 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 29 Apr, 1996 1 commit
-
-
law authored
%r7 byte registers. (rtx_equal_function_value_matters): Remove extra declaration. (output_simode_bld): New function. * h8300/h8300.h (NO_FUNCTION_CSE): Do define this. Register pressure makes cse-int function addresses rarely a win. (reg_class): Remove unnecessary register classes LONG_REGS, SP_REG, SP_AND_G_REGS. (REG_CLASS_NAMES): Corresponding changes. (REG_CLASS_CONTENTS): Corresponding changes. (REGNO_REG_CLASS): Corresponding changes. (REG_CLASS_FROM_LETTER): Corresponding chagnes. (output_simode_bld): Declare. * h8300/h8300.md: Nuke comments for stuff which has been fixed. (all patterns): Remove references to register class "a" (SP_REGS) which no longer exists. (many patterns): Accept auto-inc auto-dec addresses in more cases. (zero_extendqisi2): New pattern for the H8/300. (zero_extendhisi2): Only use zero_extendhisi2_h8300 when not optimizing. (extendhisi2): Only use extendhisi2_h8300 when not optimizing. (extendqisi2): New pattern for the H8/300. (bitfield related patterns): Completely rewrite. (fancy_bclr, fancy_btst): Deleted. Redundant with new bitfield patterns. (addhi3 pattern for h8300): Handle case where we can't make matching constraints (works around hard to fix reload problem). (stack_pointer_manip): Delete. (and not patterns): New combiner patterns. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11902 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 18 Apr, 1996 1 commit
-
-
law authored
except those which have varying length branches. Eliminate obsolete "type" attributes. Add additional comments about insn length computation problems and further optimizations. Add "length" and "cc" attributes to insns without them, fix a few length computations. Remove patterns which are commented out. * h8300/h8300.md (zero extension expanders and insns): Simplify, fix various length problems, provide optimized versions for the h8300 and h8300h. (sign extension expanders and insns): Likewise. Make them nearly identical to zero_extension patterns and insns. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11849 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 16 Apr, 1996 1 commit
-
-
law authored
meets the 'J' constraint, then only two bytes are needed for this insn. Improve code generated for the h8300h when both operands are registers. (iorhi3, xorhi3): Likewise. Rework to be nearly identical to andhi3. (andsi3): If 2nd operand is a CONST_INT that meets the 'J' constraint, then only two bytes are need for this insn. Improve code generated for the h8300h regardless of the type of the 2nd operand. Make this pattern work on the h8300 too. (iorsi3, xorsi3): Likewise. Rework to be nearly identical to andsi3. (iorqi3_internal): Make this pattern look more like andqi3_internal. (one_cmplhi2, one_cmplsi2): Fix length computation for H8300H. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11830 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 13 Apr, 1996 2 commits
-
-
law authored
* h8300/h8300.md (subhi3): Turn into a define_expand. (subhi3 using adds_subs): New pattern. (H8300 subhi): Derived from old subhi pattern. Simplified. (H8300H subhi): Likewise. (subsi using adds_subs): New pattern. Only used on H8300H. (subsi_h8300): Allow "a" registers as destination. (subsi_h8300h): Allow "a" registers as destination. Simplify. * h8300/h8300.md (bcs_qiqi, bcs_hihi, bs_hiqi): Fix thinkos in last change. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11754 138bc75d-0d04-0410-961f-82ee72b054a4
-
law authored
wrong, stupid, or just don't make any sense yet. * h8300.c (adds_subs_operand): New function. (output_adds_subs): New function. * h8300.md (addhi3): Turn into a define_expand. (addhi3 using adds_subs): New pattern. (H8300 addhi): Derived from old addhi pattern. Simplified. (H8300H addhi): Likewise. (addsi using adds_subs): New pattern. Only used on H8300H. (addsi_h8300): Allow "a" registers as destination. (addsi_h8300h): Simplify. Allow "a" registers as destination. * h8300.md (bcs): New attribute type. (default_length): Compute correct length for bcs insns. (bcs_qiqi, bcs_hihi, bs_hiqi): Use new type and update to account for correct length computation. * h8300.md (movhi_internal): Demand at least one operand to be a register. (movsi_h8300): Optimize loading certain constants. (movsi_h8300h): Likewise. * h8300.h (NO_FUNCTION_CSE): Comment out. (FUNCTION_ARG_REGNO_P): Properly define for TARGET_QUICKCALL. (RETURN_IN_MEMORY): Don't return small structs in regs. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11751 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 12 Apr, 1996 1 commit
-
-
law authored
the 8-bit area. Make code for 'Y' fall into code for 'R' when operand is not a register. Update some comments. (h8300_tiny_data_p): New function. (h8300_valid_machine_decl_attribute): Handle "tiny_data" attribute. * h8300/h8300.h (OK_FOR_U): Handle memory references into the 8-bit area. (ENCODE_SECTION_INFO): Mark SYMBOL_REFs which refer to the 8-bit area. * h8300/h8300.md (many patterns): Use 'R' rather than 'X' for operands that may be memory accesses into the 8-bit area. (btst pattern): New pattern to set the cc0 (zbit) based on data in the 8-bit area. * h8300/h8300.md (one_cmplsi2): Fix length computation for h8300h. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11707 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 03 Apr, 1996 2 commits
-
-
law authored
* h8300.c (h8300_funcvec_function_p): Declaration removed from here. * h8300.md (tstqi): Tweak to work like other tstXX patterns. (cmphi): Turn into a define_expand. Add two anonymous matterns to match the output of the cmphi expander. (cmpsi): Accept constants as the second input operand. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11656 138bc75d-0d04-0410-961f-82ee72b054a4
-
law authored
lengths and simplify by reordering remaining alternatives. (movestrictqi, movhi_internal, movstricthi): Likewise. (movsi_h8300h, movsf_h8300h): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11655 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 01 Apr, 1996 1 commit
-
-
law authored
All references changed. (function_prologue): Set interrupt_handler if the current function has the "interrrupt-handler" attribute. (small_call_insn_operand): New function. (h8300_interrrupt_function_p): New function. (h8300_funcvec_function_p): New function. (h8300_valid_machine_decl_attribute): New function. * h8300.h (VALID_MACHINE_DECL_ATTRIBUTE): Define. * h8300.md (call insns): Handle calls through the function vector. Indirect calls and calls through the function vector have a length of two bytes. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11650 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 11 Mar, 1996 1 commit
-
-
dje authored
(CC_DONE_CBIT): Delete. (CC_OVERFLOW_0,CC_OVERFLOW_UNUSABLE,CC_NO_CARRY): Define. * h8300/h8300.c (cond_string): Delete CC_DONE_CBIT handling. (notice_update_cc): Delete CC_CBIT, CC_WHOOPS. Add CC_SET_ZN_C0. (restore_compare_p): New function. (shift_one): Use shll instead of shal so overflow bit is usable. Set cc_valid bits to cc_status.flags values. (emit_a_shift): Set cc_status.flags. * h8300/h8300.md (attr cc): Delete whoops,cbit. Add set_zn_c0. (all patterns) Update cc attr setting. (tstqi,tsthi,tstsi): Delete CC_DONE_CBIT handling. (addhi3,subhi3): Change define_expand to define_insn. (branch_true,branch_false): Check if compare needs to be restored. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@11514 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 28 Aug, 1995 1 commit
-
-
kenner authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@10289 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 19 Aug, 1995 1 commit
-
-
kenner authored
attribute to work. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@10249 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 15 Jun, 1995 2 commits
-
-
kenner authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@9986 138bc75d-0d04-0410-961f-82ee72b054a4
-
kenner authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@9985 138bc75d-0d04-0410-961f-82ee72b054a4
-
- 22 May, 1995 1 commit
-
-
dje authored
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@9774 138bc75d-0d04-0410-961f-82ee72b054a4
-