OSDN Git Service

* gdbarch.sh: Add field ``postdefault''. Rename fields
authorcagney <cagney>
Tue, 30 May 2000 01:29:26 +0000 (01:29 +0000)
committercagney <cagney>
Tue, 30 May 2000 01:29:26 +0000 (01:29 +0000)
``startup'' and ``default'' to ``staticdefault'' and
``predefault''.  Fix initialization of valid_p.  Create/compare
gdbarch.log.

gdb/ChangeLog
gdb/gdbarch.sh

index ed98823..4b105a9 100644 (file)
@@ -1,3 +1,10 @@
+Tue May 30 11:22:28 2000  Andrew Cagney  <cagney@b1.cygnus.com>
+
+       * gdbarch.sh: Add field ``postdefault''.  Rename fields
+       ``startup'' and ``default'' to ``staticdefault'' and
+       ``predefault''.  Fix initialization of valid_p.  Create/compare
+       gdbarch.log.
+
 Mon May 29 22:47:16 2000  Andrew Cagney  <cagney@b1.cygnus.com>
 
        * config/sparc/nm-sun4sol2.h (GDB_GREGSET_T, GDB_FPREGSET_T):
index cbc7cf3..3dd27c2 100755 (executable)
@@ -38,11 +38,11 @@ compare_new ()
 # multi-arch is not enabled.
 default_is_fallback_p ()
 {
-    [ "${default}" != "" -a "${invalid_p}" = "0" ]
+    [ "${predefault}" != "" -a "${invalid_p}" = "0" ]
 }
 
 # Format of the input table
-read="class level macro returntype function formal actual attrib startup default invalid_p fmt print print_p description"
+read="class level macro returntype function formal actual attrib staticdefault predefault postdefault invalid_p fmt print print_p description"
 
 class_is_variable_p ()
 {
@@ -69,18 +69,24 @@ do_read ()
 {
     if eval read $read
     then
-       test "${startup}" || startup=0
+       test "${staticdefault}" || staticdefault=0
        test "${fmt}" || fmt="%ld"
        test "${print}" || print="(long) ${macro}"
        #FIXME:
-       #Should set DEFAULT to zero and force the user to provide
+       #Should set PREDEFAULT to zero and force the user to provide
        #an invalid_p=0
-       #test "${default}" || default=0 - NO
+       #test "${predefault}" || predefault=0 - NO
        case "${invalid_p}" in
            0 ) valid_p=1 ;;
-           "" ) test "${default}" && valid_p="gdbarch->${function} != ${default}"
+           "" )
+               if [ "${predefault}" ]
+               then
+                   valid_p="gdbarch->${function} != ${predefault}"
+               else
+                   valid_p="gdbarch->${function} != 0"
+               fi
                #NOT_YET
-               #test "${default}" && invalid_p="gdbarch->${function} == ${default}"
+               #test "${predefault}" && invalid_p="gdbarch->${function} == ${predefault}"
                ;;
            * ) valid_p="!(${invalid_p})"
        esac
@@ -149,32 +155,61 @@ do
        # Any GCC attributes that should be attached to the function
        # declaration.  At present this field is unused.
 
-    startup ) : ;;
+    staticdefault ) : ;;
 
        # To help with the GDB startup a static gdbarch object is
-       # created.  STARTUP is the value to insert into that static
-       # gdbarch object.
+       # created.  STATICDEFAULT is the value to insert into that
+       # static gdbarch object.  Since this a static object only
+       # simple expressions can be used.
 
-       # By default ``0'' is used.
+       # If STATICDEFAULT is empty, zero is used.
 
-    default ) : ;;
+    predefault ) : ;;
 
-       # Any initial value to assign to a new gdbarch object after it
-       # as been malloc()ed.  Zero is used by default.
+       # A initial value to assign to MEMBER of the freshly
+       # malloc()ed gdbarch object.  After the gdbarch object has
+       # been initialized using PREDEFAULT, it is passed to the
+       # target code for further updates.
 
