mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-02-23 13:21:43 +08:00
m32c_md_end attempted to pad out a code section with nops, but this was just plain wrong in many ways: - The padding didn't happen at all if the last section emitted wasn't a code section. - The padding went to the wrong place if subsections were used, and the last subseg used wasn't the highest numbered subseg. - Padding wasn't added to all code sections. - If the last section was empty, it was padded to 4 bytes. - The padding didn't go to a 4-byte alignment boundary, instead it effectively made the last instruction 4 bytes in size. - The padding didn't take into account that code sections may have contents other than machine instructions. So, rip it out and handle nop padding properly, also fixing .align .balign/.p2align in the middle of code. gas/ * config/tc-m32c.c (insn_size): Delete static var. (md_begin): Don't set it. (m32c_md_end): Delete. (md_assemble): Add insn_size auto var. * config/tc-m32c.h (md_end): Don't define. (m32c_md_end): Delete. (NOP_OPCODE, HANDLE_ALIGN, MAX_MEM_FOR_RS_ALIGN_CODE): Define. * testsuite/gas/all/align.d: Remove m32c from notarget list. * testsuite/gas/all/incbin.d: Likewise. * testsuite/gas/elf/dwarf2-11.d: Likewise. * testsuite/gas/macros/semi.d: Likewise. * testsuite/gas/all/gas.exp (do_comment): Similarly. ld/ * testsuite/ld-scripts/fill.d: Don't xfail m32c * testsuite/ld-scripts/fill16.d: Likewise. |
||
---|---|---|
.. | ||
config | ||
ld-aarch64 | ||
ld-alpha | ||
ld-arc | ||
ld-arm | ||
ld-auto-import | ||
ld-avr | ||
ld-bootstrap | ||
ld-cdtest | ||
ld-checks | ||
ld-cris | ||
ld-crx | ||
ld-csky | ||
ld-cygwin | ||
ld-d10v | ||
ld-discard | ||
ld-elf | ||
ld-elfcomm | ||
ld-elfvers | ||
ld-elfvsb | ||
ld-elfweak | ||
ld-fastcall | ||
ld-frv | ||
ld-gc | ||
ld-h8300 | ||
ld-i386 | ||
ld-ia64 | ||
ld-ifunc | ||
ld-libs | ||
ld-linkonce | ||
ld-m68hc11 | ||
ld-m68k | ||
ld-mep | ||
ld-metag | ||
ld-mips-elf | ||
ld-misc | ||
ld-mmix | ||
ld-mn10300 | ||
ld-msp430-elf | ||
ld-nds32 | ||
ld-nios2 | ||
ld-or1k | ||
ld-pe | ||
ld-pie | ||
ld-plugin | ||
ld-powerpc | ||
ld-pru | ||
ld-riscv-elf | ||
ld-s12z | ||
ld-s390 | ||
ld-scripts | ||
ld-selective | ||
ld-sh | ||
ld-shared | ||
ld-size | ||
ld-sparc | ||
ld-spu | ||
ld-srec | ||
ld-tic6x | ||
ld-tilegx | ||
ld-tilepro | ||
ld-undefined | ||
ld-unique | ||
ld-v850 | ||
ld-vax-elf | ||
ld-visium | ||
ld-vxworks | ||
ld-x86-64 | ||
ld-xc16x | ||
ld-xstormy16 | ||
ld-xtensa | ||
ld-z8k | ||
lib | ||
ChangeLog-2004 | ||
ChangeLog-2005 | ||
ChangeLog-2006 | ||
ChangeLog-2007 | ||
ChangeLog-2008 | ||
ChangeLog-2009 | ||
ChangeLog-2010 | ||
ChangeLog-2011 | ||
ChangeLog-2012 | ||
ChangeLog-2013 | ||
ChangeLog-2014 | ||
ChangeLog-2015 | ||
ChangeLog-9303 |