mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-11-16 12:34:43 +00:00
On x86, MAX_MEM_FOR_RS_ALIGN_CODE is 35, when the most common
alignment is 2**3 or 2**4, where the max memory required for the
alignment nops is 7 and 15 bytes respectively. So there is some
memory wasted since commit 83d94ae428. It's not a large amount,
especially considering that frag overhead on x86_46 is 144 bytes,
but even so I'd rather not be blamed for increasing gas memory usage.
So to reduce the memory we'd like to take the alignment into
consideration when initialising an rs_align_code frag. The only
difficulty here is start_bundle making an rs_align_code frag with an
alignment of zero initially, then later increasing the alignment. We
change that to use the bundle alignment when setting up the frag. I
think that is sufficient as bundle_align_p2 can't change in the middle
of a start_bundle/finish_bundle sequence.
I haven't modified any targets other than x86 in this patch. Most
won't benefit much due to using fairly small MAX_MEM_FOR_RS_ALIGN_CODE.
* read.c (start_bundle): Create rs_align_code frag with
bundle_align_p2 alignment, then set to zero alignment.
(finish_bundle): Adjust comment.
* frags.c (MAX_MEM_FOR_RS_ALIGN_CODE): Pass p2align and max
to macro.
* config/tc-i386.h (HANDLE_ALIGN): Assert that max_bytes is
sufficient for nop padding.
(max_mem_for_rs_align_code): New inline function.
(MAX_MEM_FOR_RS_ALIGN_CODE): Use it.
* config/tc-aarch64.h: Adjust MAX_MEM_FOR_RS_ALIGN_CODE.
* config/tc-alpha.h: Likewise.
* config/tc-arc.h: Likewise.
* config/tc-arm.h: Likewise.
* config/tc-epiphany.h: Likewise.
* config/tc-frv.h: Likewise.
* config/tc-ia64.h: Likewise.
* config/tc-kvx.h: Likewise.
* config/tc-loongarch.h: Likewise.
* config/tc-m32r.h: Likewise.
* config/tc-metag.h: Likewise.
* config/tc-mips.h: Likewise.
* config/tc-nds32.h: Likewise.
* config/tc-ppc.h: Likewise.
* config/tc-riscv.h: Likewise.
* config/tc-rl78.h: Likewise.
* config/tc-rx.h: Likewise.
* config/tc-score.h: Likewise.
* config/tc-sh.h: Likewise.
* config/tc-sparc.h: Likewise.
* config/tc-spu.h: Likewise.
* config/tc-tilegx.h: Likewise.
* config/tc-tilepro.h: Likewise.
* config/tc-visium.h: Likewise.
* config/tc-xtensa.h: Likewise.
116 lines
4.0 KiB
C
116 lines
4.0 KiB
C
/* tc-rx.h - header file for Renesas RX
|
|
Copyright (C) 2008-2025 Free Software Foundation, Inc.
|
|
|
|
This file is part of GAS, the GNU Assembler.
|
|
|
|
GAS is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
GAS is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GAS; see the file COPYING. If not, write to the Free
|
|
Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
|
|
02110-1301, USA. */
|
|
|
|
#define TC_RX
|
|
|
|
extern int target_big_endian;
|
|
|
|
#define LISTING_HEADER (target_big_endian ? "RX GAS BE" : "RX GAS LE")
|
|
#define LISTING_LHS_WIDTH 8
|
|
#define LISTING_WORD_SIZE 1
|
|
|
|
#define TARGET_ARCH bfd_arch_rx
|
|
|
|
/* Instruction bytes are big endian, data bytes can be either. */
|
|
#define TARGET_BYTES_BIG_ENDIAN 0
|
|
|
|
#ifndef TE_LINUX
|
|
#define TARGET_FORMAT (target_big_endian ? "elf32-rx-be" : "elf32-rx-le")
|
|
#else
|
|
#define TARGET_FORMAT "elf32-rx-linux"
|
|
#endif
|
|
|
|
/* We don't need to handle .word strangely. */
|
|
#define WORKING_DOT_WORD
|
|
|
|
/* Permit temporary numeric labels. */
|
|
#define LOCAL_LABELS_FB 1
|
|
/* But make sure that the binutils treat them as locals. */
|
|
#define LOCAL_LABEL_PREFIX '.'
|
|
|
|
/* Allow classic-style constants. */
|
|
#define NUMBERS_WITH_SUFFIX 1
|
|
|
|
/* .-foo gets turned into PC relative relocs. */
|
|
#define DIFF_EXPR_OK
|
|
|
|
#define md_end rx_md_end
|
|
extern void rx_md_end (void);
|
|
|
|
/* Note - the definition of MD_RELAX_FRAG here includes a reference to the
|
|
MAX_ITERATIONS variable which is defined locally in write.c:relax_segment()
|
|
but which is not normally passed to target specific relaxing code. This
|
|
reference is needed however as the number of iterations of the RX relaxing
|
|
code needs to be constrained by the maximum number of iterations allowed
|
|
by relax_segment(). See PR 24464 for more details. */
|
|
#define md_relax_frag(SEG, FRAGP, STRETCH) \
|
|
rx_relax_frag ((SEG), (FRAGP), (STRETCH), max_iterations)
|
|
extern int rx_relax_frag (segT, fragS *, long, unsigned long);
|
|
|
|
#define TC_FRAG_TYPE struct rx_bytesT *
|
|
#define TC_FRAG_INIT(fragp, max_bytes) rx_frag_init (fragp)
|
|
extern void rx_frag_init (fragS *);
|
|
|
|
/* Call md_pcrel_from_section(), not md_pcrel_from(). */
|
|
#define MD_PCREL_FROM_SECTION(FIXP, SEC) md_pcrel_from_section (FIXP, SEC)
|
|
|
|
/* RX doesn't have a 32 bit PCREL relocations. */
|
|
#define TC_FORCE_RELOCATION_SUB_LOCAL(FIX, SEG) 1
|
|
|
|
#define TC_VALIDATE_FIX_SUB(FIX, SEG) \
|
|
rx_validate_fix_sub (FIX)
|
|
extern int rx_validate_fix_sub (struct fix *);
|
|
|
|
#define TC_CONS_FIX_NEW(FRAG, WHERE, NBYTES, EXP, RELOC) \
|
|
rx_cons_fix_new (FRAG, WHERE, NBYTES, EXP, RELOC)
|
|
extern void rx_cons_fix_new (fragS *, int, int, expressionS *,
|
|
bfd_reloc_code_real_type);
|
|
|
|
#define tc_fix_adjustable(x) 0
|
|
|
|
#define md_do_align(n, fill, len, max, around) \
|
|
if ((n) \
|
|
&& !need_pass_2 \
|
|
&& (!(fill) \
|
|
|| ((char)*(fill) == (char)0x03 && (len) == 1)) \
|
|
&& subseg_text_p (now_seg)) \
|
|
{ \
|
|
frag_align_code ((n), (max)); \
|
|
goto around; \
|
|
}
|
|
|
|
#define MAX_MEM_FOR_RS_ALIGN_CODE(p2align, max) 8
|
|
#define HANDLE_ALIGN(SEC, FRAG) rx_handle_align (FRAG)
|
|
extern void rx_handle_align (fragS *);
|
|
|
|
#define RELOC_EXPANSION_POSSIBLE 1
|
|
#define MAX_RELOC_EXPANSION 4
|
|
|
|
#define elf_tc_final_processing rx_elf_final_processing
|
|
extern void rx_elf_final_processing (void);
|
|
|
|
extern bool rx_use_conventional_section_names;
|
|
#define TEXT_SECTION_NAME (rx_use_conventional_section_names ? ".text" : "P")
|
|
#define DATA_SECTION_NAME (rx_use_conventional_section_names ? ".data" : "D_1")
|
|
#define BSS_SECTION_NAME (rx_use_conventional_section_names ? ".bss" : "B_1")
|
|
|
|
#define md_start_line_hook rx_start_line
|
|
extern void rx_start_line (void);
|