-       # Specify a non-empty DEFAULT and a zero INVALID_P to create a
+       # If PREDEFAULT is empty, zero is used.
+
+       # Specify a non-empty PREDEFAULT and a zero INVALID_P to
+       # create a fallback value or function for when multi-arch is
+       # disabled.  Specify a zero PREDEFAULT function to make that
+       # fallback call internal_error().
+
+    postdefault ) : ;;
+
+       # A value to assign to MEMBER of the new gdbarch object should
+       # the target code fail to change the PREDEFAULT value.
+
+       # If POSTDEFAULT is empty, no post update is performed.
+
+       # If both INVALID_P and POSTDEFAULT are non-empty then
+       # INVALID_P will be used to determine if MEMBER should be
+       # changed to POSTDEFAULT.
+
+       # FIXME: NOT YET.  Can this be simplified?  Specify a
+       # non-empty POSTDEFAULT and a zero INVALID_P to create a
        # fallback value or function for when multi-arch is disabled.
-       # Specify a zero DEFAULT function to make that fallback
-       # illegal to call.
+       # Specify a zero POSTDEFAULT function to make that fallback
+       # call internal_error(). This overrides PREDEFAULT.
 
     invalid_p ) : ;;
 
-       # A predicate equation that validates MEMBER. Non-zero is
+       # A predicate equation that validates MEMBER.  Non-zero is
        # returned if the code creating the new architecture failed to
-       # initialize the MEMBER or initialized the member to something
-       # invalid. By default, a check that the value is no longer
-       # equal to DEFAULT is performed.  The equation ``0'' disables
-       # the invalid_p check.
+       # initialize MEMBER or the initialized the member is invalid.
+       # If POSTDEFAULT is non-empty then MEMBER will be updated to
+       # that value.  If POSTDEFAULT is empty then internal_error()
+       # is called.
+
+       # If INVALID_P is empty, a check that MEMBER is no longer
+       # equal to PREDEFAULT is used.
+
+       # The expression ``0'' disables the INVALID_P check.
+
+       # See also PREDEFAULT and POSTDEFAULT.
 
     fmt ) : ;;
 
@@ -182,14 +217,14 @@ do
        # MEMBER.  Sometimes "%s" is useful.  For functions, this is
        # ignored and the function address is printed.
 
-       # By default ```%ld'' is used.  
+       # If FMT is empty, ``%ld'' is used.  
 
     print ) : ;;
 
        # An optional equation that casts MEMBER to a value suitable
        # for formatting by FMT.
 
-       # By default ``(long)'' is used.
+       # If PRINT is empty, ``(long)'' is used.
 
     print_p ) : ;;
 
@@ -199,9 +234,11 @@ do
        #   exp -> Wrap print up in ``if (${print_p}) ...
        #   ``'' -> No predicate
 
+       # If PRINT_P is empty, ``1'' is always used.
+
     description ) : ;;
 
-      # Currently unused.
+       # Currently unused.
 
     *) exit 1;;
   esac
