X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Fregformats%2Fregdat.sh;h=1839a881213c0603fb88a3e54bd7139a2777fb78;hb=6e2118f588c6f33a741a706725f8e23db57251b3;hp=fabc910f082b2cc36e9eba971c46b76bc9e36935;hpb=bdf61915fc102bc07c12aa450376d7402bd427b4;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/regformats/regdat.sh b/gdb/regformats/regdat.sh index fabc910f08..1839a88121 100755 --- a/gdb/regformats/regdat.sh +++ b/gdb/regformats/regdat.sh @@ -1,7 +1,7 @@ #!/bin/sh -u # Register protocol definitions for GDB, the GNU debugger. -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2020 Free Software Foundation, Inc. # # This file is part of GDB. # @@ -118,12 +118,21 @@ xmltarget=x xmlarch=x xmlosabi=x expedite=x +feature=x exec < $1 while do_read do if test "${type}" = "name"; then name="${entry}" - echo "static struct reg regs_${name}[] = {" + + echo "const struct target_desc *tdesc_${name};" + echo "" + echo "void" + echo "init_registers_${name} (void)" + echo "{" + echo " static struct target_desc tdesc_${name}_s;" + echo " struct target_desc *result = &tdesc_${name}_s;" + echo " struct tdesc_feature *feature = tdesc_create_feature (result, \"${name}\");" continue elif test "${type}" = "xmltarget"; then xmltarget="${entry}" @@ -137,20 +146,28 @@ do elif test "${type}" = "expedite"; then expedite="${entry}" continue + elif test "${type}" = "feature"; then + feature="${entry}" + continue elif test "${name}" = x; then echo "$0: $1 does not specify \`\`name''." 1>&2 exit 1 else - echo " { \"${entry}\", ${offset}, ${type} }," + echo " tdesc_create_reg (feature, \"${entry}\"," + echo " 0, 0, NULL, ${type}, NULL);" + offset=`expr ${offset} + ${type}` i=`expr $i + 1` fi done -echo "};" echo echo "static const char *expedite_regs_${name}[] = { \"`echo ${expedite} | sed 's/,/", "/g'`\", 0 };" -if test "${xmltarget}" = x; then + +echo "#ifndef IN_PROCESS_AGENT" +if test "${feature}" != x; then + echo "static const char *xmltarget_${name} = 0;" +elif test "${xmltarget}" = x; then if test "${xmlarch}" = x && test "${xmlosabi}" = x; then echo "static const char *xmltarget_${name} = 0;" else @@ -169,20 +186,10 @@ fi echo cat <reg_defs = regs_${name}; - result->num_registers = sizeof (regs_${name}) / sizeof (regs_${name}[0]); - result->expedite_regs = expedite_regs_${name}; result->xmltarget = xmltarget_${name}; +#endif - init_target_desc (result); + init_target_desc (result, expedite_regs_${name}); tdesc_${name} = result; }