diff options
author | law <law@138bc75d-0d04-0410-961f-82ee72b054a4> | 1998-05-21 19:12:20 +0000 |
---|---|---|
committer | law <law@138bc75d-0d04-0410-961f-82ee72b054a4> | 1998-05-21 19:12:20 +0000 |
commit | 3245cd4f3ecba3217d5d170fc67739415880e1cf (patch) | |
tree | dd9220c69002dd9a1d5f1820be3e18c2112c0bec /gcc/final.c | |
parent | aff4ad886056a6d7cda3c7dcd7bf6131b1100582 (diff) | |
download | ppe42-gcc-3245cd4f3ecba3217d5d170fc67739415880e1cf.tar.gz ppe42-gcc-3245cd4f3ecba3217d5d170fc67739415880e1cf.zip |
* acconfig.h (HAVE_GAS_MAX_SKIP_P2ALIGN): New tag.
* configure.in: Check for it.
* i386/gas.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Use it.
* final.c (uid_align, uid_shuid, label_align): Make static.
(label_align): Change type to struct label_alignment pointer.
(LABEL_TO_ALIGNMENT, shorten_branches): Update due to type change.
(LABEL_TO_MAX_SKIP): Define.
(LABEL_ALIGN_MAX_SKIP, LOOP_ALIGN_MAX_SKIP,
LABEL_ALIGN_AFTER_BARRIER_MAX_SKIP): Provide defaults.
(shorten_branches): Record the maximum bytes to skip when
aligning a label.
(final_scan_insn): Use the maximum bytes to skip when aligning a label
if ASM_OUTPUT_MAX_SKIP_ALIGN is available.
* i386.h (LOOP_ALIGN_MAX_SKIP,
LABEL_ALIGN_AFTER_BARRIER_MAX_SKIP): Define.
* i386.c (override_options): i386_align_jumps and i386_align_loops
default to 4 if ASM_OUTPUT_MAX_SKIP_ALIGN is available.
* invoke.texi: Document new i386 align-loops and align-jumps behavior.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@19933 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/final.c')
-rw-r--r-- | gcc/final.c | 69 |
1 files changed, 56 insertions, 13 deletions
diff --git a/gcc/final.c b/gcc/final.c index 9dac1376851..f6f6670f174 100644 --- a/gcc/final.c +++ b/gcc/final.c @@ -649,9 +649,14 @@ int insn_current_align; for each insn we'll call the alignment chain of this insn in the following comments. */ -rtx *uid_align; -int *uid_shuid; -short *label_align; +struct label_alignment { + short alignment; + short max_skip; +}; + +static rtx *uid_align; +static int *uid_shuid; +static struct label_alignment *label_align; /* Indicate that branch shortening hasn't yet been done. */ @@ -794,14 +799,26 @@ get_attr_length (insn) #define LABEL_ALIGN(LABEL) 0 #endif +#ifndef LABEL_ALIGN_MAX_SKIP +#define LABEL_ALIGN_MAX_SKIP 0 +#endif + #ifndef LOOP_ALIGN #define LOOP_ALIGN(LABEL) 0 #endif +#ifndef LOOP_ALIGN_MAX_SKIP +#define LOOP_ALIGN_MAX_SKIP 0 +#endif + #ifndef LABEL_ALIGN_AFTER_BARRIER #define LABEL_ALIGN_AFTER_BARRIER(LABEL) 0 #endif +#ifndef LABEL_ALIGN_AFTER_BARRIER_MAX_SKIP +#define LABEL_ALIGN_AFTER_BARRIER_MAX_SKIP 0 +#endif + #ifndef ADDR_VEC_ALIGN int final_addr_vec_align (addr_vec) @@ -826,7 +843,10 @@ final_addr_vec_align (addr_vec) static int min_labelno, max_labelno; #define LABEL_TO_ALIGNMENT(LABEL) \ - (label_align[CODE_LABEL_NUMBER (LABEL) - min_labelno]) + (label_align[CODE_LABEL_NUMBER (LABEL) - min_labelno].alignment) + +#define LABEL_TO_MAX_SKIP(LABEL) \ + (label_align[CODE_LABEL_NUMBER (LABEL) - min_labelno].max_skip) /* For the benefit of port specific code do this also as a function. */ int @@ -962,6 +982,7 @@ shorten_branches (first) int max_uid; int i; int max_log; + int max_skip; #ifdef HAVE_ATTR_length #define MAX_CODE_ALIGN 16 rtx seq; @@ -1001,10 +1022,10 @@ shorten_branches (first) max_labelno = max_label_num (); min_labelno = get_first_label_num (); - label_align - = (short*) xmalloc ((max_labelno - min_labelno + 1) * sizeof (short)); - bzero ((char *) label_align, - (max_labelno - min_labelno + 1) * sizeof (short)); + label_align = (struct label_alignment *) xmalloc ( + (max_labelno - min_labelno + 1) * sizeof (struct label_alignment)); + bzero (label_align, + (max_labelno - min_labelno + 1) * sizeof (struct label_alignment)); uid_shuid = (int *) xmalloc (max_uid * sizeof *uid_shuid); @@ -1014,7 +1035,10 @@ shorten_branches (first) impose on the next CODE_LABEL (or the current one if we are processing the CODE_LABEL itself). */ - for (max_log = 0, insn = get_insns (), i = 1; insn; insn = NEXT_INSN (insn)) + max_log = 0; + max_skip = 0; + + for (insn = get_insns (), i = 1; insn; insn = NEXT_INSN (insn)) { int log; @@ -1033,7 +1057,10 @@ shorten_branches (first) log = LABEL_ALIGN (insn); if (max_log < log) - max_log = log; + { + max_log = log; + max_skip = LABEL_ALIGN_MAX_SKIP; + } next = NEXT_INSN (insn); /* ADDR_VECs only take room if read-only data goes into the text section. */ #if !defined(READONLY_DATA_SECTION) || defined(JUMP_TABLES_IN_TEXT_SECTION) @@ -1045,12 +1072,17 @@ shorten_branches (first) { log = ADDR_VEC_ALIGN (next); if (max_log < log) - max_log = log; + { + max_log = log; + max_skip = LABEL_ALIGN_MAX_SKIP; + } } } #endif LABEL_TO_ALIGNMENT (insn) = max_log; + LABEL_TO_MAX_SKIP (insn) = max_skip; max_log = 0; + max_skip = 0; } else if (GET_CODE (insn) == BARRIER) { @@ -1062,7 +1094,10 @@ shorten_branches (first) { log = LABEL_ALIGN_AFTER_BARRIER (insn); if (max_log < log) - max_log = log; + { + max_log = log; + max_skip = LABEL_ALIGN_AFTER_BARRIER_MAX_SKIP; + } break; } } @@ -1078,7 +1113,10 @@ shorten_branches (first) { log = LOOP_ALIGN (insn); if (max_log < log) - max_log = log; + { + max_log = log; + max_skip = LOOP_ALIGN_MAX_SKIP; + } break; } } @@ -2222,9 +2260,14 @@ final_scan_insn (insn, file, optimize, prescan, nopeepholes) if (CODE_LABEL_NUMBER (insn) <= max_labelno) { int align = LABEL_TO_ALIGNMENT (insn); + int max_skip = LABEL_TO_MAX_SKIP (insn); if (align && NEXT_INSN (insn)) +#ifdef ASM_OUTPUT_MAX_SKIP_ALIGN + ASM_OUTPUT_MAX_SKIP_ALIGN (file, align, max_skip); +#else ASM_OUTPUT_ALIGN (file, align); +#endif } CC_STATUS_INIT; if (prescan > 0) |