Copyright 2000-2011 Free Software Foundation, Inc. The material in this patch is a derivative work of the gdb package, and is subject to licensing and copyright of its parent package. This patch adds/enhances support for the Texas Instruments MSP430 family of microcontrollers to GNU gdb. The material incorporated is maintained in a git repository hosted at: git://mspgcc.git.sourceforge.net/gitroot/mspgcc/gdb This patch incorporates changes between: upstream/release/gdb-7.2a (c06d833afeb33bb26ac9649dc444cc0678ca357a) and gdb-7_2/gdb-7.2a (58c8225524d36fc0962289497226283f004d2628) To build, obtain the upstream release distribution from: ftp://ftp.gnu.org/pub/gnu/gdb/gdb-7.2a.tar.bz2 Unpack the distribution, apply the patch, and build. (Note: The example commands are in Bourne-shell syntax.) tar xjf gdb-7.2a.tar.bz2 ( cd gdb-7.2 ; patch -p1 < ../msp430-gdb-7.2a-20111205.patch ) mkdir -p BUILD/gdb cd BUILD/gdb ../../gdb-7.2/configure \ --target=msp430 \ --prefix=/usr/local/msp430 \ 2>&1 | tee co make 2>&1 | tee mo make install 2>&1 | tee moi For support please use the mspgcc-users mailing list. You can subscribe at https://lists.sourceforge.net/lists/listinfo/mspgcc-users. Once subscribed, you can post by email to mspgcc-users@lists.sourceforge.net. To report bugs, please file a tracker ticket on SourceForge at https://sourceforge.net/tracker/?group_id=42303&atid=432701 Patch file generated: 2011-12-05T14:24:19-06:00 Log of relevant changes: ad6c20c [2011-10-06 11:34:04 -0500] Consolidate decl/defn, hide unreferenced defn ec15542 [2011-10-06 11:06:42 -0500] Remove undefined static function declarations 078b594 [2011-10-06 11:37:41 -0500] Remove dependence on hacked version number b6227c5 [2011-01-03 15:51:28 -0600] Convert sim/msp430 to autoconf.ac and regenerate 94fc11f [2011-01-03 12:01:49 -0600] Return null pointer if no useful information found 4f1d068 [2010-07-16 19:50:34 -0500] Apply gdb-6.8.patch from c018dd1 c9f44ae [2011-01-03 10:52:34 -0600] Remove gratuitous whitespace 6810f9a [2011-01-03 10:51:22 -0600] Run everything through GNU indent c7026b3 [2010-12-13 11:06:53 -0600] patch from Luca Bruno 8c4adc3 [2010-01-14 11:58:49 +0000] Added patch for gcc 4.4.2 fixing incorrect structure pushing Fixed incorrect "call offset(sp)" instruction generation and simulation Fixed incorrect prologue generation for function with stack frame pointer caused by stack arguments and without local variables 00ba8a8 [2009-11-21 19:30:36 +0000] Added full support for DWARF2 frame info and epilogue-based unwinder. 032bcf9 [2009-10-25 10:25:58 +0000] git-svn-id: http://mspgcc4.svn.sourceforge.net/svnroot/mspgcc4@17 9c79f009-54bf-40f1-a1dd-edde5f34ab85 a254b44 [2009-10-24 19:14:13 +0000] Added full support for GDB 6.8 and 7.0 Added support for GCC 4.4.2 diff --git gdb-7.2a.orig/bfd/archures.c gdb-7.2a/bfd/archures.c index 0e08571..fa47f55 100644 --- gdb-7.2a.orig/bfd/archures.c +++ gdb-7.2a/bfd/archures.c @@ -403,7 +403,13 @@ DESCRIPTION .#define bfd_mach_msp14 14 .#define bfd_mach_msp15 15 .#define bfd_mach_msp16 16 +.#define bfd_mach_msp20 20 .#define bfd_mach_msp21 21 +.#define bfd_mach_msp22 22 +.#define bfd_mach_msp23 23 +.#define bfd_mach_msp24 24 +.#define bfd_mach_msp241 241 +.#define bfd_mach_msp26 26 .#define bfd_mach_msp31 31 .#define bfd_mach_msp32 32 .#define bfd_mach_msp33 33 @@ -411,6 +417,9 @@ DESCRIPTION .#define bfd_mach_msp42 42 .#define bfd_mach_msp43 43 .#define bfd_mach_msp44 44 +.#define bfd_mach_msp46 46 +.#define bfd_mach_msp47 47 +.#define bfd_mach_msp54 54 . bfd_arch_xc16x, {* Infineon's XC16X Series. *} .#define bfd_mach_xc16x 1 .#define bfd_mach_xc16xl 2 diff --git gdb-7.2a.orig/bfd/bfd-in2.h gdb-7.2a/bfd/bfd-in2.h index f97c67f..21f282a 100644 --- gdb-7.2a.orig/bfd/bfd-in2.h +++ gdb-7.2a/bfd/bfd-in2.h @@ -2069,7 +2069,13 @@ enum bfd_architecture #define bfd_mach_msp14 14 #define bfd_mach_msp15 15 #define bfd_mach_msp16 16 +#define bfd_mach_msp20 20 #define bfd_mach_msp21 21 +#define bfd_mach_msp22 22 +#define bfd_mach_msp23 23 +#define bfd_mach_msp24 24 +#define bfd_mach_msp241 241 +#define bfd_mach_msp26 26 #define bfd_mach_msp31 31 #define bfd_mach_msp32 32 #define bfd_mach_msp33 33 @@ -2077,6 +2083,9 @@ enum bfd_architecture #define bfd_mach_msp42 42 #define bfd_mach_msp43 43 #define bfd_mach_msp44 44 +#define bfd_mach_msp46 46 +#define bfd_mach_msp47 47 +#define bfd_mach_msp54 54 bfd_arch_xc16x, /* Infineon's XC16X Series. */ #define bfd_mach_xc16x 1 #define bfd_mach_xc16xl 2 @@ -4471,6 +4480,25 @@ This is the 5 bits of a value. */ BFD_RELOC_MSP430_16_BYTE, BFD_RELOC_MSP430_2X_PCREL, BFD_RELOC_MSP430_RL_PCREL, + BFD_RELOC_MSP430X_SRC_BYTE, + BFD_RELOC_MSP430X_SRC, + BFD_RELOC_MSP430X_DST_BYTE, + BFD_RELOC_MSP430X_DST, + BFD_RELOC_MSP430X_DST_2ND_BYTE, + BFD_RELOC_MSP430X_DST_2ND, + BFD_RELOC_MSP430X_PCREL_SRC_BYTE, + BFD_RELOC_MSP430X_PCREL_SRC, + BFD_RELOC_MSP430X_PCREL_DST_BYTE, + BFD_RELOC_MSP430X_PCREL_DST, + BFD_RELOC_MSP430X_PCREL_DST_2ND, + BFD_RELOC_MSP430X_PCREL_DST_2ND_BYTE, + BFD_RELOC_MSP430X_S_BYTE, + BFD_RELOC_MSP430X_S, + BFD_RELOC_MSP430X_D_BYTE, + BFD_RELOC_MSP430X_D, + BFD_RELOC_MSP430X_PCREL_D, + BFD_RELOC_MSP430X_INDXD, + BFD_RELOC_MSP430X_PCREL_INDXD, /* IQ2000 Relocations. */ BFD_RELOC_IQ2000_OFFSET_16, diff --git gdb-7.2a.orig/bfd/cpu-msp430.c gdb-7.2a/bfd/cpu-msp430.c index 63c301a..88ed2ae 100644 --- gdb-7.2a.orig/bfd/cpu-msp430.c +++ gdb-7.2a/bfd/cpu-msp430.c @@ -65,29 +65,56 @@ static const bfd_arch_info_type arch_info_struct[] = /* msp430x16x. */ N (16, bfd_mach_msp16, "msp:16", FALSE, & arch_info_struct[7]), + /* msp430x20x */ + N (16, bfd_mach_msp20, "msp:20", FALSE, & arch_info_struct[8]), + /* msp430x21x. */ - N (16, bfd_mach_msp21, "msp:21", FALSE, & arch_info_struct[8]), + N (16, bfd_mach_msp21, "msp:21", FALSE, & arch_info_struct[9]), + + /* msp430x22x */ + N (16, bfd_mach_msp22, "msp:22", FALSE, & arch_info_struct[10]), + + /* msp430x23x0. */ + N (16, bfd_mach_msp23, "msp:23", FALSE, & arch_info_struct[11]), + + /* msp430x24x, msp430x24x1, msp430x2410 */ + N (16, bfd_mach_msp24, "msp:24", FALSE, & arch_info_struct[12]), + + /* msp430x241x */ + N (16, bfd_mach_msp241, "msp:241", FALSE, & arch_info_struct[13]), + + /* msp430x26x */ + N (16, bfd_mach_msp26, "msp:26", FALSE, & arch_info_struct[14]), /* msp430x31x. */ - N (16, bfd_mach_msp31, "msp:31", FALSE, & arch_info_struct[9]), + N (16, bfd_mach_msp31, "msp:31", FALSE, & arch_info_struct[15]), /* msp430x32x. */ - N (16, bfd_mach_msp32, "msp:32", FALSE, & arch_info_struct[10]), + N (16, bfd_mach_msp32, "msp:32", FALSE, & arch_info_struct[16]), /* msp430x33x. */ - N (16, bfd_mach_msp33, "msp:33", FALSE, & arch_info_struct[11]), + N (16, bfd_mach_msp33, "msp:33", FALSE, & arch_info_struct[17]), /* msp430x41x. */ - N (16, bfd_mach_msp41, "msp:41", FALSE, & arch_info_struct[12]), + N (16, bfd_mach_msp41, "msp:41", FALSE, & arch_info_struct[18]), /* msp430x42x. */ - N (16, bfd_mach_msp42, "msp:42", FALSE, & arch_info_struct[13]), + N (16, bfd_mach_msp42, "msp:42", FALSE, & arch_info_struct[19]), /* msp430x43x. */ - N (16, bfd_mach_msp43, "msp:43", FALSE, & arch_info_struct[14]), + N (16, bfd_mach_msp43, "msp:43", FALSE, & arch_info_struct[20]), /* msp430x44x. */ - N (16, bfd_mach_msp43, "msp:44", FALSE, NULL) + N (16, bfd_mach_msp44, "msp:44", FALSE, & arch_info_struct[21]), + + /* msp430x46xx. */ + N (20, bfd_mach_msp46, "msp:46", FALSE, & arch_info_struct[22]), + + /* msp430x47x3, 47x4. */ + N (16, bfd_mach_msp47, "msp:47", FALSE, & arch_info_struct[23]), + + /* msp430x54xx. */ + N (20, bfd_mach_msp54, "msp:54", FALSE, NULL) }; const bfd_arch_info_type bfd_msp430_arch = diff --git gdb-7.2a.orig/bfd/elf32-msp430.c gdb-7.2a/bfd/elf32-msp430.c index 285475c..837344e 100644 --- gdb-7.2a.orig/bfd/elf32-msp430.c +++ gdb-7.2a/bfd/elf32-msp430.c @@ -90,7 +90,7 @@ static reloc_howto_type elf_msp430_howto_table[] = 0xffff, /* dst_mask */ FALSE), /* pcrel_offset */ - /* A 16 bit absolute relocation for command address. */ + /* A 16 bit PC relative relocation for command address. */ HOWTO (R_MSP430_16_PCREL, /* type */ 1, /* rightshift */ 1, /* size (0 = byte, 1 = short, 2 = long) */ @@ -120,7 +120,7 @@ static reloc_howto_type elf_msp430_howto_table[] = 0xffff, /* dst_mask */ FALSE), /* pcrel_offset */ - /* A 16 bit absolute relocation for command address. */ + /* A 16 bit PC relative relocation, byte operations. */ HOWTO (R_MSP430_16_PCREL_BYTE,/* type */ 1, /* rightshift */ 1, /* size (0 = byte, 1 = short, 2 = long) */ @@ -163,7 +163,292 @@ static reloc_howto_type elf_msp430_howto_table[] = FALSE, /* partial_inplace */ 0, /* src_mask */ 0xffff, /* dst_mask */ - TRUE) /* pcrel_offset */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute src operand relocation, byte operations */ + HOWTO (R_MSP430X_SRC_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_SRC_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute src operand relocation */ + HOWTO (R_MSP430X_SRC, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_SRC", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute dst operand relocation, src is register mode, byte operations */ + HOWTO (R_MSP430X_DST_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_DST_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute dst operand relocation, src is register mode */ + HOWTO (R_MSP430X_DST, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_DST", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute dst operand relocation, byte operations */ + HOWTO (R_MSP430X_DST_2ND_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_DST_2ND_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x absolute dst operand relocation */ + HOWTO (R_MSP430X_DST_2ND, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_DST_2ND", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative src operand relocation, byte operations */ + HOWTO (R_MSP430X_PCREL_SRC_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_SRC_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative src operand relocation */ + HOWTO (R_MSP430X_PCREL_SRC, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_SRC", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative dst operand relocation, src is register mode, byte operations */ + HOWTO (R_MSP430X_PCREL_DST_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_DST_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative dst operand relocation, src is register mode */ + HOWTO (R_MSP430X_PCREL_DST, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_DST", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative dst operand relocation, byte operations */ + HOWTO (R_MSP430X_PCREL_DST_2ND_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_DST_2ND_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x PC relative dst operand relocation */ + HOWTO (R_MSP430X_PCREL_DST_2ND, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_DST_2ND", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 20 bit msp430x address instructions immediate src operand relocation */ + HOWTO (R_MSP430X_S_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_S_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x address instructions absolute src operand relocation */ + HOWTO (R_MSP430X_S, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_S", /* name */ + FALSE, /* partial_inplace */ + 0xfffff, /* src_mask */ + 0, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x address instructions immediate dst operand relocation */ + HOWTO (R_MSP430X_D_BYTE, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_D_BYTE", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x address instructions absolute dst operand relocation */ + HOWTO (R_MSP430X_D, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_D", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + FALSE), /* pcrel_offset */ + + /* A 20 bit msp430x address instructions absolute dst operand relocation */ + HOWTO (R_MSP430X_PCREL_D, /* type */ + 0, /* rightshift */ + 2, /* size (0 = byte, 1 = short, 2 = long) */ + 20, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_D", /* name */ + FALSE, /* partial_inplace */ + 0, /* src_mask */ + 0xfffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 16 bit msp430x relocation *** for msp430x calla 16-bit PC-relative index ***/ + HOWTO (R_MSP430X_PCREL_INDXD, /* type */ + 0, /* rightshift */ + 1, /* size (0 = byte, 1 = short, 2 = long) */ + 16, /* bitsize */ + TRUE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_PCREL_INDXD", /* name */ + FALSE, /* partial_inplace */ + 0xffff, /* src_mask */ + 0xffff, /* dst_mask */ + TRUE), /* pcrel_offset */ + + /* A 16 bit msp430x relocation *** for msp430x bra/calla 16-bit index ***/ + HOWTO (R_MSP430X_INDXD, /* type */ + 0, /* rightshift */ + 1, /* size (0 = byte, 1 = short, 2 = long) */ + 16, /* bitsize */ + FALSE, /* pc_relative */ + 0, /* bitpos */ + complain_overflow_dont,/* complain_on_overflow */ + bfd_elf_generic_reloc, /* special_function */ + "R_MSP430X_INDXD", /* name */ + FALSE, /* partial_inplace */ + 0xffff, /* src_mask */ + 0xffff, /* dst_mask */ + FALSE), /* pcrel_offset */ }; /* Map BFD reloc types to MSP430 ELF reloc types. */ @@ -185,7 +470,29 @@ static const struct msp430_reloc_map msp430_reloc_map[] = {BFD_RELOC_MSP430_16_PCREL_BYTE, R_MSP430_16_PCREL_BYTE}, {BFD_RELOC_MSP430_16_BYTE, R_MSP430_16_BYTE}, {BFD_RELOC_MSP430_2X_PCREL, R_MSP430_2X_PCREL}, - {BFD_RELOC_MSP430_RL_PCREL, R_MSP430_RL_PCREL} + {BFD_RELOC_MSP430_RL_PCREL, R_MSP430_RL_PCREL}, + + {BFD_RELOC_MSP430X_SRC_BYTE, R_MSP430X_SRC_BYTE}, + {BFD_RELOC_MSP430X_SRC, R_MSP430X_SRC}, + {BFD_RELOC_MSP430X_DST_BYTE, R_MSP430X_DST_BYTE}, + {BFD_RELOC_MSP430X_DST, R_MSP430X_DST}, + {BFD_RELOC_MSP430X_DST_2ND_BYTE, R_MSP430X_DST_2ND_BYTE}, + {BFD_RELOC_MSP430X_DST_2ND, R_MSP430X_DST_2ND}, + + {BFD_RELOC_MSP430X_PCREL_SRC_BYTE, R_MSP430X_PCREL_SRC_BYTE}, + {BFD_RELOC_MSP430X_PCREL_SRC, R_MSP430X_PCREL_SRC}, + {BFD_RELOC_MSP430X_PCREL_DST_BYTE, R_MSP430X_PCREL_DST_BYTE}, + {BFD_RELOC_MSP430X_PCREL_DST, R_MSP430X_PCREL_DST}, + {BFD_RELOC_MSP430X_PCREL_DST_2ND_BYTE, R_MSP430X_PCREL_DST_2ND_BYTE}, + {BFD_RELOC_MSP430X_PCREL_DST_2ND, R_MSP430X_PCREL_DST_2ND}, + + {BFD_RELOC_MSP430X_S_BYTE, R_MSP430X_S_BYTE}, + {BFD_RELOC_MSP430X_S, R_MSP430X_S}, + {BFD_RELOC_MSP430X_D_BYTE, R_MSP430X_D_BYTE}, + {BFD_RELOC_MSP430X_D, R_MSP430X_D}, + {BFD_RELOC_MSP430X_PCREL_D, R_MSP430X_PCREL_D}, + {BFD_RELOC_MSP430X_INDXD, R_MSP430X_INDXD}, + {BFD_RELOC_MSP430X_PCREL_INDXD, R_MSP430X_PCREL_INDXD}, }; static reloc_howto_type * @@ -207,10 +514,7 @@ bfd_elf32_bfd_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, { unsigned int i; - for (i = 0; - i < (sizeof (elf_msp430_howto_table) - / sizeof (elf_msp430_howto_table[0])); - i++) + for (i = 0; i < ARRAY_SIZE (elf_msp430_howto_table); i++) if (elf_msp430_howto_table[i].name != NULL && strcasecmp (elf_msp430_howto_table[i].name, r_name) == 0) return &elf_msp430_howto_table[i]; @@ -282,18 +586,44 @@ msp430_final_link_relocate (reloc_howto_type * howto, bfd * input_bfd, { bfd_reloc_status_type r = bfd_reloc_ok; bfd_vma x; - bfd_signed_vma srel; + bfd_signed_vma srel = 0; - switch (howto->type) + if (howto->type > R_MSP430_32 && howto->type < R_MSP430_max) { - case R_MSP430_10_PCREL: contents += rel->r_offset; srel = (bfd_signed_vma) relocation; srel += rel->r_addend; - srel -= rel->r_offset; + + if(howto->pc_relative) + { + srel -= rel->r_offset; + srel -= (input_section->output_section->vma + + input_section->output_offset); + } + + switch (howto->type) + { + case R_MSP430X_PCREL_D: // PC relative dst operand of calla + case R_MSP430X_PCREL_INDXD: // 16-bit idx in mova/bra instruction PC relative (symbolic) mode operand + srel -= 2; // operand located 2 bytes after opcode + break; + case R_MSP430X_PCREL_SRC: // PC-relative 20-bit address operand + case R_MSP430X_PCREL_SRC_BYTE: + case R_MSP430X_PCREL_DST: + case R_MSP430X_PCREL_DST_BYTE: + srel -= 4; // operand located 4 bytes after opcode + break; + case R_MSP430X_PCREL_DST_2ND: + case R_MSP430X_PCREL_DST_2ND_BYTE: + srel -= 6; // operand located 6 bytes after opcode + break; + } + } + + switch (howto->type) + { + case R_MSP430_10_PCREL: srel -= 2; /* Branch instructions add 2 to the PC... */ - srel -= (input_section->output_section->vma + - input_section->output_offset); if (srel & 1) return bfd_reloc_outofrange; @@ -311,13 +641,7 @@ msp430_final_link_relocate (reloc_howto_type * howto, bfd * input_bfd, break; case R_MSP430_2X_PCREL: - contents += rel->r_offset; - srel = (bfd_signed_vma) relocation; - srel += rel->r_addend; - srel -= rel->r_offset; srel -= 2; /* Branch instructions add 2 to the PC... */ - srel -= (input_section->output_section->vma + - input_section->output_offset); if (srel & 1) return bfd_reloc_outofrange; @@ -341,13 +665,7 @@ msp430_final_link_relocate (reloc_howto_type * howto, bfd * input_bfd, case R_MSP430_16_PCREL: case R_MSP430_RL_PCREL: - contents += rel->r_offset; - srel = (bfd_signed_vma) relocation; - srel += rel->r_addend; - srel -= rel->r_offset; /* Only branch instructions add 2 to the PC... */ - srel -= (input_section->output_section->vma + - input_section->output_offset); if (srel & 1) return bfd_reloc_outofrange; @@ -356,35 +674,138 @@ msp430_final_link_relocate (reloc_howto_type * howto, bfd * input_bfd, break; case R_MSP430_16_PCREL_BYTE: - contents += rel->r_offset; - srel = (bfd_signed_vma) relocation; - srel += rel->r_addend; - srel -= rel->r_offset; /* Only branch instructions add 2 to the PC... */ - srel -= (input_section->output_section->vma + - input_section->output_offset); bfd_put_16 (input_bfd, srel & 0xffff, contents); break; case R_MSP430_16_BYTE: - contents += rel->r_offset; - srel = (bfd_signed_vma) relocation; - srel += rel->r_addend; bfd_put_16 (input_bfd, srel & 0xffff, contents); break; case R_MSP430_16: - contents += rel->r_offset; - srel = (bfd_signed_vma) relocation; - srel += rel->r_addend; - if (srel & 1) return bfd_reloc_notsupported; bfd_put_16 (input_bfd, srel & 0xffff, contents); break; + case R_MSP430X_SRC: // address operand + case R_MSP430X_PCREL_SRC: // PC-relative address operand + + // 20 bit reloc for msp430x + // src in Non-register mode extended instructions, + // imm/abs in bra instruction + + // src(19:16) located at positions 10:7 of extension word + // src(15:0) located just after opcode + + if (srel & 1) // odd address + return bfd_reloc_notsupported; + /* and fall trough, no break here!!! */ + case R_MSP430X_SRC_BYTE: // byte instructions or immediate operand + case R_MSP430X_PCREL_SRC_BYTE: + x = bfd_get_16 (input_bfd, contents); + /* 4 most-significant bits */ + x = (x & 0xf87f) | ((srel >> 9) & 0x0780); + bfd_put_16 (input_bfd, x, contents); + /* 16 least-significant bits */ + bfd_put_16 (input_bfd, srel & 0xffff, contents + 4); + break; + + case R_MSP430X_DST: // address operand + case R_MSP430X_PCREL_DST: + + // 20 bit reloc for msp430x + // dst in Non-register mode extended instructions, + // imm/abs/20-bit idx in calla instruction + + // dst(19:16) located at positions 3:0 of extension word + // dst(15:0) located just after opcode + + if (srel & 1) // odd address + return bfd_reloc_notsupported; + /* and fall trough, no break here!!! */ + case R_MSP430X_DST_BYTE: // byte instructions or immediate operand + case R_MSP430X_PCREL_DST_BYTE: + x = bfd_get_16 (input_bfd, contents); + /* 4 most-significant bits */ + x = (x & 0xfff0) | ((srel >> 16) & 0x000f); + bfd_put_16 (input_bfd, x, contents); + /* 16 least-significant bits */ + bfd_put_16 (input_bfd, srel & 0xffff, contents + 4); + break; + + case R_MSP430X_DST_2ND: // address operand + case R_MSP430X_PCREL_DST_2ND: + + // 20 bit reloc for msp430x + // dst in Non-register mode extended instructions, + + // dst(19:16) located at positions 3:0 of extension word + // dst(15:0) located after src(15:0) + + if (srel & 1) // odd address + return bfd_reloc_notsupported; + /* and fall trough, no break here!!! */ + case R_MSP430X_DST_2ND_BYTE: // byte instructions or immediate operand + case R_MSP430X_PCREL_DST_2ND_BYTE: + x = bfd_get_16 (input_bfd, contents); + /* 4 most-significant bits */ + x = (x & 0xfff0) | ((srel >> 16) & 0x000f); + bfd_put_16 (input_bfd, x, contents); + /* 16 least-significant bits */ + bfd_put_16 (input_bfd, srel & 0xffff, contents + 6); + break; + + case R_MSP430X_S: // absolute src operand of address instructions + // 20 bit reloc for msp430x + + // src(19:16) located at positions 11:8 of opcode + // src(15:0) located just after opcode + + if (srel & 1) //odd address + return bfd_reloc_notsupported; + /* and fall trough, no break here!!! */ + case R_MSP430X_S_BYTE: // immediate src operand of address instructions + x = bfd_get_16 (input_bfd, contents); + /* 4 most-significant bits */ + x = (x & 0xf0ff) | ((srel >> 8) & 0x0f00); + bfd_put_16 (input_bfd, x, contents); + /* 16 least-significant bits */ + bfd_put_16 (input_bfd, srel & 0xffff, contents + 2); + break; + + case R_MSP430X_D: // absolute dst operand of address instructions + case R_MSP430X_PCREL_D: // PC relative dst operand of calla + // 20 bit reloc for msp430x, + + // dst(19:16) located at positions 3:0 of opcode + // dst(15:0) located just after opcode + + if (srel & 1) //odd address + return bfd_reloc_notsupported; + /* and fall trough, no break here!!! */ + case R_MSP430X_D_BYTE: //immediate dst operand of address instructions + + x = bfd_get_16 (input_bfd, contents); + /* 4 most-significant bits */ + x = (x & 0xfff0) | ((srel >> 16) & 0x000f); + bfd_put_16 (input_bfd, x, contents); + /* 16 least-significant bits */ + bfd_put_16 (input_bfd, srel & 0xffff, contents + 2); + break; + + case R_MSP430X_PCREL_INDXD: // 16-bit idx in mova/bra instruction PC relative (symbolic) mode operand + + if (srel & 1) //odd address + return bfd_reloc_notsupported; + case R_MSP430X_INDXD: // 16-bit idx in calla/mova/bra instruction + + x = srel & 0xffff; + bfd_put_16 (input_bfd, x, contents + 2); //16 least-significant bits + break; + default: r = _bfd_final_link_relocate (howto, input_bfd, input_section, contents, rel->r_offset, @@ -560,6 +981,34 @@ bfd_elf_msp430_final_write_processing (bfd * abfd, val = E_MSP430_MACH_MSP430x16; break; + case bfd_mach_msp20: + val = E_MSP430_MACH_MSP430x20; + break; + + case bfd_mach_msp21: + val = E_MSP430_MACH_MSP430x21; + break; + + case bfd_mach_msp22: + val = E_MSP430_MACH_MSP430x22; + break; + + case bfd_mach_msp23: + val = E_MSP430_MACH_MSP430x23; + break; + + case bfd_mach_msp24: + val = E_MSP430_MACH_MSP430x24; + break; + + case bfd_mach_msp241: + val = E_MSP430_MACH_MSP430x241; + break; + + case bfd_mach_msp26: + val = E_MSP430_MACH_MSP430x26; + break; + case bfd_mach_msp31: val = E_MSP430_MACH_MSP430x31; break; @@ -587,6 +1036,14 @@ bfd_elf_msp430_final_write_processing (bfd * abfd, case bfd_mach_msp44: val = E_MSP430_MACH_MSP430x44; break; + + case bfd_mach_msp47: + val = E_MSP430_MACH_MSP430x47; + break; + + case bfd_mach_msp54: + val = E_MSP430_MACH_MSP430x54; + break; } elf_elfheader (abfd)->e_machine = EM_MSP430; @@ -637,6 +1094,34 @@ elf32_msp430_object_p (bfd * abfd) e_set = bfd_mach_msp16; break; + case E_MSP430_MACH_MSP430x20: + e_set = bfd_mach_msp20; + break; + + case E_MSP430_MACH_MSP430x21: + e_set = bfd_mach_msp21; + break; + + case E_MSP430_MACH_MSP430x22: + e_set = bfd_mach_msp22; + break; + + case E_MSP430_MACH_MSP430x23: + e_set = bfd_mach_msp23; + break; + + case E_MSP430_MACH_MSP430x24: + e_set = bfd_mach_msp24; + break; + + case E_MSP430_MACH_MSP430x241: + e_set = bfd_mach_msp241; + break; + + case E_MSP430_MACH_MSP430x26: + e_set = bfd_mach_msp26; + break; + case E_MSP430_MACH_MSP430x31: e_set = bfd_mach_msp31; break; @@ -664,6 +1149,17 @@ elf32_msp430_object_p (bfd * abfd) case E_MSP430_MACH_MSP430x44: e_set = bfd_mach_msp44; break; + + case E_MSP430_MACH_MSP430x46: + e_set = bfd_mach_msp46; + break; + + case E_MSP430_MACH_MSP430x47: + e_set = bfd_mach_msp47; + break; + + case E_MSP430_MACH_MSP430x54: + e_set = bfd_mach_msp54; } } diff --git gdb-7.2a.orig/bfd/libbfd.h gdb-7.2a/bfd/libbfd.h index 3da79d9..4ca4f00 100644 --- gdb-7.2a.orig/bfd/libbfd.h +++ gdb-7.2a/bfd/libbfd.h @@ -2134,6 +2134,25 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@", "BFD_RELOC_MSP430_16_BYTE", "BFD_RELOC_MSP430_2X_PCREL", "BFD_RELOC_MSP430_RL_PCREL", + "BFD_RELOC_MSP430X_SRC_BYTE", + "BFD_RELOC_MSP430X_SRC", + "BFD_RELOC_MSP430X_DST_BYTE", + "BFD_RELOC_MSP430X_DST", + "BFD_RELOC_MSP430X_DST_2ND_BYTE", + "BFD_RELOC_MSP430X_DST_2ND", + "BFD_RELOC_MSP430X_PCREL_SRC_BYTE", + "BFD_RELOC_MSP430X_PCREL_SRC", + "BFD_RELOC_MSP430X_PCREL_DST_BYTE", + "BFD_RELOC_MSP430X_PCREL_DST", + "BFD_RELOC_MSP430X_PCREL_DST_2ND", + "BFD_RELOC_MSP430X_PCREL_DST_2ND_BYTE", + "BFD_RELOC_MSP430X_S_BYTE", + "BFD_RELOC_MSP430X_S", + "BFD_RELOC_MSP430X_D_BYTE", + "BFD_RELOC_MSP430X_D", + "BFD_RELOC_MSP430X_PCREL_D", + "BFD_RELOC_MSP430X_INDXD", + "BFD_RELOC_MSP430X_PCREL_INDXD", "BFD_RELOC_IQ2000_OFFSET_16", "BFD_RELOC_IQ2000_OFFSET_21", "BFD_RELOC_IQ2000_UHI16", diff --git gdb-7.2a.orig/bfd/reloc.c gdb-7.2a/bfd/reloc.c index 7d16869..d083467 100644 --- gdb-7.2a.orig/bfd/reloc.c +++ gdb-7.2a/bfd/reloc.c @@ -5118,6 +5118,44 @@ ENUMX BFD_RELOC_MSP430_2X_PCREL ENUMX BFD_RELOC_MSP430_RL_PCREL +ENUMX + BFD_RELOC_MSP430X_SRC_BYTE +ENUMX + BFD_RELOC_MSP430X_SRC +ENUMX + BFD_RELOC_MSP430X_DST_BYTE +ENUMX + BFD_RELOC_MSP430X_DST +ENUMX + BFD_RELOC_MSP430X_DST_2ND_BYTE +ENUMX + BFD_RELOC_MSP430X_DST_2ND +ENUMX + BFD_RELOC_MSP430X_PCREL_SRC_BYTE +ENUMX + BFD_RELOC_MSP430X_PCREL_SRC +ENUMX + BFD_RELOC_MSP430X_PCREL_DST_BYTE +ENUMX + BFD_RELOC_MSP430X_PCREL_DST +ENUMX + BFD_RELOC_MSP430X_PCREL_DST_2ND +ENUMX + BFD_RELOC_MSP430X_PCREL_DST_2ND_BYTE +ENUMX + BFD_RELOC_MSP430X_S_BYTE +ENUMX + BFD_RELOC_MSP430X_S +ENUMX + BFD_RELOC_MSP430X_D_BYTE +ENUMX + BFD_RELOC_MSP430X_D +ENUMX + BFD_RELOC_MSP430X_PCREL_D +ENUMX + BFD_RELOC_MSP430X_INDXD +ENUMX + BFD_RELOC_MSP430X_PCREL_INDXD ENUMDOC msp430 specific relocation codes diff --git gdb-7.2a.orig/gdb/configure.tgt gdb-7.2a/gdb/configure.tgt index 97a532f..4cb2ebd 100644 --- gdb-7.2a.orig/gdb/configure.tgt +++ gdb-7.2a/gdb/configure.tgt @@ -367,6 +367,17 @@ mn10300-*-*) gdb_sim=../sim/mn10300/libsim.a ;; +msp430-*-*) + #gdb_target=msp430 + #gdb_multi_arch=yes + #target-specific object files to use + gdb_target_obs="msp430-tdep.o" + #simulator library for target + gdb_sim=../sim/msp430/libsim.a + #set to "yes" if gdbserver supports target + build_gdbserver=no + ;; + mt-*-*) # Target: Morpho Technologies ms1 processor gdb_target_obs="mt-tdep.o" diff --git gdb-7.2a.orig/gdb/msp430-tdep.c gdb-7.2a/gdb/msp430-tdep.c new file mode 100644 index 0000000..b008b76 --- /dev/null +++ gdb-7.2a/gdb/msp430-tdep.c @@ -0,0 +1,1485 @@ +/* This work is partially financed by the European Commission under the +* Framework 6 Information Society Technologies Project +* "Wirelessly Accessible Sensor Populations (WASP)". +*/ + +/* + GDB 6.x/7.x port by Ivan Shcherbakov +*/ + +/* Target-dependent code for the Texas Instruments MSP430 MCUs. + + Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003 Free Software + Foundation, Inc. + + This file is part of GDB. + + This program 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 2 of the License, or + (at your option) any later version. + + This program 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 this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +/* Contributed by Steve Underwood */ + +#include "defs.h" +#include "frame.h" +#include "frame-unwind.h" +#include "frame-base.h" +#include "symtab.h" +#include "gdbtypes.h" +#include "gdbcmd.h" +#include "gdbcore.h" +#include "gdb_string.h" +#include "value.h" +#include "inferior.h" +#include "dis-asm.h" +#include "symfile.h" +#include "objfiles.h" +#include "language.h" +#include "arch-utils.h" +#include "regcache.h" +#include "remote.h" +#include "floatformat.h" +#include "sim-regno.h" +#include "disasm.h" +#include "trad-frame.h" +#include "dwarf2-frame.h" + +#include "gdb_assert.h" + +#define NUM_REGS 16 + +struct gdbarch_tdep +{ + int dummy; +}; + +/* MSP430 register names. */ + +enum regnums +{ + /* The MSP430 has 16 registers (R0-R15). Registers R5-R15 are general + purpose. + R0 is the program counter + R1 is the stack pointer + R2 is the status register + R3 is hardwired to 0 + R4 is used as the frame pointer (but is a general purpose register). + + Functions will return their values in registers R15-R12, as they fit. + */ + E_R0_REGNUM, E_PC_REGNUM = E_R0_REGNUM, + E_R1_REGNUM, E_SP_REGNUM = E_R1_REGNUM, + E_R2_REGNUM, E_PSW_REGNUM = E_R2_REGNUM, + E_R3_REGNUM, + E_R4_REGNUM, E_FP_REGNUM = E_R4_REGNUM, + E_R5_REGNUM, + E_R6_REGNUM, + E_R7_REGNUM, E_LST_ARG_REGNUM = E_R7_REGNUM, + E_R8_REGNUM, + E_R9_REGNUM, + E_R10_REGNUM, + E_R11_REGNUM, + E_R12_REGNUM, + E_R13_REGNUM, + E_R14_REGNUM, + E_R15_REGNUM, E_PTR_RET_REGNUM = E_R15_REGNUM, + E_NUM_REGS, + /* msp430 calling convention. */ + E_FIRST_ARG_REG = E_R15_REGNUM, + E_LAST_ARG_REG = E_R14_REGNUM, + E_NEXT_ARG_REG_DELTA = -1, //Register numbers decreases for every next argument + + RET1_REGNUM = E_R15_REGNUM, +}; + +/* + our 'frame' member of 'fi' is a stack bottom after func. prologue. + return address is located at 'frame' + Scanning prologues. + A typical msp430 function's prologue is one of the following: + + 1. some call + + push rXX <-- where XX is r15 down to r4 + ... + push r4 <-- If used or fpn + sub #[SIZE], r1 + mov r1, r4 <-- If frame pointer needed + + 2. main() w/o -mno-stack-init + + mov #[SMTH], r1 + mov r1, r4 <-- If frame pointer needed + + 3. with -mno-stack-init it looks like (1), but no regs are saved. + + 4. No optimize, usual funct: + push rXX + push r5 + push r4 + mov r1, r5 + add #[sizeofpushed+2], r5 + sub #[framesize], r1 + mov r1, r4 + + 5. main does not look any different + + 6. any prologue may start from eint (0xd2, 0x32); +*/ + +/* patterns */ +static unsigned short eint = 0xd232; +static unsigned short push_rn = 0x1200; /* bitmask: push rX */ +static unsigned short load_fp = 0x4104; /* match: mov r1, r4 */ +static unsigned short sub_val = 0x8031; /* sub #VAL, r1 , VAL is not one of the consts. */ +static unsigned short sub_2 = 0x8321; +static unsigned short sub_4 = 0x8221; +static unsigned short sub_8 = 0x8231; +static unsigned short load_ap = 0x4105; /* match: mov r1, r5 */ +static unsigned short add_val = 0x5035; /* followed by add value */ +static unsigned short add_2 = 0x5325; +static unsigned short add_4 = 0x5225; +static unsigned short add_8 = 0x5235; +static unsigned short init_sp = 0x4031; /* followed by value ... XXX + assuming no stupid things happen */ + +/* The base of the current frame is actually in the stack pointer. + This happens when there is no frame pointer (msp430 ABI does not + require a frame pointer) or when we're stopped in the prologue or + epilogue itself. In these cases, msp430_analyze_prologue will need + to update fi->frame before returning or analyzing the register + save instructions. */ +#define MY_FRAME_IN_SP 0x1 + +/* The base of the current frame is in a frame pointer register. + This register is noted in frame_extra_info->fp_regnum. + + Note that the existence of an FP might also indicate that the + function has called alloca. */ +#define MY_FRAME_IN_FP 0x2 + +/* This flag is set to indicate that this frame is the top-most + frame. This tells frame chain not to bother trying to unwind + beyond this frame. */ +#define NO_MORE_FRAMES 0x4 + +static CORE_ADDR current_sp; +static int msp430_real_fp = E_SP_REGNUM; + +/* Local functions */ + +extern void _initialize_msp430_tdep (void); + +static CORE_ADDR +msp430_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp) +{ + return sp & ~1; +} + +/* Should we use EXTRACT_STRUCT_VALUE_ADDRESS instead of + EXTRACT_RETURN_VALUE? GCC_P is true if compiled with gcc + and TYPE is the type (which is known to be struct, union or array). + + The msp430 returns anything less than 8 bytes in size in + registers. */ + +static int +msp430_use_struct_convention (struct type *type) +{ + long alignment; + int i; + enum type_code code = TYPE_CODE (type); + + /* The msp430 only passes a struct in a register when that structure + has an alignment that matches the size of a register. */ + /* If the structure doesn't fit in 4 registers, put it on the + stack. */ + if (TYPE_LENGTH (type) > 8) + return 1; + + //If type is not a structure, it is passed through a register + if (code != TYPE_CODE_STRUCT) + return 0; + + /* If the struct contains only one field, don't put it on the stack + - gcc can fit it in one or more registers. */ + if (TYPE_NFIELDS (type) == 1) + return 0; + alignment = TYPE_LENGTH (TYPE_FIELD_TYPE (type, 0)); + for (i = 1; i < TYPE_NFIELDS (type); i++) + { + /* If the alignment changes, just assume it goes on the + stack. */ + if (TYPE_LENGTH (TYPE_FIELD_TYPE (type, i)) != alignment) + return 1; + } + /* If the alignment is suitable for the msp430's 16 bit registers, + don't put it on the stack. */ + if (alignment == 2 || alignment == 4) + return 0; + return 1; +} + + +static const unsigned char * +msp430_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR * pcptr, + int *lenptr) +{ + static char breakpoint[] = { 0x00, 0x00 }; + + *lenptr = 2; + return breakpoint; +} + +/* Map the REG_NR onto an ascii name. Return NULL or an empty string + when the reg_nr isn't valid. */ + +static const char * +msp430_register_name (struct gdbarch *gdbarch, int reg_nr) +{ + static char *register_names[] = { + "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", + "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15" + }; + + if (reg_nr < 0) + return NULL; + if (reg_nr >= (sizeof (register_names) / sizeof (*register_names))) + return NULL; + return register_names[reg_nr]; +} + +/* Return the GDB type object for the "standard" data type + of data in register N. */ + +static struct type * +msp430_register_type (struct gdbarch *gdbarch, int reg_nr) +{ + if (reg_nr == E_PC_REGNUM) + return builtin_type (gdbarch)->builtin_func_ptr; + if (reg_nr == E_SP_REGNUM || reg_nr == E_FP_REGNUM) + return builtin_type (gdbarch)->builtin_data_ptr; + return builtin_type (gdbarch)->builtin_int16; +} + +static void +msp430_address_to_pointer (struct gdbarch *gdbarch, struct type *type, + gdb_byte * buf, CORE_ADDR addr) +{ + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + store_unsigned_integer (buf, TYPE_LENGTH (type), byte_order, addr); +} + +static CORE_ADDR +msp430_pointer_to_address (struct gdbarch *gdbarch, struct type *type, + const gdb_byte * buf) +{ + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + return extract_unsigned_integer (buf, TYPE_LENGTH (type), byte_order); +} + +/* Don't do anything if we have an integer. This way users can type 'x + ' w/o having gdb outsmarting them. The internal gdb conversions + to the correct space are taken care of in the pointer_to_address + function. If we don't do this, 'x $fp' will not work. */ +static CORE_ADDR +msp430_integer_to_address (struct gdbarch *gdbarch, struct type *type, + const gdb_byte * buf) +{ + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + return extract_unsigned_integer (buf, TYPE_LENGTH (type), byte_order); +} + +/* Write into appropriate registers a function return value + of type TYPE, given in virtual format. + + Things always get returned in RET1_REGNUM, RET2_REGNUM, ... */ + +static void +msp430_store_return_value (struct type *type, + struct regcache *regcache, const gdb_byte * valbuf) +{ + /* Only char return values need to be shifted right within the first + regnum. */ + if (TYPE_LENGTH (type) == 1 && TYPE_CODE (type) == TYPE_CODE_INT) + { + bfd_byte tmp[2]; + tmp[1] = *(bfd_byte *) valbuf; + regcache_cooked_write (regcache, RET1_REGNUM, tmp); + } + else + { + int reg; + /* A structure is never more than 8 bytes long. See + use_struct_convention(). */ + gdb_assert (TYPE_LENGTH (type) <= 8); + /* Write out most registers, stop loop before trying to write + out any dangling byte at the end of the buffer. */ + for (reg = 0; (reg * 2) + 1 < TYPE_LENGTH (type); reg++) + { + regcache_cooked_write (regcache, + RET1_REGNUM - reg, + (bfd_byte *) valbuf + reg * 2); + } + /* Write out any dangling byte at the end of the buffer. */ + if ((reg * 2) + 1 == TYPE_LENGTH (type)) + regcache_cooked_write_part (regcache, reg, 0, 1, + (bfd_byte *) valbuf + reg * 2); + } +} + + +static int +get_insn (CORE_ADDR pc, struct gdbarch *gdbarch) +{ + char buf[4]; + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + + read_memory (0xfffful & pc, buf, 2); + return extract_unsigned_integer (buf, 2, byte_order); +} + +typedef struct _parsed_prologue +{ + int valid; + int saved_register_block_size; + int locals_block_size; + int register_offsets[NUM_REGS]; + int flags; + int sp_already_decremented_by; //Value between 0 (first instruction of prologue is about to execute) and frame_size (prologue has completed) +} parsed_prologue; + +static CORE_ADDR +msp430_scan_prologue (struct gdbarch *gdbarch, CORE_ADDR pc, + parsed_prologue * parsed) +{ + CORE_ADDR func_addr, func_end, addr, stop; + CORE_ADDR stack_size; + //CORE_ADDR stack_top; + int insn, rn; + int status; + int fp_regnum = 0; /* dummy, valid when (flags & MY_FRAME_IN_FP) */ + int flags; + int framesize; + int register_offsets[NUM_REGS]; + int pushed_reg_count = 0; + int sp_already_decremented_by = 0; + char *name; + int vpc = 0; + CORE_ADDR start_addr; + int i; + int reti = 0; + CORE_ADDR original_pc = pc; + + msp430_real_fp = E_SP_REGNUM; /* Wild guess */ + + /* Find the start of this function. */ + status = find_pc_partial_function (pc, &name, &func_addr, &func_end); + + /* If the start of this function could not be found or if the debbuger + is stopped at the first instruction of the prologue, do nothing. */ + if (status == 0) + return 0xfffful & pc; + + /* If the debugger is entry function, give up. */ + if (func_addr == entry_point_address ()) + return 0xfffful & pc; + + + /* At the start of a function, our frame is in the stack pointer. */ + flags = MY_FRAME_IN_SP; + /* Get the first insn from memory (all msp430 instructions are 16 bits) */ + insn = get_insn (pc, gdbarch); + + if (func_addr) + pc = func_addr; + + /* Figure out where to stop scanning */ + stop = func_end; + + /* Don't walk off the end of the function */ + stop = (stop > func_end ? func_end : stop); + + /* REGISTER_OFFSETS will contain offsets, from the top of the frame + (NOT the frame pointer), for the various saved registers or -1 + if the register is not saved. */ + for (rn = 0; rn < NUM_REGS; rn++) + register_offsets[rn] = -1; + + /* stack_top = read_sp(); */ + /* stack_top = read_register (E_SP_REGNUM); */ + /* regcache_cooked_read_unsigned(get_current_regcache(), E_SP_REGNUM, &stack_top); */ + + /* Analyze the prologue. Things we determine from analyzing the + prologue include: + * the size of the frame + * where saved registers are located (and which are saved) + * FP used? */ + framesize = 0; + + if (name && strcmp ("main", name) == 0) + { + start_addr = func_addr; + insn = get_insn (pc + vpc, gdbarch); + + if (insn == init_sp) + { + /* ok... will be a frame pointer adjustment? */ + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + vpc += 2; /* skip this and value. */ + start_addr = func_addr + vpc; + } + else if (insn == sub_val) /* -mno-stack-init */ + { + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + vpc += 2; + start_addr = func_addr + vpc; + } + else if (insn == sub_2) + { + vpc += 2; + start_addr = func_addr + vpc; + } + else if (insn == sub_4) + { + vpc += 2; + start_addr = func_addr + vpc; + } + else if (insn == sub_8) + { + vpc += 2; + start_addr = func_addr + vpc; + } + else + { + /* we're here cause no frame adjustment required + and main main frame size is over any reasonable value... + should never happen cause memory not less than 0x200 */ + vpc += 2; + start_addr = func_addr + vpc; + } + insn = get_insn (pc + vpc, gdbarch); /* check if fp being initialized */ + if (insn == load_fp) + { + vpc += 2; + start_addr = func_addr + vpc; + msp430_real_fp = E_SP_REGNUM; + } + return start_addr; + } + + //Function is not "main()". Start analyzing prologue + + /* check eint + Actually, there is only way to check if this is an interrupt + is to check eint - enable nested. + Ordinary interrupts cannot be caught */ + insn = get_insn (pc + vpc, gdbarch); + if (insn == eint) + vpc += 2; + + /* check pushes */ + for (i = 15; i >= 2; i--) + { + int rn; + insn = get_insn (pc + vpc, gdbarch); + if ((insn & 0xfff0) != push_rn) + break; + + if (original_pc > (pc + vpc)) + sp_already_decremented_by += 2; //This 'push' instruction has already been executed + + rn = insn & 15; + vpc += 2; + pushed_reg_count++; + register_offsets[rn] = pushed_reg_count * 2; //Offset from beginning of the frame [0 = return value] + } + + /* now check if there is an arg pointer */ + insn = get_insn (pc + vpc, gdbarch); + if (insn == load_ap) + { + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + if (insn == add_val) + { + vpc += 2; /* insn */ + vpc += 2; /* actual value */ + insn = get_insn (pc + vpc, gdbarch); + } + else if (insn == add_2 || insn == add_4 || insn == add_8) + { + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + } + } + + /* check if stack pointer has been adjusted */ + + if (insn == sub_val) + { + vpc += 2; + framesize = get_insn (pc + vpc, gdbarch); + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + } + else if (insn == sub_2) + { + framesize = 2; + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + } + else if (insn == sub_4) + { + framesize = 4; + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + } + else if (insn == sub_8) + { + framesize = 8; + vpc += 2; + insn = get_insn (pc + vpc, gdbarch); + } + + if (original_pc > (pc + vpc - 2)) + sp_already_decremented_by += framesize; //The sp decreasing instruction has already been executed + + /* check if fp loaded */ + if (insn == load_fp) + { + msp430_real_fp = E_SP_REGNUM; + + if (original_pc > (pc + vpc)) + flags = MY_FRAME_IN_FP; //Frame is already in FP only if the FP loading instruction is already executed + vpc += 2; + } + + if (parsed) + { + parsed->valid = 1; + memcpy (parsed->register_offsets, register_offsets, + sizeof (parsed->register_offsets)); + parsed->flags = flags; + parsed->locals_block_size = framesize; + parsed->saved_register_block_size = pushed_reg_count * 2; + + if (sp_already_decremented_by > + (parsed->saved_register_block_size + parsed->locals_block_size)) + sp_already_decremented_by = + parsed->saved_register_block_size + parsed->locals_block_size; + + parsed->sp_already_decremented_by = sp_already_decremented_by; + } + + /* Return addr of first non-prologue insn. */ + return func_addr + vpc; +} + +static CORE_ADDR +msp430_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR pc) +{ + return msp430_scan_prologue (gdbarch, pc, NULL); +} + +typedef int bool; +static const int true = 1; +static const int false = 0; + +typedef struct _msp430_global_cache //Various global stuff. Used by IsValidCodePtr(), IsValidDataPtr() +{ + bool cache_valid; + ULONGEST min_code_ptr; + ULONGEST max_code_ptr; + ULONGEST min_data_ptr; + ULONGEST max_data_ptr; +} msp430_global_cache; + +static bool ProvideValidGlobalCache (msp430_global_cache * pCache); +static bool +IsValidCodePtr (msp430_global_cache * pCache, ULONGEST ptr) +{ + if (!ProvideValidGlobalCache (pCache)) + return false; + return (ptr >= pCache->min_code_ptr) && (ptr <= pCache->max_code_ptr); +} + +#if 0 +static bool +IsValidDataPtr (msp430_global_cache * pCache, ULONGEST ptr) +{ + if (!ProvideValidGlobalCache (pCache)) + return false; + return (ptr >= pCache->min_data_ptr) && (ptr <= pCache->max_data_ptr); +} +#endif + +struct msp430_unwind_cache +{ + /* The previous frame's inner most stack address. Used as this + frame ID's stack_addr. */ + CORE_ADDR prev_sp; + /* The frame's base, optionally used by the high-level debug info. */ + CORE_ADDR base; + //int size; + /* How far the SP and r4 (FP) have been offset from the start of + the stack frame (as defined by the previous frame's stack + pointer). */ +// LONGEST sp_offset; +// LONGEST fp_offset; + int uses_frame; + /* Table indicating the location of each and every register. */ + struct trad_frame_saved_reg *saved_regs; + msp430_global_cache global_cache; +}; + + +static int +DetectPushedArgumentsSize (CORE_ADDR FirstInstructionAfterCall) +{ + return 0; +} + +static struct msp430_unwind_cache * +msp430_build_unwind_cache_from_epilogue (struct frame_info *associated_frame, + void **this_prologue_cache) +{ + //Note that on GDB v7 associated_frame is the curent frame, while on gdb v6, it is the next frame + struct frame_info *this_frame = associated_frame; + + const int TargetPointerSize = 2; + + struct gdbarch *gdbarch = get_frame_arch (associated_frame); + + ULONGEST this_pc, this_sp; + ULONGEST frame_bottom; //Either SP or FP, depending on whether FP is used + + int insn, pc_off = 0, i, prev_sp = 0; + + int register_offsets[E_NUM_REGS]; + + struct msp430_unwind_cache *info = 0; + + + if (frame_relative_level (this_frame) != 0) + return NULL; + + if ((*this_prologue_cache)) + return (*this_prologue_cache); + + //Extract PC and SP (start of frame) for THIS frame. + this_pc = get_frame_pc (this_frame); + this_sp = get_frame_sp (this_frame); + + if (!this_sp || !this_pc) + return info; //Cannot extract any useful frame information + + memset (register_offsets, -1, sizeof (register_offsets)); + + for (pc_off = 0; pc_off <= 16; pc_off += 2) + { + insn = get_insn (this_pc + pc_off, gdbarch); + if ((insn & 0xFFF0) == 0x4130) + { /* This is a POP instruction */ + int poppedRegNum = insn & 0x000F; + register_offsets[poppedRegNum] = pc_off; + if (poppedRegNum == E_PC_REGNUM) + { + prev_sp = this_sp + pc_off + 2; + break; + } + } + else if (insn == 0x1300) + { /* This is a "reti" instruction */ + register_offsets[E_PSW_REGNUM] = pc_off; + register_offsets[E_PC_REGNUM] = pc_off + 2; + prev_sp = this_sp + pc_off + 4; + break; + } + else + return NULL; + } + + info = FRAME_OBSTACK_ZALLOC (struct msp430_unwind_cache); + (*this_prologue_cache) = info; + info->saved_regs = trad_frame_alloc_saved_regs (associated_frame); + + for (i = 0; i < E_NUM_REGS; i++) + { + if (register_offsets[i] != -1) + { + ULONGEST reg_val = + get_frame_memory_unsigned (associated_frame, + this_sp + register_offsets[i], 2); + trad_frame_set_value (info->saved_regs, i, reg_val); + } + } + + if (prev_sp) + trad_frame_set_value (info->saved_regs, E_SP_REGNUM, prev_sp); + + info->prev_sp = prev_sp; + info->base = prev_sp; + + return info; +} + +static struct msp430_unwind_cache + *msp430_build_unwind_cache_from_epilogue (struct frame_info + *associated_frame, + void **this_prologue_cache); + +static void +msp430_epilogue_frame_this_id (struct frame_info *this_frame, + void **this_prologue_cache, + struct frame_id *this_id) +{ + struct msp430_unwind_cache *info = + msp430_build_unwind_cache_from_epilogue (this_frame, this_prologue_cache); + CORE_ADDR base; + CORE_ADDR func; + struct frame_id id; + + if (!info) + return; + + /* The FUNC is easy. */ + func = get_frame_func (this_frame); + + /* Hopefully the prologue analysis either correctly determined the + frame's base (which is the SP from the previous frame), or set + that base to "NULL". */ + base = info->prev_sp; + if (base == 0) + return; + + id = frame_id_build (base, func); + (*this_id) = id; +} + +/* -------------------------------------------------------------------------------------------------- */ + +/* Put here the code to store, into fi->saved_regs, the addresses of + the saved registers of frame described by FRAME_INFO. This + includes special registers such as pc and fp saved in special ways + in the stack frame. sp is even more special: the address we return + for it IS the sp for the next frame. */ + +static struct msp430_unwind_cache * +msp430_frame_unwind_cache (struct frame_info *associated_frame, + void **this_prologue_cache) +{ + //Note that on GDB v7 associated_frame is the curent frame, while on gdb v6, it is the next frame + struct frame_info *this_frame = associated_frame; + + const int TargetPointerSize = 2; + + struct gdbarch *gdbarch = get_frame_arch (associated_frame); + parsed_prologue parsed = { 0, }; + /*CORE_ADDR pc; + ULONGEST prev_sp; + ULONGEST this_base; + int i; */ + + ULONGEST this_pc, this_sp, this_fp, sp_iter; + ULONGEST frame_bottom; //Either SP or FP, depending on whether FP is used + + struct msp430_unwind_cache *info; + + if ((*this_prologue_cache)) + return (*this_prologue_cache); + + info = FRAME_OBSTACK_ZALLOC (struct msp430_unwind_cache); + (*this_prologue_cache) = info; + info->saved_regs = trad_frame_alloc_saved_regs (associated_frame); + + //info->size = 0; + //info->sp_offset = 0; + + //Extract PC and SP (start of frame) for THIS frame. + + this_pc = get_frame_pc (this_frame); + this_sp = get_frame_sp (this_frame); + this_fp = get_frame_register_unsigned (this_frame, E_FP_REGNUM); + + if (!this_sp || !this_pc) + return info; //Cannot extract any useful frame information + + if (!ProvideValidGlobalCache (&info->global_cache)) + return info; + + msp430_scan_prologue (gdbarch, this_pc, &parsed); + frame_bottom = this_sp; + + if (parsed.valid) + { + ULONGEST saved_return_ptr, retptr; + info->uses_frame = ((parsed.flags & MY_FRAME_IN_FP) != 0); + if (info->uses_frame && this_fp) + frame_bottom = this_fp; + + saved_return_ptr = frame_bottom + parsed.sp_already_decremented_by; // parsed.locals_block_size + parsed.saved_register_block_size; + retptr = + get_frame_memory_unsigned (associated_frame, saved_return_ptr, + TargetPointerSize); + if (IsValidCodePtr (&info->global_cache, retptr)) + { + int i; + info->prev_sp = saved_return_ptr + TargetPointerSize; + + if (!info->uses_frame) + info->prev_sp += DetectPushedArgumentsSize (retptr); + + info->base = saved_return_ptr; + + //Read and save pushed register values, discovered by msp430_scan_prologue() + for (i = 0; + i < + (sizeof (parsed.register_offsets) / + sizeof (parsed.register_offsets[0])); i++) + { + ULONGEST saved_reg_addr, reg_val; + if ((i == E_PC_REGNUM) || (i == E_SP_REGNUM)) + continue; + if (parsed.register_offsets[i] == -1) + continue; + + if (parsed.register_offsets[i] > + parsed.sp_already_decremented_by) + continue; //We are now in the middle of the prologue and this register has not yet been saved to stack. + + saved_reg_addr = info->base - parsed.register_offsets[i]; + reg_val = + get_frame_memory_unsigned (associated_frame, saved_reg_addr, + TargetPointerSize); + + trad_frame_set_value (info->saved_regs, i, reg_val); + } + + trad_frame_set_value (info->saved_regs, E_PC_REGNUM, retptr); + trad_frame_set_value (info->saved_regs, E_SP_REGNUM, info->prev_sp); + return info; + } + //If the saved return address is not valid, the frame was detected incorrectly. Use generic frame scanning then. + } + + //We failed to rebuild frame structure based on function prologue. Just scan the stack for the next valid code address and assume it is a return address. + + for (sp_iter = frame_bottom; sp_iter <= info->global_cache.max_data_ptr; sp_iter += TargetPointerSize) //Traverse stack towards the top + { + ULONGEST ptr = + get_frame_memory_unsigned (associated_frame, sp_iter, + TargetPointerSize); + if (IsValidCodePtr (&info->global_cache, ptr)) //If a valid pointer was found on stack, assume it is the return pointer + { + trad_frame_set_value (info->saved_regs, E_PC_REGNUM, ptr); + info->prev_sp = sp_iter + TargetPointerSize; + trad_frame_set_value (info->saved_regs, E_SP_REGNUM, info->prev_sp); + info->base = sp_iter; + return info; + } + } + + return info; +} + +static void +msp430_print_registers_info (struct gdbarch *gdbarch, + struct ui_file *file, + struct frame_info *frame, int regnum, int all) +{ + if ((regnum >= 0) && gdbarch) + { + default_print_registers_info (gdbarch, file, frame, regnum, all); + return; + } + { + int r; + for (r = 0; r < E_NUM_REGS; r++) + { + ULONGEST tmp = get_frame_register_unsigned (frame, r); + //regcache_cooked_read_unsigned(get_current_regcache(), r, &tmp); + switch (r) + { + case E_PC_REGNUM: + fprintf_filtered (file, "pc/"); + break; + case E_SP_REGNUM: + fprintf_filtered (file, "sp/"); + break; + case E_PSW_REGNUM: + fprintf_filtered (file, "sr/"); + break; + case E_FP_REGNUM: + fprintf_filtered (file, "fp/"); + break; + default: + if (r < 10) + fprintf_filtered (file, " "); + else + fprintf_filtered (file, " "); + break; + } + fprintf_filtered (file, "r%d: %04lx ", r, (long) tmp); + if ((r % 4) == 3) + fprintf_filtered (file, "\n"); + } + } +} + +static void +show_regs (char *args, int from_tty) +{ + msp430_print_registers_info (get_frame_arch (get_current_frame ()), + gdb_stdout, get_current_frame (), -1, 1); +} + +static CORE_ADDR +msp430_read_pc (struct regcache *regcache) +{ + ULONGEST pc; + regcache_cooked_read_unsigned (regcache, E_PC_REGNUM, &pc); + + return pc; +} + +static void +msp430_write_pc (struct regcache *regcache, CORE_ADDR pc) +{ + regcache_cooked_write_unsigned (regcache, E_PC_REGNUM, pc); +} + +static CORE_ADDR +msp430_unwind_sp (struct gdbarch *gdbarch, struct frame_info *next_frame) +{ + ULONGEST sp; + sp = frame_unwind_register_unsigned (next_frame, E_SP_REGNUM); + return sp; +} + +/* When arguments must be pushed onto the stack, they go on in reverse + order. The below implements a FILO (stack) to do this. */ + +struct stack_item +{ + int len; + struct stack_item *prev; + void *data; +}; + +static struct stack_item *push_stack_item (struct stack_item *prev, + const void *contents, int len); +static struct stack_item * +push_stack_item (struct stack_item *prev, const void *contents, int len) +{ + struct stack_item *si; + si = xmalloc (sizeof (struct stack_item)); + si->data = xmalloc (len); + si->len = len; + si->prev = prev; + memcpy (si->data, contents, len); + return si; +} + +static struct stack_item *pop_stack_item (struct stack_item *si); +static struct stack_item * +pop_stack_item (struct stack_item *si) +{ + struct stack_item *dead = si; + si = si->prev; + xfree (dead->data); + xfree (dead); + return si; +} + +static CORE_ADDR +msp430_push_dummy_call (struct gdbarch *gdbarch, + struct value *func_addr, + struct regcache *regcache, + CORE_ADDR bp_addr, + int nargs, + struct value **args, + CORE_ADDR sp, + int struct_return, CORE_ADDR struct_addr) +{ + int i; + int regnum = E_FIRST_ARG_REG; + struct stack_item *si = NULL; + long val; + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + + /* Set the return address. For the msp430, the return breakpoint is + always at BP_ADDR. */ + //regcache_cooked_write_unsigned (regcache, LR_REGNUM, bp_addr); + + /* If STRUCT_RETURN is true, then the struct return address (in + STRUCT_ADDR) will consume the first argument-passing register. + Both adjust the register count and store that value. */ + if (struct_return) + { + regcache_cooked_write_unsigned (regcache, regnum, struct_addr); + regnum++; + } + + /* Fill in registers and arg lists */ + for (i = 0; i < nargs; i++) + { + struct value *arg = args[i]; + struct type *type = check_typedef (value_type (arg)); + const gdb_byte *contents = value_contents (arg); + int len = TYPE_LENGTH (type); + + /* printf ("push: type=%d len=%d\n", TYPE_CODE (type), len); */ + if (len <= 2 && (regnum != E_LAST_ARG_REG)) + /* fits in a single register, do not align */ + { + val = extract_unsigned_integer (contents, len, byte_order); + regcache_cooked_write_unsigned (regcache, regnum, val); + regnum += E_NEXT_ARG_REG_DELTA; + } + else + { + int regs_remaining; + static char invalid_e_last_reg[(E_LAST_ARG_REG & 1) == 0]; //Last register should be aligned by 2. Otherwise, the following code will fail horribly. + + if (regnum & 0x01) + regnum += E_NEXT_ARG_REG_DELTA; + + if (E_NEXT_ARG_REG_DELTA > 0) + regs_remaining = (E_LAST_ARG_REG - regnum) + 1; + else + regs_remaining = (regnum - E_LAST_ARG_REG) + 1; + + if (len <= regs_remaining) + /* value fits in remaining registers, store keeping left + aligned */ + { + int b; + for (b = 0; b < (len & ~1); b += 2) + { + val = + extract_unsigned_integer (&contents[b], 2, byte_order); + regcache_cooked_write_unsigned (regcache, regnum++, val); + } + if (b < len) + { + val = + extract_unsigned_integer (&contents[b], 1, byte_order); + regcache_cooked_write_unsigned (regcache, regnum++, + (val << 8)); + } + } + else + { + /* arg will go onto stack */ + regnum = E_LAST_ARG_REG; + si = push_stack_item (si, contents, len); + } + } + } + + while (si) + { + sp = (sp - si->len) & ~1; + write_memory (sp, si->data, si->len); + si = pop_stack_item (si); + } + + //Push return address + sp -= 2; + write_memory (sp, (gdb_byte *) & bp_addr, 2); + + /* Finally, update the SP register. */ + regcache_cooked_write_unsigned (regcache, E_SP_REGNUM, sp); + + //The SP value returned here is used to verify the dummy frame after the function has exited. + //When the function returns, it pops the return address from the stack. Thus, the SP value will + //be greater by sizeof(void *). + return sp + 2; +} + + +/* Given a return value in `regbuf' with a type `valtype', + extract and copy its value into `valbuf'. */ +static void +msp430_extract_return_value (struct type *type, struct regcache *regcache, + gdb_byte * valbuf) +{ + struct gdbarch *gdbarch = get_regcache_arch (regcache); + enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); + int len; + if (TYPE_LENGTH (type) == 1) + { + ULONGEST c; + regcache_cooked_read_unsigned (regcache, RET1_REGNUM, &c); + store_unsigned_integer (valbuf, 1, byte_order, c); + } + else + { + /* For return values of odd size, the first byte is in the + least significant part of the first register. The + remaining bytes in remaining registers. Interestingly, when + such values are passed in, the last byte is in the most + significant byte of that same register - wierd. */ + int reg = RET1_REGNUM; + int off = 0; + if (TYPE_LENGTH (type) & 1) + { + regcache_cooked_read_part (regcache, reg, 1, 1, + (bfd_byte *) valbuf + off); + off++; + reg++; + } + /* Transfer the remaining registers. */ + for (; off < TYPE_LENGTH (type); reg++, off += 2) + { + regcache_cooked_read (regcache, reg, (bfd_byte *) valbuf + off); + } + } +} + +static enum return_value_convention +msp430_return_value (struct gdbarch *gdbarch, struct type *func_type, + struct type *valtype, struct regcache *regcache, + gdb_byte * readbuf, const gdb_byte * writebuf) +{ + if (msp430_use_struct_convention (valtype)) + return RETURN_VALUE_STRUCT_CONVENTION; + if (writebuf) + msp430_store_return_value (valtype, regcache, writebuf); + else if (readbuf) + msp430_extract_return_value (valtype, regcache, readbuf); + return RETURN_VALUE_REGISTER_CONVENTION; +} + + +/* Translate a GDB virtual ADDR/LEN into a format the remote target + understands. Returns number of bytes that can be transfered + starting at TARG_ADDR. Return ZERO if no bytes can be transfered + (segmentation fault). Since the simulator knows all about how the + VM system works, we just call that to do the translation. */ + +static void eraseflash_command (char *, int); + +static void mcu_info (char *, int); + +/* MSP430 specific releasejtag command sets this variable */ +static int release_jtag_on_go; + +/* MSP430 specific "erase" command */ +static void +eraseflash_command (char *args, int from_tty) +{ + /* Erase a section of flash memory. */ + + if (args == NULL || (strcmp (args, "all") == 0)) + { + /* No args or "all" */ + printf_filtered ("Erasing all flash memory\n"); + current_target.to_rcmd ("erase all", gdb_stdtarg); + } + else if (strcmp (args, "info") == 0) + { + /* 1st arg "info" */ + printf_filtered ("Erasing info flash memory\n"); + current_target.to_rcmd ("erase info", gdb_stdtarg); + } + else if (strcmp (args, "main") == 0) + { + /* 1st arg "main" */ + printf_filtered ("Erasing main flash memory\n"); + current_target.to_rcmd ("erase main", gdb_stdtarg); + } + else + { + /* Address as arg */ + printf_filtered ("Erasing flash memory from %d for %d bytes\n", 0, 0); + current_target.to_rcmd ("erase ???", gdb_stdtarg); + //snprintf(buf2, 1000, "segment at 0x%04llx, size %ld bytes...", address, size); + } +} + +/* MSP430 specific "info mcu" command, which displays information about the attached device + (part number, memory limits, etc.). */ +static void +mcu_info (char *args, int from_tty) +{ + current_target.to_rcmd ("identify", gdb_stdtarg); +} + +/* Collect trace data from the target board and format it into a form + more useful for display. */ + +static CORE_ADDR +msp430_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame) +{ + ULONGEST pc; + pc = frame_unwind_register_unsigned (next_frame, E_PC_REGNUM); + return pc; +} + +/* Given a GDB frame, determine the address of the calling function's + frame. This will be used to create a new GDB frame struct. */ + +static void +msp430_frame_this_id (struct frame_info *this_frame, + void **this_prologue_cache, struct frame_id *this_id) +{ + struct msp430_unwind_cache *info + = msp430_frame_unwind_cache (this_frame, this_prologue_cache); + CORE_ADDR base; + CORE_ADDR func; + struct frame_id id; + + /* The FUNC is easy. */ + func = get_frame_func (this_frame); + + /* Hopefully the prologue analysis either correctly determined the + frame's base (which is the SP from the previous frame), or set + that base to "NULL". */ + base = info->prev_sp; + if (base == 0) + return; + + id = frame_id_build (base, func); + (*this_id) = id; +} + +static struct value * +msp430_frame_prev_register (struct frame_info *associated_frame, + void **this_prologue_cache, int regnum) +{ + struct msp430_unwind_cache *info + = msp430_frame_unwind_cache (associated_frame, this_prologue_cache); + return trad_frame_get_prev_register (associated_frame, info->saved_regs, + regnum); +} + +static int +msp430_epilogue_frame_sniffer (const struct frame_unwind *self, + struct frame_info *this_frame, + void **this_cache) +{ + struct msp430_unwind_cache *info = + msp430_build_unwind_cache_from_epilogue (this_frame, this_cache); + return (info != NULL); +} + + +static const struct frame_unwind msp430_frame_unwind = { + NORMAL_FRAME, + msp430_frame_this_id, + msp430_frame_prev_register, + NULL, + default_frame_sniffer, +}; + +static const struct frame_unwind msp430_epilogue_frame_unwind = { + NORMAL_FRAME, + msp430_epilogue_frame_this_id, + msp430_frame_prev_register, + NULL, + msp430_epilogue_frame_sniffer, +}; + +static CORE_ADDR +msp430_frame_base_address (struct frame_info *associated_frame, + void **this_cache) +{ + struct msp430_unwind_cache *info = + msp430_frame_unwind_cache (associated_frame, this_cache); + return info->base; +} + +static const struct frame_base msp430_frame_base = { + &msp430_frame_unwind, + msp430_frame_base_address, + msp430_frame_base_address, + msp430_frame_base_address +}; + +/* Assuming NEXT_FRAME->prev is a dummy, return the frame ID of that + dummy frame. The frame ID's base needs to match the TOS value + saved by save_dummy_frame_tos(), and the PC match the dummy frame's + breakpoint. */ + + +static struct frame_id +msp430_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame) +{ + ULONGEST base; + base = get_frame_register_unsigned (this_frame, E_SP_REGNUM); + return frame_id_build (base, get_frame_pc (this_frame)); +} + + +static gdbarch_init_ftype msp430_gdbarch_init; + +static struct gdbarch * +msp430_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) +{ + struct gdbarch *gdbarch; + struct gdbarch_tdep *tdep; + + /* Find a candidate among the list of pre-declared architectures. */ + arches = gdbarch_list_lookup_by_info (arches, &info); + if (arches != NULL) + return arches->gdbarch; + + /* None found, create a new architecture from the information + provided. */ + tdep = XMALLOC (struct gdbarch_tdep); + gdbarch = gdbarch_alloc (&info, tdep); + + switch (info.bfd_arch_info->mach) + { + default: + break; + } + + set_gdbarch_short_bit (gdbarch, 2 * TARGET_CHAR_BIT); + set_gdbarch_int_bit (gdbarch, 2 * TARGET_CHAR_BIT); + set_gdbarch_long_bit (gdbarch, 4 * TARGET_CHAR_BIT); + set_gdbarch_long_long_bit (gdbarch, 8 * TARGET_CHAR_BIT); + set_gdbarch_ptr_bit (gdbarch, 2 * TARGET_CHAR_BIT); + set_gdbarch_addr_bit (gdbarch, 16); + + /* NOTE: The msp430 has 32 bit 'float' and 'double'. 'long double' is 64 bits. */ + set_gdbarch_float_bit (gdbarch, 4 * TARGET_CHAR_BIT); + set_gdbarch_double_bit (gdbarch, 4 * TARGET_CHAR_BIT); + set_gdbarch_long_double_bit (gdbarch, 8 * TARGET_CHAR_BIT); + + set_gdbarch_float_format (gdbarch, floatformats_ieee_single); + set_gdbarch_double_format (gdbarch, floatformats_ieee_single); + set_gdbarch_long_double_format (gdbarch, floatformats_ieee_double); + + set_gdbarch_read_pc (gdbarch, msp430_read_pc); + set_gdbarch_write_pc (gdbarch, msp430_write_pc); + set_gdbarch_unwind_sp (gdbarch, msp430_unwind_sp); + + set_gdbarch_num_regs (gdbarch, E_NUM_REGS); + + set_gdbarch_sp_regnum (gdbarch, E_SP_REGNUM); + set_gdbarch_pc_regnum (gdbarch, E_PC_REGNUM); + + set_gdbarch_register_name (gdbarch, msp430_register_name); + set_gdbarch_register_type (gdbarch, msp430_register_type); + + set_gdbarch_return_value (gdbarch, msp430_return_value); + set_gdbarch_print_insn (gdbarch, print_insn_msp430); + + set_gdbarch_address_to_pointer (gdbarch, msp430_address_to_pointer); + set_gdbarch_pointer_to_address (gdbarch, msp430_pointer_to_address); + set_gdbarch_integer_to_address (gdbarch, msp430_integer_to_address); + + /* set_gdbarch_use_struct_convention (gdbarch, msp430_use_struct_convention); */ + + set_gdbarch_skip_prologue (gdbarch, msp430_skip_prologue); + set_gdbarch_inner_than (gdbarch, core_addr_lessthan); + + set_gdbarch_decr_pc_after_break (gdbarch, 4); + + /* These values and methods are used when gdb calls a target function. */ + set_gdbarch_push_dummy_call (gdbarch, msp430_push_dummy_call); + set_gdbarch_breakpoint_from_pc (gdbarch, msp430_breakpoint_from_pc); + set_gdbarch_return_value (gdbarch, msp430_return_value); + + /* set_gdbarch_function_start_offset (gdbarch, 0); */ + + set_gdbarch_frame_args_skip (gdbarch, 0); + /* set_gdbarch_frameless_function_invocation (gdbarch, frameless_look_for_prologue); */ + + /*set_gdbarch_store_return_value (gdbarch, msp430_store_return_value); */ + + set_gdbarch_frame_align (gdbarch, msp430_frame_align); + + set_gdbarch_print_registers_info (gdbarch, msp430_print_registers_info); + + frame_unwind_append_unwinder (gdbarch, &msp430_epilogue_frame_unwind); + dwarf2_append_unwinders (gdbarch); + frame_unwind_append_unwinder (gdbarch, &msp430_frame_unwind); + + frame_base_set_default (gdbarch, &msp430_frame_base); + + /* Methods for saving / extracting a dummy frame's ID. The ID's + stack address must match the SP value returned by + PUSH_DUMMY_CALL, and saved by generic_save_dummy_frame_tos. */ + set_gdbarch_dummy_id (gdbarch, msp430_dummy_id); + + set_gdbarch_unwind_pc (gdbarch, msp430_unwind_pc); + + return gdbarch; +} + +void +_initialize_msp430_tdep (void) +{ + register_gdbarch_init (bfd_arch_msp430, msp430_gdbarch_init); + + /* Add backwards compatible deprecated MSP430 specific commands */ + deprecate_cmd (add_com + ("regs", class_vars, show_regs, "Print all registers"), + "info registers"); + + /* Add new MSP430 specific commands */ + add_com ("eraseflash", + class_support, eraseflash_command, "Erase flash memory."); + + add_info ("mcu", mcu_info, "Display info about the attached MCU."); + + add_setshow_boolean_cmd ("releasejtag", + no_class, + &release_jtag_on_go, + "Set release JTAG pins on go.\n", + "Show release JTAG pins on go.\n", + "Use on to set pins and off to release them... ahh I dont know really.\n", + NULL, NULL, &setlist, &showlist); + remote_timeout = 999999999; +} + +//---------------------------------------------------------------------------------------------------------------------- + +bool +ProvideValidGlobalCache (msp430_global_cache * pCache) +{ + struct minimal_symbol *pSym = NULL; + + if (pCache->cache_valid) + return true; + pSym = lookup_minimal_symbol ("__data_start", NULL, NULL); + if (!pSym) + return false; + pCache->min_data_ptr = pSym->ginfo.value.address; + + pSym = lookup_minimal_symbol ("__stack", NULL, NULL); + if (!pSym) + return false; + pCache->max_data_ptr = pSym->ginfo.value.address - 1; + + pSym = lookup_minimal_symbol ("__dtors_end", NULL, NULL); + if (!pSym) + return false; + pCache->min_code_ptr = pSym->ginfo.value.address; + + pSym = lookup_minimal_symbol ("_etext", NULL, NULL); + if (!pSym) + return false; + pCache->max_code_ptr = pSym->ginfo.value.address - 1; + + pCache->cache_valid = true; + return true; +} + diff --git gdb-7.2a.orig/include/elf/msp430.h gdb-7.2a/include/elf/msp430.h index 44f5c51..31372c7 100644 --- gdb-7.2a.orig/include/elf/msp430.h +++ gdb-7.2a/include/elf/msp430.h @@ -33,6 +33,13 @@ #define E_MSP430_MACH_MSP430x14 14 #define E_MSP430_MACH_MSP430x15 15 #define E_MSP430_MACH_MSP430x16 16 +#define E_MSP430_MACH_MSP430x20 20 +#define E_MSP430_MACH_MSP430x21 21 +#define E_MSP430_MACH_MSP430x22 22 +#define E_MSP430_MACH_MSP430x23 23 +#define E_MSP430_MACH_MSP430x24 24 +#define E_MSP430_MACH_MSP430x241 241 +#define E_MSP430_MACH_MSP430x26 26 #define E_MSP430_MACH_MSP430x31 31 #define E_MSP430_MACH_MSP430x32 32 #define E_MSP430_MACH_MSP430x33 33 @@ -40,6 +47,9 @@ #define E_MSP430_MACH_MSP430x42 42 #define E_MSP430_MACH_MSP430x43 43 #define E_MSP430_MACH_MSP430x44 44 +#define E_MSP430_MACH_MSP430x46 46 +#define E_MSP430_MACH_MSP430x47 47 +#define E_MSP430_MACH_MSP430x54 54 /* Relocations. */ START_RELOC_NUMBERS (elf_msp430_reloc_type) @@ -52,6 +62,25 @@ START_RELOC_NUMBERS (elf_msp430_reloc_type) RELOC_NUMBER (R_MSP430_16_PCREL_BYTE, 6) RELOC_NUMBER (R_MSP430_2X_PCREL, 7) RELOC_NUMBER (R_MSP430_RL_PCREL, 8) + RELOC_NUMBER (R_MSP430X_SRC_BYTE, 9) + RELOC_NUMBER (R_MSP430X_SRC, 10) + RELOC_NUMBER (R_MSP430X_DST_BYTE, 11) + RELOC_NUMBER (R_MSP430X_DST, 12) + RELOC_NUMBER (R_MSP430X_DST_2ND_BYTE, 13) + RELOC_NUMBER (R_MSP430X_DST_2ND, 14) + RELOC_NUMBER (R_MSP430X_PCREL_SRC_BYTE, 15) + RELOC_NUMBER (R_MSP430X_PCREL_SRC, 16) + RELOC_NUMBER (R_MSP430X_PCREL_DST_BYTE, 17) + RELOC_NUMBER (R_MSP430X_PCREL_DST, 18) + RELOC_NUMBER (R_MSP430X_PCREL_DST_2ND, 19) + RELOC_NUMBER (R_MSP430X_PCREL_DST_2ND_BYTE, 20) + RELOC_NUMBER (R_MSP430X_S_BYTE, 21) + RELOC_NUMBER (R_MSP430X_S, 22) + RELOC_NUMBER (R_MSP430X_D_BYTE, 23) + RELOC_NUMBER (R_MSP430X_D, 24) + RELOC_NUMBER (R_MSP430X_PCREL_D, 25) + RELOC_NUMBER (R_MSP430X_INDXD, 26) + RELOC_NUMBER (R_MSP430X_PCREL_INDXD, 27) END_RELOC_NUMBERS (R_MSP430_max) diff --git gdb-7.2a.orig/include/opcode/msp430.h gdb-7.2a/include/opcode/msp430.h index d3bf130..60ec9d6 100644 --- gdb-7.2a.orig/include/opcode/msp430.h +++ gdb-7.2a/include/opcode/msp430.h @@ -26,7 +26,7 @@ struct msp430_operand_s int ol; /* Operand length words. */ int am; /* Addr mode. */ int reg; /* Register. */ - int mode; /* Pperand mode. */ + int mode; /* Operand mode. */ #define OP_REG 0 #define OP_EXP 1 #ifndef DASM_SECTION @@ -34,91 +34,240 @@ struct msp430_operand_s #endif }; -#define BYTE_OPERATION (1 << 6) /* Byte operation flag for all instructions. */ +#define BYTE_OPERATION (1 << 6) /* Byte operation flag for 430 instructions. */ +#define BYTE_OPERATION_X (1 << 22) /* Byte operation flag for 430x instructions. */ +#define NON_ADDR_OPERATION (1 << 6) /* Address operation flag for 430x instructions. */ + +typedef enum +{ + DEFAULT_OP, // instruction has no modifier + WORD_OP, // .w + BYTE_OP, // .b + ADDR_OP // .a +} +opwidth_t; + +typedef enum +{ + CORE_430, // 1xxx, 2xxx, 3xxx, 4xxx + CORE_430X, // 241x, 26xx, 46xx + CORE_430X2, // 5xxx +} +core_t; + +typedef enum +{ + FMT_EMULATED = 0, + FMT_DOUBLE_OPERAND, + FMT_SINGLE_OPERAND, + FMT_JUMP, + FMT_EMULATED_POLYMORPH_JUMP, + FMT_EMULATED_LONG_POLYMORPH_JUMP, + FMT_X_DOUBLE_OPERAND, + FMT_X_SINGLE_OPERAND, + FMT_X_EXCEPTION, + FMT_X_EMULATED, + FMT_X_ADDRESS, + + FMT_X = FMT_X_DOUBLE_OPERAND, + FMT_MASK = 0x000f, + + /* allowed modifiers: .b, .w, .a */ + MOD_NONE = 0, + MOD_W = 1 << 4, + MOD_B = 1 << 5, + MOD_A = 1 << 6, + MOD_MASK = 0x0070, + + /* opcode variant */ + VAR_MASK = 0x0380, +} +format_t; + +#define OP_V(x) (x << 7) struct msp430_opcode_s { char *name; - int fmt; - int insn_opnumb; - int bin_opcode; - int bin_mask; + format_t fmt; + unsigned int insn_opnumb; + unsigned int bin_opcode; + unsigned int bin_mask; +}; + +#define opcode_format(opcode) (opcode->fmt & FMT_MASK) +#define opcode_modifier(opcode) (opcode->fmt & MOD_MASK) +#define opcode_variant(opcode) ((opcode->fmt & VAR_MASK) >> 7) + +/* opcode variants: */ +enum +{ + V_NONE = 0, // ordinary instruction + + /* FMT_EMULATED: */ + V_NOOP, // no operands: set/clear bit instructions, reti + V_SHIFT, // shift instructions + V_BR, // br instruction + + /* FMT_SINGLE_OPERAND: */ + V_RETI = 1, // reti + V_CALL = 2, // hex operand in disassembly + + /* FMT_X_SINGLE_OPERAND: */ + // V_NONE - #N operand disallowed + V_SWPSXT = 1, // #N operand disallowed, special A/L, B/W bits case with .a modifier + V_PUSHX, // #N operand allowed + + /* FMT_X_EXCEPTIONS: */ + V_CALLA = 0, // calla + V_ROTM, // two operands, rotations + V_POPM, // two operands, popm + V_PUSHM, // two operands, pushm + + /* FMT_X_EMULATED: */ + // V_NONE - substituted by 430x double operand instruction + V_X_SHIFT, // shifts + V_RETA, // reta, short instruction, no operands + V_EMU_ADDR, // substituted by address instruction other than mova + V_BRA, // bra, substituted by mova address instruction == format II exception instruction + // clra emulated by msp430 instruction + + /* FMT_X_ADDRESS: */ + V_MOVA = 1, // mova, more address modes allowed }; -#define MSP_INSN(name, size, numb, bin, mask) { #name, size, numb, bin, mask } +#define MSP_INSN(name, format, opnumb, bin, mask) { #name, format, opnumb, bin, mask } -static struct msp430_opcode_s msp430_opcodes[] = +static struct msp430_opcode_s const msp430_opcodes[] = { - MSP_INSN (and, 1, 2, 0xf000, 0xf000), - MSP_INSN (inv, 0, 1, 0xe330, 0xfff0), - MSP_INSN (xor, 1, 2, 0xe000, 0xf000), - MSP_INSN (setz, 0, 0, 0xd322, 0xffff), - MSP_INSN (setc, 0, 0, 0xd312, 0xffff), - MSP_INSN (eint, 0, 0, 0xd232, 0xffff), - MSP_INSN (setn, 0, 0, 0xd222, 0xffff), - MSP_INSN (bis, 1, 2, 0xd000, 0xf000), - MSP_INSN (clrz, 0, 0, 0xc322, 0xffff), - MSP_INSN (clrc, 0, 0, 0xc312, 0xffff), - MSP_INSN (dint, 0, 0, 0xc232, 0xffff), - MSP_INSN (clrn, 0, 0, 0xc222, 0xffff), - MSP_INSN (bic, 1, 2, 0xc000, 0xf000), - MSP_INSN (bit, 1, 2, 0xb000, 0xf000), - MSP_INSN (dadc, 0, 1, 0xa300, 0xff30), - MSP_INSN (dadd, 1, 2, 0xa000, 0xf000), - MSP_INSN (tst, 0, 1, 0x9300, 0xff30), - MSP_INSN (cmp, 1, 2, 0x9000, 0xf000), - MSP_INSN (decd, 0, 1, 0x8320, 0xff30), - MSP_INSN (dec, 0, 1, 0x8310, 0xff30), - MSP_INSN (sub, 1, 2, 0x8000, 0xf000), - MSP_INSN (sbc, 0, 1, 0x7300, 0xff30), - MSP_INSN (subc, 1, 2, 0x7000, 0xf000), - MSP_INSN (adc, 0, 1, 0x6300, 0xff30), - MSP_INSN (rlc, 0, 2, 0x6000, 0xf000), - MSP_INSN (addc, 1, 2, 0x6000, 0xf000), - MSP_INSN (incd, 0, 1, 0x5320, 0xff30), - MSP_INSN (inc, 0, 1, 0x5310, 0xff30), - MSP_INSN (rla, 0, 2, 0x5000, 0xf000), - MSP_INSN (add, 1, 2, 0x5000, 0xf000), - MSP_INSN (nop, 0, 0, 0x4303, 0xffff), - MSP_INSN (clr, 0, 1, 0x4300, 0xff30), - MSP_INSN (ret, 0, 0, 0x4130, 0xff30), - MSP_INSN (pop, 0, 1, 0x4130, 0xff30), - MSP_INSN (br, 0, 3, 0x4000, 0xf000), - MSP_INSN (mov, 1, 2, 0x4000, 0xf000), - MSP_INSN (jmp, 3, 1, 0x3c00, 0xfc00), - MSP_INSN (jl, 3, 1, 0x3800, 0xfc00), - MSP_INSN (jge, 3, 1, 0x3400, 0xfc00), - MSP_INSN (jn, 3, 1, 0x3000, 0xfc00), - MSP_INSN (jc, 3, 1, 0x2c00, 0xfc00), - MSP_INSN (jhs, 3, 1, 0x2c00, 0xfc00), - MSP_INSN (jnc, 3, 1, 0x2800, 0xfc00), - MSP_INSN (jlo, 3, 1, 0x2800, 0xfc00), - MSP_INSN (jz, 3, 1, 0x2400, 0xfc00), - MSP_INSN (jeq, 3, 1, 0x2400, 0xfc00), - MSP_INSN (jnz, 3, 1, 0x2000, 0xfc00), - MSP_INSN (jne, 3, 1, 0x2000, 0xfc00), - MSP_INSN (reti, 2, 0, 0x1300, 0xffc0), - MSP_INSN (call, 2, 1, 0x1280, 0xffc0), - MSP_INSN (push, 2, 1, 0x1200, 0xff80), - MSP_INSN (sxt, 2, 1, 0x1180, 0xffc0), - MSP_INSN (rra, 2, 1, 0x1100, 0xff80), - MSP_INSN (swpb, 2, 1, 0x1080, 0xffc0), - MSP_INSN (rrc, 2, 1, 0x1000, 0xff80), + MSP_INSN (and, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xf000, 0xfffff000), + MSP_INSN (inv, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0xe330, 0xfffffff0), + MSP_INSN (xor, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xe000, 0xfffff000), + MSP_INSN (setz, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xd322, 0xffffffff), + MSP_INSN (setc, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xd312, 0xffffffff), + MSP_INSN (eint, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xd232, 0xffffffff), + MSP_INSN (setn, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xd222, 0xffffffff), + MSP_INSN (bis, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xd000, 0xfffff000), + MSP_INSN (clrz, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xc322, 0xffffffff), + MSP_INSN (clrc, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xc312, 0xffffffff), + MSP_INSN (dint, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xc232, 0xffffffff), + MSP_INSN (clrn, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0xc222, 0xffffffff), + MSP_INSN (bic, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xc000, 0xfffff000), + MSP_INSN (bit, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xb000, 0xfffff000), + MSP_INSN (dadc, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0xa300, 0xffffff30), + MSP_INSN (dadd, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0xa000, 0xfffff000), + MSP_INSN (tst, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x9300, 0xffffff30), + MSP_INSN (cmp, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x9000, 0xfffff000), + MSP_INSN (decd, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x8320, 0xffffff30), + MSP_INSN (dec, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x8310, 0xffffff30), + MSP_INSN (sub, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x8000, 0xfffff000), + MSP_INSN (sbc, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x7300, 0xffffff30), + MSP_INSN (subc, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x7000, 0xfffff000), + MSP_INSN (adc, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x6300, 0xffffff30), + MSP_INSN (rlc, FMT_EMULATED | MOD_W|MOD_B | OP_V(V_SHIFT), 2, 0x6000, 0xfffff000), + MSP_INSN (addc, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x6000, 0xfffff000), + MSP_INSN (incd, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x5320, 0xffffff30), + MSP_INSN (inc, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x5310, 0xffffff30), + MSP_INSN (rla, FMT_EMULATED | MOD_W|MOD_B | OP_V(V_SHIFT), 2, 0x5000, 0xfffff000), + MSP_INSN (add, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x5000, 0xfffff000), + MSP_INSN (nop, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0x4303, 0xffffffff), + MSP_INSN (clr, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x4300, 0xffffff30), + MSP_INSN (clra, FMT_EMULATED | MOD_NONE | OP_V(0), 1, 0x4300, 0xffffff30), // MOV #0, Rdst + MSP_INSN (ret, FMT_EMULATED | MOD_NONE | OP_V(V_NOOP), 0, 0x4130, 0xffffffff), + MSP_INSN (pop, FMT_EMULATED | MOD_W|MOD_B | OP_V(0), 1, 0x4130, 0xffffff30), + MSP_INSN (br, FMT_EMULATED | MOD_NONE | OP_V(V_BR), 1, 0x4000, 0xfffff08f), + MSP_INSN (mov, FMT_DOUBLE_OPERAND | MOD_W|MOD_B | OP_V(0), 2, 0x4000, 0xfffff000), + + MSP_INSN (jmp, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x3c00, 0xfffffc00), + MSP_INSN (jl, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x3800, 0xfffffc00), + MSP_INSN (jge, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x3400, 0xfffffc00), + MSP_INSN (jn, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x3000, 0xfffffc00), + MSP_INSN (jc, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2c00, 0xfffffc00), + MSP_INSN (jhs, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2c00, 0xfffffc00), + MSP_INSN (jnc, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2800, 0xfffffc00), + MSP_INSN (jlo, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2800, 0xfffffc00), + MSP_INSN (jz, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2400, 0xfffffc00), + MSP_INSN (jeq, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2400, 0xfffffc00), + MSP_INSN (jnz, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2000, 0xfffffc00), + MSP_INSN (jne, FMT_JUMP | MOD_NONE | OP_V(0), 1, 0x2000, 0xfffffc00), + + MSP_INSN (reti, FMT_SINGLE_OPERAND | MOD_NONE | OP_V(V_RETI), 0, 0x1300, 0xffffffc0), + MSP_INSN (call, FMT_SINGLE_OPERAND | MOD_NONE | OP_V(V_CALL), 1, 0x1280, 0xffffffc0), + MSP_INSN (push, FMT_SINGLE_OPERAND | MOD_W|MOD_B | OP_V(0), 1, 0x1200, 0xffffff80), + MSP_INSN (sxt, FMT_SINGLE_OPERAND | MOD_NONE | OP_V(0), 1, 0x1180, 0xffffffc0), + MSP_INSN (rra, FMT_SINGLE_OPERAND | MOD_W|MOD_B | OP_V(0), 1, 0x1100, 0xffffff80), + MSP_INSN (swpb, FMT_SINGLE_OPERAND | MOD_NONE | OP_V(0), 1, 0x1080, 0xffffffc0), + MSP_INSN (rrc, FMT_SINGLE_OPERAND | MOD_W|MOD_B | OP_V(0), 1, 0x1000, 0xffffff80), + + + /* emulated instructions placed just before instruction emulated by for disassembly search */ + MSP_INSN (popx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x41301800, 0xff30f800), // MOVX @SP+, dst + MSP_INSN (clrx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x43001800, 0xff30f800), // MOVX #0, dst + MSP_INSN (movx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x40001800, 0xf000f800), + MSP_INSN (incx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x53101800, 0xff30f800), // ADDX #1, dst + MSP_INSN (incdx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x53201800, 0xff30f800), // ADDX #2, dst + MSP_INSN (rlax, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(V_X_SHIFT), 1, 0x50001800, 0xf000f800), // ADDX dst, dst + MSP_INSN (addx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x50001800, 0xf000f800), + MSP_INSN (adcx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x63001800, 0xff30f800), // ADDCX #0, dst + MSP_INSN (rlcx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(V_X_SHIFT), 1, 0x60001800, 0xf000f800), // ADDCX dst, dst + MSP_INSN (addcx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x60001800, 0xf000f800), + MSP_INSN (sbcx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x73001800, 0xff30f800), // SUBCX #0, dst + MSP_INSN (subcx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x70001800, 0xf000f800), + MSP_INSN (decx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x83101800, 0xff30f800), // SUBX #1, dst + MSP_INSN (decdx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x83201800, 0xff30f800), // SUBX #2, dst + MSP_INSN (subx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x80001800, 0xf000f800), + MSP_INSN (tstx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x93001800, 0xff30f800), // CMPX #0, dst + MSP_INSN (cmpx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0x90001800, 0xf000f800), + MSP_INSN (dadcx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0xa3001800, 0xff30f800), // DADDX #0, dst + MSP_INSN (daddx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xa0001800, 0xf000f800), + MSP_INSN (bitx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xb0001800, 0xf000f800), + MSP_INSN (bicx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xc0001800, 0xf000f800), + MSP_INSN (bisx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xd0001800, 0xf000f800), + MSP_INSN (invx, FMT_X_EMULATED | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0xe3301800, 0xff30f800), // XORX #-1, dst + MSP_INSN (xorx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xe0001800, 0xf000f800), + MSP_INSN (andx, FMT_X_DOUBLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 2, 0xf0001800, 0xf000f800), + + MSP_INSN (rrcx, FMT_X_SINGLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x10001800, 0xff80f800), + MSP_INSN (swpbx, FMT_X_SINGLE_OPERAND | MOD_W|MOD_A | OP_V(V_SWPSXT), 1, 0x10801800, 0xffc0f800), + MSP_INSN (rrax, FMT_X_SINGLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(0), 1, 0x11001800, 0xff80f800), + MSP_INSN (sxtx, FMT_X_SINGLE_OPERAND | MOD_W|MOD_A | OP_V(V_SWPSXT), 1, 0x11801800, 0xffc0f800), + MSP_INSN (pushx, FMT_X_SINGLE_OPERAND | MOD_W|MOD_B|MOD_A | OP_V(V_PUSHX), 1, 0x12001800, 0xff80f800), + + MSP_INSN (calla, FMT_X_EXCEPTION | MOD_NONE | OP_V(V_CALLA), 1, 0x1300, 0xffffff00), + MSP_INSN (pushm, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_PUSHM), 2, 0x1400, 0xfffffe00), + MSP_INSN (popm, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_POPM), 2, 0x1600, 0xfffffe00), + MSP_INSN (rrcm, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_ROTM), 2, 0x0040, 0xfffff3e0), + MSP_INSN (rram, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_ROTM), 2, 0x0140, 0xfffff3e0), + MSP_INSN (rlam, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_ROTM), 2, 0x0240, 0xfffff3e0), + MSP_INSN (rrum, FMT_X_EXCEPTION | MOD_W|MOD_A | OP_V(V_ROTM), 2, 0x0340, 0xfffff3e0), + + /* Address. */ + MSP_INSN (incda, FMT_X_EMULATED | MOD_NONE | OP_V(V_EMU_ADDR), 1, 0x03e0, 0xfffffff0), // ADDA #2, Rdst = ADDA R3, Rdst + MSP_INSN (adda, FMT_X_ADDRESS | MOD_NONE | OP_V(0), 2, 0x00a0, 0xfffff0b0), + MSP_INSN (tsta, FMT_X_EMULATED | MOD_NONE | OP_V(V_EMU_ADDR), 1, 0x03d0, 0xfffffff0), // CMPA #0, Rdst = CMPA R3, Rdst + MSP_INSN (cmpa, FMT_X_ADDRESS | MOD_NONE | OP_V(0), 2, 0x0090, 0xfffff0b0), + MSP_INSN (decda, FMT_X_EMULATED | MOD_NONE | OP_V(V_EMU_ADDR), 1, 0x03f0, 0xfffffff0), // SUBA #2, Rdst = SUBA R3, Rdst + MSP_INSN (suba, FMT_X_ADDRESS | MOD_NONE | OP_V(0), 2, 0x00b0, 0xfffff0b0), + MSP_INSN (reta, FMT_X_EMULATED | MOD_NONE | OP_V(V_RETA), 0, 0x0110, 0xffffffff), // MOVA @SP+, PC + MSP_INSN (bra, FMT_X_EMULATED | MOD_NONE | OP_V(V_BRA), 1, 0x0000, 0xfffff0cf), // MOVA dst, PC + MSP_INSN (bra, FMT_X_EMULATED | MOD_NONE | OP_V(V_BRA), 1, 0x0080, 0xfffff0bf), // MOVA #imm20, PC; MOVA Rsrc, Rdst + MSP_INSN (mova, FMT_X_ADDRESS | MOD_NONE | OP_V(V_MOVA), 1, 0x0000, 0xfffff000), + /* Simple polymorphs. */ - MSP_INSN (beq, 4, 0, 0, 0xffff), - MSP_INSN (bne, 4, 1, 0, 0xffff), - MSP_INSN (blt, 4, 2, 0, 0xffff), - MSP_INSN (bltu, 4, 3, 0, 0xffff), - MSP_INSN (bge, 4, 4, 0, 0xffff), - MSP_INSN (bgeu, 4, 5, 0, 0xffff), - MSP_INSN (bltn, 4, 6, 0, 0xffff), - MSP_INSN (jump, 4, 7, 0, 0xffff), - /* Long polymorphs. */ - MSP_INSN (bgt, 5, 0, 0, 0xffff), - MSP_INSN (bgtu, 5, 1, 0, 0xffff), - MSP_INSN (bleu, 5, 2, 0, 0xffff), - MSP_INSN (ble, 5, 3, 0, 0xffff), + MSP_INSN (beq, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(0), 1, 0, 0xffff), + MSP_INSN (bne, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(1), 1, 0, 0xffff), + MSP_INSN (blt, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(2), 1, 0, 0xffff), + MSP_INSN (bltu, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(3), 1, 0, 0xffff), + MSP_INSN (bge, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(4), 1, 0, 0xffff), + MSP_INSN (bgeu, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(5), 1, 0, 0xffff), + MSP_INSN (bltn, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(6), 1, 0, 0xffff), + MSP_INSN (jump, FMT_EMULATED_POLYMORPH_JUMP | MOD_NONE | OP_V(7), 1, 0, 0xffff), + /* Long polymorphs. */ + MSP_INSN (bgt, FMT_EMULATED_LONG_POLYMORPH_JUMP | MOD_NONE | OP_V(0), 1, 0, 0xffff), + MSP_INSN (bgtu, FMT_EMULATED_LONG_POLYMORPH_JUMP | MOD_NONE | OP_V(1), 1, 0, 0xffff), + MSP_INSN (bleu, FMT_EMULATED_LONG_POLYMORPH_JUMP | MOD_NONE | OP_V(2), 1, 0, 0xffff), + MSP_INSN (ble, FMT_EMULATED_LONG_POLYMORPH_JUMP | MOD_NONE | OP_V(3), 1, 0, 0xffff), /* End of instruction set. */ { NULL, 0, 0, 0, 0 } }; diff --git gdb-7.2a.orig/opcodes/msp430-dis.c gdb-7.2a/opcodes/msp430-dis.c index 9d7edbe..22a6ebd 100644 --- gdb-7.2a.orig/opcodes/msp430-dis.c +++ gdb-7.2a/opcodes/msp430-dis.c @@ -1,6 +1,5 @@ /* Disassemble MSP430 instructions. - Copyright (C) 2002, 2004, 2005, 2007, 2009, 2010 - Free Software Foundation, Inc. + Copyright (C) 2002, 2004, 2005, 2007, 2009 Free Software Foundation, Inc. Contributed by Dmitry Diky @@ -52,12 +51,153 @@ msp430dis_opcode (bfd_vma addr, disassemble_info *info) return bfd_getl16 (buffer); } +static unsigned short +msp430dis_operand (bfd_vma addr, disassemble_info *info, int reg, int am, int *cmd_len) +{ + static int const op_length [][5] = + { + // am | reg 0 1 2 3 >3 + /* 0 */ { 0, 0, 0, 0, 0 }, // Rn + /* 1 */ { 2, 2, 2, 0, 2 }, // x(Rn) + /* 2 */ { 0, 0, 0, 0, 0 }, // @Rn + /* 3 */ { 2, 0, 0, 0, 0 }, // @Rn+ + }; + if (reg >= (int)(sizeof(op_length[0]) / sizeof(op_length[0][0]))) + reg = sizeof(op_length[0]) / sizeof(op_length[0][0])- 1; + + if (op_length[am][reg]) + { + bfd_byte buffer[2]; + int status = info->read_memory_func (addr, buffer, 2, info); + if (status != 0) + { + info->memory_error_func (status, addr, info); + return -1; + } + *cmd_len += 2; + return bfd_getl16 (buffer); + } + return 0; +} + +typedef enum +{ + OP_20BIT, + OP_16BIT, + OP_20BIT_HEX, + OP_16BIT_HEX, + OP_DECIMAL, +} operand_t; + +static void +msp430x_decode_operand(int reg, int am, int addr, int dst, operand_t size, char *op, char *comm) +{ + if (op) // if operand not hidden in emulated instruction + switch (am) + { + case 0: // Rn + if (reg == 3) + { + sprintf (op, "#0"); // constant #0 + sprintf (comm, "r3 As==00"); + } + else + { + sprintf (op, "r%d", reg); + } + break; + case 1: // x(Rn) + if (reg == 0) // Symbolic, ADDR + { + if (size == OP_20BIT || size == OP_20BIT_HEX) + sprintf (op, "0x%05x", dst & 0xfffff); + else + sprintf (op, "0x%04x", dst & 0xffff); + sprintf (comm, "PC rel. 0x%05x", ((int)addr + dst) & 0xfffff); + } + else if (reg == 2) // Absolute, &ADDR + { + if (size == OP_20BIT || size == OP_20BIT_HEX) + sprintf (op, "&0x%05x", dst & 0xfffff); + else + sprintf (op, "&0x%04x", dst & 0xffff); + } + else if (reg == 3) // constant #1 + { + sprintf (op, "#1"); + sprintf (comm, "r3 As==01"); + } + else // Indexed, x(Rn) + { + sprintf (op, "%d(r%d)", dst, reg); + if (size == OP_20BIT || size == OP_20BIT_HEX) + sprintf (comm, "0x%05x(r%d)", dst & 0xfffff, reg); + else + sprintf (comm, "0x%04x(r%d)", dst & 0xffff, reg); + } + break; + case 2: // @Rn + if (reg == 2) // constant #4 + { + sprintf (op, "#4"); + sprintf (comm, "r2 As==10"); + } + else if(reg == 3) // constant #2 + { + sprintf (op, "#2"); + sprintf (comm, "r3 As==10"); + } + else + { + sprintf (op, "@r%d", reg); + } + break; + case 3: // @Rn+ + switch (reg) + { + case 0: // immediate, #N + switch (size) + { + case OP_16BIT: + sprintf (op, "#%d", dst); + sprintf (comm, "#0x%04x", dst & 0xffff); + break; + case OP_16BIT_HEX: + sprintf (op, "#0x%04x", dst & 0xffff); + break; + case OP_20BIT: + sprintf (op, "#%d", dst); + sprintf (comm, "#0x%05x", dst & 0xfffff); + break; + case OP_20BIT_HEX: + sprintf (op, "#0x%05x", dst & 0xfffff); + break; + default: // #n in rxxm + sprintf (op, "#%d", dst); + break; + } + break; + case 2: // constant #8 + sprintf (op, "#8"); + sprintf (comm, "r2 As==11"); + break; + case 3: // constant #-1 + sprintf (op, "#-1"); + sprintf (comm, "r3 As==11"); + break; + default: + sprintf (op, "@r%d+", reg); + break; + } + break; + } +} + static int -msp430_nooperands (struct msp430_opcode_s *opcode, +msp430_nooperands (struct msp430_opcode_s const *opcode, bfd_vma addr ATTRIBUTE_UNUSED, unsigned short insn ATTRIBUTE_UNUSED, - char *comm, - int *cycles) + char *comm) { /* Pop with constant. */ if (insn == 0x43b2) @@ -65,18 +205,16 @@ msp430_nooperands (struct msp430_opcode_s *opcode, if (insn == opcode->bin_opcode) return 2; - if (opcode->fmt == 0) + if (opcode_format(opcode) == FMT_EMULATED) { if ((insn & 0x0f00) != 3 || (insn & 0x0f00) != 2) return 0; strcpy (comm, "emulated..."); - *cycles = 1; } else { strcpy (comm, "return from interupt"); - *cycles = 5; } return 2; @@ -84,16 +222,14 @@ msp430_nooperands (struct msp430_opcode_s *opcode, static int msp430_singleoperand (disassemble_info *info, - struct msp430_opcode_s *opcode, + struct msp430_opcode_s const *opcode, bfd_vma addr, unsigned short insn, char *op, - char *comm, - int *cycles) + char *comm) { int regs = 0, regd = 0; int ad = 0, as = 0; - int where = 0; int cmd_len = 2; short dst = 0; @@ -102,9 +238,9 @@ msp430_singleoperand (disassemble_info *info, as = (insn & 0x0030) >> 4; ad = (insn & 0x0080) >> 7; - switch (opcode->fmt) + switch (opcode_format(opcode)) { - case 0: /* Emulated work with dst register. */ + case FMT_EMULATED: /* Emulated work with dst register. */ if (regs != 2 && regs != 3 && regs != 1) return 0; @@ -116,167 +252,23 @@ msp430_singleoperand (disassemble_info *info, if ((opcode->bin_opcode & 0xff00) == 0x5300 && as == 3) return 0; - if (ad == 0) - { - *cycles = 1; - - /* Register. */ - if (regd == 0) - { - *cycles += 1; - sprintf (op, "r0"); - } - else if (regd == 1) - sprintf (op, "r1"); - - else if (regd == 2) - sprintf (op, "r2"); - - else - sprintf (op, "r%d", regd); - } - else /* ad == 1 msp430dis_opcode. */ - { - if (regd == 0) - { - /* PC relative. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - *cycles = 4; - sprintf (op, "0x%04x", dst); - sprintf (comm, "PC rel. abs addr 0x%04x", - PS ((short) (addr + 2) + dst)); - } - else if (regd == 2) - { - /* Absolute. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - *cycles = 4; - sprintf (op, "&0x%04x", PS (dst)); - } - else - { - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - *cycles = 4; - sprintf (op, "%d(r%d)", dst, regd); - } - } + dst = msp430dis_operand (addr + cmd_len, info, regd, ad, &cmd_len); + msp430x_decode_operand (regd, ad, addr + cmd_len, dst, OP_16BIT, op, comm); break; - case 2: /* rrc, push, call, swpb, rra, sxt, push, call, reti etc... */ - if (as == 0) - { - if (regd == 3) - { - /* Constsnts. */ - sprintf (op, "#0"); - sprintf (comm, "r3 As==00"); - } - else - { - /* Register. */ - sprintf (op, "r%d", regd); - } - *cycles = 1; - } - else if (as == 2) - { - *cycles = 1; - if (regd == 2) - { - sprintf (op, "#4"); - sprintf (comm, "r2 As==10"); - } - else if (regd == 3) - { - sprintf (op, "#2"); - sprintf (comm, "r3 As==10"); - } - else - { - *cycles = 3; - /* Indexed register mode @Rn. */ - sprintf (op, "@r%d", regd); - } - } - else if (as == 3) - { - *cycles = 1; - if (regd == 2) - { - sprintf (op, "#8"); - sprintf (comm, "r2 As==11"); - } - else if (regd == 3) - { - sprintf (op, "#-1"); - sprintf (comm, "r3 As==11"); - } - else if (regd == 0) - { - *cycles = 3; - /* absolute. @pc+ */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op, "#%d", dst); - sprintf (comm, "#0x%04x", PS (dst)); - } - else - { - *cycles = 3; - sprintf (op, "@r%d+", regd); - } - } - else if (as == 1) - { - *cycles = 4; - if (regd == 0) - { - /* PC relative. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op, "0x%04x", PS (dst)); - sprintf (comm, "PC rel. 0x%04x", - PS ((short) addr + 2 + dst)); - } - else if (regd == 2) - { - /* Absolute. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op, "&0x%04x", PS (dst)); - } - else if (regd == 3) - { - *cycles = 1; - sprintf (op, "#1"); - sprintf (comm, "r3 As==01"); - } - else - { - /* Indexd. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op, "%d(r%d)", dst, regd); - } - } + case FMT_SINGLE_OPERAND: /* rrc, push, call, swpb, rra, sxt, push, call, reti etc... */ + dst = msp430dis_operand (addr + cmd_len, info, regd, as, &cmd_len); + if(opcode_variant(opcode) != V_CALL) + msp430x_decode_operand (regd, as, addr + cmd_len, dst, OP_16BIT, op, comm); + else + msp430x_decode_operand (regd, as, addr + cmd_len, dst, OP_16BIT_HEX, op, comm); break; - case 3: /* Jumps. */ - where = insn & 0x03ff; - if (where & 0x200) - where |= ~0x03ff; - if (where > 512 || where < -511) - return 0; - - where *= 2; - sprintf (op, "$%+-8d", where + 2); - sprintf (comm, "abs 0x%x", PS ((short) (addr) + 2 + where)); - *cycles = 2; + case FMT_JUMP: /* Jumps. */ + dst = (short)((insn & 0x03ff) << 6) >> 5; // sign extension, word addr to byte addr conversion + sprintf (op, "$%+-8d", dst + 2); + sprintf (comm, "abs 0x%x", PS ((short) (addr) + 2 + dst)); return 2; - break; default: cmd_len = 0; } @@ -286,26 +278,26 @@ msp430_singleoperand (disassemble_info *info, static int msp430_doubleoperand (disassemble_info *info, - struct msp430_opcode_s *opcode, + struct msp430_opcode_s const *opcode, bfd_vma addr, unsigned short insn, char *op1, char *op2, char *comm1, - char *comm2, - int *cycles) + char *comm2) { int regs = 0, regd = 0; int ad = 0, as = 0; int cmd_len = 2; - short dst = 0; + short ops; + short opd; regd = insn & 0x0f; regs = (insn & 0x0f00) >> 8; as = (insn & 0x0030) >> 4; ad = (insn & 0x0080) >> 7; - if (opcode->fmt == 0) + if (opcode_format(opcode) == FMT_EMULATED) { /* Special case: rla and rlc are the only 2 emulated instructions that fall into two operand instructions. */ @@ -320,347 +312,352 @@ msp430_doubleoperand (disassemble_info *info, if (regd != regs || as != ad) return 0; /* May be 'data' section. */ - if (ad == 0) + if (ad == 0 && regd == 3) // #N { - /* Register mode. */ - if (regd == 3) - { - strcpy (comm1, _("Illegal as emulation instr")); - return -1; - } - - sprintf (op1, "r%d", regd); - *cycles = 1; - } - else /* ad == 1 */ - { - if (regd == 0) - { - /* PC relative, Symbolic. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 4; - *cycles = 6; - sprintf (op1, "0x%04x", PS (dst)); - sprintf (comm1, "PC rel. 0x%04x", - PS ((short) addr + 2 + dst)); - - } - else if (regd == 2) - { - /* Absolute. */ - dst = msp430dis_opcode (addr + 2, info); - /* If the 'src' field is not the same as the dst - then this is not an rla instruction. */ - if (dst != msp430dis_opcode (addr + 4, info)) - return 0; - cmd_len += 4; - *cycles = 6; - sprintf (op1, "&0x%04x", PS (dst)); - } - else - { - /* Indexed. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 4; - *cycles = 6; - sprintf (op1, "%d(r%d)", dst, regd); - } + strcpy (comm1, _("Illegal as emulation instr")); + return -1; } + ops = msp430dis_operand (addr + cmd_len, info, regs, as, &cmd_len); + opd = msp430dis_operand (addr + cmd_len, info, regd, ad, &cmd_len); + /* If the 'src' field is not the same as the dst + then this is not an rla instruction. */ + if (ops != opd) + return 0; + msp430x_decode_operand (regs, as, addr + cmd_len, ops, OP_16BIT, op1, comm1); *op2 = 0; *comm2 = 0; return cmd_len; } - /* Two operands exactly. */ + if (ad == 0 && regd == 3) { /* R2/R3 are illegal as dest: may be data section. */ strcpy (comm1, _("Illegal as 2-op instr")); return -1; } + ops = msp430dis_operand (addr + cmd_len, info, regs, as, &cmd_len); + msp430x_decode_operand (regs, as, addr + cmd_len, ops, OP_16BIT, op1, comm1); - /* Source. */ - if (as == 0) - { - *cycles = 1; - if (regs == 3) - { - /* Constsnts. */ - sprintf (op1, "#0"); - sprintf (comm1, "r3 As==00"); - } - else - { - /* Register. */ - sprintf (op1, "r%d", regs); - } - } - else if (as == 2) - { - *cycles = 1; + opd = msp430dis_operand (addr + cmd_len, info, regd, ad, &cmd_len); + msp430x_decode_operand (regd, ad, addr + cmd_len, opd, OP_16BIT, op2, comm2); + return cmd_len; +} - if (regs == 2) - { - sprintf (op1, "#4"); - sprintf (comm1, "r2 As==10"); - } - else if (regs == 3) - { - sprintf (op1, "#2"); - sprintf (comm1, "r3 As==10"); - } - else - { - *cycles = 2; +static int +msp430_branchinstr (disassemble_info *info, + struct msp430_opcode_s const *opcode ATTRIBUTE_UNUSED, + bfd_vma addr ATTRIBUTE_UNUSED, + unsigned short insn, + char *op1, + char *comm1) +{ + int regs = (insn & 0x0f00) >> 8; + int as = (insn & 0x0030) >> 4; + int cmd_len = 2; + short dst; - /* Indexed register mode @Rn. */ - sprintf (op1, "@r%d", regs); - } - if (!regs) - *cycles = 3; - } - else if (as == 3) + dst = msp430dis_operand (addr + cmd_len, info, regs, as, &cmd_len); + msp430x_decode_operand(regs, as, addr + cmd_len, dst, OP_16BIT_HEX, op1, comm1); + + return cmd_len; +} + +static opwidth_t +msp430x_opwidth(unsigned int insn) +{ + insn &= NON_ADDR_OPERATION | BYTE_OPERATION_X; + + if(insn == (NON_ADDR_OPERATION | BYTE_OPERATION_X)) + return BYTE_OP; + if(insn == NON_ADDR_OPERATION) + return WORD_OP; + if(insn == BYTE_OPERATION_X) + return ADDR_OP; + + return 0; // reserved +} + +static int +msp430x_singleoperand (disassemble_info *info, + struct msp430_opcode_s const *opcode, + bfd_vma addr, + unsigned int insn, + char *op, + char *comm, + int *repeats) +{ + int reg = (insn >> 16) & 0xf; + int am = (insn >> 20) & 0x3; + int cmd_len = 4; + int dst = 0; + + if ( opcode_variant(opcode) < V_PUSHX ) + if ((am == 3 && reg == 0) // #N operand + || (am == 0 && reg == 3) // R3 is illegal as dest: may be data section. + ) + { + strcpy (comm, _("Illegal as 1-op instr")); + return -1; + } + + // extract repeat count if any + if ( am == 0 ) // extension word for register mode { - if (regs == 2) - { - sprintf (op1, "#8"); - sprintf (comm1, "r2 As==11"); - *cycles = 1; - } - else if (regs == 3) - { - sprintf (op1, "#-1"); - sprintf (comm1, "r3 As==11"); - *cycles = 1; - } - else if (regs == 0) - { - *cycles = 3; - /* Absolute. @pc+. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "#%d", dst); - sprintf (comm1, "#0x%04x", PS (dst)); - } - else - { - *cycles = 2; - sprintf (op1, "@r%d+", regs); - } - } - else if (as == 1) - { - if (regs == 0) - { - *cycles = 4; - /* PC relative. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "0x%04x", PS (dst)); - sprintf (comm1, "PC rel. 0x%04x", - PS ((short) addr + 2 + dst)); - } - else if (regs == 2) - { - *cycles = 2; - /* Absolute. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "&0x%04x", PS (dst)); - sprintf (comm1, "0x%04x", PS (dst)); - } - else if (regs == 3) - { - *cycles = 1; - sprintf (op1, "#1"); - sprintf (comm1, "r3 As==01"); - } - else - { - *cycles = 3; - /* Indexed. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "%d(r%d)", dst, regs); - } + if (insn & 0x008f) // repetitions + { + if (insn & 0x0080) + *repeats = insn & 0xf; // positive number is Rn + else + *repeats = 0 - (insn & 0xf); // negative number is #N + } } - /* Destination. Special care needed on addr + XXXX. */ + // extract operands + dst = msp430dis_operand(addr + cmd_len, info, reg, am, &cmd_len) | ((insn & 0x0000000f) << 16); + dst = (dst << 12) >> 12; // sign extension + msp430x_decode_operand(reg, am, addr + cmd_len, dst, OP_20BIT, op, comm); + + return cmd_len; +} - if (ad == 0) +static int +msp430x_exception (disassemble_info *info, + struct msp430_opcode_s const *opcode, + bfd_vma addr, + unsigned int insn, + char *op1, + char *op2, + char *comm1, + char *comm2, + opwidth_t *op_width) +{ + int reg = 0; + int cmd_len = 2; + int n = 0; + int dst = 0; + + reg = insn & 0xf; + + switch(opcode_variant(opcode)) { - /* Register. */ - if (regd == 0) - { - *cycles += 1; - sprintf (op2, "r0"); - } - else if (regd == 1) - sprintf (op2, "r1"); + case V_CALLA: + switch((insn >> 4) & 0xf) + { + case 4: // Rdst + msp430x_decode_operand(reg, 0, 0, 0, 0, op1, comm1); + break; + case 5: // x(Rdst) + dst = (short)msp430dis_operand(addr + cmd_len, info, reg, 1, &cmd_len); + msp430x_decode_operand(reg, 1, addr + cmd_len, dst, OP_16BIT, op1, comm1); + break; + case 6: // @Rdst + msp430x_decode_operand(reg, 2, 0, 0, 0, op1, comm1); + break; + case 7: // @Rdst+ + msp430x_decode_operand(reg, 3, 0, 0, 0, op1, comm1); + break; + case 8: // &abs20 + dst = msp430dis_operand(addr + cmd_len, info, 2, 1, &cmd_len) | ((insn & 0x000f) << 16); + msp430x_decode_operand(2, 1, addr + cmd_len, dst, OP_20BIT_HEX, op1, comm1); + break; + case 9: // EDE + dst = msp430dis_operand(addr + cmd_len, info, 0, 1, &cmd_len) | ((insn & 0x000f) << 16); + msp430x_decode_operand(0, 1, addr + cmd_len, dst, OP_20BIT, op1, comm1); + break; + case 0xb: // #imm20 + dst = msp430dis_operand(addr + cmd_len, info, 0, 3, &cmd_len) | ((insn & 0x000f) << 16); + msp430x_decode_operand(0, 3, addr + cmd_len, dst, OP_20BIT_HEX, op1, comm1); + break; + } + break; + case V_PUSHM: + n = ((insn >> 4) & 0xf) + 1; + msp430x_decode_operand(0, 3, 0, n, OP_DECIMAL, op1, comm1); // #N + msp430x_decode_operand(reg, 0, 0, 0, 0, op2, comm2); // Rdst + if ((insn & 0x0100) == 0) + *op_width = ADDR_OP; + break; + case V_POPM: + n = ((insn >> 4) & 0xf) + 1; + reg = (reg + n - 1) & 0xf; + msp430x_decode_operand(0, 3, 0, n, OP_DECIMAL, op1, comm1); // #N + msp430x_decode_operand(reg, 0, 0, 0, 0, op2, comm2); // Rdst + if ((insn & 0x0100) == 0) + *op_width = ADDR_OP; + break; + case V_ROTM: + n = ((insn >> 10) & 0x3) + 1; + msp430x_decode_operand(0, 3, 0, n, OP_DECIMAL, op1, comm1); // #N + msp430x_decode_operand(reg, 0, 0, 0, 0, op2, comm2); // Rdst + if ((insn & 0x0010) == 0) + *op_width = ADDR_OP; + break; + default: + break; + } + return cmd_len; +} - else if (regd == 2) - sprintf (op2, "r2"); +static int +msp430x_doubleoperand (disassemble_info *info, + struct msp430_opcode_s const *opcode, + bfd_vma addr, + unsigned int insn, + char *op1, + char *op2, + char *comm1, + char *comm2, + opwidth_t *op_width, + int *repeats) +{ + int regs, regd; + int as, ad; + int ops, opd; + int cmd_len = 4; - else - sprintf (op2, "r%d", regd); + regd = (insn >> 16) & 0xf; + regs = (insn >> 24) & 0xf; + as = (insn >> 20) & 0x3; + ad = (insn >> 23) & 0x1; + + if (ad == 0 && regd == 3) + { + // R3 is illegal as dest: may be data section. + if (comm1) + strcpy (comm1, _("Illegal as 2-op instr")); + else if (comm2) + strcpy (comm2, _("Illegal as 2-op instr")); + return -1; } - else /* ad == 1. */ + *op_width = msp430x_opwidth(insn); + + // extract repeat count if any + if ( as == 0 && ad == 0 ) // extension word for register mode { - * cycles += 3; - - if (regd == 0) - { - /* PC relative. */ - *cycles += 1; - dst = msp430dis_opcode (addr + cmd_len, info); - sprintf (op2, "0x%04x", PS (dst)); - sprintf (comm2, "PC rel. 0x%04x", - PS ((short) addr + cmd_len + dst)); - cmd_len += 2; - } - else if (regd == 2) - { - /* Absolute. */ - dst = msp430dis_opcode (addr + cmd_len, info); - cmd_len += 2; - sprintf (op2, "&0x%04x", PS (dst)); - } - else - { - dst = msp430dis_opcode (addr + cmd_len, info); - cmd_len += 2; - sprintf (op2, "%d(r%d)", dst, regd); - } + if (insn & 0x008f) // repetitions + { + if (insn & 0x0080) + *repeats = insn & 0xf; // positive number is Rn + else + *repeats = 0 - (insn & 0xf); // negative number is #N + } } + // extract operands + ops = msp430dis_operand(addr + cmd_len, info, regs, as, &cmd_len) | ((insn & 0x00000780) << 9); + ops = (ops << 12) >> 12; // sign extension + msp430x_decode_operand(regs, as, addr + cmd_len, ops, OP_20BIT, op1, comm1); + + opd = msp430dis_operand(addr + cmd_len, info, regd, ad, &cmd_len) | ((insn & 0x0000000f) << 16); + opd = (opd << 12) >> 12; // sign extension + if (opcode_variant(opcode) == V_X_SHIFT && ops != opd) + return 0; // different operand => not emulated shift + + msp430x_decode_operand(regd, ad, addr + cmd_len, opd, OP_20BIT, op2, comm2); return cmd_len; } static int -msp430_branchinstr (disassemble_info *info, - struct msp430_opcode_s *opcode ATTRIBUTE_UNUSED, - bfd_vma addr ATTRIBUTE_UNUSED, +msp430x_address (disassemble_info *info, + bfd_vma addr, unsigned short insn, char *op1, + char *op2, char *comm1, - int *cycles) + char *comm2) { - int regs = 0, regd = 0; - int as = 0; int cmd_len = 2; - short dst = 0; - - regd = insn & 0x0f; - regs = (insn & 0x0f00) >> 8; - as = (insn & 0x0030) >> 4; - - if (regd != 0) /* Destination register is not a PC. */ - return 0; - - /* dst is a source register. */ - if (as == 0) + int dst = 0; + typedef struct { - /* Constants. */ - if (regs == 3) - { - *cycles = 1; - sprintf (op1, "#0"); - sprintf (comm1, "r3 As==00"); - } - else - { - /* Register. */ - *cycles = 1; - sprintf (op1, "r%d", regs); - } + int as, regs; + int ad, regd; + int length; } - else if (as == 2) + operands_t; + + static operands_t const operands_table[] = { - if (regs == 2) - { - *cycles = 2; - sprintf (op1, "#4"); - sprintf (comm1, "r2 As==10"); - } - else if (regs == 3) - { - *cycles = 1; - sprintf (op1, "#2"); - sprintf (comm1, "r3 As==10"); - } - else - { - /* Indexed register mode @Rn. */ - *cycles = 2; - sprintf (op1, "@r%d", regs); - } - } - else if (as == 3) + { 2, -1, 0, -1, 0 }, // 0 @Rsrc, Rdst + { 3, -1, 0, -1, 0 }, // 1 @Rsrc+, Rdst + { 1, 2, 0, -1, 2 }, // 2 &abs20, Rdst + { 1, -1, 0, -1, 2 }, // 3 x(Rsrc), Rdst + { 0, 0, 0, 0, 0 }, // 4 + { 0, 0, 0, 0, 0 }, // 5 + { 0, -1, 1, 2, 2 }, // 6 Rsrc, &abs20 + { 0, -1, 1, -1, 2 }, // 7 Rsrc, x(Rdst) + { 3, 0, 0, -1, 2 }, // 8 #imm20, Rdst + { 3, 0, 0, -1, 2 }, // 9 #imm20, Rdst + { 3, 0, 0, -1, 2 }, // a #imm20, Rdst + { 3, 0, 0, -1, 2 }, // b #imm20, Rdst + { 0, -1, 0, -1, 0 }, // c Rsrc, Rdst + { 0, -1, 0, -1, 0 }, // d Rsrc, Rdst + { 0, -1, 0, -1, 0 }, // e Rsrc, Rdst + { 0, -1, 0, -1, 0 }, // f Rsrc, Rdst + }; + + operands_t operands = operands_table[(insn >> 4) & 0xf]; + if(((insn >> 4) & 0xf) == 6) + dst = msp430dis_opcode (addr + cmd_len, info) | ((insn & 0x000f) << 16); + else if(((insn >> 4) & 0xb) == 3) + dst = (short)msp430dis_opcode (addr + cmd_len, info); + else if(operands.length != 0) + dst = msp430dis_opcode(addr + cmd_len, info) | ((insn & 0x0f00) << 8); + + if(operands.regs == -1) + operands.regs = (insn >> 8 ) & 0x000f; + if(operands.regd == -1) + operands.regd = (insn >> 0 ) & 0x000f; + + if (operands.regd == 3) { - if (regs == 2) - { - *cycles = 1; - sprintf (op1, "#8"); - sprintf (comm1, "r2 As==11"); - } - else if (regs == 3) - { - *cycles = 1; - sprintf (op1, "#-1"); - sprintf (comm1, "r3 As==11"); - } - else if (regs == 0) - { - /* Absolute. @pc+ */ - *cycles = 3; - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "#0x%04x", PS (dst)); - } - else - { - *cycles = 2; - sprintf (op1, "@r%d+", regs); - } + // R3 is illegal as dest: may be data section. + if (comm1) + strcpy (comm1, _("Illegal as address instr")); + else if (comm2) + strcpy (comm2, _("Illegal as address instr")); + return -1; } - else if (as == 1) - { - * cycles = 3; + // extract operands + msp430x_decode_operand(operands.regs, operands.as, addr + cmd_len, dst, + ((insn >> 4) & 0xf) == 3 ? OP_16BIT_HEX : OP_20BIT_HEX, op1, comm1); + msp430x_decode_operand(operands.regd, operands.ad, addr + cmd_len, dst, + ((insn >> 4) & 0xf) == 7 ? OP_16BIT_HEX : OP_20BIT_HEX, op2, comm2); + return cmd_len + operands.length; +} - if (regs == 0) - { - /* PC relative. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - (*cycles)++; - sprintf (op1, "0x%04x", PS (dst)); - sprintf (comm1, "PC rel. 0x%04x", - PS ((short) addr + 2 + dst)); - } - else if (regs == 2) - { - /* Absolute. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "&0x%04x", PS (dst)); - } - else if (regs == 3) - { - (*cycles)--; - sprintf (op1, "#1"); - sprintf (comm1, "r3 As==01"); - } - else - { - /* Indexd. */ - dst = msp430dis_opcode (addr + 2, info); - cmd_len += 2; - sprintf (op1, "%d(r%d)", dst, regs); - } - } +static int +msp430x_emulated (disassemble_info *info, + struct msp430_opcode_s const *opcode, + bfd_vma addr, + unsigned int insn, + char *op1, + char *comm1, + opwidth_t *op_width, + int *repeats) +{ - return cmd_len; + switch(opcode_variant(opcode)) + { + case V_NONE: + case V_X_SHIFT: + // emulated by double operand instruction + return msp430x_doubleoperand(info, opcode, addr, insn, (char *)0, op1, + (char *)0, comm1, op_width, repeats); + case V_RETA: // reta, substituted by mova + return 2; + case V_EMU_ADDR: // substituted by other address instruction + return msp430x_address(info, addr, insn, (char *)0, op1, + (char *)0, comm1); + case V_BRA: // bra, substituted by mova + return msp430x_address(info, addr, insn, op1, (char *)0, + comm1, (char *)0); + default: + break; + } + return 0; } int @@ -668,85 +665,147 @@ print_insn_msp430 (bfd_vma addr, disassemble_info *info) { void *stream = info->stream; fprintf_ftype prin = info->fprintf_func; - struct msp430_opcode_s *opcode; + struct msp430_opcode_s const *opcode; char op1[32], op2[32], comm1[64], comm2[64]; int cmd_len = 0; - unsigned short insn; - int cycles = 0; - char *bc = ""; - char dinfo[32]; /* Debug purposes. */ - + unsigned int insn; + int repeats = 0; + core_t core = CORE_430; + + opwidth_t op_width = DEFAULT_OP; // word instruction by default + static char const *width_modifier[] = + {"", "", ".b", ".a" }; + insn = msp430dis_opcode (addr, info); - sprintf (dinfo, "0x%04x", insn); - if (((int) addr & 0xffff) > 0xffdf) + if (info->mach == 241 || info->mach == 26 || info->mach == 46) + { + core = CORE_430X; + } + else if (info->mach == 54) + { + core = CORE_430X2; + } + + if ( (core == CORE_430 && ((int) addr & 0xffff) >= 0xffe0) + || ( core == CORE_430X && (((int) addr & 0xfffff) >= 0xffc0) && ((int) addr & 0xfffff) < 0x10000) + || ( core == CORE_430X2 && (((int) addr & 0xfffff) >= 0xff80) && ((int) addr & 0xfffff) < 0x10000) + ) { (*prin) (stream, "interrupt service routine at 0x%04x", 0xffff & insn); return 2; } + if (core > CORE_430 && ((insn & 0xf800) == 0x1800)) // Extended instruction + insn |= msp430dis_opcode(addr + 2, info) << 16; + *comm1 = 0; *comm2 = 0; for (opcode = msp430_opcodes; opcode->name; opcode++) { if ((insn & opcode->bin_mask) == opcode->bin_opcode - && opcode->bin_opcode != 0x9300) +// && opcode->bin_opcode != 0x9300 // was disasm tst instruction as cmp #0, dst? + ) { *op1 = 0; *op2 = 0; *comm1 = 0; *comm2 = 0; - /* r0 as destination. Ad should be zero. */ - if (opcode->insn_opnumb == 3 && (insn & 0x000f) == 0 - && (0x0080 & insn) == 0) + /* unsupported instruction */ + if(opcode_format(opcode) >= FMT_X && core < CORE_430X) + break; + + /* r0 as destination. Ad should be zero. Rdst=0 and Ad=0 are encoded in opcode & opcode_mask */ + if (opcode_format(opcode) == FMT_EMULATED && opcode_variant(opcode) == V_BR) { cmd_len = - msp430_branchinstr (info, opcode, addr, insn, op1, comm1, - &cycles); + msp430_branchinstr (info, opcode, addr, insn, op1, comm1); if (cmd_len) break; } - - switch (opcode->insn_opnumb) - { - case 0: - cmd_len = msp430_nooperands (opcode, addr, insn, comm1, &cycles); - break; - case 2: - cmd_len = - msp430_doubleoperand (info, opcode, addr, insn, op1, op2, - comm1, comm2, &cycles); - if (insn & BYTE_OPERATION) - bc = ".b"; - break; - case 1: - cmd_len = - msp430_singleoperand (info, opcode, addr, insn, op1, comm1, - &cycles); - if (insn & BYTE_OPERATION && opcode->fmt != 3) - bc = ".b"; - break; - default: - break; - } + if(opcode_format(opcode) < FMT_X) + switch (opcode->insn_opnumb) + { + case 0: + cmd_len = msp430_nooperands (opcode, addr, insn, comm1); + break; + case 2: + cmd_len = + msp430_doubleoperand (info, opcode, addr, insn, op1, op2, + comm1, comm2); + if (insn & BYTE_OPERATION) + op_width = BYTE_OP; + break; + case 1: + cmd_len = + msp430_singleoperand (info, opcode, addr, insn, op1, comm1); + if (insn & BYTE_OPERATION && opcode_format(opcode) != FMT_JUMP) + op_width = BYTE_OP; + break; + default: + break; + } + else // 430x instruction + switch(opcode_format(opcode)) + { + case FMT_X_SINGLE_OPERAND: + if( opcode_variant(opcode) == V_SWPSXT // swpbx, sxtx + && (insn & (NON_ADDR_OPERATION | BYTE_OPERATION_X)) == 0) // .a, special case + insn ^= BYTE_OPERATION_X; // make A/L, B/W as ordinary + + op_width = msp430x_opwidth(insn); + + if( opcode_variant(opcode) == V_SWPSXT && op_width == BYTE_OP) // swpbx, sxtx + strcpy (comm1, _("Illegal A/L, B/W bits setting")); + + cmd_len = msp430x_singleoperand (info, opcode, addr, insn, op1, comm1, + &repeats); + break; + case FMT_X_EXCEPTION: + cmd_len = msp430x_exception (info, opcode, addr, insn, op1, op2, + comm1, comm2, &op_width); + break; + case FMT_X_DOUBLE_OPERAND: + cmd_len = msp430x_doubleoperand (info, opcode, addr, insn, op1, op2, + comm1, comm2, &op_width, &repeats); + break; + case FMT_X_EMULATED: + cmd_len = msp430x_emulated (info, opcode, addr, insn, op1, + comm1, &op_width, &repeats); + break; + + case FMT_X_ADDRESS: + cmd_len = msp430x_address (info, addr, insn, op1, op2, + comm1, comm2); + break; + default: + break; + } } if (cmd_len) break; } - dinfo[5] = 0; - if (cmd_len < 1) { /* Unknown opcode, or invalid combination of operands. */ - (*prin) (stream, ".word 0x%04x; ????", PS (insn)); + (*prin) (stream, ".word 0x%04x; ????\t%s%s", PS (insn), comm1, comm2); return 2; } - (*prin) (stream, "%s%s", opcode->name, bc); + + if (repeats) + { + if (repeats < 0) + (*prin) (stream, ".rpt\t#%d\n\t\t\t\t", 0 - repeats); + else + (*prin) (stream, ".rpt\tr%d\n\t\t\t\t", repeats); + } + + (*prin) (stream, "%s%s", opcode->name, width_modifier[op_width]); if (*op1) (*prin) (stream, "\t%s", op1); @@ -765,23 +824,11 @@ print_insn_msp430 (bfd_vma addr, disassemble_info *info) if (*comm1 || *comm2) (*prin) (stream, ";"); - else if (cycles) - { - if (*op2) - (*prin) (stream, ";"); - else - { - if (strlen (op1) < 7) - (*prin) (stream, ";"); - else - (*prin) (stream, "\t;"); - } - } if (*comm1) (*prin) (stream, "%s", comm1); if (*comm1 && *comm2) - (*prin) (stream, ","); + (*prin) (stream, ", "); if (*comm2) - (*prin) (stream, " %s", comm2); + (*prin) (stream, "%s", comm2); return cmd_len; } diff --git gdb-7.2a.orig/sim/configure gdb-7.2a/sim/configure index b6488e2..9404d6b 100755 --- gdb-7.2a.orig/sim/configure +++ gdb-7.2a/sim/configure @@ -651,6 +651,7 @@ microblaze mips mn10300 moxie +msp430 rx sh64 sh @@ -3758,6 +3759,15 @@ subdirs="$subdirs arm" sim_testsuite=yes ;; + msp430-*-*) + + sim_arch=msp430 + subdirs="$subdirs msp430" + + + sim_testsuite=yes + sim_igen=yes + ;; rx-*-*) sim_arch=rx diff --git gdb-7.2a.orig/sim/configure.tgt gdb-7.2a/sim/configure.tgt index 592bc3c..0bb6b53 100644 --- gdb-7.2a.orig/sim/configure.tgt +++ gdb-7.2a/sim/configure.tgt @@ -82,6 +82,11 @@ case "${target}" in SIM_ARCH(moxie) sim_testsuite=yes ;; + msp430-*-*) + SIM_ARCH(msp430) + sim_testsuite=yes + sim_igen=yes + ;; rx-*-*) SIM_ARCH(rx) ;; diff --git gdb-7.2a.orig/sim/msp430/Makefile.in gdb-7.2a/sim/msp430/Makefile.in new file mode 100644 index 0000000..c8c95d8 --- /dev/null +++ gdb-7.2a/sim/msp430/Makefile.in @@ -0,0 +1,29 @@ +# Makefile template for Configure for the MCore sim library. +# Copyright (C) 1990, 91, 92, 95, 96, 19, 1999 Free Software Foundation, Inc. +# Written by Cygnus Solutions. +# +# This program 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 2 of the License, or +# (at your option) any later version. +# +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +## COMMON_PRE_CONFIG_FRAG + +SIM_OBJS = interp.o sim-load.o +SIM_EXTRA_LIBS = -lm -lz +SIM_EXTRA_CLEAN = msp430-clean + +## COMMON_POST_CONFIG_FRAG + +interp.o: interp.c + +msp430-clean: diff --git gdb-7.2a.orig/sim/msp430/config.in gdb-7.2a/sim/msp430/config.in new file mode 100644 index 0000000..21724bc --- /dev/null +++ gdb-7.2a/sim/msp430/config.in @@ -0,0 +1,34 @@ +/* config.in. Generated automatically from configure.in by autoheader. */ + +/* Define as the return type of signal handlers (int or void). */ +#undef RETSIGTYPE + +/* Define if you have the getrusage function. */ +#undef HAVE_GETRUSAGE + +/* Define if you have the sigaction function. */ +#undef HAVE_SIGACTION + +/* Define if you have the time function. */ +#undef HAVE_TIME + +/* Define if you have the header file. */ +#undef HAVE_STDLIB_H + +/* Define if you have the header file. */ +#undef HAVE_STRING_H + +/* Define if you have the header file. */ +#undef HAVE_STRINGS_H + +/* Define if you have the header file. */ +#undef HAVE_SYS_RESOURCE_H + +/* Define if you have the header file. */ +#undef HAVE_SYS_TIME_H + +/* Define if you have the header file. */ +#undef HAVE_TIME_H + +/* Define if you have the header file. */ +#undef HAVE_UNISTD_H diff --git gdb-7.2a.orig/sim/msp430/configure gdb-7.2a/sim/msp430/configure new file mode 100755 index 0000000..13e5e55 --- /dev/null +++ gdb-7.2a/sim/msp430/configure @@ -0,0 +1,5867 @@ +#! /bin/sh +# Guess values for system-dependent variables and create Makefiles. +# Generated by GNU Autoconf 2.64. +# +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, +# 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software +# Foundation, Inc. +# +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. +## -------------------- ## +## M4sh Initialization. ## +## -------------------- ## + +# Be more Bourne compatible +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi + + +as_nl=' +' +export as_nl +# Printing a long string crashes Solaris 7 /usr/bin/printf. +as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo +# Prefer a ksh shell builtin over an external printf program on Solaris, +# but without wasting forks for bash or zsh. +if test -z "$BASH_VERSION$ZSH_VERSION" \ + && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='print -r --' + as_echo_n='print -rn --' +elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='printf %s\n' + as_echo_n='printf %s' +else + if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then + as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' + as_echo_n='/usr/ucb/echo -n' + else + as_echo_body='eval expr "X$1" : "X\\(.*\\)"' + as_echo_n_body='eval + arg=$1; + case $arg in #( + *"$as_nl"*) + expr "X$arg" : "X\\(.*\\)$as_nl"; + arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; + esac; + expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" + ' + export as_echo_n_body + as_echo_n='sh -c $as_echo_n_body as_echo' + fi + export as_echo_body + as_echo='sh -c $as_echo_body as_echo' +fi + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + + +# IFS +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent editors from complaining about space-tab. +# (If _AS_PATH_WALK were called with IFS unset, it would disable word +# splitting by setting IFS to empty value.) +IFS=" "" $as_nl" + +# Find who we are. Look in the path if we contain no directory separator. +case $0 in #(( + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break + done +IFS=$as_save_IFS + + ;; +esac +# We did not find ourselves, most probably we were run as `sh COMMAND' +# in which case we are not to be found in the path. +if test "x$as_myself" = x; then + as_myself=$0 +fi +if test ! -f "$as_myself"; then + $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 + exit 1 +fi + +# Unset variables that we do not need and which cause bugs (e.g. in +# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" +# suppresses any "Segmentation fault" message there. '((' could +# trigger a bug in pdksh 5.2.14. +for as_var in BASH_ENV ENV MAIL MAILPATH +do eval test x\${$as_var+set} = xset \ + && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : +done +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +LC_ALL=C +export LC_ALL +LANGUAGE=C +export LANGUAGE + +# CDPATH. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +if test "x$CONFIG_SHELL" = x; then + as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which + # is contrary to our usage. Disable this feature. + alias -g '\${1+\"\$@\"}'='\"\$@\"' + setopt NO_GLOB_SUBST +else + case \`(set -o) 2>/dev/null\` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi +" + as_required="as_fn_return () { (exit \$1); } +as_fn_success () { as_fn_return 0; } +as_fn_failure () { as_fn_return 1; } +as_fn_ret_success () { return 0; } +as_fn_ret_failure () { return 1; } + +exitcode=0 +as_fn_success || { exitcode=1; echo as_fn_success failed.; } +as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } +as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } +as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } +if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : + +else + exitcode=1; echo positional parameters were not saved. +fi +test x\$exitcode = x0 || exit 1" + as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO + as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO + eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && + test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 +test \$(( 1 + 1 )) = 2 || exit 1" + if (eval "$as_required") 2>/dev/null; then : + as_have_required=yes +else + as_have_required=no +fi + if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : + +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +as_found=false +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + as_found=: + case $as_dir in #( + /*) + for as_base in sh bash ksh sh5; do + # Try only shells that exist, to save several forks. + as_shell=$as_dir/$as_base + if { test -f "$as_shell" || test -f "$as_shell.exe"; } && + { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : + CONFIG_SHELL=$as_shell as_have_required=yes + if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : + break 2 +fi +fi + done;; + esac + as_found=false +done +$as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && + { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : + CONFIG_SHELL=$SHELL as_have_required=yes +fi; } +IFS=$as_save_IFS + + + if test "x$CONFIG_SHELL" != x; then : + # We cannot yet assume a decent shell, so we have to provide a + # neutralization value for shells without unset; and this also + # works around shells that cannot unset nonexistent variables. + BASH_ENV=/dev/null + ENV=/dev/null + (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV + export CONFIG_SHELL + exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} +fi + + if test x$as_have_required = xno; then : + $as_echo "$0: This script requires a shell more modern than all" + $as_echo "$0: the shells that I found on your system." + if test x${ZSH_VERSION+set} = xset ; then + $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" + $as_echo "$0: be upgraded to zsh 4.3.4 or later." + else + $as_echo "$0: Please tell bug-autoconf@gnu.org about your system, +$0: including any error possibly output before this +$0: message. Then install a modern shell, or manually run +$0: the script under such a shell if you do have one." + fi + exit 1 +fi +fi +fi +SHELL=${CONFIG_SHELL-/bin/sh} +export SHELL +# Unset more variables known to interfere with behavior of common tools. +CLICOLOR_FORCE= GREP_OPTIONS= +unset CLICOLOR_FORCE GREP_OPTIONS + +## --------------------- ## +## M4sh Shell Functions. ## +## --------------------- ## +# as_fn_unset VAR +# --------------- +# Portably unset VAR. +as_fn_unset () +{ + { eval $1=; unset $1;} +} +as_unset=as_fn_unset + +# as_fn_set_status STATUS +# ----------------------- +# Set $? to STATUS, without forking. +as_fn_set_status () +{ + return $1 +} # as_fn_set_status + +# as_fn_exit STATUS +# ----------------- +# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. +as_fn_exit () +{ + set +e + as_fn_set_status $1 + exit $1 +} # as_fn_exit + +# as_fn_mkdir_p +# ------------- +# Create "$as_dir" as a directory, including parents if necessary. +as_fn_mkdir_p () +{ + + case $as_dir in #( + -*) as_dir=./$as_dir;; + esac + test -d "$as_dir" || eval $as_mkdir_p || { + as_dirs= + while :; do + case $as_dir in #( + *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( + *) as_qdir=$as_dir;; + esac + as_dirs="'$as_qdir' $as_dirs" + as_dir=`$as_dirname -- "$as_dir" || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + test -d "$as_dir" && break + done + test -z "$as_dirs" || eval "mkdir $as_dirs" + } || test -d "$as_dir" || as_fn_error "cannot create directory $as_dir" + + +} # as_fn_mkdir_p +# as_fn_append VAR VALUE +# ---------------------- +# Append the text in VALUE to the end of the definition contained in VAR. Take +# advantage of any shell optimizations that allow amortized linear growth over +# repeated appends, instead of the typical quadratic growth present in naive +# implementations. +if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : + eval 'as_fn_append () + { + eval $1+=\$2 + }' +else + as_fn_append () + { + eval $1=\$$1\$2 + } +fi # as_fn_append + +# as_fn_arith ARG... +# ------------------ +# Perform arithmetic evaluation on the ARGs, and store the result in the +# global $as_val. Take advantage of shells that can avoid forks. The arguments +# must be portable across $(()) and expr. +if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : + eval 'as_fn_arith () + { + as_val=$(( $* )) + }' +else + as_fn_arith () + { + as_val=`expr "$@" || test $? -eq 1` + } +fi # as_fn_arith + + +# as_fn_error ERROR [LINENO LOG_FD] +# --------------------------------- +# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are +# provided, also output the error to LOG_FD, referencing LINENO. Then exit the +# script with status $?, using 1 if that was 0. +as_fn_error () +{ + as_status=$?; test $as_status -eq 0 && as_status=1 + if test "$3"; then + as_lineno=${as_lineno-"$2"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + $as_echo "$as_me:${as_lineno-$LINENO}: error: $1" >&$3 + fi + $as_echo "$as_me: error: $1" >&2 + as_fn_exit $as_status +} # as_fn_error + +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + +if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then + as_dirname=dirname +else + as_dirname=false +fi + +as_me=`$as_basename -- "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + + + as_lineno_1=$LINENO as_lineno_1a=$LINENO + as_lineno_2=$LINENO as_lineno_2a=$LINENO + eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && + test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { + # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) + sed -n ' + p + /[$]LINENO/= + ' <$as_myself | + sed ' + s/[$]LINENO.*/&-/ + t lineno + b + :lineno + N + :loop + s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ + t loop + s/-\n.*// + ' >$as_me.lineno && + chmod +x "$as_me.lineno" || + { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } + + # Don't try to exec as it changes $[0], causing all sort of problems + # (the dirname of $[0] is not the place where we might find the + # original and so on. Autoconf is especially sensitive to this). + . "./$as_me.lineno" + # Exit status is that of the last command. + exit +} + +ECHO_C= ECHO_N= ECHO_T= +case `echo -n x` in #((((( +-n*) + case `echo 'xy\c'` in + *c*) ECHO_T=' ';; # ECHO_T is single tab character. + xy) ECHO_C='\c';; + *) echo `echo ksh88 bug on AIX 6.1` > /dev/null + ECHO_T=' ';; + esac;; +*) + ECHO_N='-n';; +esac + +rm -f conf$$ conf$$.exe conf$$.file +if test -d conf$$.dir; then + rm -f conf$$.dir/conf$$.file +else + rm -f conf$$.dir + mkdir conf$$.dir 2>/dev/null +fi +if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + as_ln_s='ln -s' + # ... but there are two gotchas: + # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. + # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. + # In both cases, we have to default to `cp -p'. + ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || + as_ln_s='cp -p' + elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln + else + as_ln_s='cp -p' + fi +else + as_ln_s='cp -p' +fi +rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file +rmdir conf$$.dir 2>/dev/null + +if mkdir -p . 2>/dev/null; then + as_mkdir_p='mkdir -p "$as_dir"' +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +if test -x / >/dev/null 2>&1; then + as_test_x='test -x' +else + if ls -dL / >/dev/null 2>&1; then + as_ls_L_option=L + else + as_ls_L_option= + fi + as_test_x=' + eval sh -c '\'' + if test -d "$1"; then + test -d "$1/."; + else + case $1 in #( + -*)set "./$1";; + esac; + case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( + ???[sx]*):;;*)false;;esac;fi + '\'' sh + ' +fi +as_executable_p=$as_test_x + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + +exec 7<&0 &1 + +# Name of the host. +# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, +# so uname gets run too. +ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` + +# +# Initializations. +# +ac_default_prefix=/usr/local +ac_clean_files= +ac_config_libobj_dir=. +LIBOBJS= +cross_compiling=no +subdirs= +MFLAGS= +MAKEFLAGS= + +# Identity of this package. +PACKAGE_NAME= +PACKAGE_TARNAME= +PACKAGE_VERSION= +PACKAGE_STRING= +PACKAGE_BUGREPORT= +PACKAGE_URL= + +ac_unique_file="Makefile.in" +# Factoring default headers for most tests. +ac_includes_default="\ +#include +#ifdef HAVE_SYS_TYPES_H +# include +#endif +#ifdef HAVE_SYS_STAT_H +# include +#endif +#ifdef STDC_HEADERS +# include +# include +#else +# ifdef HAVE_STDLIB_H +# include +# endif +#endif +#ifdef HAVE_STRING_H +# if !defined STDC_HEADERS && defined HAVE_MEMORY_H +# include +# endif +# include +#endif +#ifdef HAVE_STRINGS_H +# include +#endif +#ifdef HAVE_INTTYPES_H +# include +#endif +#ifdef HAVE_STDINT_H +# include +#endif +#ifdef HAVE_UNISTD_H +# include +#endif" + +ac_subst_vars='LTLIBOBJS +LIBOBJS +cgen_breaks +REPORT_BUGS_TEXI +REPORT_BUGS_TO +PKGVERSION +sim_profile +sim_trace +sim_stdio +sim_debug +sim_cflags +sim_bswap +MAINT +EGREP +GREP +CPP +CATOBJEXT +GENCAT +INSTOBJEXT +DATADIRNAME +CATALOGS +POSUB +GMSGFMT +XGETTEXT +INCINTL +LIBINTL_DEP +LIBINTL +USE_NLS +RANLIB +AR +HDEFINES +CC_FOR_BUILD +INSTALL_DATA +INSTALL_SCRIPT +INSTALL_PROGRAM +OBJEXT +EXEEXT +ac_ct_CC +CPPFLAGS +LDFLAGS +CFLAGS +CC +target_os +target_vendor +target_cpu +target +host_os +host_vendor +host_cpu +host +build_os +build_vendor +build_cpu +build +WERROR_CFLAGS +WARN_CFLAGS +sim_xor_endian +sim_stdcall +sim_smp +sim_reserved_bits +sim_regparm +sim_packages +sim_inline +sim_hw +sim_hw_objs +sim_hw_cflags +sim_default_model +sim_scache +sim_float +sim_hostendian +sim_endian +sim_bitsize +sim_assert +sim_alignment +sim_environment +target_alias +host_alias +build_alias +LIBS +ECHO_T +ECHO_N +ECHO_C +DEFS +mandir +localedir +libdir +psdir +pdfdir +dvidir +htmldir +infodir +docdir +oldincludedir +includedir +localstatedir +sharedstatedir +sysconfdir +datadir +datarootdir +libexecdir +sbindir +bindir +program_transform_name +prefix +exec_prefix +PACKAGE_URL +PACKAGE_BUGREPORT +PACKAGE_STRING +PACKAGE_VERSION +PACKAGE_TARNAME +PACKAGE_NAME +PATH_SEPARATOR +SHELL' +ac_subst_files='' +ac_user_opts=' +enable_option_checking +with_zlib +enable_maintainer_mode +enable_sim_bswap +enable_sim_cflags +enable_sim_debug +enable_sim_stdio +enable_sim_trace +enable_sim_profile +with_pkgversion +with_bugurl +' + ac_precious_vars='build_alias +host_alias +target_alias +CC +CFLAGS +LDFLAGS +LIBS +CPPFLAGS +CPP' + + +# Initialize some variables set by options. +ac_init_help= +ac_init_version=false +ac_unrecognized_opts= +ac_unrecognized_sep= +# The variables have the same names as the options, with +# dashes changed to underlines. +cache_file=/dev/null +exec_prefix=NONE +no_create= +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +verbose= +x_includes=NONE +x_libraries=NONE + +# Installation directory options. +# These are left unexpanded so users can "make install exec_prefix=/foo" +# and all the variables that are supposed to be based on exec_prefix +# by default will actually change. +# Use braces instead of parens because sh, perl, etc. also accept them. +# (The list follows the same order as the GNU Coding Standards.) +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datarootdir='${prefix}/share' +datadir='${datarootdir}' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +includedir='${prefix}/include' +oldincludedir='/usr/include' +docdir='${datarootdir}/doc/${PACKAGE}' +infodir='${datarootdir}/info' +htmldir='${docdir}' +dvidir='${docdir}' +pdfdir='${docdir}' +psdir='${docdir}' +libdir='${exec_prefix}/lib' +localedir='${datarootdir}/locale' +mandir='${datarootdir}/man' + +ac_prev= +ac_dashdash= +for ac_option +do + # If the previous option needs an argument, assign it. + if test -n "$ac_prev"; then + eval $ac_prev=\$ac_option + ac_prev= + continue + fi + + case $ac_option in + *=*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; + *) ac_optarg=yes ;; + esac + + # Accept the important Cygnus configure options, so we can diagnose typos. + + case $ac_dashdash$ac_option in + --) + ac_dashdash=yes ;; + + -bindir | --bindir | --bindi | --bind | --bin | --bi) + ac_prev=bindir ;; + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) + bindir=$ac_optarg ;; + + -build | --build | --buil | --bui | --bu) + ac_prev=build_alias ;; + -build=* | --build=* | --buil=* | --bui=* | --bu=*) + build_alias=$ac_optarg ;; + + -cache-file | --cache-file | --cache-fil | --cache-fi \ + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) + ac_prev=cache_file ;; + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) + cache_file=$ac_optarg ;; + + --config-cache | -C) + cache_file=config.cache ;; + + -datadir | --datadir | --datadi | --datad) + ac_prev=datadir ;; + -datadir=* | --datadir=* | --datadi=* | --datad=*) + datadir=$ac_optarg ;; + + -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ + | --dataroo | --dataro | --datar) + ac_prev=datarootdir ;; + -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ + | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) + datarootdir=$ac_optarg ;; + + -disable-* | --disable-*) + ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error "invalid feature name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=no ;; + + -docdir | --docdir | --docdi | --doc | --do) + ac_prev=docdir ;; + -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) + docdir=$ac_optarg ;; + + -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) + ac_prev=dvidir ;; + -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) + dvidir=$ac_optarg ;; + + -enable-* | --enable-*) + ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error "invalid feature name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=\$ac_optarg ;; + + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ + | --exec | --exe | --ex) + ac_prev=exec_prefix ;; + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ + | --exec=* | --exe=* | --ex=*) + exec_prefix=$ac_optarg ;; + + -gas | --gas | --ga | --g) + # Obsolete; use --with-gas. + with_gas=yes ;; + + -help | --help | --hel | --he | -h) + ac_init_help=long ;; + -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) + ac_init_help=recursive ;; + -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) + ac_init_help=short ;; + + -host | --host | --hos | --ho) + ac_prev=host_alias ;; + -host=* | --host=* | --hos=* | --ho=*) + host_alias=$ac_optarg ;; + + -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) + ac_prev=htmldir ;; + -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ + | --ht=*) + htmldir=$ac_optarg ;; + + -includedir | --includedir | --includedi | --included | --include \ + | --includ | --inclu | --incl | --inc) + ac_prev=includedir ;; + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ + | --includ=* | --inclu=* | --incl=* | --inc=*) + includedir=$ac_optarg ;; + + -infodir | --infodir | --infodi | --infod | --info | --inf) + ac_prev=infodir ;; + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) + infodir=$ac_optarg ;; + + -libdir | --libdir | --libdi | --libd) + ac_prev=libdir ;; + -libdir=* | --libdir=* | --libdi=* | --libd=*) + libdir=$ac_optarg ;; + + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ + | --libexe | --libex | --libe) + ac_prev=libexecdir ;; + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ + | --libexe=* | --libex=* | --libe=*) + libexecdir=$ac_optarg ;; + + -localedir | --localedir | --localedi | --localed | --locale) + ac_prev=localedir ;; + -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) + localedir=$ac_optarg ;; + + -localstatedir | --localstatedir | --localstatedi | --localstated \ + | --localstate | --localstat | --localsta | --localst | --locals) + ac_prev=localstatedir ;; + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ + | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) + localstatedir=$ac_optarg ;; + + -mandir | --mandir | --mandi | --mand | --man | --ma | --m) + ac_prev=mandir ;; + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) + mandir=$ac_optarg ;; + + -nfp | --nfp | --nf) + # Obsolete; use --without-fp. + with_fp=no ;; + + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c | -n) + no_create=yes ;; + + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) + no_recursion=yes ;; + + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ + | --oldin | --oldi | --old | --ol | --o) + ac_prev=oldincludedir ;; + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) + oldincludedir=$ac_optarg ;; + + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) + ac_prev=prefix ;; + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) + prefix=$ac_optarg ;; + + -program-prefix | --program-prefix | --program-prefi | --program-pref \ + | --program-pre | --program-pr | --program-p) + ac_prev=program_prefix ;; + -program-prefix=* | --program-prefix=* | --program-prefi=* \ + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) + program_prefix=$ac_optarg ;; + + -program-suffix | --program-suffix | --program-suffi | --program-suff \ + | --program-suf | --program-su | --program-s) + ac_prev=program_suffix ;; + -program-suffix=* | --program-suffix=* | --program-suffi=* \ + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) + program_suffix=$ac_optarg ;; + + -program-transform-name | --program-transform-name \ + | --program-transform-nam | --program-transform-na \ + | --program-transform-n | --program-transform- \ + | --program-transform | --program-transfor \ + | --program-transfo | --program-transf \ + | --program-trans | --program-tran \ + | --progr-tra | --program-tr | --program-t) + ac_prev=program_transform_name ;; + -program-transform-name=* | --program-transform-name=* \ + | --program-transform-nam=* | --program-transform-na=* \ + | --program-transform-n=* | --program-transform-=* \ + | --program-transform=* | --program-transfor=* \ + | --program-transfo=* | --program-transf=* \ + | --program-trans=* | --program-tran=* \ + | --progr-tra=* | --program-tr=* | --program-t=*) + program_transform_name=$ac_optarg ;; + + -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) + ac_prev=pdfdir ;; + -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) + pdfdir=$ac_optarg ;; + + -psdir | --psdir | --psdi | --psd | --ps) + ac_prev=psdir ;; + -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) + psdir=$ac_optarg ;; + + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + silent=yes ;; + + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) + ac_prev=sbindir ;; + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ + | --sbi=* | --sb=*) + sbindir=$ac_optarg ;; + + -sharedstatedir | --sharedstatedir | --sharedstatedi \ + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ + | --sharedst | --shareds | --shared | --share | --shar \ + | --sha | --sh) + ac_prev=sharedstatedir ;; + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ + | --sha=* | --sh=*) + sharedstatedir=$ac_optarg ;; + + -site | --site | --sit) + ac_prev=site ;; + -site=* | --site=* | --sit=*) + site=$ac_optarg ;; + + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) + ac_prev=srcdir ;; + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) + srcdir=$ac_optarg ;; + + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ + | --syscon | --sysco | --sysc | --sys | --sy) + ac_prev=sysconfdir ;; + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) + sysconfdir=$ac_optarg ;; + + -target | --target | --targe | --targ | --tar | --ta | --t) + ac_prev=target_alias ;; + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) + target_alias=$ac_optarg ;; + + -v | -verbose | --verbose | --verbos | --verbo | --verb) + verbose=yes ;; + + -version | --version | --versio | --versi | --vers | -V) + ac_init_version=: ;; + + -with-* | --with-*) + ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error "invalid package name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=\$ac_optarg ;; + + -without-* | --without-*) + ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error "invalid package name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=no ;; + + --x) + # Obsolete; use --with-x. + with_x=yes ;; + + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ + | --x-incl | --x-inc | --x-in | --x-i) + ac_prev=x_includes ;; + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) + x_includes=$ac_optarg ;; + + -x-libraries | --x-libraries | --x-librarie | --x-librari \ + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) + ac_prev=x_libraries ;; + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) + x_libraries=$ac_optarg ;; + + -*) as_fn_error "unrecognized option: \`$ac_option' +Try \`$0 --help' for more information." + ;; + + *=*) + ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` + # Reject names that are not valid shell variable names. + case $ac_envvar in #( + '' | [0-9]* | *[!_$as_cr_alnum]* ) + as_fn_error "invalid variable name: \`$ac_envvar'" ;; + esac + eval $ac_envvar=\$ac_optarg + export $ac_envvar ;; + + *) + # FIXME: should be removed in autoconf 3.0. + $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 + expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && + $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 + : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} + ;; + + esac +done + +if test -n "$ac_prev"; then + ac_option=--`echo $ac_prev | sed 's/_/-/g'` + as_fn_error "missing argument to $ac_option" +fi + +if test -n "$ac_unrecognized_opts"; then + case $enable_option_checking in + no) ;; + fatal) as_fn_error "unrecognized options: $ac_unrecognized_opts" ;; + *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; + esac +fi + +# Check all directory arguments for consistency. +for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ + datadir sysconfdir sharedstatedir localstatedir includedir \ + oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ + libdir localedir mandir +do + eval ac_val=\$$ac_var + # Remove trailing slashes. + case $ac_val in + */ ) + ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` + eval $ac_var=\$ac_val;; + esac + # Be sure to have absolute directory names. + case $ac_val in + [\\/$]* | ?:[\\/]* ) continue;; + NONE | '' ) case $ac_var in *prefix ) continue;; esac;; + esac + as_fn_error "expected an absolute directory name for --$ac_var: $ac_val" +done + +# There might be people who depend on the old broken behavior: `$host' +# used to hold the argument of --host etc. +# FIXME: To remove some day. +build=$build_alias +host=$host_alias +target=$target_alias + +# FIXME: To remove some day. +if test "x$host_alias" != x; then + if test "x$build_alias" = x; then + cross_compiling=maybe + $as_echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. + If a cross compiler is detected then cross compile mode will be used." >&2 + elif test "x$build_alias" != "x$host_alias"; then + cross_compiling=yes + fi +fi + +ac_tool_prefix= +test -n "$host_alias" && ac_tool_prefix=$host_alias- + +test "$silent" = yes && exec 6>/dev/null + + +ac_pwd=`pwd` && test -n "$ac_pwd" && +ac_ls_di=`ls -di .` && +ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || + as_fn_error "working directory cannot be determined" +test "X$ac_ls_di" = "X$ac_pwd_ls_di" || + as_fn_error "pwd does not report name of working directory" + + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then + ac_srcdir_defaulted=yes + # Try the directory containing this script, then the parent directory. + ac_confdir=`$as_dirname -- "$as_myself" || +$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_myself" : 'X\(//\)[^/]' \| \ + X"$as_myself" : 'X\(//\)$' \| \ + X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_myself" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + srcdir=$ac_confdir + if test ! -r "$srcdir/$ac_unique_file"; then + srcdir=.. + fi +else + ac_srcdir_defaulted=no +fi +if test ! -r "$srcdir/$ac_unique_file"; then + test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." + as_fn_error "cannot find sources ($ac_unique_file) in $srcdir" +fi +ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" +ac_abs_confdir=`( + cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error "$ac_msg" + pwd)` +# When building in place, set srcdir=. +if test "$ac_abs_confdir" = "$ac_pwd"; then + srcdir=. +fi +# Remove unnecessary trailing slashes from srcdir. +# Double slashes in file names in object file debugging info +# mess up M-x gdb in Emacs. +case $srcdir in +*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; +esac +for ac_var in $ac_precious_vars; do + eval ac_env_${ac_var}_set=\${${ac_var}+set} + eval ac_env_${ac_var}_value=\$${ac_var} + eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} + eval ac_cv_env_${ac_var}_value=\$${ac_var} +done + +# +# Report the --help message. +# +if test "$ac_init_help" = "long"; then + # Omit some internal or obsolete options to make the list less imposing. + # This message is too long to be a string in the A/UX 3.1 sh. + cat <<_ACEOF +\`configure' configures this package to adapt to many kinds of systems. + +Usage: $0 [OPTION]... [VAR=VALUE]... + +To assign environment variables (e.g., CC, CFLAGS...), specify them as +VAR=VALUE. See below for descriptions of some of the useful variables. + +Defaults for the options are specified in brackets. + +Configuration: + -h, --help display this help and exit + --help=short display options specific to this package + --help=recursive display the short help of all the included packages + -V, --version display version information and exit + -q, --quiet, --silent do not print \`checking...' messages + --cache-file=FILE cache test results in FILE [disabled] + -C, --config-cache alias for \`--cache-file=config.cache' + -n, --no-create do not create output files + --srcdir=DIR find the sources in DIR [configure dir or \`..'] + +Installation directories: + --prefix=PREFIX install architecture-independent files in PREFIX + [$ac_default_prefix] + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX + [PREFIX] + +By default, \`make install' will install all the files in +\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify +an installation prefix other than \`$ac_default_prefix' using \`--prefix', +for instance \`--prefix=\$HOME'. + +For better control, use the options below. + +Fine tuning of the installation directories: + --bindir=DIR user executables [EPREFIX/bin] + --sbindir=DIR system admin executables [EPREFIX/sbin] + --libexecdir=DIR program executables [EPREFIX/libexec] + --sysconfdir=DIR read-only single-machine data [PREFIX/etc] + --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] + --localstatedir=DIR modifiable single-machine data [PREFIX/var] + --libdir=DIR object code libraries [EPREFIX/lib] + --includedir=DIR C header files [PREFIX/include] + --oldincludedir=DIR C header files for non-gcc [/usr/include] + --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] + --datadir=DIR read-only architecture-independent data [DATAROOTDIR] + --infodir=DIR info documentation [DATAROOTDIR/info] + --localedir=DIR locale-dependent data [DATAROOTDIR/locale] + --mandir=DIR man documentation [DATAROOTDIR/man] + --docdir=DIR documentation root [DATAROOTDIR/doc/PACKAGE] + --htmldir=DIR html documentation [DOCDIR] + --dvidir=DIR dvi documentation [DOCDIR] + --pdfdir=DIR pdf documentation [DOCDIR] + --psdir=DIR ps documentation [DOCDIR] +_ACEOF + + cat <<\_ACEOF + +Program names: + --program-prefix=PREFIX prepend PREFIX to installed program names + --program-suffix=SUFFIX append SUFFIX to installed program names + --program-transform-name=PROGRAM run sed PROGRAM on installed program names + +System types: + --build=BUILD configure for building on BUILD [guessed] + --host=HOST cross-compile to build programs to run on HOST [BUILD] + --target=TARGET configure for building compilers for TARGET [HOST] +_ACEOF +fi + +if test -n "$ac_init_help"; then + + cat <<\_ACEOF + +Optional Features: + --disable-option-checking ignore unrecognized --enable/--with options + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) + --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --enable-maintainer-mode Enable developer functionality. + --enable-sim-bswap Use Host specific BSWAP instruction. + --enable-sim-cflags=opts Extra CFLAGS for use in building simulator + --enable-sim-debug=opts Enable debugging flags + --enable-sim-stdio Specify whether to use stdio for console input/output. + --enable-sim-trace=opts Enable tracing flags + --enable-sim-profile=opts Enable profiling flags + +Optional Packages: + --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] + --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --with-zlib include zlib support (auto/yes/no) default=auto + --with-pkgversion=PKG Use PKG in the version string in place of "GDB" + --with-bugurl=URL Direct users to URL to report a bug + +Some influential environment variables: + CC C compiler command + CFLAGS C compiler flags + LDFLAGS linker flags, e.g. -L if you have libraries in a + nonstandard directory + LIBS libraries to pass to the linker, e.g. -l + CPPFLAGS C/C++/Objective C preprocessor flags, e.g. -I if + you have headers in a nonstandard directory + CPP C preprocessor + +Use these variables to override the choices made by `configure' or to help +it to find libraries and programs with nonstandard names/locations. + +Report bugs to the package provider. +_ACEOF +ac_status=$? +fi + +if test "$ac_init_help" = "recursive"; then + # If there are subdirs, report their specific --help. + for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue + test -d "$ac_dir" || + { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || + continue + ac_builddir=. + +case "$ac_dir" in +.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; +*) + ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` + # A ".." for each directory in $ac_dir_suffix. + ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` + case $ac_top_builddir_sub in + "") ac_top_builddir_sub=. ac_top_build_prefix= ;; + *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; + esac ;; +esac +ac_abs_top_builddir=$ac_pwd +ac_abs_builddir=$ac_pwd$ac_dir_suffix +# for backward compatibility: +ac_top_builddir=$ac_top_build_prefix + +case $srcdir in + .) # We are building in place. + ac_srcdir=. + ac_top_srcdir=$ac_top_builddir_sub + ac_abs_top_srcdir=$ac_pwd ;; + [\\/]* | ?:[\\/]* ) # Absolute name. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir + ac_abs_top_srcdir=$srcdir ;; + *) # Relative name. + ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_build_prefix$srcdir + ac_abs_top_srcdir=$ac_pwd/$srcdir ;; +esac +ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix + + cd "$ac_dir" || { ac_status=$?; continue; } + # Check for guested configure. + if test -f "$ac_srcdir/configure.gnu"; then + echo && + $SHELL "$ac_srcdir/configure.gnu" --help=recursive + elif test -f "$ac_srcdir/configure"; then + echo && + $SHELL "$ac_srcdir/configure" --help=recursive + else + $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 + fi || ac_status=$? + cd "$ac_pwd" || { ac_status=$?; break; } + done +fi + +test -n "$ac_init_help" && exit $ac_status +if $ac_init_version; then + cat <<\_ACEOF +configure +generated by GNU Autoconf 2.64 + +Copyright (C) 2009 Free Software Foundation, Inc. +This configure script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it. +_ACEOF + exit +fi + +## ------------------------ ## +## Autoconf initialization. ## +## ------------------------ ## + +# ac_fn_c_try_compile LINENO +# -------------------------- +# Try to compile conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext + if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + return $ac_retval + +} # ac_fn_c_try_compile + +# ac_fn_c_try_cpp LINENO +# ---------------------- +# Try to preprocess conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_cpp () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { { ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } >/dev/null && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + return $ac_retval + +} # ac_fn_c_try_cpp + +# ac_fn_c_check_header_mongrel LINENO HEADER VAR INCLUDES +# ------------------------------------------------------- +# Tests whether HEADER exists, giving a warning if it cannot be compiled using +# the include files in INCLUDES and setting the cache variable VAR +# accordingly. +ac_fn_c_check_header_mongrel () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : + $as_echo_n "(cached) " >&6 +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +else + # Is the header compilable? +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 usability" >&5 +$as_echo_n "checking $2 usability... " >&6; } +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +#include <$2> +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_header_compiler=yes +else + ac_header_compiler=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_compiler" >&5 +$as_echo "$ac_header_compiler" >&6; } + +# Is the header present? +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 presence" >&5 +$as_echo_n "checking $2 presence... " >&6; } +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include <$2> +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + ac_header_preproc=yes +else + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_preproc" >&5 +$as_echo "$ac_header_preproc" >&6; } + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in #(( + yes:no: ) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&5 +$as_echo "$as_me: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} + ;; + no:yes:* ) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: present but cannot be compiled" >&5 +$as_echo "$as_me: WARNING: $2: present but cannot be compiled" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: check for missing prerequisite headers?" >&5 +$as_echo "$as_me: WARNING: $2: check for missing prerequisite headers?" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: see the Autoconf documentation" >&5 +$as_echo "$as_me: WARNING: $2: see the Autoconf documentation" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&5 +$as_echo "$as_me: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} + ;; +esac + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : + $as_echo_n "(cached) " >&6 +else + eval "$3=\$ac_header_compiler" +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +fi + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + +} # ac_fn_c_check_header_mongrel + +# ac_fn_c_try_run LINENO +# ---------------------- +# Try to link conftest.$ac_ext, and return whether this succeeded. Assumes +# that executables *can* be run. +ac_fn_c_try_run () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then : + ac_retval=0 +else + $as_echo "$as_me: program exited with status $ac_status" >&5 + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=$ac_status +fi + rm -rf conftest.dSYM conftest_ipa8_conftest.oo + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + return $ac_retval + +} # ac_fn_c_try_run + +# ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES +# ------------------------------------------------------- +# Tests whether HEADER exists and can be compiled using the include files in +# INCLUDES, setting the cache variable VAR accordingly. +ac_fn_c_check_header_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +#include <$2> +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + eval "$3=yes" +else + eval "$3=no" +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + +} # ac_fn_c_check_header_compile + +# ac_fn_c_try_link LINENO +# ----------------------- +# Try to link conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_link () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext conftest$ac_exeext + if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + $as_test_x conftest$ac_exeext + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information + # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would + # interfere with the next link command; also delete a directory that is + # left behind by Apple's compiler. We do this before executing the actions. + rm -rf conftest.dSYM conftest_ipa8_conftest.oo + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + return $ac_retval + +} # ac_fn_c_try_link + +# ac_fn_c_check_func LINENO FUNC VAR +# ---------------------------------- +# Tests whether FUNC exists, setting the cache variable VAR accordingly +ac_fn_c_check_func () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +/* Define $2 to an innocuous variant, in case declares $2. + For example, HP-UX 11i declares gettimeofday. */ +#define $2 innocuous_$2 + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $2 (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $2 + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char $2 (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_$2 || defined __stub___$2 +choke me +#endif + +int +main () +{ +return $2 (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + eval "$3=yes" +else + eval "$3=no" +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + +} # ac_fn_c_check_func +cat >config.log <<_ACEOF +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. + +It was created by $as_me, which was +generated by GNU Autoconf 2.64. Invocation command line was + + $ $0 $@ + +_ACEOF +exec 5>>config.log +{ +cat <<_ASUNAME +## --------- ## +## Platform. ## +## --------- ## + +hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` + +/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` +/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` +/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` +/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` + +_ASUNAME + +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + $as_echo "PATH: $as_dir" + done +IFS=$as_save_IFS + +} >&5 + +cat >&5 <<_ACEOF + + +## ----------- ## +## Core tests. ## +## ----------- ## + +_ACEOF + + +# Keep a trace of the command line. +# Strip out --no-create and --no-recursion so they do not pile up. +# Strip out --silent because we don't want to record it for future runs. +# Also quote any args containing shell meta-characters. +# Make two passes to allow for proper duplicate-argument suppression. +ac_configure_args= +ac_configure_args0= +ac_configure_args1= +ac_must_keep_next=false +for ac_pass in 1 2 +do + for ac_arg + do + case $ac_arg in + -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + continue ;; + *\'*) + ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + case $ac_pass in + 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; + 2) + as_fn_append ac_configure_args1 " '$ac_arg'" + if test $ac_must_keep_next = true; then + ac_must_keep_next=false # Got value, back to normal. + else + case $ac_arg in + *=* | --config-cache | -C | -disable-* | --disable-* \ + | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ + | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ + | -with-* | --with-* | -without-* | --without-* | --x) + case "$ac_configure_args0 " in + "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; + esac + ;; + -* ) ac_must_keep_next=true ;; + esac + fi + as_fn_append ac_configure_args " '$ac_arg'" + ;; + esac + done +done +{ ac_configure_args0=; unset ac_configure_args0;} +{ ac_configure_args1=; unset ac_configure_args1;} + +# When interrupted or exit'd, cleanup temporary files, and complete +# config.log. We remove comments because anyway the quotes in there +# would cause problems or look ugly. +# WARNING: Use '\'' to represent an apostrophe within the trap. +# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. +trap 'exit_status=$? + # Save into config.log some information that might help in debugging. + { + echo + + cat <<\_ASBOX +## ---------------- ## +## Cache variables. ## +## ---------------- ## +_ASBOX + echo + # The following way of writing the cache mishandles newlines in values, +( + for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do + eval ac_val=\$$ac_var + case $ac_val in #( + *${as_nl}*) + case $ac_var in #( + *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 +$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; + esac + case $ac_var in #( + _ | IFS | as_nl) ;; #( + BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( + *) { eval $ac_var=; unset $ac_var;} ;; + esac ;; + esac + done + (set) 2>&1 | + case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( + *${as_nl}ac_space=\ *) + sed -n \ + "s/'\''/'\''\\\\'\'''\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" + ;; #( + *) + sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" + ;; + esac | + sort +) + echo + + cat <<\_ASBOX +## ----------------- ## +## Output variables. ## +## ----------------- ## +_ASBOX + echo + for ac_var in $ac_subst_vars + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + + if test -n "$ac_subst_files"; then + cat <<\_ASBOX +## ------------------- ## +## File substitutions. ## +## ------------------- ## +_ASBOX + echo + for ac_var in $ac_subst_files + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + fi + + if test -s confdefs.h; then + cat <<\_ASBOX +## ----------- ## +## confdefs.h. ## +## ----------- ## +_ASBOX + echo + cat confdefs.h + echo + fi + test "$ac_signal" != 0 && + $as_echo "$as_me: caught signal $ac_signal" + $as_echo "$as_me: exit $exit_status" + } >&5 + rm -f core *.core core.conftest.* && + rm -f -r conftest* confdefs* conf$$* $ac_clean_files && + exit $exit_status +' 0 +for ac_signal in 1 2 13 15; do + trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal +done +ac_signal=0 + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -f -r conftest* confdefs.h + +$as_echo "/* confdefs.h */" > confdefs.h + +# Predefined preprocessor variables. + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_NAME "$PACKAGE_NAME" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_TARNAME "$PACKAGE_TARNAME" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_VERSION "$PACKAGE_VERSION" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_STRING "$PACKAGE_STRING" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_URL "$PACKAGE_URL" +_ACEOF + + +# Let the site file select an alternate cache file if it wants to. +# Prefer an explicitly selected file to automatically selected ones. +ac_site_file1=NONE +ac_site_file2=NONE +if test -n "$CONFIG_SITE"; then + ac_site_file1=$CONFIG_SITE +elif test "x$prefix" != xNONE; then + ac_site_file1=$prefix/share/config.site + ac_site_file2=$prefix/etc/config.site +else + ac_site_file1=$ac_default_prefix/share/config.site + ac_site_file2=$ac_default_prefix/etc/config.site +fi +for ac_site_file in "$ac_site_file1" "$ac_site_file2" +do + test "x$ac_site_file" = xNONE && continue + if test -r "$ac_site_file"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 +$as_echo "$as_me: loading site script $ac_site_file" >&6;} + sed 's/^/| /' "$ac_site_file" >&5 + . "$ac_site_file" + fi +done + +if test -r "$cache_file"; then + # Some versions of bash will fail to source /dev/null (special + # files actually), so we avoid doing that. + if test -f "$cache_file"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 +$as_echo "$as_me: loading cache $cache_file" >&6;} + case $cache_file in + [\\/]* | ?:[\\/]* ) . "$cache_file";; + *) . "./$cache_file";; + esac + fi +else + { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 +$as_echo "$as_me: creating cache $cache_file" >&6;} + >$cache_file +fi + +# Check that the precious variables saved in the cache have kept the same +# value. +ac_cache_corrupted=false +for ac_var in $ac_precious_vars; do + eval ac_old_set=\$ac_cv_env_${ac_var}_set + eval ac_new_set=\$ac_env_${ac_var}_set + eval ac_old_val=\$ac_cv_env_${ac_var}_value + eval ac_new_val=\$ac_env_${ac_var}_value + case $ac_old_set,$ac_new_set in + set,) + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,set) + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,);; + *) + if test "x$ac_old_val" != "x$ac_new_val"; then + # differences in whitespace do not lead to failure. + ac_old_val_w=`echo x $ac_old_val` + ac_new_val_w=`echo x $ac_new_val` + if test "$ac_old_val_w" != "$ac_new_val_w"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 +$as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} + ac_cache_corrupted=: + else + { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 +$as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} + eval $ac_var=\$ac_old_val + fi + { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 +$as_echo "$as_me: former value: \`$ac_old_val'" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 +$as_echo "$as_me: current value: \`$ac_new_val'" >&2;} + fi;; + esac + # Pass precious variables to config.status. + if test "$ac_new_set" = set; then + case $ac_new_val in + *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; + *) ac_arg=$ac_var=$ac_new_val ;; + esac + case " $ac_configure_args " in + *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. + *) as_fn_append ac_configure_args " '$ac_arg'" ;; + esac + fi +done +if $ac_cache_corrupted; then + { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 +$as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} + as_fn_error "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 +fi +## -------------------- ## +## Main body of script. ## +## -------------------- ## + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_config_headers="$ac_config_headers config.h:config.in" + + +# This file contains common code used by all simulators. +# +# SIM_AC_COMMON invokes AC macros used by all simulators and by the common +# directory. It is intended to be invoked before any target specific stuff. +# SIM_AC_OUTPUT is a cover function to AC_OUTPUT to generate the Makefile. +# It is intended to be invoked last. +# +# The simulator's configure.in should look like: +# +# dnl Process this file with autoconf to produce a configure script. +# sinclude(../common/aclocal.m4) +# AC_PREREQ(2.5)dnl +# AC_INIT(Makefile.in) +# +# SIM_AC_COMMON +# +# ... target specific stuff ... +# +# SIM_AC_OUTPUT + +# Include global overrides and fixes for Autoconf. + + + + + + + + + + + + + + + + + + + + + + + +# _AC_CHECK_DECL_BODY +# ------------------- +# Shell function body for AC_CHECK_DECL. +# _AC_CHECK_DECL_BODY + +# _AC_CHECK_DECLS(SYMBOL, ACTION-IF_FOUND, ACTION-IF-NOT-FOUND, +# INCLUDES) +# ------------------------------------------------------------- +# Helper to AC_CHECK_DECLS, which generates the check for a single +# SYMBOL with INCLUDES, performs the AC_DEFINE, then expands +# ACTION-IF-FOUND or ACTION-IF-NOT-FOUND. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +sim_inline="-DDEFAULT_INLINE=0" + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +# intl sister-directory configuration rules. +# + +# The idea behind this macro is that there's no need to repeat all the +# autoconf probes done by the intl directory - it's already done them +# for us. In fact, there's no need even to look at the cache for the +# answers. All we need to do is nab a few pieces of information. +# The intl directory is set up to make this easy, by generating a +# small file which can be sourced as a shell script; then we produce +# the necessary substitutions and definitions for this directory. + + + +# Autoconf M4 include file defining utility macros for complex Canadian +# cross builds. + + + + + + + + + +#### +# _NCN_TOOL_PREFIXES: Some stuff that oughtta be done in AC_CANONICAL_SYSTEM +# or AC_INIT. +# These demand that AC_CANONICAL_SYSTEM be called beforehand. + +#### +# NCN_STRICT_CHECK_TOOLS(variable, progs-to-check-for,[value-if-not-found],[path]) +# Like plain AC_CHECK_TOOLS, but require prefix if build!=host. + + +#### +# NCN_STRICT_CHECK_TARGET_TOOLS(variable, progs-to-check-for,[value-if-not-found],[path]) +# Like CVS Autoconf AC_CHECK_TARGET_TOOLS, but require prefix if build!=target. + + + +# Backported from Autoconf 2.5x; can go away when and if +# we switch. Put the OS path separator in $PATH_SEPARATOR. + + + + +# ACX_HAVE_GCC_FOR_TARGET +# Check if the variable GCC_FOR_TARGET really points to a GCC binary. + + +# ACX_CHECK_INSTALLED_TARGET_TOOL(VAR, PROG) +# Searching for installed target binutils. We need to take extra care, +# else we may find the wrong assembler, linker, etc., and lose. +# +# First try --with-build-time-tools, if specified. +# +# For build != host, we ask the installed GCC for the name of the tool it +# uses, and accept it if it is an absolute path. This is because the +# only good choice for a compiler is the same GCC version that is being +# installed (or we couldn't make target libraries), and we assume that +# on the host system we'll have not only the same GCC version, but also +# the same binutils version. +# +# For build == host, search the same directories that the installed +# compiler will search. We used to do this for the assembler, linker, +# and nm only; for simplicity of configuration, however, we extend this +# criterion to tools (such as ar and ranlib) that are never invoked by +# the compiler, to avoid mismatches. +# +# Also note we have to check MD_EXEC_PREFIX before checking the user's path +# if build == target. This makes the most sense only when bootstrapping, +# but we also do so when build != host. In this case, we hope that the +# build and host systems will have similar contents of MD_EXEC_PREFIX. +# +# If we do not find a suitable binary, then try the user's path. + + +### +# AC_PROG_CPP_WERROR +# Used for autoconf 2.5x to force AC_PREPROC_IFELSE to reject code which +# triggers warnings from the preprocessor. Will be in autoconf 2.58. +# For now, using this also overrides header checks to use only the +# preprocessor (matches 2.13 behavior; matching 2.58's behavior is a +# bit harder from here). +# Eventually autoconf will default to checking headers with the compiler +# instead, and we'll have to do this differently. + +# AC_PROG_CPP_WERROR + +# Test for GNAT. +# We require the gnatbind program, and a compiler driver that +# understands Ada. We use the user's CC setting, already found, +# and possibly add $1 to the command-line parameters. +# +# Sets the shell variable have_gnat to yes or no as appropriate, and +# substitutes GNATBIND and GNATMAKE. + + + + + + + + + + + + + + + + + + + + + + + + + +# Bugs in autoconf 2.59 break the call to SIM_AC_COMMON, hack around +# it by inlining the macro's contents. +# This file contains common code used by all simulators. +# +# common.m4 invokes AC macros used by all simulators and by the common +# directory. It is intended to be included before any target specific +# stuff. SIM_AC_OUTPUT is a cover function to AC_OUTPUT to generate +# the Makefile. It is intended to be invoked last. +# +# The simulator's configure.in should look like: +# +# dnl Process this file with autoconf to produce a configure script. +# AC_PREREQ(2.5)dnl +# AC_INIT(Makefile.in) +# AC_CONFIG_HEADER(config.h:config.in) +# +# sinclude(../common/aclocal.m4) +# sinclude(../common/common.m4) +# +# ... target specific stuff ... + +ac_aux_dir= +for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do + for ac_t in install-sh install.sh shtool; do + if test -f "$ac_dir/$ac_t"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/$ac_t -c" + break 2 + fi + done +done +if test -z "$ac_aux_dir"; then + as_fn_error "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 +fi + +# These three variables are undocumented and unsupported, +# and are intended to be withdrawn in a future Autoconf release. +# They can cause serious problems if a builder's source tree is in a directory +# whose full name contains unusual characters. +ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. +ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. +ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. + + +# Make sure we can run config.sub. +$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || + as_fn_error "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 +$as_echo_n "checking build system type... " >&6; } +if test "${ac_cv_build+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_build_alias=$build_alias +test "x$ac_build_alias" = x && + ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` +test "x$ac_build_alias" = x && + as_fn_error "cannot guess build type; you must specify one" "$LINENO" 5 +ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || + as_fn_error "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 +$as_echo "$ac_cv_build" >&6; } +case $ac_cv_build in +*-*-*) ;; +*) as_fn_error "invalid value of canonical build" "$LINENO" 5;; +esac +build=$ac_cv_build +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_build +shift +build_cpu=$1 +build_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +build_os=$* +IFS=$ac_save_IFS +case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 +$as_echo_n "checking host system type... " >&6; } +if test "${ac_cv_host+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test "x$host_alias" = x; then + ac_cv_host=$ac_cv_build +else + ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || + as_fn_error "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 +$as_echo "$ac_cv_host" >&6; } +case $ac_cv_host in +*-*-*) ;; +*) as_fn_error "invalid value of canonical host" "$LINENO" 5;; +esac +host=$ac_cv_host +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_host +shift +host_cpu=$1 +host_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +host_os=$* +IFS=$ac_save_IFS +case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5 +$as_echo_n "checking target system type... " >&6; } +if test "${ac_cv_target+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test "x$target_alias" = x; then + ac_cv_target=$ac_cv_host +else + ac_cv_target=`$SHELL "$ac_aux_dir/config.sub" $target_alias` || + as_fn_error "$SHELL $ac_aux_dir/config.sub $target_alias failed" "$LINENO" 5 +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_target" >&5 +$as_echo "$ac_cv_target" >&6; } +case $ac_cv_target in +*-*-*) ;; +*) as_fn_error "invalid value of canonical target" "$LINENO" 5;; +esac +target=$ac_cv_target +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_target +shift +target_cpu=$1 +target_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +target_os=$* +IFS=$ac_save_IFS +case $target_os in *\ *) target_os=`echo "$target_os" | sed 's/ /-/g'`;; esac + + +# The aliases save the names the user supplied, while $host etc. +# will get canonicalized. +test -n "$target_alias" && + test "$program_prefix$program_suffix$program_transform_name" = \ + NONENONEs,x,x, && + program_prefix=${target_alias}- + +test "$program_prefix" != NONE && + program_transform_name="s&^&$program_prefix&;$program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && + program_transform_name="s&\$&$program_suffix&;$program_transform_name" +# Double any \ or $. +# By default was `s,x,x', remove it if useless. +ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' +program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error "no acceptable C compiler found in \$PATH +See \`config.log' for more details." "$LINENO" 5; } + +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + rm -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out conftest.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 +$as_echo_n "checking for C compiler default output file name... " >&6; } +ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` + +# The possible output files: +ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" + +ac_rmfiles= +for ac_file in $ac_files +do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + * ) ac_rmfiles="$ac_rmfiles $ac_file";; + esac +done +rm -f $ac_rmfiles + +if { { ac_try="$ac_link_default" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link_default") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. +# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' +# in a Makefile. We should not override ac_cv_exeext if it was cached, +# so that the user can short-circuit this test for compilers unknown to +# Autoconf. +for ac_file in $ac_files '' +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; + then :; else + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + fi + # We set ac_cv_exeext here because the later test for it is not + # safe: cross compilers may not add the suffix if given an `-o' + # argument, so we may need to know it at that point already. + # Even if this section looks crufty: it has the advantage of + # actually working. + break;; + * ) + break;; + esac +done +test "$ac_cv_exeext" = no && ac_cv_exeext= + +else + ac_file='' +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 +$as_echo "$ac_file" >&6; } +if test -z "$ac_file"; then : + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +{ as_fn_set_status 77 +as_fn_error "C compiler cannot create executables +See \`config.log' for more details." "$LINENO" 5; }; } +fi +ac_exeext=$ac_cv_exeext + +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 +$as_echo_n "checking whether the C compiler works... " >&6; } +# If not cross compiling, check that we can run a simple program. +if test "$cross_compiling" != yes; then + if { ac_try='./$ac_file' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error "cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details." "$LINENO" 5; } + fi + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + +rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out conftest.out +ac_clean_files=$ac_clean_files_save +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 +$as_echo_n "checking whether we are cross compiling... " >&6; } +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 +$as_echo "$cross_compiling" >&6; } + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 +$as_echo_n "checking for suffix of executables... " >&6; } +if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + break;; + * ) break;; + esac +done +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error "cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details." "$LINENO" 5; } +fi +rm -f conftest$ac_cv_exeext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 +$as_echo "$ac_cv_exeext" >&6; } + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 +$as_echo_n "checking for suffix of object files... " >&6; } +if test "${ac_cv_objext+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + for ac_file in conftest.o conftest.obj conftest.*; do + test -f "$ac_file" || continue; + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error "cannot compute suffix of object files: cannot compile +See \`config.log' for more details." "$LINENO" 5; } +fi +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 +$as_echo "$ac_cv_objext" >&6; } +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if test "${ac_cv_c_compiler_gnu+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if test "${ac_cv_prog_cc_g+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +else + CFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if test "${ac_cv_prog_cc_c89+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#include +#include +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_c89=$ac_arg +fi +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac +if test "x$ac_cv_prog_cc_c89" != xno; then : + +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AmigaOS /C/install, which installs bootblocks on floppy discs +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# OS/2's system install, which has a completely different semantic +# ./install, which can be erroneously created by make from ./install.sh. +# Reject install programs that cannot install multiple files. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 +$as_echo_n "checking for a BSD-compatible install... " >&6; } +if test -z "$INSTALL"; then +if test "${ac_cv_path_install+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + # Account for people who put trailing slashes in PATH elements. +case $as_dir/ in #(( + ./ | .// | /[cC]/* | \ + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ + ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ + /usr/ucb/* ) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then + if test $ac_prog = install && + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + elif test $ac_prog = install && + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # program-specific install script used by HP pwplus--don't use. + : + else + rm -rf conftest.one conftest.two conftest.dir + echo one > conftest.one + echo two > conftest.two + mkdir conftest.dir + if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && + test -s conftest.one && test -s conftest.two && + test -s conftest.dir/conftest.one && + test -s conftest.dir/conftest.two + then + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" + break 3 + fi + fi + fi + done + done + ;; +esac + + done +IFS=$as_save_IFS + +rm -rf conftest.one conftest.two conftest.dir + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL=$ac_cv_path_install + else + # As a last resort, use the slow shell script. Don't cache a + # value for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + INSTALL=$ac_install_sh + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 +$as_echo "$INSTALL" >&6; } + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + + +# Put a plausible default for CC_FOR_BUILD in Makefile. +if test "x$cross_compiling" = "xno"; then + CC_FOR_BUILD='$(CC)' +else + CC_FOR_BUILD=gcc +fi + + + + +AR=${AR-ar} + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_RANLIB+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 +$as_echo "$RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 +$as_echo "$ac_ct_RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_RANLIB" = x; then + RANLIB=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + RANLIB=$ac_ct_RANLIB + fi +else + RANLIB="$ac_cv_prog_RANLIB" +fi + + +ALL_LINGUAS= +# If we haven't got the data from the intl directory, +# assume NLS is disabled. +USE_NLS=no +LIBINTL= +LIBINTL_DEP= +INCINTL= +XGETTEXT= +GMSGFMT= +POSUB= + +if test -f ../../intl/config.intl; then + . ../../intl/config.intl +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether NLS is requested" >&5 +$as_echo_n "checking whether NLS is requested... " >&6; } +if test x"$USE_NLS" != xyes; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + +$as_echo "#define ENABLE_NLS 1" >>confdefs.h + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for catalogs to be installed" >&5 +$as_echo_n "checking for catalogs to be installed... " >&6; } + # Look for .po and .gmo files in the source directory. + CATALOGS= + XLINGUAS= + for cat in $srcdir/po/*.gmo $srcdir/po/*.po; do + # If there aren't any .gmo files the shell will give us the + # literal string "../path/to/srcdir/po/*.gmo" which has to be + # weeded out. + case "$cat" in *\**) + continue;; + esac + # The quadruple backslash is collapsed to a double backslash + # by the backticks, then collapsed again by the double quotes, + # leaving us with one backslash in the sed expression (right + # before the dot that mustn't act as a wildcard). + cat=`echo $cat | sed -e "s!$srcdir/po/!!" -e "s!\\\\.po!.gmo!"` + lang=`echo $cat | sed -e "s!\\\\.gmo!!"` + # The user is allowed to set LINGUAS to a list of languages to + # install catalogs for. If it's empty that means "all of them." + if test "x$LINGUAS" = x; then + CATALOGS="$CATALOGS $cat" + XLINGUAS="$XLINGUAS $lang" + else + case "$LINGUAS" in *$lang*) + CATALOGS="$CATALOGS $cat" + XLINGUAS="$XLINGUAS $lang" + ;; + esac + fi + done + LINGUAS="$XLINGUAS" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LINGUAS" >&5 +$as_echo "$LINGUAS" >&6; } + + + DATADIRNAME=share + + INSTOBJEXT=.mo + + GENCAT=gencat + + CATOBJEXT=.gmo + +fi + +# Check for common headers. +# FIXME: Seems to me this can cause problems for i386-windows hosts. +# At one point there were hardcoded AC_DEFINE's if ${host} = i386-*-windows*. + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 +$as_echo_n "checking how to run the C preprocessor... " >&6; } +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then + if test "${ac_cv_prog_CPP+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + # Double quotes because CPP needs to be expanded + for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" + do + ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + break +fi + + done + ac_cv_prog_CPP=$CPP + +fi + CPP=$ac_cv_prog_CPP +else + ac_cv_prog_CPP=$CPP +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 +$as_echo "$CPP" >&6; } +ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error "C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." "$LINENO" 5; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 +$as_echo_n "checking for grep that handles long lines and -e... " >&6; } +if test "${ac_cv_path_GREP+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$GREP"; then + ac_path_GREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in grep ggrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue +# Check for GNU ac_path_GREP and select it if it is found. + # Check for GNU $ac_path_GREP +case `"$ac_path_GREP" --version 2>&1` in +*GNU*) + ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'GREP' >> "conftest.nl" + "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_GREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_GREP="$ac_path_GREP" + ac_path_GREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_GREP_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_GREP"; then + as_fn_error "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 + fi +else + ac_cv_path_GREP=$GREP +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 +$as_echo "$ac_cv_path_GREP" >&6; } + GREP="$ac_cv_path_GREP" + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 +$as_echo_n "checking for egrep... " >&6; } +if test "${ac_cv_path_EGREP+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 + then ac_cv_path_EGREP="$GREP -E" + else + if test -z "$EGREP"; then + ac_path_EGREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in egrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" + { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue +# Check for GNU ac_path_EGREP and select it if it is found. + # Check for GNU $ac_path_EGREP +case `"$ac_path_EGREP" --version 2>&1` in +*GNU*) + ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'EGREP' >> "conftest.nl" + "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_EGREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_EGREP="$ac_path_EGREP" + ac_path_EGREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_EGREP_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_EGREP"; then + as_fn_error "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 + fi +else + ac_cv_path_EGREP=$EGREP +fi + + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 +$as_echo "$ac_cv_path_EGREP" >&6; } + EGREP="$ac_cv_path_EGREP" + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 +$as_echo_n "checking for ANSI C header files... " >&6; } +if test "${ac_cv_header_stdc+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#include +#include + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_header_stdc=yes +else + ac_cv_header_stdc=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +if test $ac_cv_header_stdc = yes; then + # SunOS 4.x string.h does not declare mem*, contrary to ANSI. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "memchr" >/dev/null 2>&1; then : + +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "free" >/dev/null 2>&1; then : + +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. + if test "$cross_compiling" = yes; then : + : +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#if ((' ' & 0x0FF) == 0x020) +# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') +# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) +#else +# define ISLOWER(c) \ + (('a' <= (c) && (c) <= 'i') \ + || ('j' <= (c) && (c) <= 'r') \ + || ('s' <= (c) && (c) <= 'z')) +# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) +#endif + +#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) +int +main () +{ + int i; + for (i = 0; i < 256; i++) + if (XOR (islower (i), ISLOWER (i)) + || toupper (i) != TOUPPER (i)) + return 2; + return 0; +} +_ACEOF +if ac_fn_c_try_run "$LINENO"; then : + +else + ac_cv_header_stdc=no +fi +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ + conftest.$ac_objext conftest.beam conftest.$ac_ext +fi + +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 +$as_echo "$ac_cv_header_stdc" >&6; } +if test $ac_cv_header_stdc = yes; then + +$as_echo "#define STDC_HEADERS 1" >>confdefs.h + +fi + +# On IRIX 5.3, sys/types and inttypes.h are conflicting. +for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ + inttypes.h stdint.h unistd.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default +" +eval as_val=\$$as_ac_Header + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + +for ac_header in stdlib.h string.h strings.h unistd.h time.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" +eval as_val=\$$as_ac_Header + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + +for ac_header in sys/time.h sys/resource.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" +eval as_val=\$$as_ac_Header + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + +for ac_header in fcntl.h fpu_control.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" +eval as_val=\$$as_ac_Header + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + +for ac_header in dlfcn.h errno.h sys/stat.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" +eval as_val=\$$as_ac_Header + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + +for ac_func in getrusage time sigaction __setfpucw +do : + as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` +ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var" +eval as_val=\$$as_ac_var + if test "x$as_val" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1 +_ACEOF + +fi +done + + +# Check for socket libraries +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for bind in -lsocket" >&5 +$as_echo_n "checking for bind in -lsocket... " >&6; } +if test "${ac_cv_lib_socket_bind+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsocket $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char bind (); +int +main () +{ +return bind (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_socket_bind=yes +else + ac_cv_lib_socket_bind=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_socket_bind" >&5 +$as_echo "$ac_cv_lib_socket_bind" >&6; } +if test "x$ac_cv_lib_socket_bind" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBSOCKET 1 +_ACEOF + + LIBS="-lsocket $LIBS" + +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lnsl" >&5 +$as_echo_n "checking for gethostbyname in -lnsl... " >&6; } +if test "${ac_cv_lib_nsl_gethostbyname+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lnsl $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char gethostbyname (); +int +main () +{ +return gethostbyname (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_nsl_gethostbyname=yes +else + ac_cv_lib_nsl_gethostbyname=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nsl_gethostbyname" >&5 +$as_echo "$ac_cv_lib_nsl_gethostbyname" >&6; } +if test "x$ac_cv_lib_nsl_gethostbyname" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBNSL 1 +_ACEOF + + LIBS="-lnsl $LIBS" + +fi + + +# BFD conditionally uses zlib, so we must link it in if libbfd does, by +# using the same condition. + + # See if the user specified whether he wants zlib support or not. + +# Check whether --with-zlib was given. +if test "${with_zlib+set}" = set; then : + withval=$with_zlib; +else + with_zlib=auto +fi + + + if test "$with_zlib" != "no"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for library containing zlibVersion" >&5 +$as_echo_n "checking for library containing zlibVersion... " >&6; } +if test "${ac_cv_search_zlibVersion+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + ac_func_search_save_LIBS=$LIBS +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char zlibVersion (); +int +main () +{ +return zlibVersion (); + ; + return 0; +} +_ACEOF +for ac_lib in '' z; do + if test -z "$ac_lib"; then + ac_res="none required" + else + ac_res=-l$ac_lib + LIBS="-l$ac_lib $ac_func_search_save_LIBS" + fi + if ac_fn_c_try_link "$LINENO"; then : + ac_cv_search_zlibVersion=$ac_res +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext + if test "${ac_cv_search_zlibVersion+set}" = set; then : + break +fi +done +if test "${ac_cv_search_zlibVersion+set}" = set; then : + +else + ac_cv_search_zlibVersion=no +fi +rm conftest.$ac_ext +LIBS=$ac_func_search_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_search_zlibVersion" >&5 +$as_echo "$ac_cv_search_zlibVersion" >&6; } +ac_res=$ac_cv_search_zlibVersion +if test "$ac_res" != no; then : + test "$ac_res" = "none required" || LIBS="$ac_res $LIBS" + for ac_header in zlib.h +do : + ac_fn_c_check_header_mongrel "$LINENO" "zlib.h" "ac_cv_header_zlib_h" "$ac_includes_default" +if test "x$ac_cv_header_zlib_h" = x""yes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_ZLIB_H 1 +_ACEOF + +fi + +done + +fi + + if test "$with_zlib" = "yes" -a "$ac_cv_header_zlib_h" != "yes"; then + as_fn_error "zlib (libz) library was explicitly requested but not found" "$LINENO" 5 + fi + fi + + +. ${srcdir}/../../bfd/configure.host + + + +USE_MAINTAINER_MODE=no +# Check whether --enable-maintainer-mode was given. +if test "${enable_maintainer_mode+set}" = set; then : + enableval=$enable_maintainer_mode; case "${enableval}" in + yes) MAINT="" USE_MAINTAINER_MODE=yes ;; + no) MAINT="#" ;; + *) as_fn_error "\"--enable-maintainer-mode does not take a value\"" "$LINENO" 5; MAINT="#" ;; +esac +if test x"$silent" != x"yes" && test x"$MAINT" = x""; then + echo "Setting maintainer mode" 6>&1 +fi +else + MAINT="#" +fi + + + +# Check whether --enable-sim-bswap was given. +if test "${enable_sim_bswap+set}" = set; then : + enableval=$enable_sim_bswap; case "${enableval}" in + yes) sim_bswap="-DWITH_BSWAP=1 -DUSE_BSWAP=1";; + no) sim_bswap="-DWITH_BSWAP=0";; + *) as_fn_error "\"--enable-sim-bswap does not take a value\"" "$LINENO" 5; sim_bswap="";; +esac +if test x"$silent" != x"yes" && test x"$sim_bswap" != x""; then + echo "Setting bswap flags = $sim_bswap" 6>&1 +fi +else + sim_bswap="" +fi + + + +# Check whether --enable-sim-cflags was given. +if test "${enable_sim_cflags+set}" = set; then : + enableval=$enable_sim_cflags; case "${enableval}" in + yes) sim_cflags="-O2 -fomit-frame-pointer";; + trace) as_fn_error "\"Please use --enable-sim-debug instead.\"" "$LINENO" 5; sim_cflags="";; + no) sim_cflags="";; + *) sim_cflags=`echo "${enableval}" | sed -e "s/,/ /g"`;; +esac +if test x"$silent" != x"yes" && test x"$sim_cflags" != x""; then + echo "Setting sim cflags = $sim_cflags" 6>&1 +fi +else + sim_cflags="" +fi + + + +# Check whether --enable-sim-debug was given. +if test "${enable_sim_debug+set}" = set; then : + enableval=$enable_sim_debug; case "${enableval}" in + yes) sim_debug="-DDEBUG=7 -DWITH_DEBUG=7";; + no) sim_debug="-DDEBUG=0 -DWITH_DEBUG=0";; + *) sim_debug="-DDEBUG='(${enableval})' -DWITH_DEBUG='(${enableval})'";; +esac +if test x"$silent" != x"yes" && test x"$sim_debug" != x""; then + echo "Setting sim debug = $sim_debug" 6>&1 +fi +else + sim_debug="" +fi + + + +# Check whether --enable-sim-stdio was given. +if test "${enable_sim_stdio+set}" = set; then : + enableval=$enable_sim_stdio; case "${enableval}" in + yes) sim_stdio="-DWITH_STDIO=DO_USE_STDIO";; + no) sim_stdio="-DWITH_STDIO=DONT_USE_STDIO";; + *) as_fn_error "\"Unknown value $enableval passed to --enable-sim-stdio\"" "$LINENO" 5; sim_stdio="";; +esac +if test x"$silent" != x"yes" && test x"$sim_stdio" != x""; then + echo "Setting stdio flags = $sim_stdio" 6>&1 +fi +else + sim_stdio="" +fi + + + +# Check whether --enable-sim-trace was given. +if test "${enable_sim_trace+set}" = set; then : + enableval=$enable_sim_trace; case "${enableval}" in + yes) sim_trace="-DTRACE=1 -DWITH_TRACE=-1";; + no) sim_trace="-DTRACE=0 -DWITH_TRACE=0";; + [-0-9]*) + sim_trace="-DTRACE='(${enableval})' -DWITH_TRACE='(${enableval})'";; + [a-z]*) + sim_trace="" + for x in `echo "$enableval" | sed -e "s/,/ /g"`; do + if test x"$sim_trace" = x; then + sim_trace="-DWITH_TRACE='(TRACE_$x" + else + sim_trace="${sim_trace}|TRACE_$x" + fi + done + sim_trace="$sim_trace)'" ;; +esac +if test x"$silent" != x"yes" && test x"$sim_trace" != x""; then + echo "Setting sim trace = $sim_trace" 6>&1 +fi +else + sim_trace="" +fi + + + +# Check whether --enable-sim-profile was given. +if test "${enable_sim_profile+set}" = set; then : + enableval=$enable_sim_profile; case "${enableval}" in + yes) sim_profile="-DPROFILE=1 -DWITH_PROFILE=-1";; + no) sim_profile="-DPROFILE=0 -DWITH_PROFILE=0";; + [-0-9]*) + sim_profile="-DPROFILE='(${enableval})' -DWITH_PROFILE='(${enableval})'";; + [a-z]*) + sim_profile="" + for x in `echo "$enableval" | sed -e "s/,/ /g"`; do + if test x"$sim_profile" = x; then + sim_profile="-DWITH_PROFILE='(PROFILE_$x" + else + sim_profile="${sim_profile}|PROFILE_$x" + fi + done + sim_profile="$sim_profile)'" ;; +esac +if test x"$silent" != x"yes" && test x"$sim_profile" != x""; then + echo "Setting sim profile = $sim_profile" 6>&1 +fi +else + sim_profile="-DPROFILE=1 -DWITH_PROFILE=-1" +fi + + + + +# Check whether --with-pkgversion was given. +if test "${with_pkgversion+set}" = set; then : + withval=$with_pkgversion; case "$withval" in + yes) as_fn_error "package version not specified" "$LINENO" 5 ;; + no) PKGVERSION= ;; + *) PKGVERSION="($withval) " ;; + esac +else + PKGVERSION="(GDB) " + +fi + + + + + +# Check whether --with-bugurl was given. +if test "${with_bugurl+set}" = set; then : + withval=$with_bugurl; case "$withval" in + yes) as_fn_error "bug URL not specified" "$LINENO" 5 ;; + no) BUGURL= + ;; + *) BUGURL="$withval" + ;; + esac +else + BUGURL="http://www.gnu.org/software/gdb/bugs/" + +fi + + case ${BUGURL} in + "") + REPORT_BUGS_TO= + REPORT_BUGS_TEXI= + ;; + *) + REPORT_BUGS_TO="<$BUGURL>" + REPORT_BUGS_TEXI=@uref{`echo "$BUGURL" | sed 's/@/@@/g'`} + ;; + esac; + + + + +cat >>confdefs.h <<_ACEOF +#define PKGVERSION "$PKGVERSION" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define REPORT_BUGS_TO "$REPORT_BUGS_TO" +_ACEOF + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking return type of signal handlers" >&5 +$as_echo_n "checking return type of signal handlers... " >&6; } +if test "${ac_cv_type_signal+set}" = set; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include + +int +main () +{ +return *(signal (0, 0)) (0) == 1; + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_type_signal=int +else + ac_cv_type_signal=void +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_type_signal" >&5 +$as_echo "$ac_cv_type_signal" >&6; } + +cat >>confdefs.h <<_ACEOF +#define RETSIGTYPE $ac_cv_type_signal +_ACEOF + + + + + +sim_link_files= +sim_link_links= + +sim_link_links=tconfig.h +if test -f ${srcdir}/tconfig.in +then + sim_link_files=tconfig.in +else + sim_link_files=../common/tconfig.in +fi + +# targ-vals.def points to the libc macro description file. +case "${target}" in +*-*-*) TARG_VALS_DEF=../common/nltvals.def ;; +esac +sim_link_files="${sim_link_files} ${TARG_VALS_DEF}" +sim_link_links="${sim_link_links} targ-vals.def" + + + +ac_sources="$sim_link_files" +ac_dests="$sim_link_links" +while test -n "$ac_sources"; do + set $ac_dests; ac_dest=$1; shift; ac_dests=$* + set $ac_sources; ac_source=$1; shift; ac_sources=$* + ac_config_links_1="$ac_config_links_1 $ac_dest:$ac_source" +done +ac_config_links="$ac_config_links $ac_config_links_1" + +cgen_breaks="" +if grep CGEN_MAINT $srcdir/Makefile.in >/dev/null; then +cgen_breaks="break cgen_rtx_error"; +fi + +ac_config_files="$ac_config_files Makefile.sim:Makefile.in" + +ac_config_files="$ac_config_files Make-common.sim:../common/Make-common.in" + +ac_config_files="$ac_config_files .gdbinit:../common/gdbinit.in" + +ac_config_commands="$ac_config_commands Makefile" + +ac_config_commands="$ac_config_commands stamp-h" + +cat >confcache <<\_ACEOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs, see configure's option --config-cache. +# It is not useful on other systems. If it contains results you don't +# want to keep, you may remove or edit it. +# +# config.status only pays attention to the cache file if you give it +# the --recheck option to rerun configure. +# +# `ac_cv_env_foo' variables (set or unset) will be overridden when +# loading this file, other *unset* `ac_cv_foo' will be assigned the +# following values. + +_ACEOF + +# The following way of writing the cache mishandles newlines in values, +# but we know of no workaround that is simple, portable, and efficient. +# So, we kill variables containing newlines. +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +( + for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do + eval ac_val=\$$ac_var + case $ac_val in #( + *${as_nl}*) + case $ac_var in #( + *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 +$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; + esac + case $ac_var in #( + _ | IFS | as_nl) ;; #( + BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( + *) { eval $ac_var=; unset $ac_var;} ;; + esac ;; + esac + done + + (set) 2>&1 | + case $as_nl`(ac_space=' '; set) 2>&1` in #( + *${as_nl}ac_space=\ *) + # `set' does not quote correctly, so add quotes: double-quote + # substitution turns \\\\ into \\, and sed turns \\ into \. + sed -n \ + "s/'/'\\\\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" + ;; #( + *) + # `set' quotes correctly as required by POSIX, so do not add quotes. + sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" + ;; + esac | + sort +) | + sed ' + /^ac_cv_env_/b end + t clear + :clear + s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ + t end + s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ + :end' >>confcache +if diff "$cache_file" confcache >/dev/null 2>&1; then :; else + if test -w "$cache_file"; then + test "x$cache_file" != "x/dev/null" && + { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 +$as_echo "$as_me: updating cache $cache_file" >&6;} + cat confcache >$cache_file + else + { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 +$as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} + fi +fi +rm -f confcache + +test "x$prefix" = xNONE && prefix=$ac_default_prefix +# Let make expand exec_prefix. +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' + +DEFS=-DHAVE_CONFIG_H + +ac_libobjs= +ac_ltlibobjs= +for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue + # 1. Remove the extension, and $U if already installed. + ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' + ac_i=`$as_echo "$ac_i" | sed "$ac_script"` + # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR + # will be set to the directory where LIBOBJS objects are built. + as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" + as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' +done +LIBOBJS=$ac_libobjs + +LTLIBOBJS=$ac_ltlibobjs + + + +: ${CONFIG_STATUS=./config.status} +ac_write_fail=0 +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files $CONFIG_STATUS" +{ $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 +$as_echo "$as_me: creating $CONFIG_STATUS" >&6;} +as_write_fail=0 +cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 +#! $SHELL +# Generated by $as_me. +# Run this file to recreate the current configuration. +# Compiler output produced by configure, useful for debugging +# configure, is in config.log if it exists. + +debug=false +ac_cs_recheck=false +ac_cs_silent=false + +SHELL=\${CONFIG_SHELL-$SHELL} +export SHELL +_ASEOF +cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 +## -------------------- ## +## M4sh Initialization. ## +## -------------------- ## + +# Be more Bourne compatible +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi + + +as_nl=' +' +export as_nl +# Printing a long string crashes Solaris 7 /usr/bin/printf. +as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo +# Prefer a ksh shell builtin over an external printf program on Solaris, +# but without wasting forks for bash or zsh. +if test -z "$BASH_VERSION$ZSH_VERSION" \ + && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='print -r --' + as_echo_n='print -rn --' +elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='printf %s\n' + as_echo_n='printf %s' +else + if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then + as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' + as_echo_n='/usr/ucb/echo -n' + else + as_echo_body='eval expr "X$1" : "X\\(.*\\)"' + as_echo_n_body='eval + arg=$1; + case $arg in #( + *"$as_nl"*) + expr "X$arg" : "X\\(.*\\)$as_nl"; + arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; + esac; + expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" + ' + export as_echo_n_body + as_echo_n='sh -c $as_echo_n_body as_echo' + fi + export as_echo_body + as_echo='sh -c $as_echo_body as_echo' +fi + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + + +# IFS +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent editors from complaining about space-tab. +# (If _AS_PATH_WALK were called with IFS unset, it would disable word +# splitting by setting IFS to empty value.) +IFS=" "" $as_nl" + +# Find who we are. Look in the path if we contain no directory separator. +case $0 in #(( + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break + done +IFS=$as_save_IFS + + ;; +esac +# We did not find ourselves, most probably we were run as `sh COMMAND' +# in which case we are not to be found in the path. +if test "x$as_myself" = x; then + as_myself=$0 +fi +if test ! -f "$as_myself"; then + $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 + exit 1 +fi + +# Unset variables that we do not need and which cause bugs (e.g. in +# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" +# suppresses any "Segmentation fault" message there. '((' could +# trigger a bug in pdksh 5.2.14. +for as_var in BASH_ENV ENV MAIL MAILPATH +do eval test x\${$as_var+set} = xset \ + && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : +done +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +LC_ALL=C +export LC_ALL +LANGUAGE=C +export LANGUAGE + +# CDPATH. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + + +# as_fn_error ERROR [LINENO LOG_FD] +# --------------------------------- +# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are +# provided, also output the error to LOG_FD, referencing LINENO. Then exit the +# script with status $?, using 1 if that was 0. +as_fn_error () +{ + as_status=$?; test $as_status -eq 0 && as_status=1 + if test "$3"; then + as_lineno=${as_lineno-"$2"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + $as_echo "$as_me:${as_lineno-$LINENO}: error: $1" >&$3 + fi + $as_echo "$as_me: error: $1" >&2 + as_fn_exit $as_status +} # as_fn_error + + +# as_fn_set_status STATUS +# ----------------------- +# Set $? to STATUS, without forking. +as_fn_set_status () +{ + return $1 +} # as_fn_set_status + +# as_fn_exit STATUS +# ----------------- +# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. +as_fn_exit () +{ + set +e + as_fn_set_status $1 + exit $1 +} # as_fn_exit + +# as_fn_unset VAR +# --------------- +# Portably unset VAR. +as_fn_unset () +{ + { eval $1=; unset $1;} +} +as_unset=as_fn_unset +# as_fn_append VAR VALUE +# ---------------------- +# Append the text in VALUE to the end of the definition contained in VAR. Take +# advantage of any shell optimizations that allow amortized linear growth over +# repeated appends, instead of the typical quadratic growth present in naive +# implementations. +if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : + eval 'as_fn_append () + { + eval $1+=\$2 + }' +else + as_fn_append () + { + eval $1=\$$1\$2 + } +fi # as_fn_append + +# as_fn_arith ARG... +# ------------------ +# Perform arithmetic evaluation on the ARGs, and store the result in the +# global $as_val. Take advantage of shells that can avoid forks. The arguments +# must be portable across $(()) and expr. +if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : + eval 'as_fn_arith () + { + as_val=$(( $* )) + }' +else + as_fn_arith () + { + as_val=`expr "$@" || test $? -eq 1` + } +fi # as_fn_arith + + +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + +if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then + as_dirname=dirname +else + as_dirname=false +fi + +as_me=`$as_basename -- "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + +ECHO_C= ECHO_N= ECHO_T= +case `echo -n x` in #((((( +-n*) + case `echo 'xy\c'` in + *c*) ECHO_T=' ';; # ECHO_T is single tab character. + xy) ECHO_C='\c';; + *) echo `echo ksh88 bug on AIX 6.1` > /dev/null + ECHO_T=' ';; + esac;; +*) + ECHO_N='-n';; +esac + +rm -f conf$$ conf$$.exe conf$$.file +if test -d conf$$.dir; then + rm -f conf$$.dir/conf$$.file +else + rm -f conf$$.dir + mkdir conf$$.dir 2>/dev/null +fi +if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + as_ln_s='ln -s' + # ... but there are two gotchas: + # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. + # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. + # In both cases, we have to default to `cp -p'. + ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || + as_ln_s='cp -p' + elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln + else + as_ln_s='cp -p' + fi +else + as_ln_s='cp -p' +fi +rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file +rmdir conf$$.dir 2>/dev/null + + +# as_fn_mkdir_p +# ------------- +# Create "$as_dir" as a directory, including parents if necessary. +as_fn_mkdir_p () +{ + + case $as_dir in #( + -*) as_dir=./$as_dir;; + esac + test -d "$as_dir" || eval $as_mkdir_p || { + as_dirs= + while :; do + case $as_dir in #( + *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( + *) as_qdir=$as_dir;; + esac + as_dirs="'$as_qdir' $as_dirs" + as_dir=`$as_dirname -- "$as_dir" || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + test -d "$as_dir" && break + done + test -z "$as_dirs" || eval "mkdir $as_dirs" + } || test -d "$as_dir" || as_fn_error "cannot create directory $as_dir" + + +} # as_fn_mkdir_p +if mkdir -p . 2>/dev/null; then + as_mkdir_p='mkdir -p "$as_dir"' +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +if test -x / >/dev/null 2>&1; then + as_test_x='test -x' +else + if ls -dL / >/dev/null 2>&1; then + as_ls_L_option=L + else + as_ls_L_option= + fi + as_test_x=' + eval sh -c '\'' + if test -d "$1"; then + test -d "$1/."; + else + case $1 in #( + -*)set "./$1";; + esac; + case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( + ???[sx]*):;;*)false;;esac;fi + '\'' sh + ' +fi +as_executable_p=$as_test_x + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + +exec 6>&1 +## ----------------------------------- ## +## Main body of $CONFIG_STATUS script. ## +## ----------------------------------- ## +_ASEOF +test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# Save the log message, to keep $0 and so on meaningful, and to +# report actual input values of CONFIG_FILES etc. instead of their +# values after options handling. +ac_log=" +This file was extended by $as_me, which was +generated by GNU Autoconf 2.64. Invocation command line was + + CONFIG_FILES = $CONFIG_FILES + CONFIG_HEADERS = $CONFIG_HEADERS + CONFIG_LINKS = $CONFIG_LINKS + CONFIG_COMMANDS = $CONFIG_COMMANDS + $ $0 $@ + +on `(hostname || uname -n) 2>/dev/null | sed 1q` +" + +_ACEOF + +case $ac_config_files in *" +"*) set x $ac_config_files; shift; ac_config_files=$*;; +esac + +case $ac_config_headers in *" +"*) set x $ac_config_headers; shift; ac_config_headers=$*;; +esac + + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +# Files that config.status was made for. +config_files="$ac_config_files" +config_headers="$ac_config_headers" +config_links="$ac_config_links" +config_commands="$ac_config_commands" + +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +ac_cs_usage="\ +\`$as_me' instantiates files and other configuration actions +from templates according to the current configuration. Unless the files +and actions are specified as TAGs, all are instantiated by default. + +Usage: $0 [OPTION]... [TAG]... + + -h, --help print this help, then exit + -V, --version print version number and configuration settings, then exit + -q, --quiet, --silent + do not print progress messages + -d, --debug don't remove temporary files + --recheck update $as_me by reconfiguring in the same conditions + --file=FILE[:TEMPLATE] + instantiate the configuration file FILE + --header=FILE[:TEMPLATE] + instantiate the configuration header FILE + +Configuration files: +$config_files + +Configuration headers: +$config_headers + +Configuration links: +$config_links + +Configuration commands: +$config_commands + +Report bugs to the package provider." + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +ac_cs_version="\\ +config.status +configured by $0, generated by GNU Autoconf 2.64, + with options \\"`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\" + +Copyright (C) 2009 Free Software Foundation, Inc. +This config.status script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it." + +ac_pwd='$ac_pwd' +srcdir='$srcdir' +INSTALL='$INSTALL' +test -n "\$AWK" || AWK=awk +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# The default lists apply if the user does not specify any file. +ac_need_defaults=: +while test $# != 0 +do + case $1 in + --*=*) + ac_option=`expr "X$1" : 'X\([^=]*\)='` + ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` + ac_shift=: + ;; + *) + ac_option=$1 + ac_optarg=$2 + ac_shift=shift + ;; + esac + + case $ac_option in + # Handling of the options. + -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) + ac_cs_recheck=: ;; + --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) + $as_echo "$ac_cs_version"; exit ;; + --debug | --debu | --deb | --de | --d | -d ) + debug=: ;; + --file | --fil | --fi | --f ) + $ac_shift + case $ac_optarg in + *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + as_fn_append CONFIG_FILES " '$ac_optarg'" + ac_need_defaults=false;; + --header | --heade | --head | --hea ) + $ac_shift + case $ac_optarg in + *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + as_fn_append CONFIG_HEADERS " '$ac_optarg'" + ac_need_defaults=false;; + --he | --h) + # Conflict between --help and --header + as_fn_error "ambiguous option: \`$1' +Try \`$0 --help' for more information.";; + --help | --hel | -h ) + $as_echo "$ac_cs_usage"; exit ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil | --si | --s) + ac_cs_silent=: ;; + + # This is an error. + -*) as_fn_error "unrecognized option: \`$1' +Try \`$0 --help' for more information." ;; + + *) as_fn_append ac_config_targets " $1" + ac_need_defaults=false ;; + + esac + shift +done + +ac_configure_extra_args= + +if $ac_cs_silent; then + exec 6>/dev/null + ac_configure_extra_args="$ac_configure_extra_args --silent" +fi + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +if \$ac_cs_recheck; then + set X '$SHELL' '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion + shift + \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 + CONFIG_SHELL='$SHELL' + export CONFIG_SHELL + exec "\$@" +fi + +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +exec 5>>config.log +{ + echo + sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX +## Running $as_me. ## +_ASBOX + $as_echo "$ac_log" +} >&5 + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 + +# Handling of arguments. +for ac_config_target in $ac_config_targets +do + case $ac_config_target in + "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h:config.in" ;; + "$ac_config_links_1") CONFIG_LINKS="$CONFIG_LINKS $ac_config_links_1" ;; + "Makefile.sim") CONFIG_FILES="$CONFIG_FILES Makefile.sim:Makefile.in" ;; + "Make-common.sim") CONFIG_FILES="$CONFIG_FILES Make-common.sim:../common/Make-common.in" ;; + ".gdbinit") CONFIG_FILES="$CONFIG_FILES .gdbinit:../common/gdbinit.in" ;; + "Makefile") CONFIG_COMMANDS="$CONFIG_COMMANDS Makefile" ;; + "stamp-h") CONFIG_COMMANDS="$CONFIG_COMMANDS stamp-h" ;; + + *) as_fn_error "invalid argument: \`$ac_config_target'" "$LINENO" 5;; + esac +done + + +# If the user did not use the arguments to specify the items to instantiate, +# then the envvar interface is used. Set only those that are not. +# We use the long form for the default assignment because of an extremely +# bizarre bug on SunOS 4.1.3. +if $ac_need_defaults; then + test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files + test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers + test "${CONFIG_LINKS+set}" = set || CONFIG_LINKS=$config_links + test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands +fi + +# Have a temporary directory for convenience. Make it in the build tree +# simply because there is no reason against having it here, and in addition, +# creating and moving files from /tmp can sometimes cause problems. +# Hook for its removal unless debugging. +# Note that there is a small window in which the directory will not be cleaned: +# after its creation but before its name has been assigned to `$tmp'. +$debug || +{ + tmp= + trap 'exit_status=$? + { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status +' 0 + trap 'as_fn_exit 1' 1 2 13 15 +} +# Create a (secure) tmp directory for tmp files. + +{ + tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && + test -n "$tmp" && test -d "$tmp" +} || +{ + tmp=./conf$$-$RANDOM + (umask 077 && mkdir "$tmp") +} || as_fn_error "cannot create a temporary directory in ." "$LINENO" 5 + +# Set up the scripts for CONFIG_FILES section. +# No need to generate them if there are no CONFIG_FILES. +# This happens for instance with `./config.status config.h'. +if test -n "$CONFIG_FILES"; then + + +ac_cr=`echo X | tr X '\015'` +# On cygwin, bash can eat \r inside `` if the user requested igncr. +# But we know of no other shell where ac_cr would be empty at this +# point, so we can use a bashism as a fallback. +if test "x$ac_cr" = x; then + eval ac_cr=\$\'\\r\' +fi +ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` +if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then + ac_cs_awk_cr='\r' +else + ac_cs_awk_cr=$ac_cr +fi + +echo 'BEGIN {' >"$tmp/subs1.awk" && +_ACEOF + + +{ + echo "cat >conf$$subs.awk <<_ACEOF" && + echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && + echo "_ACEOF" +} >conf$$subs.sh || + as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 +ac_delim_num=`echo "$ac_subst_vars" | grep -c '$'` +ac_delim='%!_!# ' +for ac_last_try in false false false false false :; do + . ./conf$$subs.sh || + as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 + + ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` + if test $ac_delim_n = $ac_delim_num; then + break + elif $ac_last_try; then + as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 + else + ac_delim="$ac_delim!$ac_delim _$ac_delim!! " + fi +done +rm -f conf$$subs.sh + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +cat >>"\$tmp/subs1.awk" <<\\_ACAWK && +_ACEOF +sed -n ' +h +s/^/S["/; s/!.*/"]=/ +p +g +s/^[^!]*!// +:repl +t repl +s/'"$ac_delim"'$// +t delim +:nl +h +s/\(.\{148\}\).*/\1/ +t more1 +s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ +p +n +b repl +:more1 +s/["\\]/\\&/g; s/^/"/; s/$/"\\/ +p +g +s/.\{148\}// +t nl +:delim +h +s/\(.\{148\}\).*/\1/ +t more2 +s/["\\]/\\&/g; s/^/"/; s/$/"/ +p +b +:more2 +s/["\\]/\\&/g; s/^/"/; s/$/"\\/ +p +g +s/.\{148\}// +t delim +' >$CONFIG_STATUS || ac_write_fail=1 +rm -f conf$$subs.awk +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +_ACAWK +cat >>"\$tmp/subs1.awk" <<_ACAWK && + for (key in S) S_is_set[key] = 1 + FS = "" + +} +{ + line = $ 0 + nfields = split(line, field, "@") + substed = 0 + len = length(field[1]) + for (i = 2; i < nfields; i++) { + key = field[i] + keylen = length(key) + if (S_is_set[key]) { + value = S[key] + line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) + len += length(value) + length(field[++i]) + substed = 1 + } else + len += 1 + keylen + } + + print line +} + +_ACAWK +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then + sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" +else + cat +fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \ + || as_fn_error "could not setup config files machinery" "$LINENO" 5 +_ACEOF + +# VPATH may cause trouble with some makes, so we remove $(srcdir), +# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and +# trailing colons and then remove the whole line if VPATH becomes empty +# (actually we leave an empty line to preserve line numbers). +if test "x$srcdir" = x.; then + ac_vpsub='/^[ ]*VPATH[ ]*=/{ +s/:*\$(srcdir):*/:/ +s/:*\${srcdir}:*/:/ +s/:*@srcdir@:*/:/ +s/^\([^=]*=[ ]*\):*/\1/ +s/:*$// +s/^[^=]*=[ ]*$// +}' +fi + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +fi # test -n "$CONFIG_FILES" + +# Set up the scripts for CONFIG_HEADERS section. +# No need to generate them if there are no CONFIG_HEADERS. +# This happens for instance with `./config.status Makefile'. +if test -n "$CONFIG_HEADERS"; then +cat >"$tmp/defines.awk" <<\_ACAWK || +BEGIN { +_ACEOF + +# Transform confdefs.h into an awk script `defines.awk', embedded as +# here-document in config.status, that substitutes the proper values into +# config.h.in to produce config.h. + +# Create a delimiter string that does not exist in confdefs.h, to ease +# handling of long lines. +ac_delim='%!_!# ' +for ac_last_try in false false :; do + ac_t=`sed -n "/$ac_delim/p" confdefs.h` + if test -z "$ac_t"; then + break + elif $ac_last_try; then + as_fn_error "could not make $CONFIG_HEADERS" "$LINENO" 5 + else + ac_delim="$ac_delim!$ac_delim _$ac_delim!! " + fi +done + +# For the awk script, D is an array of macro values keyed by name, +# likewise P contains macro parameters if any. Preserve backslash +# newline sequences. + +ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* +sed -n ' +s/.\{148\}/&'"$ac_delim"'/g +t rset +:rset +s/^[ ]*#[ ]*define[ ][ ]*/ / +t def +d +:def +s/\\$// +t bsnl +s/["\\]/\\&/g +s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ +D["\1"]=" \3"/p +s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p +d +:bsnl +s/["\\]/\\&/g +s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ +D["\1"]=" \3\\\\\\n"\\/p +t cont +s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p +t cont +d +:cont +n +s/.\{148\}/&'"$ac_delim"'/g +t clear +:clear +s/\\$// +t bsnlc +s/["\\]/\\&/g; s/^/"/; s/$/"/p +d +:bsnlc +s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p +b cont +' >$CONFIG_STATUS || ac_write_fail=1 + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 + for (key in D) D_is_set[key] = 1 + FS = "" +} +/^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { + line = \$ 0 + split(line, arg, " ") + if (arg[1] == "#") { + defundef = arg[2] + mac1 = arg[3] + } else { + defundef = substr(arg[1], 2) + mac1 = arg[2] + } + split(mac1, mac2, "(") #) + macro = mac2[1] + prefix = substr(line, 1, index(line, defundef) - 1) + if (D_is_set[macro]) { + # Preserve the white space surrounding the "#". + print prefix "define", macro P[macro] D[macro] + next + } else { + # Replace #undef with comments. This is necessary, for example, + # in the case of _POSIX_SOURCE, which is predefined and required + # on some systems where configure will not decide to define it. + if (defundef == "undef") { + print "/*", prefix defundef, macro, "*/" + next + } + } +} +{ print } +_ACAWK +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 + as_fn_error "could not setup config headers machinery" "$LINENO" 5 +fi # test -n "$CONFIG_HEADERS" + + +eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :L $CONFIG_LINKS :C $CONFIG_COMMANDS" +shift +for ac_tag +do + case $ac_tag in + :[FHLC]) ac_mode=$ac_tag; continue;; + esac + case $ac_mode$ac_tag in + :[FHL]*:*);; + :L* | :C*:*) as_fn_error "invalid tag \`$ac_tag'" "$LINENO" 5;; + :[FH]-) ac_tag=-:-;; + :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; + esac + ac_save_IFS=$IFS + IFS=: + set x $ac_tag + IFS=$ac_save_IFS + shift + ac_file=$1 + shift + + case $ac_mode in + :L) ac_source=$1;; + :[FH]) + ac_file_inputs= + for ac_f + do + case $ac_f in + -) ac_f="$tmp/stdin";; + *) # Look for the file first in the build tree, then in the source tree + # (if the path is not absolute). The absolute path cannot be DOS-style, + # because $ac_f cannot contain `:'. + test -f "$ac_f" || + case $ac_f in + [\\/$]*) false;; + *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; + esac || + as_fn_error "cannot find input file: \`$ac_f'" "$LINENO" 5;; + esac + case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac + as_fn_append ac_file_inputs " '$ac_f'" + done + + # Let's still pretend it is `configure' which instantiates (i.e., don't + # use $as_me), people would be surprised to read: + # /* config.h. Generated by config.status. */ + configure_input='Generated from '` + $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' + `' by configure.' + if test x"$ac_file" != x-; then + configure_input="$ac_file. $configure_input" + { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 +$as_echo "$as_me: creating $ac_file" >&6;} + fi + # Neutralize special characters interpreted by sed in replacement strings. + case $configure_input in #( + *\&* | *\|* | *\\* ) + ac_sed_conf_input=`$as_echo "$configure_input" | + sed 's/[\\\\&|]/\\\\&/g'`;; #( + *) ac_sed_conf_input=$configure_input;; + esac + + case $ac_tag in + *:-:* | *:-) cat >"$tmp/stdin" \ + || as_fn_error "could not create $ac_file" "$LINENO" 5 ;; + esac + ;; + esac + + ac_dir=`$as_dirname -- "$ac_file" || +$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$ac_file" : 'X\(//\)[^/]' \| \ + X"$ac_file" : 'X\(//\)$' \| \ + X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$ac_file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + as_dir="$ac_dir"; as_fn_mkdir_p + ac_builddir=. + +case "$ac_dir" in +.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; +*) + ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` + # A ".." for each directory in $ac_dir_suffix. + ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` + case $ac_top_builddir_sub in + "") ac_top_builddir_sub=. ac_top_build_prefix= ;; + *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; + esac ;; +esac +ac_abs_top_builddir=$ac_pwd +ac_abs_builddir=$ac_pwd$ac_dir_suffix +# for backward compatibility: +ac_top_builddir=$ac_top_build_prefix + +case $srcdir in + .) # We are building in place. + ac_srcdir=. + ac_top_srcdir=$ac_top_builddir_sub + ac_abs_top_srcdir=$ac_pwd ;; + [\\/]* | ?:[\\/]* ) # Absolute name. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir + ac_abs_top_srcdir=$srcdir ;; + *) # Relative name. + ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_build_prefix$srcdir + ac_abs_top_srcdir=$ac_pwd/$srcdir ;; +esac +ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix + + + case $ac_mode in + :F) + # + # CONFIG_FILE + # + + case $INSTALL in + [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; + *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; + esac +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# If the template does not know about datarootdir, expand it. +# FIXME: This hack should be removed a few years after 2.60. +ac_datarootdir_hack=; ac_datarootdir_seen= +ac_sed_dataroot=' +/datarootdir/ { + p + q +} +/@datadir@/p +/@docdir@/p +/@infodir@/p +/@localedir@/p +/@mandir@/p' +case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in +*datarootdir*) ac_datarootdir_seen=yes;; +*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 +$as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 + ac_datarootdir_hack=' + s&@datadir@&$datadir&g + s&@docdir@&$docdir&g + s&@infodir@&$infodir&g + s&@localedir@&$localedir&g + s&@mandir@&$mandir&g + s&\\\${datarootdir}&$datarootdir&g' ;; +esac +_ACEOF + +# Neutralize VPATH when `$srcdir' = `.'. +# Shell code in configure.ac might set extrasub. +# FIXME: do we really want to maintain this feature? +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +ac_sed_extra="$ac_vpsub +$extrasub +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +:t +/@[a-zA-Z_][a-zA-Z_0-9]*@/!b +s|@configure_input@|$ac_sed_conf_input|;t t +s&@top_builddir@&$ac_top_builddir_sub&;t t +s&@top_build_prefix@&$ac_top_build_prefix&;t t +s&@srcdir@&$ac_srcdir&;t t +s&@abs_srcdir@&$ac_abs_srcdir&;t t +s&@top_srcdir@&$ac_top_srcdir&;t t +s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t +s&@builddir@&$ac_builddir&;t t +s&@abs_builddir@&$ac_abs_builddir&;t t +s&@abs_top_builddir@&$ac_abs_top_builddir&;t t +s&@INSTALL@&$ac_INSTALL&;t t +$ac_datarootdir_hack +" +eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \ + || as_fn_error "could not create $ac_file" "$LINENO" 5 + +test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && + { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && + { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } && + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' +which seems to be undefined. Please make sure it is defined." >&5 +$as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' +which seems to be undefined. Please make sure it is defined." >&2;} + + rm -f "$tmp/stdin" + case $ac_file in + -) cat "$tmp/out" && rm -f "$tmp/out";; + *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";; + esac \ + || as_fn_error "could not create $ac_file" "$LINENO" 5 + ;; + :H) + # + # CONFIG_HEADER + # + if test x"$ac_file" != x-; then + { + $as_echo "/* $configure_input */" \ + && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" + } >"$tmp/config.h" \ + || as_fn_error "could not create $ac_file" "$LINENO" 5 + if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then + { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 +$as_echo "$as_me: $ac_file is unchanged" >&6;} + else + rm -f "$ac_file" + mv "$tmp/config.h" "$ac_file" \ + || as_fn_error "could not create $ac_file" "$LINENO" 5 + fi + else + $as_echo "/* $configure_input */" \ + && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \ + || as_fn_error "could not create -" "$LINENO" 5 + fi + ;; + :L) + # + # CONFIG_LINK + # + + if test "$ac_source" = "$ac_file" && test "$srcdir" = '.'; then + : + else + # Prefer the file from the source tree if names are identical. + if test "$ac_source" = "$ac_file" || test ! -r "$ac_source"; then + ac_source=$srcdir/$ac_source + fi + + { $as_echo "$as_me:${as_lineno-$LINENO}: linking $ac_source to $ac_file" >&5 +$as_echo "$as_me: linking $ac_source to $ac_file" >&6;} + + if test ! -r "$ac_source"; then + as_fn_error "$ac_source: file not found" "$LINENO" 5 + fi + rm -f "$ac_file" + + # Try a relative symlink, then a hard link, then a copy. + case $srcdir in + [\\/$]* | ?:[\\/]* ) ac_rel_source=$ac_source ;; + *) ac_rel_source=$ac_top_build_prefix$ac_source ;; + esac + ln -s "$ac_rel_source" "$ac_file" 2>/dev/null || + ln "$ac_source" "$ac_file" 2>/dev/null || + cp -p "$ac_source" "$ac_file" || + as_fn_error "cannot link or copy $ac_source to $ac_file" "$LINENO" 5 + fi + ;; + :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 +$as_echo "$as_me: executing $ac_file commands" >&6;} + ;; + esac + + + case $ac_file$ac_mode in + "Makefile":C) echo "Merging Makefile.sim+Make-common.sim into Makefile ..." + rm -f Makesim1.tmp Makesim2.tmp Makefile + sed -n -e '/^## COMMON_PRE_/,/^## End COMMON_PRE_/ p' Makesim1.tmp + sed -n -e '/^## COMMON_POST_/,/^## End COMMON_POST_/ p' Makesim2.tmp + sed -e '/^## COMMON_PRE_/ r Makesim1.tmp' \ + -e '/^## COMMON_POST_/ r Makesim2.tmp' \ + Makefile + rm -f Makefile.sim Make-common.sim Makesim1.tmp Makesim2.tmp + ;; + "stamp-h":C) echo > stamp-h ;; + + esac +done # for ac_tag + + +as_fn_exit 0 +_ACEOF +ac_clean_files=$ac_clean_files_save + +test $ac_write_fail = 0 || + as_fn_error "write failure creating $CONFIG_STATUS" "$LINENO" 5 + + +# configure is writing to config.log, and then calls config.status. +# config.status does its own redirection, appending to config.log. +# Unfortunately, on DOS this fails, as config.log is still kept open +# by configure, so config.status won't be able to write to it; its +# output is simply discarded. So we exec the FD to /dev/null, +# effectively closing config.log, so it can be properly (re)opened and +# appended to by config.status. When coming back to configure, we +# need to make the FD available again. +if test "$no_create" != yes; then + ac_cs_success=: + ac_config_status_args= + test "$silent" = yes && + ac_config_status_args="$ac_config_status_args --quiet" + exec 5>/dev/null + $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false + exec 5>>config.log + # Use ||, not &&, to avoid exiting from the if with $? = 1, which + # would make configure fail if this is the last instruction. + $ac_cs_success || as_fn_exit $? +fi +if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 +$as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} +fi + + diff --git gdb-7.2a.orig/sim/msp430/configure.ac gdb-7.2a/sim/msp430/configure.ac new file mode 100644 index 0000000..59ce35c --- /dev/null +++ gdb-7.2a/sim/msp430/configure.ac @@ -0,0 +1,12 @@ +dnl Process this file with autoconf to produce a configure script. +AC_PREREQ(2.59)dnl +AC_INIT(Makefile.in) +AC_CONFIG_HEADER(config.h:config.in) + +sinclude(../common/aclocal.m4) + +# Bugs in autoconf 2.59 break the call to SIM_AC_COMMON, hack around +# it by inlining the macro's contents. +sinclude(../common/common.m4) + +SIM_AC_OUTPUT diff --git gdb-7.2a.orig/sim/msp430/interp.c gdb-7.2a/sim/msp430/interp.c new file mode 100644 index 0000000..5778c89 --- /dev/null +++ gdb-7.2a/sim/msp430/interp.c @@ -0,0 +1,1904 @@ +/* Simulator for msp430 TI MCU + Copyright (C) 2002 Free Software Foundation, Inc. + +This file is part of GDB, the GNU debugger. + +This program 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 2, or (at your option) +any later version. + +This program 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 this program; if not, write to the Free Software Foundation, Inc., +59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#include +#include +#include +#include "sysdep.h" +#if !defined(__MINGW32__) +#include +#endif +#include +#if !defined(__MINGW32__) +#include /* for byte ordering macros */ +#endif +#include "bfd.h" +#include "libiberty.h" +#include "gdb/callback.h" +#include "gdb/remote-sim.h" + +/* Mingw32 doesn't have definitions for the all the Unix signals, so we need + a fudge things by defining a few here */ +#if defined(__MINGW32__) +#define SIGQUIT 3 +#define SIGTRAP 5 +#define SIGBUS 7 +#endif + +#define FIRST_PSEUDO_REG 16 +#define MEM_SIZE 65536 + +struct msp430_alu +{ + short regs[FIRST_PSEUDO_REG]; + short saved_sr; + unsigned long cycles; + unsigned long insns; + unsigned long interrupts; + char mem[MEM_SIZE]; + char prog_name[1024]; + int flags; +#define CPUOFF 0x10 +#define OSCOFF 0x20 +#define SCG0 0x40 +#define SCG1 0x80 + int signal; +}; + + +static struct msp430_alu alu; + + +#define pc (alu.regs[0]) +#define sp (alu.regs[1]) +#define sr (alu.regs[2]) +#define cg1 (alu.regs[2]) +#define cg2 (alu.regs[3]) + + +#define SET_C sr |= 0x0001 +#define SET_Z sr |= 0x0002 +#define SET_N sr |= 0x0004 +#define SET_V sr |= 0x0100 + +#define CLR_C sr &= ~0x0001 +#define CLR_Z sr &= ~0x0002 +#define CLR_N sr &= ~0x0004 +#define CLR_V sr &= ~0x0100 + +#define SR_MASK (0x0100|0x0004|0x0002|0x0001) + + +#define C ((unsigned long)(sr & 0x0001)>>0) +#define Z ((unsigned long)(sr & 0x0002)>>1) +#define N ((unsigned long)(sr & 0x0004)>>2) +#define V ((unsigned long)(sr & 0x0100)>>8) + + + +enum msp430_modes +{ + REGISTER, + INDEXED, /* x(Rn) */ + SYMBOLIC, /* addr: (pc+x) (mind pc) */ + ABSOLUTE, /* &addr (mind r2) */ + INDERECT, /* @Rn */ + INDERECTINC, /* @Rn+ */ + IMMEDIATE /* #XXXX (@pc+) */ +}; + +struct msp430_op_mode +{ + int rs; + int rd; + enum msp430_modes ms; + enum msp430_modes md; + char as; + char ad; + char byte; +}; + + +struct msp430_ops +{ + int d_reg; + short src; + short dst; + short insn; + short dval; + char byte; +}; + + +/******************************************************************/ +/*********** HARDWARE MULTIPLIER **********************************/ + +short msp430_fetch_integer (unsigned int loc); + + +#define __MPY 0x130 +#define __MPYS 0x132 +#define __MAC 0x134 +#define __MACS 0x136 +#define __OP2 0x138 +#define __RESLO 0x13a +#define __RESHI 0x13c +#define __SUMEXT 0x13e + +static struct __mpl +{ + int op1; + int op2; + int mode; + union + { + unsigned int u; + int s; + } acc; + int res; + int len; + int sumext; +} mpl; + +void +msp430_multiplier (unsigned int loc, int len) +{ + int sres; + unsigned int ures; + unsigned long long ull; + long long sll; + + if (loc == __OP2) /* perform an action */ + { + mpl.op2 = (int) msp430_fetch_integer (loc & 0xffff); + if (mpl.mode == __MPYS || mpl.mode == __MACS) + { + if (len == 1 && (mpl.op2 & 0x80)) + mpl.op2 = -((~mpl.op2 + 1) & 0xff); + else if (len == 2 && (mpl.op2 & 0x8000)) + mpl.op2 = -((~mpl.op2 + 1) & 0xffff); + } + else + { + if (len == 1) + mpl.op2 &= 0xff; + else if (len == 2) + mpl.op2 &= 0xffff; + } + + switch (mpl.mode) + { + case __MPY: + mpl.acc.u = (unsigned) mpl.op2 * (unsigned) mpl.op1; + mpl.sumext = 0; + break; + + case __MPYS: + mpl.acc.s = mpl.op2 * mpl.op1; + if ((mpl.op1 < 0 && mpl.op2 >= 0) || (mpl.op1 >= 0 && mpl.op2 < 0)) + mpl.sumext = 0xffff; + else + mpl.sumext = 0; + break; + + case __MAC: + + ures = (unsigned) mpl.op2 * (unsigned) mpl.op1; + ull = (unsigned long long) mpl.acc.u + ures; + mpl.acc.u = ull & 0xfffffffful; + + if (ull > 0x00000000ffffffffull) + mpl.sumext = 1; + else + mpl.sumext = 0; + + break; + + case __MACS: + sres = mpl.op2 * mpl.op1; + sll = (long long) mpl.acc.s + sres; + mpl.acc.s = sll & 0xfffffffful; + + if (sll > 0x000000007fffffffll) + mpl.sumext = 0xffff; + else + mpl.sumext = 0; + + break; + + default: + break; + } + + /**/} + else if (loc == __RESLO) + { + mpl.acc.u = (mpl.acc.u & 0xffff0000) | + (0xfffful & ((int) msp430_fetch_integer (loc & 0xffff))); + } + else if (loc == __RESHI) + { + mpl.acc.u = (mpl.acc.u & 0xffff) | + (((int) msp430_fetch_integer (loc & 0xffff)) << 16); + } + else if (loc == __SUMEXT) + { + return; /* read only location */ + } + else + { + mpl.mode = loc; + mpl.op1 = (int) msp430_fetch_integer (loc & 0xffff); + + if (mpl.mode == __MPYS || mpl.mode == __MACS) + { + if (len == 1 && (mpl.op1 & 0x80)) + mpl.op1 = -((~mpl.op1 + 1) & 0xff); + else if (len == 2 && (mpl.op1 & 0x8000)) + mpl.op1 = -((~mpl.op1 + 1) & 0xffff); + } + else + { + if (len == 1) + mpl.op1 &= 0xff; + else if (len == 2) + mpl.op1 &= 0xffff; + } + + /* return, cause this will write initial locs only. */ + return; + } + + /* finaly stuff the results address */ + + alu.mem[__SUMEXT] = mpl.sumext & 0xff; + alu.mem[__SUMEXT + 1] = (mpl.sumext >> 8) & 0xff; + + alu.mem[__RESLO] = mpl.acc.u & 0xff; + alu.mem[__RESLO + 1] = (mpl.acc.u >> 8) & 0xff; + alu.mem[__RESHI] = (mpl.acc.u >> 16) & 0xff; + alu.mem[__RESHI + 1] = (mpl.acc.u >> 24) & 0xff; + +} + + + +/******************************************************************/ + + +void +msp430_set_pc (unsigned int x) +{ + pc = x; +} + +unsigned int +msp430_get_pc () +{ + return (unsigned int) pc; +} + + +struct msp430_op_mode +msp430_get_op_mode_single (short insn) +{ + struct msp430_op_mode m; + int s_reg; + int d_reg; + + alu.saved_sr = sr; + + + m.as = (insn >> 4) & 3; + m.byte = (insn >> 6) & 1; + m.rd = m.rs = d_reg = s_reg = insn & 0xf; + + switch (m.as) + { + case 0: + /* cg1 - reg.mode */ + cg2 = 0; + m.ms = REGISTER; + break; + + case 1: + /* cg1 - abs.addr.mode */ + + if (s_reg == 2) + m.ms = ABSOLUTE; /* &addr */ + else if (s_reg == 0) + m.ms = SYMBOLIC; /* addr (pc + x) */ + else if (s_reg == 3) + m.ms = REGISTER; + else + m.ms = INDEXED; /* X(Rn) */ + + cg2 = 1; + break; + + case 2: + m.ms = INDERECT; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 4; + cg2 = 2; + break; + + case 3: + if (s_reg == 0) + m.ms = IMMEDIATE; + else + m.ms = INDERECTINC; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 8; + cg2 = -1; + break; + } + + return m; +} + + +struct msp430_op_mode +msp430_get_op_mode_double (short insn) +{ + struct msp430_op_mode m; + int s_reg; + int d_reg; + + alu.saved_sr = sr; + + + m.as = (insn >> 4) & 3; + m.ad = (insn >> 7) & 1; + m.byte = (insn >> 6) & 1; + s_reg = (insn >> 8) & 0xf; + d_reg = insn & 0xf; + + m.rs = s_reg; + m.rd = d_reg; + + if (m.ad == 0) + m.md = REGISTER; + else + { + if (d_reg == 2) + m.md = ABSOLUTE; /* &addr */ + else if (d_reg == 0) + m.md = SYMBOLIC; /* addr (pc + x) */ + else + m.md = INDEXED; /* X(Rn) */ + } + + switch (m.as) + { + case 0: + /* cg1 - reg.mode */ + cg2 = 0; + m.ms = REGISTER; + break; + + case 1: + /* cg1 - abs.addr.mode */ + + if (s_reg == 2) + m.ms = ABSOLUTE; /* &addr */ + else if (s_reg == 0) + m.ms = SYMBOLIC; /* addr (pc + x) */ + else if (s_reg == 3) + m.ms = REGISTER; + else + m.ms = INDEXED; /* X(Rn) */ + + cg2 = 1; + break; + + case 2: + m.ms = INDERECT; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 4; + cg2 = 2; + break; + + case 3: + if (s_reg == 0) + m.ms = IMMEDIATE; + else + m.ms = INDERECTINC; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 8; + cg2 = -1; + break; + } + + return m; +} + +static char wpr[0xffff]; /* catch read */ +static char wpw[0xffff]; /* catch write */ + + +short +msp430_fetch_integer (unsigned int loc) +{ + char *m = &alu.mem[0xffff & loc]; + short res; + + if (wpr[0xffff & loc]) + alu.signal = SIGTRAP; + + res = (0xff & (*m)) | (short) (*(m + 1)) << 8; + return res; +} + + +void +msp430_write_integer (int loc, int val, int len) +{ + int sloc = loc; + int slen = len; + + if (!len) + return; + + if (loc & 1 && len != 1) + { + alu.signal = SIGBUS; + return; + } + + while (len--) + { + alu.mem[0xffff & loc] = 0xff & val; + if (wpw[0xffff & loc]) + alu.signal = SIGTRAP; + loc++; + val >>= 8; + } + + if (sloc >= 0x0130 && sloc <= 0x013f) + msp430_multiplier (sloc, slen); +} + +int +msp430_lookup_symbol (char *symname) +{ + int symaddr = 0; + fprintf (stderr, "Sorry, address only at the moment\n"); + return (symaddr); +} + + + +void +msp430_set_watchpoint (char *mode, char *name) +{ + int addr = 0; + char *endptr; + + if (strcmp (name, "all")) + addr = -1; + /* is it an address ? */ + addr = strtol (name, &endptr, 0); + + /* nope - name */ + if (*endptr != '\n' && *endptr != '\t' && *endptr != ' ' && *endptr != 0) + { + addr = msp430_lookup_symbol (name); + } + + if (!addr || (addr < 0 && addr != -1) || addr > 0xffff) + { + fprintf (stderr, "Error: canont find '%s' symbol\n", name); + return; + } + + switch (*mode) + { + case 'r': + wpr[addr] = 1; + break; + case 'w': + wpw[addr] = 1; + break; + case 'a': + wpw[addr] = 1; + wpr[addr] = 1; + break; + case 'd': + wpw[addr] = 0; + wpr[addr] = 0; + break; + case 'c': + if (addr == -1) + { + memset (wpw, 0, sizeof (wpw)); + memset (wpr, 0, sizeof (wpr)); + } + + default: + fprintf (stderr, "Error: Invalid mode: %s\n", mode); + return; + } + + if (*mode != 'd') + { + fprintf (stderr, "Add symbol %s at 0x%04x to watchpoins list\n", name, + addr); + return; + } + else + { + fprintf (stderr, "Remove watchpoint at 0x%04x\n", addr); + } + + return; +} + + +struct msp430_ops +msp430_double_operands (short insn) +{ + short src_val = 0; + struct msp430_op_mode m = msp430_get_op_mode_double (insn); + unsigned int tmp; + int len = 0; + int cycles = 0; + struct msp430_ops ret; + + ret.byte = m.byte; + ret.d_reg = -1; + + switch (m.ms) + { + case REGISTER: + src_val = alu.regs[m.rs]; + cycles += 1; + break; + case INDEXED: + len += 1; + cycles += 3; + pc += 2; + tmp = msp430_fetch_integer (pc) + alu.regs[m.rs]; + src_val = msp430_fetch_integer (tmp); + break; + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 3; + tmp = msp430_fetch_integer (pc) + pc; + src_val = msp430_fetch_integer (tmp); + break; + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 3; + tmp = msp430_fetch_integer (pc); + src_val = msp430_fetch_integer (tmp); + break; + case INDERECT: + cycles += 2; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + break; + case INDERECTINC: + cycles += 2; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + if (m.rs != 1 && m.rs != 0) + alu.regs[m.rs] += m.byte ? 1 : 2; + else + alu.regs[m.rs] += 2; + break; + case IMMEDIATE: + cycles += 2; + pc += 2; + src_val = msp430_fetch_integer (pc); + break; + } + + ret.src = src_val; + + switch (m.md) + { + case REGISTER: + cycles += (m.ms == REGISTER + || m.ms == INDERECT + || m.ms == INDERECTINC + || m.ms == IMMEDIATE) ? ((m.rd) ? 0 : 1) : 0; + ret.dval = alu.regs[m.rd]; + ret.d_reg = m.rd; + break; + + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc); + ret.dval = msp430_fetch_integer (tmp); + break; + + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc) + pc; + ret.dval = msp430_fetch_integer (tmp); + break; + + case INDEXED: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc) + alu.regs[m.rd]; + ret.dval = msp430_fetch_integer (tmp); + break; + default: + alu.signal = SIGILL; + } + + pc += 2; + sr = alu.saved_sr; + + alu.cycles += cycles; + + return ret; +} + +struct msp430_ops +msp430_single_operands (short insn) +{ + short src_val = 0; + struct msp430_op_mode m = msp430_get_op_mode_single (insn); + unsigned int tmp; + int len = 0; + int cycles = 0; + struct msp430_ops ret; + int i_push = 0, i_call = 0; + + ret.byte = m.byte; + ret.d_reg = -1; + + if ((insn & ~0x7f) == 0x1280) + i_call = 1; + if ((insn & ~0x7f) == 0x1200) + i_push = 1; + + switch (m.ms) + { + case REGISTER: + src_val = alu.regs[m.rs]; + ret.d_reg = m.rs; + cycles += 1 + (i_push ? 2 : 0) + (i_call ? 3 : 0); + break; + case INDEXED: + len += 1; + cycles += 4 + (i_push ? 1 : 0) + (i_call ? 1 : 0); + pc += 2; + ret.dst = tmp = msp430_fetch_integer (pc) + alu.regs[m.rs]; + src_val = msp430_fetch_integer (tmp); + break; + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 4 + (i_push ? 1 : 0) + (i_call ? 1 : 0); + ret.dst = tmp = msp430_fetch_integer (pc) + pc; + src_val = msp430_fetch_integer (tmp); + break; + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 4 + (i_push ? 1 : 0) + (i_call ? 1 : 0); + ret.dst = tmp = msp430_fetch_integer (pc); + src_val = msp430_fetch_integer (tmp); + break; + case INDERECT: + cycles += 3 + (i_push ? 1 : 0) + (i_call ? 1 : 0); + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + break; + case INDERECTINC: + cycles += 3 + (i_push ? 1 : 0) + (i_call ? 2 : 0); + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + if (m.rs != 1 && m.rs != 0) + alu.regs[m.rs] += m.byte ? 1 : 2; + else + alu.regs[m.rs] += 2; + break; + case IMMEDIATE: + cycles += 3 + (i_push ? 1 : 0) + (i_call ? 2 : 0); + pc += 2; + src_val = msp430_fetch_integer (pc); + break; + } + + pc += 2; + ret.src = ret.dval = src_val; + sr = alu.saved_sr; + alu.cycles += cycles; + return ret; +} + + +short +msp430_offset (short insn) +{ + short res = insn & 0x3ff; + + if (res & 0x200) + res |= ~0x3ff; + + alu.cycles += 2; + + return res << 1; +} + +void +msp430_check_bp (unsigned int l) +{ + static unsigned int last; + + last = l; +} + + +/* c: ZNCV */ + +void +msp430_set_status (int r, char b, char *c) +{ + int tmp = b ? (r & 0xff) : (r & 0xffff); + + /* Zero flag: */ + if (*c == 'x') + { + if (!tmp) + SET_Z; + else + CLR_Z; + } + else if (*c == '0') + { + CLR_Z; + } + else if (*c == '1') + { + SET_Z; + } + + c++; + /* negative flag */ + if (*c == 'x') + { + if (tmp & (b ? 0x80 : 0x8000)) + SET_N; + else + CLR_N; + } + else if (*c == '0') + { + CLR_N; + } + else if (*c == '1') + { + SET_N; + } + + c++; + /* carry flag: */ + if (*c == 'x') + { + if (r < 0) + SET_C; + else if (b && (r & 0xffffff00ul)) + SET_C; + else if (!b && (r & 0xffff0000ul)) + SET_C; + else + CLR_C; + } + else if (*c == '0') + { + CLR_C; + } + else if (*c == '1') + { + SET_C; + } + + c++; + /* overflow flag: */ + if (*c == '0') + { + CLR_V; + } + else if (*c == '1') + { + SET_V; + } + + /* check low power modes */ + if (sr & 0x00f0) + { + alu.signal = SIGQUIT; + } +} + +#undef AND + +#define MOV 0x4 +#define ADD 0x5 +#define ADDC 0x6 +#define SUBC 0x7 +#define SUB 0x8 +#define CMP 0x9 +#define DADD 0xa +#define BIT 0xb +#define BIC 0xc +#define BIS 0xd +#define XOR 0xe +#define AND 0xf + +#define JMP 0x3c +#define JL 0x38 +#define JGE 0x34 +#define JN 0x30 +#define JC 0x2c +#define JNC 0x28 +#define JZ 0x24 +#define JNZ 0x20 + +#define SXT 0x118 +#define RETI 0x130 +#define CALL 0x128 +#define PUSH 0x120 +#define RRA 0x110 +#define SWPB 0x108 +#define RRC 0x100 + +unsigned int +extract_opcode (short insn) +{ + unsigned int tmp; + + /* debug trap */ + if (insn == 1) + return 1; + + tmp = 0x0000f000ul & (int) insn; + tmp >>= 12; + + /* double operands */ + if (tmp > 3) + return tmp; + + /* jumps */ + if (tmp == 3 || tmp == 2) + return ((unsigned int) insn >> 8) & ~3; + + /* single operands or TRAP */ + return ((unsigned int) insn >> 4) & ~7; +} + + +/* DO NOT PUT BRACES AROUND CAUSE OF SOME '~' OPERATIONS!!! */ +#define READ_SRC(ss) ss.src & (ss.byte?0xff:0xffff) +#define READ_DST(ss) (ss.dval & (ss.byte?0xff:0xffff)) + +#define WRITE_BACK(ss,x) \ +do { \ +if (ss.d_reg != -1) \ +{ \ +alu.regs[ss.d_reg] = tmp & (ss.byte? 0xff : 0xffff); \ +} \ +else \ +msp430_write_integer(ss.dst,tmp, (ss.byte?1:2) ); \ +} while(0) + + +#define MASK_SR(x) \ +do { if (x.d_reg != 2) alu.regs[2] &= SR_MASK; } while(0) + + +void +flow () +{ + short insn; + unsigned int opcode; + struct msp430_ops srp; + struct msp430_ops drp; + int tmp; + + do + { + tmp = 0; + + insn = msp430_fetch_integer (pc); + opcode = extract_opcode (insn); + + if (!opcode) + { + alu.signal = SIGTRAP; + return; + } + else if (opcode == 1) /* debug trap */ + { + alu.signal = SIGTRAP; + pc += 2; + return; + } + else if (opcode < 16) + { + drp = msp430_double_operands (insn); + } + else if (opcode < 0x3d) + { + ; + ; /* jump insn */ + } + else if (opcode & 0x100) + { + if ((opcode != CALL) && (opcode != PUSH)) + srp = msp430_single_operands (insn); + } + + alu.insns += 1; + + switch (opcode) + { + default: + fprintf (stderr, "Unknown code 0x%04x\n", insn); + + /* single operands */ + case RRC: + tmp = (C << (srp.byte ? 8 : 16)) | (READ_SRC (srp)); + tmp >>= 1; + WRITE_BACK (srp, tmp); + MASK_SR (srp); + CLR_C; + if (srp.src & 1) + SET_C; + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case SWPB: + tmp = ((srp.src << 8) & 0xff00) | ((srp.src >> 8) & 0x00ff); + WRITE_BACK (srp, tmp); + MASK_SR (srp); + break; + case RRA: + tmp = READ_SRC (srp); + tmp = + (tmp & (srp.byte ? 0x80 : 0x8000)) | ((tmp >> 1) & + (srp.byte ? 0x7f : 0x7fff)); + WRITE_BACK (srp, tmp); + MASK_SR (srp); + CLR_C; + if (srp.src & 1) + SET_C; + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case SXT: + tmp = srp.src & 0xff; + if (tmp & 0x80) + tmp |= 0xff00; + WRITE_BACK (srp, tmp); + MASK_SR (srp); + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case PUSH: + sp -= 2; + srp = msp430_single_operands (insn); + tmp = READ_SRC (srp); + msp430_write_integer (sp, tmp, 2); + break; + case CALL: + sp -= 2; + srp = msp430_single_operands (insn); + tmp = READ_SRC (srp); + msp430_write_integer (sp, pc, 2); + pc = tmp; + break; + case RETI: + sr = msp430_fetch_integer (sp); + sp += 2; + msp430_set_status (0, 0, "----"); + pc = msp430_fetch_integer (sp); + sp += 2; + break; + + /* double operand */ + + case DADD: + { + unsigned int imc = C; + unsigned int ss = drp.src; + unsigned int dd = drp.dval; + unsigned int rr = 0; + int i = 0; + tmp = 0; + + for (i = 0; i < (drp.byte ? 2 : 4); i++) + { + rr = (ss & 0xf) + (dd & 0xf) + imc; + + if (rr >= 10) + { + rr -= 10; + imc = 1; + } + else + imc = 0; + + ss >>= 4; + dd >>= 4; + tmp |= rr << (i * 4); + } + + WRITE_BACK (drp, tmp); + msp430_set_status (tmp, drp.byte, "xx--"); + if (imc) + SET_C; + else + CLR_C; + } + break; + case MOV: + tmp = READ_SRC (drp); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + msp430_set_status (0, 0, "----"); + break; + case ADD: + case ADDC: + tmp = + (READ_SRC (drp)) + READ_DST (drp) + ((opcode == ADDC) ? C : 0); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + { + int b = drp.byte ? 0x80 : 0x8000; + int f1, f2; + int s = READ_SRC (drp), d = READ_DST (drp), r = tmp; + + f1 = ((d & b) == 0) && ((s & b) == 0) && (r & b); + f2 = (d & b) && (s & b) && ((r & b) == 0); + + if (f1 || f2) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case SUB: + case SUBC: + tmp = + (~READ_SRC (drp)) + READ_DST (drp) + ((opcode == SUBC) ? C : 1); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + { + int b = drp.byte ? 0x80 : 0x8000; + int f1, f2; + int s = READ_SRC (drp), d = READ_DST (drp), r = tmp; + + f1 = ((d & b) == 0) && (s & b) && (r & b); + f2 = (d & b) && ((s & b) == 0) && ((r & b) == 0); + + if (f1 || f2) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case CMP: + tmp = (~READ_SRC (drp)) + READ_DST (drp) + 1; + MASK_SR (drp); + { + int b = drp.byte ? 0x80 : 0x8000; + int f1, f2; + int s = READ_SRC (drp), d = READ_DST (drp), r = tmp; + + f1 = ((d & b) == 0) && (s & b) && (r & b); + f2 = (d & b) && ((s & b) == 0) && ((r & b) == 0); + + if (f1 || f2) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case BIT: + tmp = (READ_SRC (drp)) & READ_DST (drp); + MASK_SR (drp); + msp430_set_status (tmp, drp.byte, "xx-0"); + if (tmp) + SET_C; + else + CLR_C; + break; + case BIC: + tmp = (~READ_SRC (drp)) & READ_DST (drp); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + msp430_set_status (tmp, drp.byte, "----"); + break; + case BIS: + tmp = (READ_SRC (drp)) | READ_DST (drp); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + msp430_set_status (tmp, drp.byte, "----"); + break; + case XOR: + tmp = (READ_SRC (drp)) ^ READ_DST (drp); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + msp430_set_status (tmp, drp.byte, "xx--"); + if (tmp) + SET_C; + else + CLR_C; + { + int b = drp.byte ? 0x80 : 0x8000; + int f; + f = ((READ_SRC (drp)) & b) && (READ_DST (drp) & b); + if (f) + SET_V; + else + CLR_V; + } + break; + case AND: + tmp = (READ_SRC (drp)) & READ_DST (drp); + WRITE_BACK (drp, tmp); + MASK_SR (drp); + msp430_set_status (tmp, drp.byte, "xx-0"); + if (tmp) + SET_C; + else + CLR_C; + break; + + + /* jumps */ + case JNZ: + tmp = msp430_offset (insn); + pc += 2 + ((!Z) ? tmp : 0); + break; + case JZ: + tmp = msp430_offset (insn); + pc += 2 + ((Z) ? tmp : 0); + break; + case JC: + tmp = msp430_offset (insn); + pc += 2 + ((C) ? tmp : 0); + break; + case JNC: + tmp = msp430_offset (insn); + pc += 2 + ((!C) ? tmp : 0); + break; + case JN: + tmp = msp430_offset (insn); + pc += 2 + ((N) ? tmp : 0); + break; + case JGE: + tmp = msp430_offset (insn); + pc += 2 + ((!(N ^ V)) ? tmp : 0); + break; + case JL: + tmp = msp430_offset (insn); + pc += 2 + ((N ^ V) ? tmp : 0); + break; + case JMP: + pc += msp430_offset (insn) + 2; + break; + } /* case */ + + } + while (alu.signal == 0); +} + + +int +msp430_interrupt (int vector) +{ + int ivec; + + if (vector < 0xffe0 || vector > 0xfffful || (vector & 1)) + return -1; + + /* get ISR address */ + ivec = msp430_fetch_integer (vector); + + /* push pc */ + sp -= 2; + msp430_write_integer (sp, pc, 2); + /* push sr */ + sp -= 2; + msp430_write_integer (sp, sr, 2); + + /* load pc */ + pc = ivec; + + alu.interrupts += 1; + + return 0; +} + + + +#ifndef NUM_ELEM +#define NUM_ELEM(A) (sizeof (A) / sizeof (A)[0]) +#endif + + +typedef short int word; +typedef unsigned short int uword; + +static unsigned long heap_ptr = 0; +host_callback *callback; + + +static int issue_messages = 10; + +unsigned long +msp430_extract_unsigned_integer (addr, len) + unsigned char *addr; + int len; +{ + unsigned long retval = 0, i = 0; + unsigned char *p; + unsigned char *startaddr = (unsigned char *) addr; + + if (len > (int) sizeof (unsigned long)) + printf + ("That operation is not available on integers of more than %d bytes.", + sizeof (unsigned long)); + /* msp430 is a little-endian beastie */ + p = startaddr; + while (len) + { + retval |= (*p) << (i * 8); + p++; + i++; + len--; + } + return retval; +} + +void +sim_size (power) + int power; +{ + fprintf (stderr, "Simulator required size id %ld\n", (1l << power)); +} + +static void +init_pointers () +{ +} + + + + + +void +msp430_store_unsigned_integer (addr, len, val) + unsigned char *addr; + int len; + unsigned long val; +{ + unsigned char *p; + unsigned char *startaddr = (unsigned char *) addr; + unsigned char *endaddr = startaddr + len; + + for (p = startaddr; p < endaddr;) + { + *p++ = val & 0xff; + val >>= 8; + } +} + +#define MEM_SIZE_FLOOR 64 + +static void +set_initial_gprs () +{ + int i; + + for (i = 0; i < 16; i++) + alu.regs[i] = 0; + alu.cycles = 0; + alu.insns = 0; + alu.interrupts = 0; + memset (wpr, 0, sizeof (wpr)); + memset (wpw, 0, sizeof (wpw)); +} + +static void +interrupt () +{ + alu.signal = SIGINT; +} + +/* Functions so that trapped open/close don't interfere with the + parent's functions. We say that we can't close the descriptors + that we didn't open. exit() and cleanup() get in trouble here, + to some extent. That's the price of emulation. */ + + +static int tracing = 0; + +void +sim_resume (sd, step, siggnal) + SIM_DESC sd; + int step, siggnal; +{ + void (*sigsave) (); + + // fprintf(stderr,"%s\n", step?"Step flow":"Free run"); + sigsave = signal (SIGINT, interrupt); + alu.signal = step ? SIGTRAP : 0; + flow (); + signal (SIGINT, sigsave); +} + + +int +sim_write (sd, addr, buffer, size) + SIM_DESC sd; + SIM_ADDR addr; + const unsigned char *buffer; + int size; +{ + memcpy (&alu.mem[(addr & 0xfffful)], buffer, size); + return size; +} + +int +sim_read (sd, addr, buffer, size) + SIM_DESC sd; + SIM_ADDR addr; + unsigned char *buffer; + int size; +{ + memcpy (buffer, &alu.mem[(addr & 0xfffful)], size); + return size; +} + + +int +sim_store_register (sd, rn, memory, length) + SIM_DESC sd; + int rn; + unsigned char *memory; + int length; +{ + init_pointers (); + + if (rn < 16 && rn >= 0) + { + if (length == 2) + { + long ival; + + /* misalignment safe */ + ival = msp430_extract_unsigned_integer (memory, 2); + alu.regs[rn] = ival; + return 2; + } + else if (length == 1) + { + long ival; + ival = msp430_extract_unsigned_integer (memory, 2); + alu.regs[rn] = ival & 0xff; + return 1; + } + } + else + return 0; + + return 0; +} + +int +sim_fetch_register (sd, rn, memory, length) + SIM_DESC sd; + int rn; + unsigned char *memory; + int length; +{ + init_pointers (); + + if (rn < 16 && rn >= 0) + { + if (length == 2) + { + long ival; + + ival = alu.regs[rn]; + /* misalignment-safe */ + msp430_store_unsigned_integer (memory, 2, ival); + return 2; + } + else if (length == 1) + { + long ival = alu.regs[rn]; + msp430_store_unsigned_integer (memory, 1, ival); + return 1; + } + } + else + return 0; + + return 0; +} + + +int +sim_trace (sd) + SIM_DESC sd; +{ + tracing = 1; + + sim_resume (sd, 0, 0); + + tracing = 0; + + return 1; +} + + + +static int stop_prog_addr; + +void +sim_stop_reason (sd, reason, sigrc) + SIM_DESC sd; + enum sim_stop *reason; + int *sigrc; +{ + if (alu.signal == SIGQUIT) + { + char *name; + int status = 0; + + if (stop_prog_addr && stop_prog_addr == (pc & 0xfffful)) + { + *sigrc = 0; + *reason = sim_exited; + } + else + { + *sigrc = alu.signal; + *reason = sim_stopped; + } + } + else + { + *reason = sim_stopped; + *sigrc = alu.signal; + } +} + + +int +sim_stop (sd) + SIM_DESC sd; +{ + return 1; +} + + +void +sim_info (sd, verbose) + SIM_DESC sd; + int verbose; +{ + + callback->printf_filtered (callback, "\n\n# instructions executed %10d\n", + alu.insns); + callback->printf_filtered (callback, "# cycles %10d\n", + alu.cycles); + callback->printf_filtered (callback, "# Interrupts %10d\n", + alu.interrupts); + +} + +#define LONG(x) (((x)[0]<<24)|((x)[1]<<16)|((x)[2]<<8)|(x)[3]) +#define SHORT(x) (((x)[0]<<8)|(x)[1]) + +SIM_DESC +sim_open (kind, cb, abfd, argv) + SIM_OPEN_KIND kind; + host_callback *cb; + struct bfd *abfd; + char **argv; +{ + char *myname; + + myname = argv[0]; + callback = cb; + + if (kind == SIM_OPEN_STANDALONE) + issue_messages = 1; + + /* Discard and reacquire memory -- start with a clean slate. */ + + set_initial_gprs (); /* Reset the GPR registers. */ + + /* Fudge our descriptor for now. */ + return (SIM_DESC) 1; +} + +void +sim_close (sd, quitting) + SIM_DESC sd; + int quitting; +{ + /* nothing to do */ +} + +static SIM_OPEN_KIND sim_kind; + + +SIM_RC +sim_load (sd, prog, abfd, from_tty) + SIM_DESC sd; + char *prog; + bfd *abfd; + int from_tty; +{ + /* Do the right thing for ELF executables; this turns out to be + just about the right thing for any object format that: + - we crack using BFD routines + - follows the traditional UNIX text/data/bss layout + - calls the bss section ".bss". */ + + extern bfd *sim_load_file (); /* ??? Don't know where this should live. */ + bfd *prog_bfd; + char *myname = prog; + + strcpy (alu.prog_name, prog); + + { + bfd *handle; + asection *s_bss; + + handle = bfd_openr (prog, 0); /* could be "msp430" */ + + + if (!handle) + { + printf ("``%s'' could not be opened.\n", prog); + return SIM_RC_FAIL; + } + + /* Makes sure that we have an object file, also cleans gets the + section headers in place. */ + if (!bfd_check_format (handle, bfd_object)) + { + /* wasn't an object file */ + bfd_close (handle); + printf ("``%s'' is not appropriate object file.\n", prog); + return SIM_RC_FAIL; + } + + /* Look for that bss section. */ + s_bss = bfd_get_section_by_name (handle, ".bss"); + + if (!s_bss) + { + printf ("``%s'' has no bss section.\n", prog); + return SIM_RC_FAIL; + } + + /* Appropriately paranoid would check that we have + a traditional text/data/bss ordering within memory. */ + + /* figure the end of the bss section */ +#if 0 + printf ("bss section at 0x%08x for 0x%08x bytes\n", + (unsigned long) s_bss->vma, (unsigned long) s_bss->_cooked_size); +#endif +#if 0 + heap_ptr = + (unsigned long) s_bss->vma + (unsigned long) s_bss->_cooked_size; +#endif + /* Clean up after ourselves. */ + bfd_close (handle); + + /* XXX: do we need to free the s_bss and handle structures? */ + } + + /* from sh -- dac */ + prog_bfd = sim_load_file (sd, myname, callback, prog, abfd, + sim_kind == SIM_OPEN_DEBUG, 0, sim_write); + if (prog_bfd == NULL) + return SIM_RC_FAIL; + + if (abfd == NULL) + bfd_close (prog_bfd); + + return SIM_RC_OK; +} + +int get_stop_addr PARAMS ((struct bfd *)); + +SIM_RC +sim_create_inferior (sd, prog_bfd, argv, env) + SIM_DESC sd; + struct bfd *prog_bfd; + char **argv; + char **env; +{ + unsigned short ivec; + unsigned char tmp; + + asection *s_vectors; + asection *s_data; + + s_vectors = bfd_get_section_by_name (prog_bfd, ".vectors"); + bfd_get_section_contents (prog_bfd, s_vectors, &tmp, 30, 1); + ivec = tmp; + bfd_get_section_contents (prog_bfd, s_vectors, &tmp, 31, 1); + ivec |= (unsigned short) tmp << 8; + + /* we need to do this cause gdb somehow + puts ".data" into .bss */ + s_data = bfd_get_section_by_name (prog_bfd, ".data"); + + if (s_data->flags & SEC_LOAD) + { + char *buffer; +#if 0 + // no longer available + bfd_size_type size = bfd_get_section_size_before_reloc (s_data); +#endif + bfd_size_type size = bfd_get_section_size (s_data); + bfd_vma lma; + + buffer = malloc (size); + + /* need a rom image !!! */ + lma = bfd_section_lma (prog_bfd, s_data); + bfd_get_section_contents (prog_bfd, s_data, buffer, 0, size); + sim_write (sd, lma, buffer, size); + } + + pc = ivec; + + stop_prog_addr = get_stop_addr (prog_bfd); + + return SIM_RC_OK; +} + +void +sim_kill (sd) + SIM_DESC sd; +{ + /* nothing to do */ +} + +void +sim_do_command (sd, cmd) + SIM_DESC sd; + char *cmd; +{ + FILE *dumpfile; + + if (cmd != NULL) + { + char **simargv = buildargv (cmd); + + if (strcmp (simargv[0], "watch") == 0) + { + if ((simargv[1] == NULL) || (simargv[2] == NULL)) + { + fprintf (stderr, "Error: missing argument to watch cmd.\n"); + return; + } + msp430_set_watchpoint (simargv[1], simargv[2]); + return; + + } + else if (strcmp (simargv[0], "dumpmem") == 0) + { + + if (simargv[1] == NULL) + { + fprintf (stderr, "Error: missing argument to dumpmem cmd.\n"); + return; + } + + fprintf (stderr, "Writing dumpfile %s...", simargv[1]); + + dumpfile = fopen (simargv[1], "w"); + fclose (dumpfile); + + fprintf (stderr, "done.\n"); + } + else if (strcmp (simargv[0], "clearstats") == 0) + { + alu.cycles = 0; + alu.interrupts = 0; + alu.insns = 0; + } + else if (strcmp (simargv[0], "verbose") == 0) + { + issue_messages = 2; + } + else if (strcmp (simargv[0], "interrupt") == 0) + { + int ivec; + + if (simargv[1] == 0) + { + fprintf (stderr, "Error: vector address required.\n"); + return; + } + + if (strcmp (simargv[1], "reset") == 0) + { + msp430_interrupt (0xfffeUL); + return; + } + + ivec = (int) strtol (simargv[1], (char **) NULL, 0); + if (msp430_interrupt (ivec)) + { + fprintf (stderr, + "Error: vector address 0x%04x (%s) is out of range.\n", + ivec, simargv[1]); + } + + return; + } + else if (strcmp (simargv[0], "ww") == 0) + { + int addr; + int val; + + if (simargv[1] == 0) + { + fprintf (stderr, "Error: address required.\n"); + return; + } + + addr = (int) strtol (simargv[1], (char **) NULL, 0); + + if (simargv[2] == 0) + { + fprintf (stderr, "Warning: missing value. Assuming zero.\n"); + val = 0; + } + else + { + val = (int) strtol (simargv[2], (char **) NULL, 0); + } + msp430_write_integer (addr & 0xffff, val & 0xffff, 2); + } + else if (strcmp (simargv[0], "wb") == 0) + { + int addr; + int val; + + if (simargv[1] == 0) + { + fprintf (stderr, "Error: address required.\n"); + return; + } + + addr = (int) strtol (simargv[1], (char **) NULL, 0); + + if (simargv[2] == 0) + { + fprintf (stderr, "Warning: missing value. Assuming zero.\n"); + val = 0; + } + else + { + val = (int) strtol (simargv[2], (char **) NULL, 0); + } + msp430_write_integer (addr & 0xffff, val & 0xff, 1); + } + else if (strncmp (simargv[0], "stat", 4) == 0) + { + fprintf (stderr, "Cycles: %d\n", alu.cycles); + fprintf (stderr, "Instructions: %d\n", alu.insns); + fprintf (stderr, "Interrupts: %d\n", alu.interrupts); + } + else + { + fprintf (stderr, + "Error: \"%s\" is not a valid MSP430 simulator command.\n", + cmd); + } + } + else + { + fprintf (stderr, "MSP430 built-in simulator commands: \n"); + fprintf (stderr, " watch [r/w/a/d] \n"); + fprintf (stderr, " dumpmem \n"); + fprintf (stderr, " clearstats\n"); + fprintf (stderr, " verbose\n"); + fprintf (stderr, " interrupt \n"); + fprintf (stderr, " ww [value]\n"); + fprintf (stderr, " wb [value]\n"); + } +} + +void +sim_set_callbacks (ptr) + host_callback *ptr; +{ + callback = ptr; +} + +int +process_symbol (asymbol * sym) +{ + int res; + + if (strcmp (sym->name, "__stop_progExec__")) + return 0; + + res = sym->value + sym->section->vma + 4; + + return res; +} + +int +get_stop_addr (struct bfd *abfd) +{ + long storage_needed; + asymbol **symbol_table; + long number_of_symbols; + long i; + int res; + + storage_needed = bfd_get_symtab_upper_bound (abfd); + + if (storage_needed < 0) + return; + + if (storage_needed == 0) + { + return; + } + + symbol_table = (asymbol **) xmalloc (storage_needed); + number_of_symbols = bfd_canonicalize_symtab (abfd, symbol_table); + + if (number_of_symbols < 0) + return; + + for (i = 0; i < number_of_symbols; i++) + { + res = process_symbol (symbol_table[i]); + if (res) + return res; + } + + return 0; +} diff --git gdb-7.2a.orig/sim/msp430/msp430-alu.c gdb-7.2a/sim/msp430/msp430-alu.c new file mode 100644 index 0000000..e013def --- /dev/null +++ gdb-7.2a/sim/msp430/msp430-alu.c @@ -0,0 +1,766 @@ + +#include +#include + + +#define FIRST_PSEUDO_REG 16 +#define MEM_SIZE 65536 + +struct msp430_alu +{ + short regs[FIRST_PSEUDO_REG]; + unsigned long cycles; + unsigned long insns; + unsigned long interrupts; + char mem[MEM_SIZE]; + int flags; +#define CPUOFF 0x10 +#define OSCOFF 0x20 +#define SCG0 0x40 +#define SCG1 0x80 + int signal; +}; + + +static struct msp430_alu alu; + + +#define pc (alu.regs[0]) +#define sp (alu.regs[1]) +#define sr (alu.regs[2]) +#define cg1 (alu.regs[2]) +#define cg2 (alu.regs[3]) + + +#define SET_C sr |= 0x0001 +#define SET_Z sr |= 0x0002 +#define SET_N sr |= 0x0004 +#define SET_V sr |= 0x0100 + +#define CLR_C sr &= ~0x0001 +#define CLR_Z sr &= ~0x0002 +#define CLR_N sr &= ~0x0004 +#define CLR_V sr &= ~0x0100 + + +#define C ((unsigned long)(sr & 0x0001)>>0) +#define Z ((unsigned long)(sr & 0x0002)>>1) +#define N ((unsigned long)(sr & 0x0004)>>2) +#define V ((unsigned long)(sr & 0x0100)>>8) + + + +enum msp430_modes +{ + REGISTER, + INDEXED, /* x(Rn) */ + SYMBOLIC, /* addr: (pc+x) (mind pc) */ + ABSOLUTE, /* &addr (mind r2) */ + INDERECT, /* @Rn */ + INDERECTINC, /* @Rn+ */ + IMMEDIATE /* #XXXX (@pc+) */ +}; + +struct msp430_op_mode +{ + int rs; + int rd; + enum msp430_modes ms; + enum msp430_modes md; + char as; + char ad; + char byte; +}; + + +struct msp430_ops +{ + int d_reg; + short src; + short dst; + short insn; + short dval; + char byte; +}; + + + +void +msp430_set_pc (unsigned int x) +{ + pc = x; +} + +unsigned int +msp430_get_pc () +{ + return (unsigned int) pc; +} + + + +struct msp430_op_mode +msp430_get_op_mode (short insn) +{ + struct msp430_op_mode m; + int s_reg; + int d_reg; + + + m.as = (insn >> 4) & 3; + m.ad = (insn >> 7) & 1; + m.byte = (insn >> 6) & 1; + s_reg = (insn >> 8) & 0xf; + d_reg = insn & 0xf; + + m.rs = s_reg; + m.rd = d_reg; + + if (m.ad == 0) + m.md = REGISTER; + else + { + if (d_reg == 2) + m.md = ABSOLUTE; /* &addr */ + else if (d_reg == 0) + m.md = SYMBOLIC; /* addr (pc + x) */ + else + m.md = INDEXED; /* X(Rn) */ + } + + switch (m.as) + { + case 0: + /* cg1 - reg.mode */ + cg2 = 0; + m.ms = REGISTER; + break; + + case 1: + /* cg1 - abs.addr.mode */ + + if (s_reg == 2) + m.ms = ABSOLUTE; /* &addr */ + else if (s_reg == 0) + m.ms = SYMBOLIC; /* addr (pc + x) */ + else if (s_reg == 3) + m.ms = REGISTER; + else + m.ms = INDEXED; /* X(Rn) */ + + cg2 = 1; + break; + + case 2: + m.ms = INDERECT; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 4; + cg2 = 2; + break; + + case 3: + if (s_reg == 0) + m.ms = IMMEDIATE; + else + m.ms = INDERECTINC; + if (s_reg == 2 || s_reg == 3) + m.ms = REGISTER; + cg1 = 8; + cg2 = -1; + break; + } + + return m; +} + +short +msp430_fetch_integer (unsigned int loc) +{ + char *m = &alu.mem[0xffff & loc]; + short res; + + res = (*m) | (short) (*(m + 1)) << 8; + return res; +} + + +void +msp430_write_integer (int loc, int val, int len) +{ + if (!len) + return; + + if (loc & 1 && len != 1) + { + alu.signal = SIGBUS; + return; + } + + while (len--) + { + alu.mem[loc] = 0xff & val; + loc++; + val >>= 8; + } +} + + +struct msp430_ops +msp430_double_operands (short insn) +{ + short src_val; + struct msp430_op_mode m = msp430_get_op_mode (insn); + unsigned int tmp; + int len = 0; + int cycles = 0; + struct msp430_ops ret; + + ret.byte = m.byte; + ret.d_reg = -1; + + switch (m.ms) + { + case REGISTER: + src_val = alu.regs[m.rs]; + cycles += (m.rd != 0) ? 1 : 2; + break; + case INDEXED: + len += 1; + cycles += 3; + pc += 2; + tmp = msp430_fetch_integer (pc) + alu.regs[m.rs]; + src_val = msp430_fetch_integer (tmp); + break; + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 3; + tmp = msp430_fetch_integer (pc) + pc; + src_val = msp430_fetch_integer (tmp); + break; + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 3; + tmp = msp430_fetch_integer (pc); + src_val = msp430_fetch_integer (tmp); + break; + case INDERECT: + cycles += 2 + (m.rd) ? 0 : 1; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + break; + case INDERECTINC: + cycles += 2 + (m.rd) ? 0 : 1; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + if (m.rs != 1 && m.rs != 0) + alu.regs[m.rs] += m.byte ? 1 : 2; + else + alu.regs[m.rs] += 2; + break; + case IMMEDIATE: + cycles += 2 + (m.rd) ? 0 : 1; + pc += 2; + src_val = msp430_fetch_integer (pc); + break; + } + + switch (m.md) + { + case REGISTER: + ret.dval = alu.regs[m.rd]; + ret.d_reg = m.rd; + break; + + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc); + ret.dval = msp430_fetch_integer (tmp); + break; + + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc) + pc; + ret.dval = msp430_fetch_integer (tmp); + break; + + case INDEXED: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc) + alu.regs[m.rd]; + ret.dval = msp430_fetch_integer (tmp); + break; + default: + alu.signal = SIGILL; + } + + + + return ret; +} + +struct msp430_ops +msp430_single_operands (short insn) +{ + short src_val; + struct msp430_op_mode m = msp430_get_op_mode (insn); + unsigned int tmp; + int len = 0; + int cycles = 0; + struct msp430_ops ret; + + ret.byte = m.byte; + ret.d_reg = -1; + + switch (m.ms) + { + case REGISTER: + src_val = alu.regs[m.rs]; + ret.d_reg = m.rs; + cycles += (m.rd) ? 1 : 2; + break; + case INDEXED: + len += 1; + cycles += 3; + pc += 2; + ret.dst = tmp = msp430_fetch_integer (pc) + alu.regs[m.rs]; + src_val = msp430_fetch_integer (tmp); + break; + case SYMBOLIC: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc) + pc; + src_val = msp430_fetch_integer (tmp); + break; + case ABSOLUTE: + len += 1; + pc += 2; + cycles += 3; + ret.dst = tmp = msp430_fetch_integer (pc); + src_val = msp430_fetch_integer (tmp); + break; + case INDERECT: + cycles += 2 + (m.rd) ? 0 : 1; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + break; + case INDERECTINC: + cycles += 2 + (m.rd) ? 0 : 1; + ret.dst = alu.regs[m.rs]; + src_val = msp430_fetch_integer (alu.regs[m.rs]); + if (m.rs != 1 && m.rs != 0) + alu.regs[m.rs] += m.byte ? 1 : 2; + else + alu.regs[m.rs] += 2; + break; + case IMMEDIATE: + cycles += 2 + (m.rd) ? 0 : 1; + pc += 2; + src_val = msp430_fetch_integer (pc); + break; + } + + pc += 2; + ret.src = ret.dval = src_val; + return ret; +} + + +short +msp430_offset (short insn) +{ + short res = insn & 0x3ff; + + if (res & 0x200) + res |= ~0x3ff; + + return res << 1; +} + +void +msp430_check_bp (unsigned int l) +{ + static unsigned int last; + + last = l; +} + + +/* C: ZNCV */ + +void +msp430_set_status (int r, char b, char *c) +{ + int tmp = b ? (r & 0xff) : (r & 0xffff); + + /* Zero flag: */ + if (*c == 'x') + { + if (!tmp) + SET_Z; + else + CLR_Z; + } + else if (*c == '0') + { + CLR_Z; + } + else if (*c == '1') + { + SET_Z; + } + + c++; + /* negative flag */ + if (*c == 'x') + { + if (tmp & (b ? 0x80 : 0x8000)) + SET_N; + else + CLR_N; + } + else if (*c == '0') + { + CLR_N; + } + else if (*c == '1') + { + SET_N; + } + + c++; + /* carry flag: */ + if (*c == 'x') + { + if (r < 0) + SET_C; + else if (b && (r & 0xffffff00ul)) + SET_C; + else if (!b && (r & 0xffff0000ul)) + SET_C; + else + CLR_C; + } + else if (*c == '0') + { + CLR_C; + } + else if (*c == '1') + { + SET_C; + } + + c++; + /* overflow flag: */ + if (*c == '0') + { + CLR_V; + } + else if (*c == '1') + { + SET_V; + } + + /* check low power modes */ + if (sr & 0x00f0) + { + alu.signal = SIGQUIT; + } +} + +#define MOV 0x4 +#define ADD 0x5 +#define ADDC 0x6 +#define SUBC 0x7 +#define SUB 0x8 +#define CMP 0x9 +#define DADD 0xa +#define BIT 0xb +#define BIC 0xc +#define BIS 0xd +#define XOR 0xe +#define AND 0xf + +#define JMP 0x3c +#define JL 0x38 +#define JGE 0x34 +#define JN 0x30 +#define JC 0x2c +#define JNC 0x28 +#define JZ 0x24 +#define JNZ 0x20 + +#define SXT 0x118 +#define RETI 0x130 +#define CALL 0x128 +#define PUSH 0x120 +#define RRA 0x110 +#define SWPB 0x108 +#define RRC 0x100 + +unsigned int +extract_opcode (short insn) +{ + unsigned int tmp; + + tmp = 0x0000f000ul & (int) insn; + tmp >>= 12; + + /* double operands */ + if (tmp > 3) + return tmp; + + /* jumps */ + if (tmp == 3 || tmp == 2) + return ((unsigned int) insn >> 8) & ~3; + + /* single operands or TRAP */ + return ((unsigned int) insn >> 4) & ~5; +} + + + +#define READ_SRC(ss) (ss.src & (ss.byte?0xff:0xffff)) +#define READ_DST(ss) (ss.dval & (ss.byte?0xff:0xffff)) + +#define WRITE_BACK(ss,x) \ +do { \ +if(ss.d_reg != -1) \ +alu.regs[ss.d_reg] = tmp & (ss.byte? 0xff : 0xffff); \ +else \ +msp430_write_integer(ss.dst,tmp, (ss.byte?1:2) ); \ +} while(0) + +void +flow () +{ + short insn; + unsigned int opcode; + struct msp430_ops srp; + struct msp430_ops drp; + int tmp; + + while (alu.signal == 0) + { + tmp = 0; + + insn = msp430_fetch_integer (pc); + opcode = extract_opcode (insn); + + if (!opcode) + { + alu.signal = SIGTRAP; + return; + } + else if (opcode < 16) + { + drp = msp430_double_operands (insn); + } + else if (opcode < 0x3d) + { + ;; /* jump insn */ + } + else if (opcode & 0x100) + { + srp = msp430_single_operands (insn); + } + + switch (opcode) + { + default: + fprintf (stderr, "Unknown code 0x%04x\n", insn); + + /* single operands */ + case RRC: + tmp = (C << (srp.byte ? 8 : 16)) | READ_SRC (srp); + tmp >>= 1; + if (srp.src & 1) + SET_C; + WRITE_BACK (srp, tmp); + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case SWPB: + tmp = ((srp.src << 8) & 0xff00) | ((srp.src >> 8) & 0x00ff); + WRITE_BACK (srp, tmp); + break; + case RRA: + tmp = READ_SRC (srp); + if (srp.src & 1) + SET_C; + tmp = + (tmp & (srp.byte ? 0xff : 0xffff)) | ((tmp >> 1) & + (srp.byte ? 0x7f : 0x7fff)); + WRITE_BACK (srp, tmp); + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case SXT: + tmp = srp.src & 0xff; + if (tmp & 0x80) + tmp |= 0xff00; + WRITE_BACK (srp, tmp); + msp430_set_status (tmp, srp.byte, "xx-0"); + break; + case PUSH: + tmp = READ_SRC (srp); + msp430_write_integer (sp, tmp, 2); + sp -= 2; + break; + case CALL: + tmp = READ_SRC (srp); + msp430_write_integer (sp, pc, 2); + pc = tmp; + break; + case RETI: + sr = msp430_fetch_integer (sp); + sp += 2; + msp430_set_status (0, 0, "----"); + pc = msp430_fetch_integer (sp); + sp += 2; + break; + + /* double operand */ + + case MOV: + tmp = READ_SRC (drp); + WRITE_BACK (drp, tmp); + msp430_set_status (0, 0, "----"); + break; + case ADD: + case ADDC: + tmp = READ_SRC (drp) + READ_DST (drp) + ((opcode == ADDC) ? C : 0); + WRITE_BACK (drp, tmp); + { + int b = drp.byte ? 0x80 : 0x8000; + int f; + + f = (!(tmp & b) + && (READ_SRC (drp) & b) + && (READ_DST (drp) & b)) + || ((tmp & b) + && !(READ_SRC (drp) & b) && !(READ_DST (drp) & b)); + if (f) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case SUB: + case SUBC: + tmp = ~READ_SRC (drp) + READ_DST (drp) + ((opcode == SUBC) ? C : 1); + WRITE_BACK (drp, tmp); + { + int b = drp.byte ? 0x80 : 0x8000; + int f; + + f = (!(tmp & b) + && (READ_SRC (drp) & b) + && (READ_DST (drp) & b)) + || ((tmp & b) + && !(READ_SRC (drp) & b) && !(READ_DST (drp) & b)); + if (f) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case CMP: + tmp = ~READ_SRC (drp) + READ_DST (drp) + 1; + { + int b = drp.byte ? 0x80 : 0x8000; + int f; + + f = (!(tmp & b) + && (READ_SRC (drp) & b) + && (READ_DST (drp) & b)) + || ((tmp & b) + && !(READ_SRC (drp) & b) && !(READ_DST (drp) & b)); + if (f) + SET_V; + else + CLR_V; + } + msp430_set_status (tmp, drp.byte, "xxx-"); + break; + case BIT: + tmp = READ_SRC (drp) & READ_DST (drp); + msp430_set_status (tmp, drp.byte, "-x-0"); + if (tmp) + SET_C; + else + CLR_C; + break; + case BIC: + tmp = ~READ_SRC (drp) & READ_DST (drp); + WRITE_BACK (drp, tmp); + msp430_set_status (tmp, drp.byte, "----"); + break; + case BIS: + tmp = READ_SRC (drp) | READ_DST (drp); + WRITE_BACK (drp, tmp); + msp430_set_status (tmp, drp.byte, "----"); + break; + case XOR: + tmp = READ_SRC (drp) ^ READ_DST (drp); + msp430_set_status (tmp, drp.byte, "xx--"); + if (tmp) + SET_C; + else + CLR_C; + { + int b = drp.byte ? 0x80 : 0x8000; + int f; + f = (READ_SRC (drp) & b) && (READ_DST (drp) & b); + if (f) + SET_V; + else + CLR_V; + } + break; + case AND: + tmp = READ_SRC (drp) & READ_DST (drp); + WRITE_BACK (drp, tmp); + msp430_set_status (tmp, drp.byte, "xx-0"); + if (tmp) + SET_C; + else + CLR_C; + break; + /* jumps */ + case JNZ: + pc += 2 + (!Z) ? msp430_offset (insn) : 0; + break; + case JZ: + pc += 2 + (Z) ? msp430_offset (insn) : 0; + break; + case JC: + pc += 2 + (C) ? msp430_offset (insn) : 0; + break; + case JNC: + pc += 2 + (!C) ? msp430_offset (insn) : 0; + break; + case JN: + pc += 2 + (N) ? msp430_offset (insn) : 0; + break; + case JGE: + pc += 2 + (!(N ^ V)) ? msp430_offset (insn) : 0; + break; + case JL: + pc += 2 + (N ^ V) ? msp430_offset (insn) : 0; + break; + case JMP: + pc += msp430_offset (insn); + break; + } /* case */ + + } /* while */ +} diff --git gdb-7.2a.orig/sim/msp430/stamp-h gdb-7.2a/sim/msp430/stamp-h new file mode 100644 index 0000000..8b13789 --- /dev/null +++ gdb-7.2a/sim/msp430/stamp-h @@ -0,0 +1 @@ + diff --git gdb-7.2a.orig/sim/msp430/sysdep.h gdb-7.2a/sim/msp430/sysdep.h new file mode 100644 index 0000000..4035572 --- /dev/null +++ gdb-7.2a/sim/msp430/sysdep.h @@ -0,0 +1,95 @@ +/* System includes and definitions used by the Motorola MCore simulator. + Copyright (C) 1999 Free Software Foundation, Inc. + Contributed by Cygnus Solutions. + +This file is part of GDB, the GNU debugger. + +This program 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 2, or (at your option) +any later version. + +This program 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 this program; if not, write to the Free Software Foundation, Inc., +59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifndef __SYSDEP_H +#define __SYSDEP_H + +#ifndef hosts_std_host_H +#include +#include +#include +#include +#include +#include +#include +#include +#include "ansidecl.h" + +#ifndef O_ACCMODE +#define O_ACCMODE (O_RDONLY | O_WRONLY | O_RDWR) +#endif +#ifndef SEEK_SET +#define SEEK_SET 0 +#endif +#ifndef SEEK_CUR +#define SEEK_CUR 1 +#endif +#ifdef STDC_HEADERS +#include +/*#include */ +#else +extern char *mktemp (); +#ifndef memset +extern PTR memset (); +#endif + +#ifndef DONTDECLARE_MALLOC +extern PTR malloc (); +extern PTR realloc (); +#endif + +#ifndef __GNUC__ +extern PTR memcpy (); +#else +/* char * memcpy (); */ +#endif + +#ifdef __STDC__ +extern void free (); +#else +extern int free (); +#endif + +#ifndef strchr +extern char *strchr (); +#endif +extern char *getenv (); +extern PTR memchr (); +extern char *strrchr (); + +extern char *strrchr (); +extern char *ctime (); +extern long atol (); +extern char *getenv (); +#endif /* STDC_HEADERS */ + +#ifndef BYTES_IN_PRINTF_INT +#define BYTES_IN_PRINTF_INT 4 +#endif + +#include "fopen-same.h" +#define hosts_std_host_H +#endif + +#ifdef STDC_HEADERS +#include +#endif /* STDC_HEADERS */ + +#endif /* __SYSDEP_H */ diff --git gdb-7.2a.orig/sim/msp430/targ-map.c gdb-7.2a/sim/msp430/targ-map.c new file mode 100644 index 0000000..b494ca9 --- /dev/null +++ gdb-7.2a/sim/msp430/targ-map.c @@ -0,0 +1,407 @@ +/* Target value mapping utilities needed by the simulator and gdb. */ +/* This file is machine generated by gentmap.c. */ + +#include +#include +#include "ansidecl.h" +#include "gdb/callback.h" +#include "targ-vals.h" + +/* syscall mapping table */ +CB_TARGET_DEFS_MAP cb_init_syscall_map[] = { + {-1, -1} +}; + +/* errno mapping table */ +CB_TARGET_DEFS_MAP cb_init_errno_map[] = { +#ifdef E2BIG + {E2BIG, TARGET_E2BIG}, +#endif +#ifdef EACCES + {EACCES, TARGET_EACCES}, +#endif +#ifdef EADDRINUSE + {EADDRINUSE, TARGET_EADDRINUSE}, +#endif +#ifdef EADDRNOTAVAIL + {EADDRNOTAVAIL, TARGET_EADDRNOTAVAIL}, +#endif +#ifdef EADV + {EADV, TARGET_EADV}, +#endif +#ifdef EAFNOSUPPORT + {EAFNOSUPPORT, TARGET_EAFNOSUPPORT}, +#endif +#ifdef EAGAIN + {EAGAIN, TARGET_EAGAIN}, +#endif +#ifdef EALREADY + {EALREADY, TARGET_EALREADY}, +#endif +#ifdef EBADE + {EBADE, TARGET_EBADE}, +#endif +#ifdef EBADF + {EBADF, TARGET_EBADF}, +#endif +#ifdef EBADFD + {EBADFD, TARGET_EBADFD}, +#endif +#ifdef EBADMSG + {EBADMSG, TARGET_EBADMSG}, +#endif +#ifdef EBADR + {EBADR, TARGET_EBADR}, +#endif +#ifdef EBADRQC + {EBADRQC, TARGET_EBADRQC}, +#endif +#ifdef EBADSLT + {EBADSLT, TARGET_EBADSLT}, +#endif +#ifdef EBFONT + {EBFONT, TARGET_EBFONT}, +#endif +#ifdef EBUSY + {EBUSY, TARGET_EBUSY}, +#endif +#ifdef ECHILD + {ECHILD, TARGET_ECHILD}, +#endif +#ifdef ECHRNG + {ECHRNG, TARGET_ECHRNG}, +#endif +#ifdef ECOMM + {ECOMM, TARGET_ECOMM}, +#endif +#ifdef ECONNABORTED + {ECONNABORTED, TARGET_ECONNABORTED}, +#endif +#ifdef ECONNREFUSED + {ECONNREFUSED, TARGET_ECONNREFUSED}, +#endif +#ifdef ECONNRESET + {ECONNRESET, TARGET_ECONNRESET}, +#endif +#ifdef EDEADLK + {EDEADLK, TARGET_EDEADLK}, +#endif +#ifdef EDEADLOCK + {EDEADLOCK, TARGET_EDEADLOCK}, +#endif +#ifdef EDESTADDRREQ + {EDESTADDRREQ, TARGET_EDESTADDRREQ}, +#endif +#ifdef EDOM + {EDOM, TARGET_EDOM}, +#endif +#ifdef EDOTDOT + {EDOTDOT, TARGET_EDOTDOT}, +#endif +#ifdef EDQUOT + {EDQUOT, TARGET_EDQUOT}, +#endif +#ifdef EEXIST + {EEXIST, TARGET_EEXIST}, +#endif +#ifdef EFAULT + {EFAULT, TARGET_EFAULT}, +#endif +#ifdef EFBIG + {EFBIG, TARGET_EFBIG}, +#endif +#ifdef EHOSTDOWN + {EHOSTDOWN, TARGET_EHOSTDOWN}, +#endif +#ifdef EHOSTUNREACH + {EHOSTUNREACH, TARGET_EHOSTUNREACH}, +#endif +#ifdef EIDRM + {EIDRM, TARGET_EIDRM}, +#endif +#ifdef EINPROGRESS + {EINPROGRESS, TARGET_EINPROGRESS}, +#endif +#ifdef EINTR + {EINTR, TARGET_EINTR}, +#endif +#ifdef EINVAL + {EINVAL, TARGET_EINVAL}, +#endif +#ifdef EIO + {EIO, TARGET_EIO}, +#endif +#ifdef EISCONN + {EISCONN, TARGET_EISCONN}, +#endif +#ifdef EISDIR + {EISDIR, TARGET_EISDIR}, +#endif +#ifdef EL2HLT + {EL2HLT, TARGET_EL2HLT}, +#endif +#ifdef EL2NSYNC + {EL2NSYNC, TARGET_EL2NSYNC}, +#endif +#ifdef EL3HLT + {EL3HLT, TARGET_EL3HLT}, +#endif +#ifdef EL3RST + {EL3RST, TARGET_EL3RST}, +#endif +#ifdef ELBIN + {ELBIN, TARGET_ELBIN}, +#endif +#ifdef ELIBACC + {ELIBACC, TARGET_ELIBACC}, +#endif +#ifdef ELIBBAD + {ELIBBAD, TARGET_ELIBBAD}, +#endif +#ifdef ELIBEXEC + {ELIBEXEC, TARGET_ELIBEXEC}, +#endif +#ifdef ELIBMAX + {ELIBMAX, TARGET_ELIBMAX}, +#endif +#ifdef ELIBSCN + {ELIBSCN, TARGET_ELIBSCN}, +#endif +#ifdef ELNRNG + {ELNRNG, TARGET_ELNRNG}, +#endif +#ifdef ELOOP + {ELOOP, TARGET_ELOOP}, +#endif +#ifdef EMFILE + {EMFILE, TARGET_EMFILE}, +#endif +#ifdef EMLINK + {EMLINK, TARGET_EMLINK}, +#endif +#ifdef EMSGSIZE + {EMSGSIZE, TARGET_EMSGSIZE}, +#endif +#ifdef EMULTIHOP + {EMULTIHOP, TARGET_EMULTIHOP}, +#endif +#ifdef ENAMETOOLONG + {ENAMETOOLONG, TARGET_ENAMETOOLONG}, +#endif +#ifdef ENETDOWN + {ENETDOWN, TARGET_ENETDOWN}, +#endif +#ifdef ENETRESET + {ENETRESET, TARGET_ENETRESET}, +#endif +#ifdef ENETUNREACH + {ENETUNREACH, TARGET_ENETUNREACH}, +#endif +#ifdef ENFILE + {ENFILE, TARGET_ENFILE}, +#endif +#ifdef ENMFILE + {ENMFILE, TARGET_ENMFILE}, +#endif +#ifdef ENOANO + {ENOANO, TARGET_ENOANO}, +#endif +#ifdef ENOBUFS + {ENOBUFS, TARGET_ENOBUFS}, +#endif +#ifdef ENOCSI + {ENOCSI, TARGET_ENOCSI}, +#endif +#ifdef ENODATA + {ENODATA, TARGET_ENODATA}, +#endif +#ifdef ENODEV + {ENODEV, TARGET_ENODEV}, +#endif +#ifdef ENOENT + {ENOENT, TARGET_ENOENT}, +#endif +#ifdef ENOEXEC + {ENOEXEC, TARGET_ENOEXEC}, +#endif +#ifdef ENOLCK + {ENOLCK, TARGET_ENOLCK}, +#endif +#ifdef ENOLINK + {ENOLINK, TARGET_ENOLINK}, +#endif +#ifdef ENOMEM + {ENOMEM, TARGET_ENOMEM}, +#endif +#ifdef ENOMSG + {ENOMSG, TARGET_ENOMSG}, +#endif +#ifdef ENONET + {ENONET, TARGET_ENONET}, +#endif +#ifdef ENOPKG + {ENOPKG, TARGET_ENOPKG}, +#endif +#ifdef ENOPROTOOPT + {ENOPROTOOPT, TARGET_ENOPROTOOPT}, +#endif +#ifdef ENOSPC + {ENOSPC, TARGET_ENOSPC}, +#endif +#ifdef ENOSR + {ENOSR, TARGET_ENOSR}, +#endif +#ifdef ENOSTR + {ENOSTR, TARGET_ENOSTR}, +#endif +#ifdef ENOSYS + {ENOSYS, TARGET_ENOSYS}, +#endif +#ifdef ENOTBLK + {ENOTBLK, TARGET_ENOTBLK}, +#endif +#ifdef ENOTCONN + {ENOTCONN, TARGET_ENOTCONN}, +#endif +#ifdef ENOTDIR + {ENOTDIR, TARGET_ENOTDIR}, +#endif +#ifdef ENOTEMPTY + {ENOTEMPTY, TARGET_ENOTEMPTY}, +#endif +#ifdef ENOTSOCK + {ENOTSOCK, TARGET_ENOTSOCK}, +#endif +#ifdef ENOTSUP + {ENOTSUP, TARGET_ENOTSUP}, +#endif +#ifdef ENOTTY + {ENOTTY, TARGET_ENOTTY}, +#endif +#ifdef ENOTUNIQ + {ENOTUNIQ, TARGET_ENOTUNIQ}, +#endif +#ifdef ENXIO + {ENXIO, TARGET_ENXIO}, +#endif +#ifdef EOPNOTSUPP + {EOPNOTSUPP, TARGET_EOPNOTSUPP}, +#endif +#ifdef EPERM + {EPERM, TARGET_EPERM}, +#endif +#ifdef EPFNOSUPPORT + {EPFNOSUPPORT, TARGET_EPFNOSUPPORT}, +#endif +#ifdef EPIPE + {EPIPE, TARGET_EPIPE}, +#endif +#ifdef EPROCLIM + {EPROCLIM, TARGET_EPROCLIM}, +#endif +#ifdef EPROTO + {EPROTO, TARGET_EPROTO}, +#endif +#ifdef EPROTONOSUPPORT + {EPROTONOSUPPORT, TARGET_EPROTONOSUPPORT}, +#endif +#ifdef EPROTOTYPE + {EPROTOTYPE, TARGET_EPROTOTYPE}, +#endif +#ifdef ERANGE + {ERANGE, TARGET_ERANGE}, +#endif +#ifdef EREMCHG + {EREMCHG, TARGET_EREMCHG}, +#endif +#ifdef EREMOTE + {EREMOTE, TARGET_EREMOTE}, +#endif +#ifdef EROFS + {EROFS, TARGET_EROFS}, +#endif +#ifdef ESHUTDOWN + {ESHUTDOWN, TARGET_ESHUTDOWN}, +#endif +#ifdef ESOCKTNOSUPPORT + {ESOCKTNOSUPPORT, TARGET_ESOCKTNOSUPPORT}, +#endif +#ifdef ESPIPE + {ESPIPE, TARGET_ESPIPE}, +#endif +#ifdef ESRCH + {ESRCH, TARGET_ESRCH}, +#endif +#ifdef ESRMNT + {ESRMNT, TARGET_ESRMNT}, +#endif +#ifdef ESTALE + {ESTALE, TARGET_ESTALE}, +#endif +#ifdef ETIME + {ETIME, TARGET_ETIME}, +#endif +#ifdef ETIMEDOUT + {ETIMEDOUT, TARGET_ETIMEDOUT}, +#endif +#ifdef ETOOMANYREFS + {ETOOMANYREFS, TARGET_ETOOMANYREFS}, +#endif +#ifdef ETXTBSY + {ETXTBSY, TARGET_ETXTBSY}, +#endif +#ifdef EUNATCH + {EUNATCH, TARGET_EUNATCH}, +#endif +#ifdef EUSERS + {EUSERS, TARGET_EUSERS}, +#endif +#ifdef EWOULDBLOCK + {EWOULDBLOCK, TARGET_EWOULDBLOCK}, +#endif +#ifdef EXDEV + {EXDEV, TARGET_EXDEV}, +#endif +#ifdef EXFULL + {EXFULL, TARGET_EXFULL}, +#endif + {0, 0} +}; + +/* open flags mapping table */ +CB_TARGET_DEFS_MAP cb_init_open_map[] = { +#ifdef O_ACCMODE + {O_ACCMODE, TARGET_O_ACCMODE}, +#endif +#ifdef O_APPEND + {O_APPEND, TARGET_O_APPEND}, +#endif +#ifdef O_CREAT + {O_CREAT, TARGET_O_CREAT}, +#endif +#ifdef O_EXCL + {O_EXCL, TARGET_O_EXCL}, +#endif +#ifdef O_NOCTTY + {O_NOCTTY, TARGET_O_NOCTTY}, +#endif +#ifdef O_NONBLOCK + {O_NONBLOCK, TARGET_O_NONBLOCK}, +#endif +#ifdef O_RDONLY + {O_RDONLY, TARGET_O_RDONLY}, +#endif +#ifdef O_RDWR + {O_RDWR, TARGET_O_RDWR}, +#endif +#ifdef O_SYNC + {O_SYNC, TARGET_O_SYNC}, +#endif +#ifdef O_TRUNC + {O_TRUNC, TARGET_O_TRUNC}, +#endif +#ifdef O_WRONLY + {O_WRONLY, TARGET_O_WRONLY}, +#endif + {-1, -1} +}; diff --git gdb-7.2a.orig/sim/msp430/targ-vals.h gdb-7.2a/sim/msp430/targ-vals.h new file mode 100644 index 0000000..9032f82 --- /dev/null +++ gdb-7.2a/sim/msp430/targ-vals.h @@ -0,0 +1,141 @@ +/* Target header values needed by the simulator and gdb. */ +/* This file is machine generated by gentmap.c. */ + +#ifndef TARG_VALS_H +#define TARG_VALS_H + +/* syscall values */ + +/* errno values */ +#define TARGET_E2BIG 7 +#define TARGET_EACCES 13 +#define TARGET_EADDRINUSE 112 +#define TARGET_EADDRNOTAVAIL 125 +#define TARGET_EADV 68 +#define TARGET_EAFNOSUPPORT 106 +#define TARGET_EAGAIN 11 +#define TARGET_EALREADY 120 +#define TARGET_EBADE 50 +#define TARGET_EBADF 9 +#define TARGET_EBADFD 81 +#define TARGET_EBADMSG 77 +#define TARGET_EBADR 51 +#define TARGET_EBADRQC 54 +#define TARGET_EBADSLT 55 +#define TARGET_EBFONT 57 +#define TARGET_EBUSY 16 +#define TARGET_ECHILD 10 +#define TARGET_ECHRNG 37 +#define TARGET_ECOMM 70 +#define TARGET_ECONNABORTED 113 +#define TARGET_ECONNREFUSED 111 +#define TARGET_ECONNRESET 104 +#define TARGET_EDEADLK 45 +#define TARGET_EDEADLOCK 56 +#define TARGET_EDESTADDRREQ 121 +#define TARGET_EDOM 33 +#define TARGET_EDOTDOT 76 +#define TARGET_EDQUOT 132 +#define TARGET_EEXIST 17 +#define TARGET_EFAULT 14 +#define TARGET_EFBIG 27 +#define TARGET_EHOSTDOWN 117 +#define TARGET_EHOSTUNREACH 118 +#define TARGET_EIDRM 36 +#define TARGET_EINPROGRESS 119 +#define TARGET_EINTR 4 +#define TARGET_EINVAL 22 +#define TARGET_EIO 5 +#define TARGET_EISCONN 127 +#define TARGET_EISDIR 21 +#define TARGET_EL2HLT 44 +#define TARGET_EL2NSYNC 38 +#define TARGET_EL3HLT 39 +#define TARGET_EL3RST 40 +#define TARGET_ELBIN 75 +#define TARGET_ELIBACC 83 +#define TARGET_ELIBBAD 84 +#define TARGET_ELIBEXEC 87 +#define TARGET_ELIBMAX 86 +#define TARGET_ELIBSCN 85 +#define TARGET_ELNRNG 41 +#define TARGET_ELOOP 92 +#define TARGET_EMFILE 24 +#define TARGET_EMLINK 31 +#define TARGET_EMSGSIZE 122 +#define TARGET_EMULTIHOP 74 +#define TARGET_ENAMETOOLONG 91 +#define TARGET_ENETDOWN 115 +#define TARGET_ENETRESET 126 +#define TARGET_ENETUNREACH 114 +#define TARGET_ENFILE 23 +#define TARGET_ENMFILE 89 +#define TARGET_ENOANO 53 +#define TARGET_ENOBUFS 105 +#define TARGET_ENOCSI 43 +#define TARGET_ENODATA 61 +#define TARGET_ENODEV 19 +#define TARGET_ENOENT 2 +#define TARGET_ENOEXEC 8 +#define TARGET_ENOLCK 46 +#define TARGET_ENOLINK 67 +#define TARGET_ENOMEM 12 +#define TARGET_ENOMSG 35 +#define TARGET_ENONET 64 +#define TARGET_ENOPKG 65 +#define TARGET_ENOPROTOOPT 109 +#define TARGET_ENOSPC 28 +#define TARGET_ENOSR 63 +#define TARGET_ENOSTR 60 +#define TARGET_ENOSYS 88 +#define TARGET_ENOTBLK 15 +#define TARGET_ENOTCONN 128 +#define TARGET_ENOTDIR 20 +#define TARGET_ENOTEMPTY 90 +#define TARGET_ENOTSOCK 108 +#define TARGET_ENOTSUP 134 +#define TARGET_ENOTTY 25 +#define TARGET_ENOTUNIQ 80 +#define TARGET_ENXIO 6 +#define TARGET_EOPNOTSUPP 95 +#define TARGET_EPERM 1 +#define TARGET_EPFNOSUPPORT 96 +#define TARGET_EPIPE 32 +#define TARGET_EPROCLIM 130 +#define TARGET_EPROTO 71 +#define TARGET_EPROTONOSUPPORT 123 +#define TARGET_EPROTOTYPE 107 +#define TARGET_ERANGE 34 +#define TARGET_EREMCHG 82 +#define TARGET_EREMOTE 66 +#define TARGET_EROFS 30 +#define TARGET_ESHUTDOWN 110 +#define TARGET_ESOCKTNOSUPPORT 124 +#define TARGET_ESPIPE 29 +#define TARGET_ESRCH 3 +#define TARGET_ESRMNT 69 +#define TARGET_ESTALE 133 +#define TARGET_ETIME 62 +#define TARGET_ETIMEDOUT 116 +#define TARGET_ETOOMANYREFS 129 +#define TARGET_ETXTBSY 26 +#define TARGET_EUNATCH 42 +#define TARGET_EUSERS 131 +#define TARGET_EWOULDBLOCK 11 +#define TARGET_EXDEV 18 +#define TARGET_EXFULL 52 + +/* open flag values */ +#define TARGET_O_ACCMODE 0x3 +#define TARGET_O_APPEND 0x8 +#define TARGET_O_CREAT 0x200 +#define TARGET_O_EXCL 0x800 +#define TARGET_O_NOCTTY 0x8000 +#define TARGET_O_NONBLOCK 0x4000 +#define TARGET_O_RDONLY 0x0 +#define TARGET_O_RDWR 0x2 +#define TARGET_O_SYNC 0x2000 +#define TARGET_O_TRUNC 0x400 +#define TARGET_O_WRONLY 0x1 + +#endif /* TARG_VALS_H */