@@ -213,11 +250,11 @@ function_list ()
 {
   # See below (DOCO) for description of each field
   cat <<EOF |
-i:2:TARGET_ARCHITECTURE:const struct bfd_arch_info *:bfd_arch_info::::&bfd_default_arch_struct:::%s:TARGET_ARCHITECTURE->printable_name:TARGET_ARCHITECTURE != NULL
+i:2:TARGET_ARCHITECTURE:const struct bfd_arch_info *:bfd_arch_info::::&bfd_default_arch_struct::::%s:TARGET_ARCHITECTURE->printable_name:TARGET_ARCHITECTURE != NULL
 #
 i:2:TARGET_BYTE_ORDER:int:byte_order::::BIG_ENDIAN
 #
-v:1:TARGET_BFD_VMA_BIT:int:bfd_vma_bit::::8 * sizeof (void*):TARGET_ARCHITECTURE->bits_per_address:0
+v:1:TARGET_BFD_VMA_BIT:int:bfd_vma_bit::::8 * sizeof (void*):TARGET_ARCHITECTURE->bits_per_address::0
 v:1:TARGET_PTR_BIT:int:ptr_bit::::8 * sizeof (void*):0
 #v:1:TARGET_CHAR_BIT:int:char_bit::::8 * sizeof (char):0
 v:1:TARGET_SHORT_BIT:int:short_bit::::8 * sizeof (short):0
@@ -227,7 +264,7 @@ v:1:TARGET_LONG_LONG_BIT:int:long_long_bit::::8 * sizeof (LONGEST):0
 v:1:TARGET_FLOAT_BIT:int:float_bit::::8 * sizeof (float):0
 v:1:TARGET_DOUBLE_BIT:int:double_bit::::8 * sizeof (double):0
 v:1:TARGET_LONG_DOUBLE_BIT:int:long_double_bit::::8 * sizeof (long double):0
-v:1:IEEE_FLOAT:int:ieee_float::::0:0:0:::
+v:1:IEEE_FLOAT:int:ieee_float::::0:0::0:::
 #
 f:1:TARGET_READ_PC:CORE_ADDR:read_pc:int pid:pid::0:0
 f:1:TARGET_WRITE_PC:void:write_pc:CORE_ADDR val, int pid:val, pid::0:0
@@ -240,10 +277,10 @@ v:2:NUM_REGS:int:num_regs::::0:-1
 v:2:SP_REGNUM:int:sp_regnum::::0:-1
 v:2:FP_REGNUM:int:fp_regnum::::0:-1
 v:2:PC_REGNUM:int:pc_regnum::::0:-1
-v:2:FP0_REGNUM:int:fp0_regnum::::0:-1:0
-v:2:NPC_REGNUM:int:npc_regnum::::0:-1:0
-v:2:NNPC_REGNUM:int:nnpc_regnum::::0:-1:0
-f:2:REGISTER_NAME:char *:register_name:int regnr:regnr:::legacy_register_name:0
+v:2:FP0_REGNUM:int:fp0_regnum::::0:-1::0
+v:2:NPC_REGNUM:int:npc_regnum::::0:-1::0
+v:2:NNPC_REGNUM:int:nnpc_regnum::::0:-1::0
+f:2:REGISTER_NAME:char *:register_name:int regnr:regnr:::legacy_register_name::0
 v:2:REGISTER_SIZE:int:register_size::::0:-1
 v:2:REGISTER_BYTES:int:register_bytes::::0:-1
 f:2:REGISTER_BYTE:int:register_byte:int reg_nr:reg_nr::0:0
@@ -255,32 +292,32 @@ f:2:REGISTER_VIRTUAL_TYPE:struct type *:register_virtual_type:int reg_nr:reg_nr:
 #
 v:1:USE_GENERIC_DUMMY_FRAMES:int:use_generic_dummy_frames::::0:-1
 v:2:CALL_DUMMY_LOCATION:int:call_dummy_location::::0:0
-f:2:CALL_DUMMY_ADDRESS:CORE_ADDR:call_dummy_address:void:::0:0:gdbarch->call_dummy_location == AT_ENTRY_POINT && gdbarch->call_dummy_address == 0:
-v:2:CALL_DUMMY_START_OFFSET:CORE_ADDR:call_dummy_start_offset::::0:-1::0x%08lx
-v:2:CALL_DUMMY_BREAKPOINT_OFFSET:CORE_ADDR:call_dummy_breakpoint_offset::::0:-1::0x%08lx
+f:2:CALL_DUMMY_ADDRESS:CORE_ADDR:call_dummy_address:void:::0:0::gdbarch->call_dummy_location == AT_ENTRY_POINT && gdbarch->call_dummy_address == 0
+v:2:CALL_DUMMY_START_OFFSET:CORE_ADDR:call_dummy_start_offset::::0:-1:::0x%08lx
+v:2:CALL_DUMMY_BREAKPOINT_OFFSET:CORE_ADDR:call_dummy_breakpoint_offset::::0:-1:::0x%08lx
 v:1:CALL_DUMMY_BREAKPOINT_OFFSET_P:int:call_dummy_breakpoint_offset_p::::0:-1
-v:2:CALL_DUMMY_LENGTH:int:call_dummy_length::::0:-1::::CALL_DUMMY_LOCATION == BEFORE_TEXT_END || CALL_DUMMY_LOCATION == AFTER_TEXT_END
+v:2:CALL_DUMMY_LENGTH:int:call_dummy_length::::0:-1:::::CALL_DUMMY_LOCATION == BEFORE_TEXT_END || CALL_DUMMY_LOCATION == AFTER_TEXT_END
 f:2:PC_IN_CALL_DUMMY:int:pc_in_call_dummy:CORE_ADDR pc, CORE_ADDR sp, CORE_ADDR frame_address:pc, sp, frame_address::0:0
 v:1:CALL_DUMMY_P:int:call_dummy_p::::0:-1
-v:2:CALL_DUMMY_WORDS:LONGEST *:call_dummy_words::::0:legacy_call_dummy_words:0:0x%08lx
-v:2:SIZEOF_CALL_DUMMY_WORDS:int:sizeof_call_dummy_words::::0:legacy_sizeof_call_dummy_words:0:0x%08lx
-v:1:CALL_DUMMY_STACK_ADJUST_P:int:call_dummy_stack_adjust_p::::0:-1::0x%08lx
-v:2:CALL_DUMMY_STACK_ADJUST:int:call_dummy_stack_adjust::::0::gdbarch->call_dummy_stack_adjust_p && gdbarch->call_dummy_stack_adjust == 0:0x%08lx::CALL_DUMMY_STACK_ADJUST_P
-f:2:FIX_CALL_DUMMY:void:fix_call_dummy:char *dummy, CORE_ADDR pc, CORE_ADDR fun, int nargs, struct value **args, struct type *type, int gcc_p:dummy, pc, fun, nargs, args, type, gcc_p::0:0
+v:2:CALL_DUMMY_WORDS:LONGEST *:call_dummy_words::::0:legacy_call_dummy_words::0:0x%08lx
+v:2:SIZEOF_CALL_DUMMY_WORDS:int:sizeof_call_dummy_words::::0:legacy_sizeof_call_dummy_words::0:0x%08lx
+v:1:CALL_DUMMY_STACK_ADJUST_P:int:call_dummy_stack_adjust_p::::0:-1:::0x%08lx
+v:2:CALL_DUMMY_STACK_ADJUST:int:call_dummy_stack_adjust::::0:::gdbarch->call_dummy_stack_adjust_p && gdbarch->call_dummy_stack_adjust == 0:0x%08lx::CALL_DUMMY_STACK_ADJUST_P
+f:2:FIX_CALL_DUMMY:void:fix_call_dummy:char *dummy, CORE_ADDR pc, CORE_ADDR fun, int nargs, struct value **args, struct type *type, int gcc_p:dummy, pc, fun, nargs, args, type, gcc_p:::0
 #
 v:2:BELIEVE_PCC_PROMOTION:int:believe_pcc_promotion::::0:::::
 v:2:BELIEVE_PCC_PROMOTION_TYPE:int:believe_pcc_promotion_type::::0:::::
-f:2:COERCE_FLOAT_TO_DOUBLE:int:coerce_float_to_double:struct type *formal, struct type *actual:formal, actual:::default_coerce_float_to_double:0
+f:2:COERCE_FLOAT_TO_DOUBLE:int:coerce_float_to_double:struct type *formal, struct type *actual:formal, actual:::default_coerce_float_to_double::0
 f:1:GET_SAVED_REGISTER:void:get_saved_register:char *raw_buffer, int *optimized, CORE_ADDR *addrp, struct frame_info *frame, int regnum, enum lval_type *lval:raw_buffer, optimized, addrp, frame, regnum, lval::generic_get_saved_register:0
 #
-f:1:REGISTER_CONVERTIBLE:int:register_convertible:int nr:nr:::generic_register_convertible_not:0
-f:2:REGISTER_CONVERT_TO_VIRTUAL:void:register_convert_to_virtual:int regnum, struct type *type, char *from, char *to:regnum, type, from, to:::0:0
-f:2:REGISTER_CONVERT_TO_RAW:void:register_convert_to_raw:struct type *type, int regnum, char *from, char *to:type, regnum, from, to:::0:0
+f:1:REGISTER_CONVERTIBLE:int:register_convertible:int nr:nr:::generic_register_convertible_not::0
+f:2:REGISTER_CONVERT_TO_VIRTUAL:void:register_convert_to_virtual:int regnum, struct type *type, char *from, char *to:regnum, type, from, to:::0::0
+f:2:REGISTER_CONVERT_TO_RAW:void:register_convert_to_raw:struct type *type, int regnum, char *from, char *to:type, regnum, from, to:::0::0
 #
-f:2:POINTER_TO_ADDRESS:CORE_ADDR:pointer_to_address:struct type *type, char *buf:type, buf:::generic_pointer_to_address:0
-f:2:ADDRESS_TO_POINTER:void:address_to_pointer:struct type *type, char *buf, CORE_ADDR addr:type, buf, addr:::generic_address_to_pointer:0
+f:2:POINTER_TO_ADDRESS:CORE_ADDR:pointer_to_address:struct type *type, char *buf:type, buf:::generic_pointer_to_address::0
+f:2:ADDRESS_TO_POINTER:void:address_to_pointer:struct type *type, char *buf, CORE_ADDR addr:type, buf, addr:::generic_address_to_pointer::0
 #
-f:2:RETURN_VALUE_ON_STACK:int:return_value_on_stack:struct type *type:type:::generic_return_value_on_stack_not:0
+f:2:RETURN_VALUE_ON_STACK:int:return_value_on_stack:struct type *type:type:::generic_return_value_on_stack_not::0
 f:2:EXTRACT_RETURN_VALUE:void:extract_return_value:struct type *type, char *regbuf, char *valbuf:type, regbuf, valbuf::0:0
 f:1:PUSH_ARGUMENTS:CORE_ADDR:push_arguments:int nargs, struct value **args, CORE_ADDR sp, int struct_return, CORE_ADDR struct_addr:nargs, args, sp, struct_return, struct_addr::0:0
 f:2:PUSH_DUMMY_FRAME:void:push_dummy_frame:void:-:::0
@@ -288,12 +325,12 @@ f:1:PUSH_RETURN_ADDRESS:CORE_ADDR:push_return_address:CORE_ADDR pc, CORE_ADDR sp
 f:2:POP_FRAME:void:pop_frame:void:-:::0
 #
 # I wish that these would just go away....
-f:2:D10V_MAKE_DADDR:CORE_ADDR:d10v_make_daddr:CORE_ADDR x:x:::0:0
-f:2:D10V_MAKE_IADDR:CORE_ADDR:d10v_make_iaddr:CORE_ADDR x:x:::0:0
-f:2:D10V_DADDR_P:int:d10v_daddr_p:CORE_ADDR x:x:::0:0
-f:2:D10V_IADDR_P:int:d10v_iaddr_p:CORE_ADDR x:x:::0:0
-f:2:D10V_CONVERT_DADDR_TO_RAW:CORE_ADDR:d10v_convert_daddr_to_raw:CORE_ADDR x:x:::0:0
-f:2:D10V_CONVERT_IADDR_TO_RAW:CORE_ADDR:d10v_convert_iaddr_to_raw:CORE_ADDR x:x:::0:0
+f:2:D10V_MAKE_DADDR:CORE_ADDR:d10v_make_daddr:CORE_ADDR x:x:::0::0
+f:2:D10V_MAKE_IADDR:CORE_ADDR:d10v_make_iaddr:CORE_ADDR x:x:::0::0
+f:2:D10V_DADDR_P:int:d10v_daddr_p:CORE_ADDR x:x:::0::0
+f:2:D10V_IADDR_P:int:d10v_iaddr_p:CORE_ADDR x:x:::0::0
+f:2:D10V_CONVERT_DADDR_TO_RAW:CORE_ADDR:d10v_convert_daddr_to_raw:CORE_ADDR x:x:::0::0
+f:2:D10V_CONVERT_IADDR_TO_RAW:CORE_ADDR:d10v_convert_iaddr_to_raw:CORE_ADDR x:x:::0::0
 #
 f:2:STORE_STRUCT_RETURN:void:store_struct_return:CORE_ADDR addr, CORE_ADDR sp:addr, sp:::0
 f:2:STORE_RETURN_VALUE:void:store_return_value:struct type *type, char *valbuf:type, valbuf:::0
@@ -304,18 +341,18 @@ f:2:FRAME_INIT_SAVED_REGS:void:frame_init_saved_regs:struct frame_info *frame:fr
 f:2:INIT_EXTRA_FRAME_INFO:void:init_extra_frame_info:int fromleaf, struct frame_info *frame:fromleaf, frame:::0
 #
 f:2:SKIP_PROLOGUE:CORE_ADDR:skip_prologue:CORE_ADDR ip:ip::0:0
-f:2:PROLOGUE_FRAMELESS_P:int:prologue_frameless_p:CORE_ADDR ip:ip::0:generic_prologue_frameless_p:0
+f:2:PROLOGUE_FRAMELESS_P:int:prologue_frameless_p:CORE_ADDR ip:ip::0:generic_prologue_frameless_p::0
 f:2:INNER_THAN:int:inner_than:CORE_ADDR lhs, CORE_ADDR rhs:lhs, rhs::0:0
-f:2:BREAKPOINT_FROM_PC:unsigned char *:breakpoint_from_pc:CORE_ADDR *pcptr, int *lenptr:pcptr, lenptr:::legacy_breakpoint_from_pc:0
-f:2:MEMORY_INSERT_BREAKPOINT:int:memory_insert_breakpoint:CORE_ADDR addr, char *contents_cache:addr, contents_cache::0:default_memory_insert_breakpoint:0
-f:2:MEMORY_REMOVE_BREAKPOINT:int:memory_remove_breakpoint:CORE_ADDR addr, char *contents_cache:addr, contents_cache::0:default_memory_remove_breakpoint:0
+f:2:BREAKPOINT_FROM_PC:unsigned char *:breakpoint_from_pc:CORE_ADDR *pcptr, int *lenptr:pcptr, lenptr:::legacy_breakpoint_from_pc::0
+f:2:MEMORY_INSERT_BREAKPOINT:int:memory_insert_breakpoint:CORE_ADDR addr, char *contents_cache:addr, contents_cache::0:default_memory_insert_breakpoint::0
+f:2:MEMORY_REMOVE_BREAKPOINT:int:memory_remove_breakpoint:CORE_ADDR addr, char *contents_cache:addr, contents_cache::0:default_memory_remove_breakpoint::0
 v:2:DECR_PC_AFTER_BREAK:CORE_ADDR:decr_pc_after_break::::0:-1
 v:2:FUNCTION_START_OFFSET:CORE_ADDR:function_start_offset::::0:-1
 #
-f:2:REMOTE_TRANSLATE_XFER_ADDRESS:void:remote_translate_xfer_address:CORE_ADDR gdb_addr, int gdb_len, CORE_ADDR *rem_addr, int *rem_len:gdb_addr, gdb_len, rem_addr, rem_len:::generic_remote_translate_xfer_address:0
+f:2:REMOTE_TRANSLATE_XFER_ADDRESS:void:remote_translate_xfer_address:CORE_ADDR gdb_addr, int gdb_len, CORE_ADDR *rem_addr, int *rem_len:gdb_addr, gdb_len, rem_addr, rem_len:::generic_remote_translate_xfer_address::0
 #
 v:2:FRAME_ARGS_SKIP:CORE_ADDR:frame_args_skip::::0:-1
-f:2:FRAMELESS_FUNCTION_INVOCATION:int:frameless_function_invocation:struct frame_info *fi:fi:::generic_frameless_function_invocation_not:0
+f:2:FRAMELESS_FUNCTION_INVOCATION:int:frameless_function_invocation:struct frame_info *fi:fi:::generic_frameless_function_invocation_not::0
 f:2:FRAME_CHAIN:CORE_ADDR:frame_chain:struct frame_info *frame:frame::0:0
 f:1:FRAME_CHAIN_VALID:int:frame_chain_valid:CORE_ADDR chain, struct frame_info *thisframe:chain, thisframe::0:0
 f:2:FRAME_SAVED_PC:CORE_ADDR:frame_saved_pc:struct frame_info *fi:fi::0:0
@@ -331,19 +368,19 @@ EOF
   grep -v '^#'
 }
 
