mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +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.
111 lines
1.9 KiB
Plaintext
111 lines
1.9 KiB
Plaintext
@c Copyright (C) 1992-2018 Free Software Foundation, Inc.
|
|
@c This file is part of the documentation for the GAS manual
|
|
|
|
@c Configuration settings for all-inclusive version of manual
|
|
|
|
@c switches:------------------------------------------------------------
|
|
@c Properties of the manual
|
|
@c ========================
|
|
@c Discuss all architectures?
|
|
@set ALL-ARCH
|
|
@c A generic form of manual (not tailored to specific target)?
|
|
@set GENERIC
|
|
@c Include text on assembler internals?
|
|
@clear INTERNALS
|
|
@c Many object formats supported in this config?
|
|
@set MULTI-OBJ
|
|
|
|
@c Object formats of interest
|
|
@c ==========================
|
|
@set AOUT
|
|
@set COFF
|
|
@set ELF
|
|
@set SOM
|
|
|
|
@c CPUs of interest
|
|
@c ================
|
|
@set AARCH64
|
|
@set ALPHA
|
|
@set ARC
|
|
@set ARM
|
|
@set AVR
|
|
@set Blackfin
|
|
@set CR16
|
|
@set CRIS
|
|
@set CSKY
|
|
@set D10V
|
|
@set D30V
|
|
@set EPIPHANY
|
|
@set H8/300
|
|
@set HPPA
|
|
@set I370
|
|
@set I80386
|
|
@set IA64
|
|
@set IP2K
|
|
@set LM32
|
|
@set M32C
|
|
@set M32R
|
|
@set xc16x
|
|
@set M68HC11
|
|
@set S12Z
|
|
@set M680X0
|
|
@set MCORE
|
|
@set METAG
|
|
@set MICROBLAZE
|
|
@set MIPS
|
|
@set MMIX
|
|
@set MS1
|
|
@set MSP430
|
|
@set NIOSII
|
|
@set NDS32
|
|
@set NS32K
|
|
@set PDP11
|
|
@set PJ
|
|
@set PPC
|
|
@set PRU
|
|
@set RL78
|
|
@set RISCV
|
|
@set RX
|
|
@set S390
|
|
@set SCORE
|
|
@set SH
|
|
@set SPARC
|
|
@set TIC54X
|
|
@set TIC6X
|
|
@set TILEGX
|
|
@set TILEPRO
|
|
@set V850
|
|
@set VAX
|
|
@set VISIUM
|
|
@set WASM32
|
|
@set XGATE
|
|
@set XSTORMY16
|
|
@set XTENSA
|
|
@set Z80
|
|
@set Z8000
|
|
|
|
@c Does this version of the assembler use the difference-table kludge?
|
|
@set DIFF-TBL-KLUGE
|
|
|
|
@c Do all machines described use IEEE floating point?
|
|
@clear IEEEFLOAT
|
|
|
|
@c Is a word 32 bits, or 16?
|
|
@clear W32
|
|
@set W16
|
|
|
|
@c Do symbols have different characters than usual?
|
|
@clear SPECIAL-SYMS
|
|
|
|
@c strings:------------------------------------------------------------
|
|
@c Name of the assembler:
|
|
@set AS as
|
|
@c Name of C compiler:
|
|
@set GCC gcc
|
|
@c Name of linker:
|
|
@set LD ld
|
|
@c Text for target machine (best not used in generic case; but just in case...)
|
|
@set TARGET machine specific
|
|
@c Name of object format NOT SET in generic version
|
|
@clear OBJ-NAME
|