mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-15 04:31:49 +08:00
b8891f8d62
This patch series is a new binutils port for C-SKY processors, including support for both the V1 and V2 processor variants. V1 is derived from the MCore architecture while V2 is substantially different, with mixed 16- and 32-bit instructions, a larger register set, a different (but overlapping) ABI, etc. There is support for bare-metal ELF targets and Linux with both glibc and uClibc. This code is being contributed jointly by C-SKY Microsystems and Mentor Graphics. C-SKY is responsible for the technical content and has proposed Lifang Xia and Yunhai Shang as port maintainers. (Note that C-SKY does have a corporate copyright assignment on file with the FSF.) Mentor Graphics' role has been cleaning up the code, adding documentation and additional test cases, etc, to address issues we anticipated reviewers would complain about. bfd * Makefile.am (ALL_MACHINES, ALL_MACHINES_CFILES): Add C-SKY. (BFD32_BACKENDS, BFD_BACKENDS_CFILES): Likewise. * Makefile.in: Regenerated. * archures.c (enum bfd_architecture): Add bfd_arch_csky and related bfd_mach defines. (bfd_csky_arch): Declare. (bfd_archures_list): Add C-SKY. * bfd-in.h (elf32_csky_build_stubs): Declare. (elf32_csky_size_stubs): Declare. (elf32_csky_next_input_section: Declare. (elf32_csky_setup_section_lists): Declare. * bfd-in2.h: Regenerated. * config.bfd: Add C-SKY. * configure.ac: Likewise. * configure: Regenerated. * cpu-csky.c: New file. * elf-bfd.h (enum elf_target_id): Add C-SKY. * elf32-csky.c: New file. * libbfd.h: Regenerated. * reloc.c: Add C-SKY relocations. * targets.c (csky_elf32_be_vec, csky_elf32_le_vec): Declare. (_bfd_target_vector): Add C-SKY target vector entries. binutils* readelf.c: Include elf/csky.h. (guess_is_rela): Handle EM_CSKY. (dump_relocations): Likewise. (get_machine_name): Likewise. (is_32bit_abs_reloc): Likewise. include * dis-asm.h (csky_symbol_is_valid): Declare. * opcode/csky.h: New file. opcodes * Makefile.am (TARGET_LIBOPCODES_CFILES): Add csky-dis.c. * Makefile.in: Regenerated. * configure.ac: Add C-SKY. * configure: Regenerated. * csky-dis.c: New file. * csky-opc.h: New file. * disassemble.c (ARCH_csky): Define. (disassembler, disassemble_init_for_target): Add case for ARCH_csky. * disassemble.h (print_insn_csky, csky_get_disassembler): Declare. gas * Makefile.am (TARGET_CPU_CFILES): Add entry for C-SKY. (TARGET_CPU_HFILES, TARGET_ENV_HFILES): Likewise. * Makefile.in: Regenerated. * config/tc-csky.c: New file. * config/tc-csky.h: New file. * config/te-csky_abiv1.h: New file. * config/te-csky_abiv1_linux.h: New file. * config/te-csky_abiv2.h: New file. * config/te-csky_abiv2_linux.h: New file. * configure.tgt: Add C-SKY. * doc/Makefile.am (CPU_DOCS): Add entry for C-SKY. * doc/Makefile.in: Regenerated. * doc/all.texi: Set CSKY feature. * doc/as.texi (Overview): Add C-SKY options. (Machine Dependencies): Likewise. * doc/c-csky.texi: New file. * testsuite/gas/csky/*: New test cases. ld * Makefile.am (ALL_EMULATION_SOURCES): Add C-SKY emulations. (ecskyelf.c, ecskyelf_linux.c): New rules. * Makefile.in: Regenerated. * configure.tgt: Add C-SKY. * emulparams/cskyelf.sh: New file. * emulparams/cskyelf_linux.sh: New file. * emultempl/cskyelf.em: New file. * gen-doc.texi: Add C-SKY. * ld.texi: Likewise. (Options specific to C-SKY targets): New section. * testsuite/ld-csky/*: New tests.
35 lines
1.1 KiB
Bash
35 lines
1.1 KiB
Bash
SCRIPT_NAME=elf
|
|
OUTPUT_FORMAT="elf32-csky-little"
|
|
BIG_OUTPUT_FORMAT="elf32-csky-big"
|
|
LITTLE_OUTPUT_FORMAT="elf32-csky-little"
|
|
NO_REL_RELOCS=yes
|
|
PAGE_SIZE=0x1000
|
|
TARGET_PAGE_SIZE=0x400
|
|
MAXPAGESIZE="CONSTANT (MAXPAGESIZE)"
|
|
TEXT_START_ADDR=0x8000
|
|
CHECK_RELOCS_AFTER_OPEN_INPUT=yes
|
|
NONPAGED_TEXT_START_ADDR=0
|
|
ARCH=csky
|
|
EMBEDDED=yes
|
|
EXTRA_EM_FILE=cskyelf
|
|
|
|
# There is a problem with the NOP value - it must work for both
|
|
# big endian and little endian systems. Unfortunately there is
|
|
# no symmetrical mcore opcode that functions as a noop. The
|
|
# chosen solution is to use "tst r0, r14". This is a symmetrical
|
|
# value, and apart from the corruption of the C bit, it has no other
|
|
# side effects. Since the carry bit is never tested without being
|
|
# explicitly set first, and since the NOP code is only used as a
|
|
# fill value between independently viable pieces of code, it should
|
|
# not matter.
|
|
NOP=0
|
|
|
|
ENTRY=__start
|
|
OTHER_BSS_SYMBOLS="__bss_start__ = . ;"
|
|
OTHER_BSS_END_SYMBOLS="__bss_end__ = . ;"
|
|
|
|
# This sets the stack to the top of the simulator memory (2^19 bytes).
|
|
# STACK_ADDR=0x80000
|
|
|
|
TEMPLATE_NAME=elf32
|