-
-# dump it out
-if true
-then
-    exec > new-gdbarch
-    function_list | while do_read # eval read $read
-    do
-       cat <<EOF
+#
+# The .log file
+#
+exec > new-gdbarch.log
+function_list | while do_read # eval read $read
+do
+    cat <<EOF
 ${class} ${macro}(${actual})
   ${returntype} ${function} ($formal)${attrib}
     level=${level}
-    startup=${startup}
-    default=${default}
+    staticdefault=${staticdefault}
+    predefault=${predefault}
+    postdefault=${predefault}
     invalid_p=${invalid_p}
     valid_p=${valid_p}
     fmt=${fmt}
@@ -351,15 +388,17 @@ ${class} ${macro}(${actual})
     print_p=${print_p}
     description=${description}
 EOF
-       if class_is_predicate_p && default_is_fallback_p
-       then
-           echo "Error: predicate function can not have a non- multi-arch default" 1>&2
-           kill $$
-           exit 1
-       fi
-    done
-    exec 1>&2
-fi
+    if class_is_predicate_p && default_is_fallback_p
+    then
+       echo "Error: predicate function can not have a non- multi-arch default" 1>&2
+       kill $$
+       exit 1
+    fi
+done
+
+exec 1>&2
+compare_new gdbarch.log
+
 
 copyright ()
 {
@@ -493,7 +532,7 @@ do
            echo ""
            echo "/* Default (value) for non- multi-arch platforms. */"
            echo "#if (GDB_MULTI_ARCH == 0) && !defined (${macro})"
-           echo "#define ${macro} (${default})"
+           echo "#define ${macro} (${predefault})"
            echo "#endif"
        fi
        echo ""
@@ -512,11 +551,11 @@ do
            echo ""
            echo "/* Default (function) for non- multi-arch platforms. */"
            echo "#if (GDB_MULTI_ARCH == 0) && !defined (${macro})"
-           if [ "${default}" = "0" ]
+           if [ "${predefault}" = "0" ]
            then
                echo "#define ${macro}(${actual}) (internal_error (\"${macro}\"), 0)"
            else
-               echo "#define ${macro}(${actual}) (${default} (${actual}))"
+               echo "#define ${macro}(${actual}) (${predefault} (${actual}))"
            fi
            echo "#endif"
        fi
@@ -983,7 +1022,7 @@ function_list | while do_read # eval read $read
 do
     if class_is_info_p
     then
-       echo "  ${startup},"
+       echo "  ${staticdefault},"
     fi
 done
 cat <<EOF
@@ -997,7 +1036,7 @@ function_list | while do_read # eval read $read
 do
     if class_is_function_p || class_is_variable_p
     then
-       echo "  ${startup},"
+       echo "  ${staticdefault},"
     fi
 done
 cat <<EOF
@@ -1038,9 +1077,9 @@ function_list | while do_read # eval read $read
 do
     if class_is_function_p || class_is_variable_p
     then
-       if [ "${default}" != "" -a "${default}" != "0" ]
+       if [ "${predefault}" != "" -a "${predefault}" != "0" ]
        then
-         echo "  gdbarch->${function} = ${default};"
+         echo "  gdbarch->${function} = ${predefault};"
        fi
     fi
 done
@@ -1102,10 +1141,10 @@ do
            echo "  if ((GDB_MULTI_ARCH >= ${level})"
            echo "      && (${invalid_p}))"
            echo "    internal_error (\"gdbarch: verify_gdbarch: ${function} invalid\");"
-       elif [ "${default}" ]
+       elif [ "${predefault}" ]
        then
            echo "  if ((GDB_MULTI_ARCH >= ${level})"
-           echo "      && (gdbarch->${function} == ${default}))"
+           echo "      && (gdbarch->${function} == ${predefault}))"
            echo "    internal_error (\"gdbarch: verify_gdbarch: ${function} invalid\");"
        fi
     fi
@@ -1227,9 +1266,9 @@ do
        then
          echo "  if (${invalid_p})"
          echo "    internal_error (\"gdbarch: gdbarch_${function} invalid\");"
-       elif [ "${default}" ]
+       elif [ "${predefault}" ]
        then
-         echo "  if (gdbarch->${function} == ${default})"
+         echo "  if (gdbarch->${function} == ${predefault})"
          echo "    internal_error (\"gdbarch: gdbarch_${function} invalid\");"
        fi
        echo "  if (gdbarch_debug >= 2)"