diff options
author | Simon Marchi <simon.marchi@efficios.com> | 2020-11-02 10:26:14 -0500 |
---|---|---|
committer | Simon Marchi <simon.marchi@efficios.com> | 2020-11-02 10:28:45 -0500 |
commit | dda83cd783075941aabe9b0292b004b11f00c831 (patch) | |
tree | 185c06ef106c06ecc55ea045a4916495c1a3526b /gdb/mep-tdep.c | |
parent | 1c2bec1918cee91221bccc30db4f0253dc31d1b7 (diff) | |
download | binutils-gdb-dda83cd783075941aabe9b0292b004b11f00c831.tar.gz |
gdb, gdbserver, gdbsupport: fix leading space vs tabs issues
Many spots incorrectly use only spaces for indentation (for example,
there are a lot of spots in ada-lang.c). I've always found it awkward
when I needed to edit one of these spots: do I keep the original wrong
indentation, or do I fix it? What if the lines around it are also
wrong, do I fix them too? I probably don't want to fix them in the same
patch, to avoid adding noise to my patch.
So I propose to fix as much as possible once and for all (hopefully).
One typical counter argument for this is that it makes code archeology
more difficult, because git-blame will show this commit as the last
change for these lines. My counter counter argument is: when
git-blaming, you often need to do "blame the file at the parent commit"
anyway, to go past some other refactor that touched the line you are
interested in, but is not the change you are looking for. So you
already need a somewhat efficient way to do this.
Using some interactive tool, rather than plain git-blame, makes this
trivial. For example, I use "tig blame <file>", where going back past
the commit that changed the currently selected line is one keystroke.
It looks like Magit in Emacs does it too (though I've never used it).
Web viewers of Github and Gitlab do it too. My point is that it won't
really make archeology more difficult.
The other typical counter argument is that it will cause conflicts with
existing patches. That's true... but it's a one time cost, and those
are not conflicts that are difficult to resolve. I have also tried "git
rebase --ignore-whitespace", it seems to work well. Although that will
re-introduce the faulty indentation, so one needs to take care of fixing
the indentation in the patch after that (which is easy).
gdb/ChangeLog:
* aarch64-linux-tdep.c: Fix indentation.
* aarch64-ravenscar-thread.c: Fix indentation.
* aarch64-tdep.c: Fix indentation.
* aarch64-tdep.h: Fix indentation.
* ada-lang.c: Fix indentation.
* ada-lang.h: Fix indentation.
* ada-tasks.c: Fix indentation.
* ada-typeprint.c: Fix indentation.
* ada-valprint.c: Fix indentation.
* ada-varobj.c: Fix indentation.
* addrmap.c: Fix indentation.
* addrmap.h: Fix indentation.
* agent.c: Fix indentation.
* aix-thread.c: Fix indentation.
* alpha-bsd-nat.c: Fix indentation.
* alpha-linux-tdep.c: Fix indentation.
* alpha-mdebug-tdep.c: Fix indentation.
* alpha-nbsd-tdep.c: Fix indentation.
* alpha-obsd-tdep.c: Fix indentation.
* alpha-tdep.c: Fix indentation.
* amd64-bsd-nat.c: Fix indentation.
* amd64-darwin-tdep.c: Fix indentation.
* amd64-linux-nat.c: Fix indentation.
* amd64-linux-tdep.c: Fix indentation.
* amd64-nat.c: Fix indentation.
* amd64-obsd-tdep.c: Fix indentation.
* amd64-tdep.c: Fix indentation.
* amd64-windows-tdep.c: Fix indentation.
* annotate.c: Fix indentation.
* arc-tdep.c: Fix indentation.
* arch-utils.c: Fix indentation.
* arch/arm-get-next-pcs.c: Fix indentation.
* arch/arm.c: Fix indentation.
* arm-linux-nat.c: Fix indentation.
* arm-linux-tdep.c: Fix indentation.
* arm-nbsd-tdep.c: Fix indentation.
* arm-pikeos-tdep.c: Fix indentation.
* arm-tdep.c: Fix indentation.
* arm-tdep.h: Fix indentation.
* arm-wince-tdep.c: Fix indentation.
* auto-load.c: Fix indentation.
* auxv.c: Fix indentation.
* avr-tdep.c: Fix indentation.
* ax-gdb.c: Fix indentation.
* ax-general.c: Fix indentation.
* bfin-linux-tdep.c: Fix indentation.
* block.c: Fix indentation.
* block.h: Fix indentation.
* blockframe.c: Fix indentation.
* bpf-tdep.c: Fix indentation.
* break-catch-sig.c: Fix indentation.
* break-catch-syscall.c: Fix indentation.
* break-catch-throw.c: Fix indentation.
* breakpoint.c: Fix indentation.
* breakpoint.h: Fix indentation.
* bsd-uthread.c: Fix indentation.
* btrace.c: Fix indentation.
* build-id.c: Fix indentation.
* buildsym-legacy.h: Fix indentation.
* buildsym.c: Fix indentation.
* c-typeprint.c: Fix indentation.
* c-valprint.c: Fix indentation.
* c-varobj.c: Fix indentation.
* charset.c: Fix indentation.
* cli/cli-cmds.c: Fix indentation.
* cli/cli-decode.c: Fix indentation.
* cli/cli-decode.h: Fix indentation.
* cli/cli-script.c: Fix indentation.
* cli/cli-setshow.c: Fix indentation.
* coff-pe-read.c: Fix indentation.
* coffread.c: Fix indentation.
* compile/compile-cplus-types.c: Fix indentation.
* compile/compile-object-load.c: Fix indentation.
* compile/compile-object-run.c: Fix indentation.
* completer.c: Fix indentation.
* corefile.c: Fix indentation.
* corelow.c: Fix indentation.
* cp-abi.h: Fix indentation.
* cp-namespace.c: Fix indentation.
* cp-support.c: Fix indentation.
* cp-valprint.c: Fix indentation.
* cris-linux-tdep.c: Fix indentation.
* cris-tdep.c: Fix indentation.
* darwin-nat-info.c: Fix indentation.
* darwin-nat.c: Fix indentation.
* darwin-nat.h: Fix indentation.
* dbxread.c: Fix indentation.
* dcache.c: Fix indentation.
* disasm.c: Fix indentation.
* dtrace-probe.c: Fix indentation.
* dwarf2/abbrev.c: Fix indentation.
* dwarf2/attribute.c: Fix indentation.
* dwarf2/expr.c: Fix indentation.
* dwarf2/frame.c: Fix indentation.
* dwarf2/index-cache.c: Fix indentation.
* dwarf2/index-write.c: Fix indentation.
* dwarf2/line-header.c: Fix indentation.
* dwarf2/loc.c: Fix indentation.
* dwarf2/macro.c: Fix indentation.
* dwarf2/read.c: Fix indentation.
* dwarf2/read.h: Fix indentation.
* elfread.c: Fix indentation.
* eval.c: Fix indentation.
* event-top.c: Fix indentation.
* exec.c: Fix indentation.
* exec.h: Fix indentation.
* expprint.c: Fix indentation.
* f-lang.c: Fix indentation.
* f-typeprint.c: Fix indentation.
* f-valprint.c: Fix indentation.
* fbsd-nat.c: Fix indentation.
* fbsd-tdep.c: Fix indentation.
* findvar.c: Fix indentation.
* fork-child.c: Fix indentation.
* frame-unwind.c: Fix indentation.
* frame-unwind.h: Fix indentation.
* frame.c: Fix indentation.
* frv-linux-tdep.c: Fix indentation.
* frv-tdep.c: Fix indentation.
* frv-tdep.h: Fix indentation.
* ft32-tdep.c: Fix indentation.
* gcore.c: Fix indentation.
* gdb_bfd.c: Fix indentation.
* gdbarch.sh: Fix indentation.
* gdbarch.c: Re-generate
* gdbarch.h: Re-generate.
* gdbcore.h: Fix indentation.
* gdbthread.h: Fix indentation.
* gdbtypes.c: Fix indentation.
* gdbtypes.h: Fix indentation.
* glibc-tdep.c: Fix indentation.
* gnu-nat.c: Fix indentation.
* gnu-nat.h: Fix indentation.
* gnu-v2-abi.c: Fix indentation.
* gnu-v3-abi.c: Fix indentation.
* go32-nat.c: Fix indentation.
* guile/guile-internal.h: Fix indentation.
* guile/scm-cmd.c: Fix indentation.
* guile/scm-frame.c: Fix indentation.
* guile/scm-iterator.c: Fix indentation.
* guile/scm-math.c: Fix indentation.
* guile/scm-ports.c: Fix indentation.
* guile/scm-pretty-print.c: Fix indentation.
* guile/scm-value.c: Fix indentation.
* h8300-tdep.c: Fix indentation.
* hppa-linux-nat.c: Fix indentation.
* hppa-linux-tdep.c: Fix indentation.
* hppa-nbsd-nat.c: Fix indentation.
* hppa-nbsd-tdep.c: Fix indentation.
* hppa-obsd-nat.c: Fix indentation.
* hppa-tdep.c: Fix indentation.
* hppa-tdep.h: Fix indentation.
* i386-bsd-nat.c: Fix indentation.
* i386-darwin-nat.c: Fix indentation.
* i386-darwin-tdep.c: Fix indentation.
* i386-dicos-tdep.c: Fix indentation.
* i386-gnu-nat.c: Fix indentation.
* i386-linux-nat.c: Fix indentation.
* i386-linux-tdep.c: Fix indentation.
* i386-nto-tdep.c: Fix indentation.
* i386-obsd-tdep.c: Fix indentation.
* i386-sol2-nat.c: Fix indentation.
* i386-tdep.c: Fix indentation.
* i386-tdep.h: Fix indentation.
* i386-windows-tdep.c: Fix indentation.
* i387-tdep.c: Fix indentation.
* i387-tdep.h: Fix indentation.
* ia64-libunwind-tdep.c: Fix indentation.
* ia64-libunwind-tdep.h: Fix indentation.
* ia64-linux-nat.c: Fix indentation.
* ia64-linux-tdep.c: Fix indentation.
* ia64-tdep.c: Fix indentation.
* ia64-tdep.h: Fix indentation.
* ia64-vms-tdep.c: Fix indentation.
* infcall.c: Fix indentation.
* infcmd.c: Fix indentation.
* inferior.c: Fix indentation.
* infrun.c: Fix indentation.
* iq2000-tdep.c: Fix indentation.
* language.c: Fix indentation.
* linespec.c: Fix indentation.
* linux-fork.c: Fix indentation.
* linux-nat.c: Fix indentation.
* linux-tdep.c: Fix indentation.
* linux-thread-db.c: Fix indentation.
* lm32-tdep.c: Fix indentation.
* m2-lang.c: Fix indentation.
* m2-typeprint.c: Fix indentation.
* m2-valprint.c: Fix indentation.
* m32c-tdep.c: Fix indentation.
* m32r-linux-tdep.c: Fix indentation.
* m32r-tdep.c: Fix indentation.
* m68hc11-tdep.c: Fix indentation.
* m68k-bsd-nat.c: Fix indentation.
* m68k-linux-nat.c: Fix indentation.
* m68k-linux-tdep.c: Fix indentation.
* m68k-tdep.c: Fix indentation.
* machoread.c: Fix indentation.
* macrocmd.c: Fix indentation.
* macroexp.c: Fix indentation.
* macroscope.c: Fix indentation.
* macrotab.c: Fix indentation.
* macrotab.h: Fix indentation.
* main.c: Fix indentation.
* mdebugread.c: Fix indentation.
* mep-tdep.c: Fix indentation.
* mi/mi-cmd-catch.c: Fix indentation.
* mi/mi-cmd-disas.c: Fix indentation.
* mi/mi-cmd-env.c: Fix indentation.
* mi/mi-cmd-stack.c: Fix indentation.
* mi/mi-cmd-var.c: Fix indentation.
* mi/mi-cmds.c: Fix indentation.
* mi/mi-main.c: Fix indentation.
* mi/mi-parse.c: Fix indentation.
* microblaze-tdep.c: Fix indentation.
* minidebug.c: Fix indentation.
* minsyms.c: Fix indentation.
* mips-linux-nat.c: Fix indentation.
* mips-linux-tdep.c: Fix indentation.
* mips-nbsd-tdep.c: Fix indentation.
* mips-tdep.c: Fix indentation.
* mn10300-linux-tdep.c: Fix indentation.
* mn10300-tdep.c: Fix indentation.
* moxie-tdep.c: Fix indentation.
* msp430-tdep.c: Fix indentation.
* namespace.h: Fix indentation.
* nat/fork-inferior.c: Fix indentation.
* nat/gdb_ptrace.h: Fix indentation.
* nat/linux-namespaces.c: Fix indentation.
* nat/linux-osdata.c: Fix indentation.
* nat/netbsd-nat.c: Fix indentation.
* nat/x86-dregs.c: Fix indentation.
* nbsd-nat.c: Fix indentation.
* nbsd-tdep.c: Fix indentation.
* nios2-linux-tdep.c: Fix indentation.
* nios2-tdep.c: Fix indentation.
* nto-procfs.c: Fix indentation.
* nto-tdep.c: Fix indentation.
* objfiles.c: Fix indentation.
* objfiles.h: Fix indentation.
* opencl-lang.c: Fix indentation.
* or1k-tdep.c: Fix indentation.
* osabi.c: Fix indentation.
* osabi.h: Fix indentation.
* osdata.c: Fix indentation.
* p-lang.c: Fix indentation.
* p-typeprint.c: Fix indentation.
* p-valprint.c: Fix indentation.
* parse.c: Fix indentation.
* ppc-linux-nat.c: Fix indentation.
* ppc-linux-tdep.c: Fix indentation.
* ppc-nbsd-nat.c: Fix indentation.
* ppc-nbsd-tdep.c: Fix indentation.
* ppc-obsd-nat.c: Fix indentation.
* ppc-ravenscar-thread.c: Fix indentation.
* ppc-sysv-tdep.c: Fix indentation.
* ppc64-tdep.c: Fix indentation.
* printcmd.c: Fix indentation.
* proc-api.c: Fix indentation.
* producer.c: Fix indentation.
* producer.h: Fix indentation.
* prologue-value.c: Fix indentation.
* prologue-value.h: Fix indentation.
* psymtab.c: Fix indentation.
* python/py-arch.c: Fix indentation.
* python/py-bpevent.c: Fix indentation.
* python/py-event.c: Fix indentation.
* python/py-event.h: Fix indentation.
* python/py-finishbreakpoint.c: Fix indentation.
* python/py-frame.c: Fix indentation.
* python/py-framefilter.c: Fix indentation.
* python/py-inferior.c: Fix indentation.
* python/py-infthread.c: Fix indentation.
* python/py-objfile.c: Fix indentation.
* python/py-prettyprint.c: Fix indentation.
* python/py-registers.c: Fix indentation.
* python/py-signalevent.c: Fix indentation.
* python/py-stopevent.c: Fix indentation.
* python/py-stopevent.h: Fix indentation.
* python/py-threadevent.c: Fix indentation.
* python/py-tui.c: Fix indentation.
* python/py-unwind.c: Fix indentation.
* python/py-value.c: Fix indentation.
* python/py-xmethods.c: Fix indentation.
* python/python-internal.h: Fix indentation.
* python/python.c: Fix indentation.
* ravenscar-thread.c: Fix indentation.
* record-btrace.c: Fix indentation.
* record-full.c: Fix indentation.
* record.c: Fix indentation.
* reggroups.c: Fix indentation.
* regset.h: Fix indentation.
* remote-fileio.c: Fix indentation.
* remote.c: Fix indentation.
* reverse.c: Fix indentation.
* riscv-linux-tdep.c: Fix indentation.
* riscv-ravenscar-thread.c: Fix indentation.
* riscv-tdep.c: Fix indentation.
* rl78-tdep.c: Fix indentation.
* rs6000-aix-tdep.c: Fix indentation.
* rs6000-lynx178-tdep.c: Fix indentation.
* rs6000-nat.c: Fix indentation.
* rs6000-tdep.c: Fix indentation.
* rust-lang.c: Fix indentation.
* rx-tdep.c: Fix indentation.
* s12z-tdep.c: Fix indentation.
* s390-linux-tdep.c: Fix indentation.
* score-tdep.c: Fix indentation.
* ser-base.c: Fix indentation.
* ser-mingw.c: Fix indentation.
* ser-uds.c: Fix indentation.
* ser-unix.c: Fix indentation.
* serial.c: Fix indentation.
* sh-linux-tdep.c: Fix indentation.
* sh-nbsd-tdep.c: Fix indentation.
* sh-tdep.c: Fix indentation.
* skip.c: Fix indentation.
* sol-thread.c: Fix indentation.
* solib-aix.c: Fix indentation.
* solib-darwin.c: Fix indentation.
* solib-frv.c: Fix indentation.
* solib-svr4.c: Fix indentation.
* solib.c: Fix indentation.
* source.c: Fix indentation.
* sparc-linux-tdep.c: Fix indentation.
* sparc-nbsd-tdep.c: Fix indentation.
* sparc-obsd-tdep.c: Fix indentation.
* sparc-ravenscar-thread.c: Fix indentation.
* sparc-tdep.c: Fix indentation.
* sparc64-linux-tdep.c: Fix indentation.
* sparc64-nbsd-tdep.c: Fix indentation.
* sparc64-obsd-tdep.c: Fix indentation.
* sparc64-tdep.c: Fix indentation.
* stabsread.c: Fix indentation.
* stack.c: Fix indentation.
* stap-probe.c: Fix indentation.
* stubs/ia64vms-stub.c: Fix indentation.
* stubs/m32r-stub.c: Fix indentation.
* stubs/m68k-stub.c: Fix indentation.
* stubs/sh-stub.c: Fix indentation.
* stubs/sparc-stub.c: Fix indentation.
* symfile-mem.c: Fix indentation.
* symfile.c: Fix indentation.
* symfile.h: Fix indentation.
* symmisc.c: Fix indentation.
* symtab.c: Fix indentation.
* symtab.h: Fix indentation.
* target-float.c: Fix indentation.
* target.c: Fix indentation.
* target.h: Fix indentation.
* tic6x-tdep.c: Fix indentation.
* tilegx-linux-tdep.c: Fix indentation.
* tilegx-tdep.c: Fix indentation.
* top.c: Fix indentation.
* tracefile-tfile.c: Fix indentation.
* tracepoint.c: Fix indentation.
* tui/tui-disasm.c: Fix indentation.
* tui/tui-io.c: Fix indentation.
* tui/tui-regs.c: Fix indentation.
* tui/tui-stack.c: Fix indentation.
* tui/tui-win.c: Fix indentation.
* tui/tui-winsource.c: Fix indentation.
* tui/tui.c: Fix indentation.
* typeprint.c: Fix indentation.
* ui-out.h: Fix indentation.
* unittests/copy_bitwise-selftests.c: Fix indentation.
* unittests/memory-map-selftests.c: Fix indentation.
* utils.c: Fix indentation.
* v850-tdep.c: Fix indentation.
* valarith.c: Fix indentation.
* valops.c: Fix indentation.
* valprint.c: Fix indentation.
* valprint.h: Fix indentation.
* value.c: Fix indentation.
* value.h: Fix indentation.
* varobj.c: Fix indentation.
* vax-tdep.c: Fix indentation.
* windows-nat.c: Fix indentation.
* windows-tdep.c: Fix indentation.
* xcoffread.c: Fix indentation.
* xml-syscall.c: Fix indentation.
* xml-tdesc.c: Fix indentation.
* xstormy16-tdep.c: Fix indentation.
* xtensa-config.c: Fix indentation.
* xtensa-linux-nat.c: Fix indentation.
* xtensa-linux-tdep.c: Fix indentation.
* xtensa-tdep.c: Fix indentation.
gdbserver/ChangeLog:
* ax.cc: Fix indentation.
* dll.cc: Fix indentation.
* inferiors.h: Fix indentation.
* linux-low.cc: Fix indentation.
* linux-nios2-low.cc: Fix indentation.
* linux-ppc-ipa.cc: Fix indentation.
* linux-ppc-low.cc: Fix indentation.
* linux-x86-low.cc: Fix indentation.
* linux-xtensa-low.cc: Fix indentation.
* regcache.cc: Fix indentation.
* server.cc: Fix indentation.
* tracepoint.cc: Fix indentation.
gdbsupport/ChangeLog:
* common-exceptions.h: Fix indentation.
* event-loop.cc: Fix indentation.
* fileio.cc: Fix indentation.
* filestuff.cc: Fix indentation.
* gdb-dlfcn.cc: Fix indentation.
* gdb_string_view.h: Fix indentation.
* job-control.cc: Fix indentation.
* signals.cc: Fix indentation.
Change-Id: I4bad7ae6be0fbe14168b8ebafb98ffe14964a695
Diffstat (limited to 'gdb/mep-tdep.c')
-rw-r--r-- | gdb/mep-tdep.c | 600 |
1 files changed, 300 insertions, 300 deletions
diff --git a/gdb/mep-tdep.c b/gdb/mep-tdep.c index 0efcf8598f9..b3bf2e8d6e8 100644 --- a/gdb/mep-tdep.c +++ b/gdb/mep-tdep.c @@ -154,9 +154,9 @@ struct gdbarch_tdep return zero. */ static const CGEN_HW_ENTRY * find_hw_entry_by_prefix_and_isa (CGEN_CPU_DESC desc, - const char *prefix, - CGEN_BITSET *copro_isa_mask, - CGEN_BITSET *generic_isa_mask) + const char *prefix, + CGEN_BITSET *copro_isa_mask, + CGEN_BITSET *generic_isa_mask) { int prefix_len = strlen (prefix); int i; @@ -165,15 +165,15 @@ find_hw_entry_by_prefix_and_isa (CGEN_CPU_DESC desc, { const CGEN_HW_ENTRY *hw = desc->hw_table.entries[i]; if (strncmp (prefix, hw->name, prefix_len) == 0) - { - CGEN_BITSET *hw_isa_mask - = ((CGEN_BITSET *) - &CGEN_ATTR_CGEN_HW_ISA_VALUE (CGEN_HW_ATTRS (hw))); - - if (cgen_bitset_intersect_p (hw_isa_mask, copro_isa_mask) - && ! cgen_bitset_intersect_p (hw_isa_mask, generic_isa_mask)) - return hw; - } + { + CGEN_BITSET *hw_isa_mask + = ((CGEN_BITSET *) + &CGEN_ATTR_CGEN_HW_ISA_VALUE (CGEN_HW_ATTRS (hw))); + + if (cgen_bitset_intersect_p (hw_isa_mask, copro_isa_mask) + && ! cgen_bitset_intersect_p (hw_isa_mask, generic_isa_mask)) + return hw; + } } return 0; @@ -192,7 +192,7 @@ find_hw_entry_by_type (CGEN_CPU_DESC desc, CGEN_HW_TYPE type) const CGEN_HW_ENTRY *hw = desc->hw_table.entries[i]; if (hw->type == type) - return hw; + return hw; } return 0; @@ -206,8 +206,8 @@ find_hw_entry_by_type (CGEN_CPU_DESC desc, CGEN_HW_TYPE type) whose hardware type is GENERIC_TYPE. */ static const CGEN_HW_ENTRY * me_module_register_set (CONFIG_ATTR me_module, - const char *prefix, - CGEN_HW_TYPE generic_type) + const char *prefix, + CGEN_HW_TYPE generic_type) { /* This is kind of tricky, because the hardware table is constructed in a way that isn't very helpful. Perhaps we can fix that, but @@ -315,11 +315,11 @@ register_name_from_keyword (CGEN_KEYWORD *keyword_table, int regnum) char *name = entry->name; /* The CGEN keyword entries for register names include the - leading $, which appears in MeP assembly as well as in GDB. - But we don't want to return that; GDB core code adds that - itself. */ + leading $, which appears in MeP assembly as well as in GDB. + But we don't want to return that; GDB core code adds that + itself. */ if (name[0] == '$') - name++; + name++; return name; } @@ -624,7 +624,7 @@ enum #define IS_CR64_REGNUM(n) (IN_SET (CR64, (n))) #define IS_FP_CR64_REGNUM(n) (IN_SET (FP_CR64, (n))) #define IS_CR_REGNUM(n) (IS_CR32_REGNUM (n) || IS_FP_CR32_REGNUM (n) \ - || IS_CR64_REGNUM (n) || IS_FP_CR64_REGNUM (n)) + || IS_CR64_REGNUM (n) || IS_FP_CR64_REGNUM (n)) #define IS_CCR_REGNUM(n) (IN_SET (CCR, (n))) #define IS_RAW_REGNUM(n) (IN_SET (RAW, (n))) @@ -756,11 +756,11 @@ mep_init_pseudoregister_maps (void) int pseudofp64 = MEP_FIRST_FP_CR64_REGNUM + i; /* Truly, the raw->pseudo mapping depends on the current module. - But we use the raw->pseudo mapping when we read the debugging - info; at that point, we don't know what module we'll actually - be running yet. So, we always supply the 64-bit register - numbers; GDB knows how to pick a smaller value out of a - larger register properly. */ + But we use the raw->pseudo mapping when we read the debugging + info; at that point, we don't know what module we'll actually + be running yet. So, we always supply the 64-bit register + numbers; GDB knows how to pick a smaller value out of a + larger register properly. */ mep_raw_to_pseudo[raw] = pseudo64; mep_pseudo_to_raw[pseudo32] = raw; mep_pseudo_to_raw[pseudofp32] = raw; @@ -798,7 +798,7 @@ mep_pseudo_cr_size (int pseudo) || IS_FP_CR32_REGNUM (pseudo)) return 32; else if (IS_CR64_REGNUM (pseudo) - || IS_FP_CR64_REGNUM (pseudo)) + || IS_FP_CR64_REGNUM (pseudo)) return 64; else gdb_assert_not_reached ("unexpected coprocessor pseudo register"); @@ -812,7 +812,7 @@ static int mep_pseudo_cr_is_float (int pseudo) { return (IS_FP_CR32_REGNUM (pseudo) - || IS_FP_CR64_REGNUM (pseudo)); + || IS_FP_CR64_REGNUM (pseudo)); } @@ -953,10 +953,10 @@ mep_register_name (struct gdbarch *gdbarch, int regnr) else if (IS_CSR_REGNUM (regnr)) { /* The 'hi' and 'lo' registers are only present on processors - that have the 'MUL' or 'DIV' instructions enabled. */ + that have the 'MUL' or 'DIV' instructions enabled. */ if ((regnr == MEP_HI_REGNUM || regnr == MEP_LO_REGNUM) - && (! (current_options () & (MEP_OPT_MUL | MEP_OPT_DIV)))) - return ""; + && (! (current_options () & (MEP_OPT_MUL | MEP_OPT_DIV)))) + return ""; return csr_names[regnr - MEP_FIRST_CSR_REGNUM]; } @@ -968,24 +968,24 @@ mep_register_name (struct gdbarch *gdbarch, int regnr) /* Does this module have a coprocessor at all? */ if (! (current_options () & MEP_OPT_COP)) - return ""; + return ""; names = current_cr_names (); if (! names) - /* This module's coprocessor has no general-purpose registers. */ - return ""; + /* This module's coprocessor has no general-purpose registers. */ + return ""; cr_size = current_cop_data_bus_width (); if (cr_size != mep_pseudo_cr_size (regnr)) - /* This module's coprocessor's GPR's are of a different size. */ - return ""; + /* This module's coprocessor's GPR's are of a different size. */ + return ""; cr_is_float = current_cr_is_float (); /* The extra ! operators ensure we get boolean equality, not - numeric equality. */ + numeric equality. */ if (! cr_is_float != ! mep_pseudo_cr_is_float (regnr)) - /* This module's coprocessor's GPR's are of a different type. */ - return ""; + /* This module's coprocessor's GPR's are of a different type. */ + return ""; return register_name_from_keyword (names, mep_pseudo_cr_index (regnr)); } @@ -993,16 +993,16 @@ mep_register_name (struct gdbarch *gdbarch, int regnr) { /* Does this module have a coprocessor at all? */ if (! (current_options () & MEP_OPT_COP)) - return ""; + return ""; { - CGEN_KEYWORD *names = current_ccr_names (); + CGEN_KEYWORD *names = current_ccr_names (); - if (! names) - /* This me_module's coprocessor has no control registers. */ - return ""; + if (! names) + /* This me_module's coprocessor has no control registers. */ + return ""; - return register_name_from_keyword (names, regnr-MEP_FIRST_CCR_REGNUM); + return register_name_from_keyword (names, regnr-MEP_FIRST_CCR_REGNUM); } } @@ -1022,7 +1022,7 @@ static struct reggroup *mep_ccr_reggroup; /* coprocessor control */ static int mep_register_reggroup_p (struct gdbarch *gdbarch, int regnum, - struct reggroup *group) + struct reggroup *group) { /* Filter reserved or unused register numbers. */ { @@ -1036,14 +1036,14 @@ mep_register_reggroup_p (struct gdbarch *gdbarch, int regnum, the existing behavior, so we'd want to run that by them. */ if (group == general_reggroup) return (IS_GPR_REGNUM (regnum) - || IS_CSR_REGNUM (regnum)); + || IS_CSR_REGNUM (regnum)); /* Everything is in the 'all' reggroup, except for the raw CSR's. */ else if (group == all_reggroup) return (IS_GPR_REGNUM (regnum) - || IS_CSR_REGNUM (regnum) - || IS_CR_REGNUM (regnum) - || IS_CCR_REGNUM (regnum)); + || IS_CSR_REGNUM (regnum) + || IS_CR_REGNUM (regnum) + || IS_CCR_REGNUM (regnum)); /* All registers should be saved and restored, except for the raw CSR's. @@ -1056,9 +1056,9 @@ mep_register_reggroup_p (struct gdbarch *gdbarch, int regnum, hardware engine, perhaps. */ else if (group == save_reggroup || group == restore_reggroup) return (IS_GPR_REGNUM (regnum) - || IS_CSR_REGNUM (regnum) - || IS_CR_REGNUM (regnum) - || IS_CCR_REGNUM (regnum)); + || IS_CSR_REGNUM (regnum) + || IS_CR_REGNUM (regnum) + || IS_CCR_REGNUM (regnum)); else if (group == mep_csr_reggroup) return IS_CSR_REGNUM (regnum); @@ -1090,21 +1090,21 @@ mep_register_type (struct gdbarch *gdbarch, int reg_nr) { int size = mep_pseudo_cr_size (reg_nr); if (size == 32) - { - if (mep_pseudo_cr_is_float (reg_nr)) - return builtin_type (gdbarch)->builtin_float; - else - return builtin_type (gdbarch)->builtin_uint32; - } + { + if (mep_pseudo_cr_is_float (reg_nr)) + return builtin_type (gdbarch)->builtin_float; + else + return builtin_type (gdbarch)->builtin_uint32; + } else if (size == 64) - { - if (mep_pseudo_cr_is_float (reg_nr)) - return builtin_type (gdbarch)->builtin_double; - else - return builtin_type (gdbarch)->builtin_uint64; - } + { + if (mep_pseudo_cr_is_float (reg_nr)) + return builtin_type (gdbarch)->builtin_double; + else + return builtin_type (gdbarch)->builtin_uint64; + } else - gdb_assert_not_reached ("unexpected cr size"); + gdb_assert_not_reached ("unexpected cr size"); } /* All other registers are 32 bits long. */ @@ -1115,8 +1115,8 @@ mep_register_type (struct gdbarch *gdbarch, int reg_nr) static enum register_status mep_pseudo_cr32_read (struct gdbarch *gdbarch, readable_regcache *regcache, - int cookednum, - gdb_byte *buf) + int cookednum, + gdb_byte *buf) { enum register_status status; enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); @@ -1140,9 +1140,9 @@ mep_pseudo_cr32_read (struct gdbarch *gdbarch, static enum register_status mep_pseudo_cr64_read (struct gdbarch *gdbarch, - readable_regcache *regcache, - int cookednum, - gdb_byte *buf) + readable_regcache *regcache, + int cookednum, + gdb_byte *buf) { return regcache->raw_read (mep_pseudo_to_raw[cookednum], buf); } @@ -1151,17 +1151,17 @@ mep_pseudo_cr64_read (struct gdbarch *gdbarch, static enum register_status mep_pseudo_register_read (struct gdbarch *gdbarch, readable_regcache *regcache, - int cookednum, - gdb_byte *buf) + int cookednum, + gdb_byte *buf) { if (IS_CSR_REGNUM (cookednum) || IS_CCR_REGNUM (cookednum)) return regcache->raw_read (mep_pseudo_to_raw[cookednum], buf); else if (IS_CR32_REGNUM (cookednum) - || IS_FP_CR32_REGNUM (cookednum)) + || IS_FP_CR32_REGNUM (cookednum)) return mep_pseudo_cr32_read (gdbarch, regcache, cookednum, buf); else if (IS_CR64_REGNUM (cookednum) - || IS_FP_CR64_REGNUM (cookednum)) + || IS_FP_CR64_REGNUM (cookednum)) return mep_pseudo_cr64_read (gdbarch, regcache, cookednum, buf); else gdb_assert_not_reached ("unexpected pseudo register"); @@ -1170,9 +1170,9 @@ mep_pseudo_register_read (struct gdbarch *gdbarch, static void mep_pseudo_csr_write (struct gdbarch *gdbarch, - struct regcache *regcache, - int cookednum, - const gdb_byte *buf) + struct regcache *regcache, + int cookednum, + const gdb_byte *buf) { enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); int size = register_size (gdbarch, cookednum); @@ -1189,21 +1189,21 @@ mep_pseudo_csr_write (struct gdbarch *gdbarch, ULONGEST old_bits; ULONGEST new_bits; ULONGEST mixed_bits; - + regcache_raw_read_unsigned (regcache, r->raw, &old_bits); new_bits = extract_unsigned_integer (buf, size, byte_order); mixed_bits = ((r->writeable_bits & new_bits) - | (~r->writeable_bits & old_bits)); + | (~r->writeable_bits & old_bits)); regcache_raw_write_unsigned (regcache, r->raw, mixed_bits); } } - + static void mep_pseudo_cr32_write (struct gdbarch *gdbarch, - struct regcache *regcache, - int cookednum, - const gdb_byte *buf) + struct regcache *regcache, + int cookednum, + const gdb_byte *buf) { enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); /* Expand the 32-bit value into a 64-bit value, and write that to @@ -1222,9 +1222,9 @@ mep_pseudo_cr32_write (struct gdbarch *gdbarch, static void mep_pseudo_cr64_write (struct gdbarch *gdbarch, - struct regcache *regcache, - int cookednum, - const gdb_byte *buf) + struct regcache *regcache, + int cookednum, + const gdb_byte *buf) { regcache->raw_write (mep_pseudo_to_raw[cookednum], buf); } @@ -1232,17 +1232,17 @@ mep_pseudo_cr64_write (struct gdbarch *gdbarch, static void mep_pseudo_register_write (struct gdbarch *gdbarch, - struct regcache *regcache, - int cookednum, - const gdb_byte *buf) + struct regcache *regcache, + int cookednum, + const gdb_byte *buf) { if (IS_CSR_REGNUM (cookednum)) mep_pseudo_csr_write (gdbarch, regcache, cookednum, buf); else if (IS_CR32_REGNUM (cookednum) - || IS_FP_CR32_REGNUM (cookednum)) + || IS_FP_CR32_REGNUM (cookednum)) mep_pseudo_cr32_write (gdbarch, regcache, cookednum, buf); else if (IS_CR64_REGNUM (cookednum) - || IS_FP_CR64_REGNUM (cookednum)) + || IS_FP_CR64_REGNUM (cookednum)) mep_pseudo_cr64_write (gdbarch, regcache, cookednum, buf); else if (IS_CCR_REGNUM (cookednum)) regcache->raw_write (mep_pseudo_to_raw[cookednum], buf); @@ -1263,9 +1263,9 @@ mep_gdb_print_insn (bfd_vma pc, disassemble_info * info) if (s) { /* The libopcodes disassembly code uses the section to find the - BFD, the BFD to find the ELF header, the ELF header to find - the me_module index, and the me_module index to select the - right instructions to print. */ + BFD, the BFD to find the ELF header, the ELF header to find + the me_module index, and the me_module index to select the + right instructions to print. */ info->section = s->the_bfd_section; } @@ -1345,9 +1345,9 @@ mep_pc_in_vliw_section (CORE_ADDR pc) void foo (void) { - asm ("movu $1, 0x123456"); - asm ("sb $1,0x5678($2)"); - asm ("clip $1, 19"); + asm ("movu $1, 0x123456"); + asm ("sb $1,0x5678($2)"); + asm ("clip $1, 19"); } compiles to this big-endian code: @@ -1418,22 +1418,22 @@ mep_get_insn (struct gdbarch *gdbarch, CORE_ADDR pc, unsigned long *insn) vliw_mode = current_options () & (MEP_OPT_VL32 | MEP_OPT_VL64); /* If PC is in a VLIW section, but the current core doesn't say - that it supports either VLIW mode, then we don't have enough - information to parse the instruction stream it contains. - Since the "undifferentiated" standard core doesn't have - either VLIW mode bit set, this could happen. + that it supports either VLIW mode, then we don't have enough + information to parse the instruction stream it contains. + Since the "undifferentiated" standard core doesn't have + either VLIW mode bit set, this could happen. - But it shouldn't be an error to (say) set a breakpoint in a - VLIW section, if you know you'll never reach it. (Perhaps - you have a script that sets a bunch of standard breakpoints.) + But it shouldn't be an error to (say) set a breakpoint in a + VLIW section, if you know you'll never reach it. (Perhaps + you have a script that sets a bunch of standard breakpoints.) - So we'll just return zero here, and hope for the best. */ + So we'll just return zero here, and hope for the best. */ if (! (vliw_mode & (MEP_OPT_VL32 | MEP_OPT_VL64))) - return 0; + return 0; /* If both VL32 and VL64 are set, that's bogus, too. */ if (vliw_mode == (MEP_OPT_VL32 | MEP_OPT_VL64)) - return 0; + return 0; } else vliw_mode = 0; @@ -1457,18 +1457,18 @@ mep_get_insn (struct gdbarch *gdbarch, CORE_ADDR pc, unsigned long *insn) if (vliw_mode) { /* In 32-bit VLIW code, all bundles are 32 bits long. We ignore the - coprocessor half of a core / copro bundle. */ + coprocessor half of a core / copro bundle. */ if (vliw_mode == MEP_OPT_VL32) - insn_len = 4; + insn_len = 4; /* In 64-bit VLIW code, all bundles are 64 bits long. We ignore the - coprocessor half of a core / copro bundle. */ + coprocessor half of a core / copro bundle. */ else if (vliw_mode == MEP_OPT_VL64) - insn_len = 8; + insn_len = 8; /* We'd better be in either core, 32-bit VLIW, or 64-bit VLIW mode. */ else - gdb_assert_not_reached ("unexpected vliw mode"); + gdb_assert_not_reached ("unexpected vliw mode"); } /* Otherwise, the top two bits of the major opcode are (again) what @@ -1546,7 +1546,7 @@ mep_get_insn (struct gdbarch *gdbarch, CORE_ADDR pc, unsigned long *insn) #define ADD_OFFSET(i) (SFIELD (i, 18, 6)) /* LDC Rn,imm5 0111_nnnn_iiii_101I xxxx_xxxx_xxxx_xxxx - imm5 = I||i[7:4] */ + imm5 = I||i[7:4] */ #define IS_LDC(i) (((i) & 0xf00e0000) == 0x700a0000) #define LDC_IMM(i) ((FIELD (i, 16, 1) << 4) | FIELD (i, 20, 4)) #define LDC_TARGET(i) (FIELD (i, 24, 4)) @@ -1610,8 +1610,8 @@ static int is_arg_reg (pv_t value) { return (value.kind == pvk_register - && MEP_R1_REGNUM <= value.reg && value.reg <= MEP_R4_REGNUM - && value.k == 0); + && MEP_R1_REGNUM <= value.reg && value.reg <= MEP_R4_REGNUM + && value.k == 0); } /* Return non-zero if a store of REG's current value VALUE to ADDR is @@ -1628,8 +1628,8 @@ is_arg_spill (struct gdbarch *gdbarch, pv_t value, pv_t addr, struct pv_area *stack) { return (is_arg_reg (value) - && pv_is_register (addr, MEP_SP_REGNUM) - && ! stack->find_reg (gdbarch, value.reg, 0)); + && pv_is_register (addr, MEP_SP_REGNUM) + && ! stack->find_reg (gdbarch, value.reg, 0)); } @@ -1657,7 +1657,7 @@ check_for_saved (void *result_untyped, pv_t addr, CORE_ADDR size, pv_t value) static void mep_analyze_prologue (struct gdbarch *gdbarch, CORE_ADDR start_pc, CORE_ADDR limit_pc, - struct mep_prologue *result) + struct mep_prologue *result) { CORE_ADDR pc; unsigned long insn; @@ -1684,116 +1684,116 @@ mep_analyze_prologue (struct gdbarch *gdbarch, next_pc = mep_get_insn (gdbarch, pc, &insn); /* A zero return from mep_get_insn means that either we weren't - able to read the instruction from memory, or that we don't - have enough information to be able to reliably decode it. So - we'll store here and hope for the best. */ + able to read the instruction from memory, or that we don't + have enough information to be able to reliably decode it. So + we'll store here and hope for the best. */ if (! next_pc) - break; + break; /* Note the current values of the SP and FP, so we can tell if - this instruction changed them, below. */ + this instruction changed them, below. */ pre_insn_fp = reg[MEP_FP_REGNUM]; pre_insn_sp = reg[MEP_SP_REGNUM]; if (IS_ADD (insn)) - { - int rn = ADD_TARGET (insn); - CORE_ADDR imm6 = ADD_OFFSET (insn); + { + int rn = ADD_TARGET (insn); + CORE_ADDR imm6 = ADD_OFFSET (insn); - reg[rn] = pv_add_constant (reg[rn], imm6); - } + reg[rn] = pv_add_constant (reg[rn], imm6); + } else if (IS_ADD3_16 (insn)) { - int rn = ADD3_16_TARGET (insn); - int imm7 = ADD3_16_OFFSET (insn); + int rn = ADD3_16_TARGET (insn); + int imm7 = ADD3_16_OFFSET (insn); - reg[rn] = pv_add_constant (reg[MEP_SP_REGNUM], imm7); - } + reg[rn] = pv_add_constant (reg[MEP_SP_REGNUM], imm7); + } else if (IS_ADD3_32 (insn)) { - int rn = ADD3_32_TARGET (insn); - int rm = ADD3_32_SOURCE (insn); - int imm16 = ADD3_32_OFFSET (insn); + int rn = ADD3_32_TARGET (insn); + int rm = ADD3_32_SOURCE (insn); + int imm16 = ADD3_32_OFFSET (insn); - reg[rn] = pv_add_constant (reg[rm], imm16); + reg[rn] = pv_add_constant (reg[rm], imm16); } else if (IS_SW_REG (insn)) - { - int rn = SW_REG_SOURCE (insn); - int rm = SW_REG_BASE (insn); - - /* If simulating this store would require us to forget - everything we know about the stack frame in the name of - accuracy, it would be better to just quit now. */ - if (stack.store_would_trash (reg[rm])) - break; - - if (is_arg_spill (gdbarch, reg[rn], reg[rm], &stack)) - after_last_frame_setup_insn = next_pc; - - stack.store (reg[rm], 4, reg[rn]); - } + { + int rn = SW_REG_SOURCE (insn); + int rm = SW_REG_BASE (insn); + + /* If simulating this store would require us to forget + everything we know about the stack frame in the name of + accuracy, it would be better to just quit now. */ + if (stack.store_would_trash (reg[rm])) + break; + + if (is_arg_spill (gdbarch, reg[rn], reg[rm], &stack)) + after_last_frame_setup_insn = next_pc; + + stack.store (reg[rm], 4, reg[rn]); + } else if (IS_SW_IMMD (insn)) - { - int rn = SW_IMMD_SOURCE (insn); - int offset = SW_IMMD_OFFSET (insn); - pv_t addr = pv_add_constant (reg[MEP_SP_REGNUM], offset); - - /* If simulating this store would require us to forget - everything we know about the stack frame in the name of - accuracy, it would be better to just quit now. */ - if (stack.store_would_trash (addr)) - break; - - if (is_arg_spill (gdbarch, reg[rn], addr, &stack)) - after_last_frame_setup_insn = next_pc; - - stack.store (addr, 4, reg[rn]); - } + { + int rn = SW_IMMD_SOURCE (insn); + int offset = SW_IMMD_OFFSET (insn); + pv_t addr = pv_add_constant (reg[MEP_SP_REGNUM], offset); + + /* If simulating this store would require us to forget + everything we know about the stack frame in the name of + accuracy, it would be better to just quit now. */ + if (stack.store_would_trash (addr)) + break; + + if (is_arg_spill (gdbarch, reg[rn], addr, &stack)) + after_last_frame_setup_insn = next_pc; + + stack.store (addr, 4, reg[rn]); + } else if (IS_MOV (insn)) { - int rn = MOV_TARGET (insn); - int rm = MOV_SOURCE (insn); + int rn = MOV_TARGET (insn); + int rm = MOV_SOURCE (insn); - reg[rn] = reg[rm]; + reg[rn] = reg[rm]; if (pv_is_register (reg[rm], rm) && is_arg_reg (reg[rm])) after_last_frame_setup_insn = next_pc; } else if (IS_SB (insn) || IS_SH (insn) || IS_SW (insn)) { - int rn = SWBH_32_SOURCE (insn); - int rm = SWBH_32_BASE (insn); - int disp = SWBH_32_OFFSET (insn); - int size = (IS_SB (insn) ? 1 - : IS_SH (insn) ? 2 - : (gdb_assert (IS_SW (insn)), 4)); - pv_t addr = pv_add_constant (reg[rm], disp); - - if (stack.store_would_trash (addr)) - break; - - if (is_arg_spill (gdbarch, reg[rn], addr, &stack)) - after_last_frame_setup_insn = next_pc; + int rn = SWBH_32_SOURCE (insn); + int rm = SWBH_32_BASE (insn); + int disp = SWBH_32_OFFSET (insn); + int size = (IS_SB (insn) ? 1 + : IS_SH (insn) ? 2 + : (gdb_assert (IS_SW (insn)), 4)); + pv_t addr = pv_add_constant (reg[rm], disp); + + if (stack.store_would_trash (addr)) + break; + + if (is_arg_spill (gdbarch, reg[rn], addr, &stack)) + after_last_frame_setup_insn = next_pc; - stack.store (addr, size, reg[rn]); + stack.store (addr, size, reg[rn]); } else if (IS_LDC (insn)) { - int rn = LDC_TARGET (insn); - int cr = LDC_IMM (insn) + MEP_FIRST_CSR_REGNUM; + int rn = LDC_TARGET (insn); + int cr = LDC_IMM (insn) + MEP_FIRST_CSR_REGNUM; - reg[rn] = reg[cr]; + reg[rn] = reg[cr]; } else if (IS_LW (insn)) - { - int rn = LW_TARGET (insn); - int rm = LW_BASE (insn); - int offset = LW_OFFSET (insn); - pv_t addr = pv_add_constant (reg[rm], offset); - - reg[rn] = stack.fetch (addr, 4); - } + { + int rn = LW_TARGET (insn); + int rm = LW_BASE (insn); + int offset = LW_OFFSET (insn); + pv_t addr = pv_add_constant (reg[rm], offset); + + reg[rn] = stack.fetch (addr, 4); + } else if (IS_BRA (insn) && BRA_DISP (insn) > 0) { /* When a loop appears as the first statement of a function @@ -1819,42 +1819,42 @@ mep_analyze_prologue (struct gdbarch *gdbarch, break; } else - /* We've hit some instruction we don't know how to simulate. - Strictly speaking, we should set every value we're - tracking to "unknown". But we'll be optimistic, assume - that we have enough information already, and stop - analysis here. */ - break; + /* We've hit some instruction we don't know how to simulate. + Strictly speaking, we should set every value we're + tracking to "unknown". But we'll be optimistic, assume + that we have enough information already, and stop + analysis here. */ + break; /* If this instruction changed the FP or decreased the SP (i.e., - allocated more stack space), then this may be a good place to - declare the prologue finished. However, there are some - exceptions: + allocated more stack space), then this may be a good place to + declare the prologue finished. However, there are some + exceptions: - - If the instruction just changed the FP back to its original - value, then that's probably a restore instruction. The - prologue should definitely end before that. + - If the instruction just changed the FP back to its original + value, then that's probably a restore instruction. The + prologue should definitely end before that. - - If the instruction increased the value of the SP (that is, - shrunk the frame), then it's probably part of a frame - teardown sequence, and the prologue should end before that. */ + - If the instruction increased the value of the SP (that is, + shrunk the frame), then it's probably part of a frame + teardown sequence, and the prologue should end before that. */ if (! pv_is_identical (reg[MEP_FP_REGNUM], pre_insn_fp)) - { - if (! pv_is_register_k (reg[MEP_FP_REGNUM], MEP_FP_REGNUM, 0)) - after_last_frame_setup_insn = next_pc; - } + { + if (! pv_is_register_k (reg[MEP_FP_REGNUM], MEP_FP_REGNUM, 0)) + after_last_frame_setup_insn = next_pc; + } else if (! pv_is_identical (reg[MEP_SP_REGNUM], pre_insn_sp)) - { - /* The comparison of constants looks odd, there, because .k - is unsigned. All it really means is that the new value - is lower than it was before the instruction. */ - if (pv_is_register (pre_insn_sp, MEP_SP_REGNUM) - && pv_is_register (reg[MEP_SP_REGNUM], MEP_SP_REGNUM) - && ((pre_insn_sp.k - reg[MEP_SP_REGNUM].k) - < (reg[MEP_SP_REGNUM].k - pre_insn_sp.k))) - after_last_frame_setup_insn = next_pc; - } + { + /* The comparison of constants looks odd, there, because .k + is unsigned. All it really means is that the new value + is lower than it was before the instruction. */ + if (pv_is_register (pre_insn_sp, MEP_SP_REGNUM) + && pv_is_register (reg[MEP_SP_REGNUM], MEP_SP_REGNUM) + && ((pre_insn_sp.k - reg[MEP_SP_REGNUM].k) + < (reg[MEP_SP_REGNUM].k - pre_insn_sp.k))) + after_last_frame_setup_insn = next_pc; + } pc = next_pc; } @@ -1905,22 +1905,22 @@ typedef BP_MANIPULATION (mep_break_insn) mep_breakpoint; static struct mep_prologue * mep_analyze_frame_prologue (struct frame_info *this_frame, - void **this_prologue_cache) + void **this_prologue_cache) { if (! *this_prologue_cache) { CORE_ADDR func_start, stop_addr; *this_prologue_cache - = FRAME_OBSTACK_ZALLOC (struct mep_prologue); + = FRAME_OBSTACK_ZALLOC (struct mep_prologue); func_start = get_frame_func (this_frame); stop_addr = get_frame_pc (this_frame); /* If we couldn't find any function containing the PC, then - just initialize the prologue cache, but don't do anything. */ + just initialize the prologue cache, but don't do anything. */ if (! func_start) - stop_addr = func_start; + stop_addr = func_start; mep_analyze_prologue (get_frame_arch (this_frame), func_start, stop_addr, @@ -1935,7 +1935,7 @@ mep_analyze_frame_prologue (struct frame_info *this_frame, base. */ static CORE_ADDR mep_frame_base (struct frame_info *this_frame, - void **this_prologue_cache) + void **this_prologue_cache) { struct mep_prologue *p = mep_analyze_frame_prologue (this_frame, this_prologue_cache); @@ -1949,13 +1949,13 @@ mep_frame_base (struct frame_info *this_frame, if (p->has_frame_ptr) { CORE_ADDR fp - = get_frame_register_unsigned (this_frame, MEP_FP_REGNUM); + = get_frame_register_unsigned (this_frame, MEP_FP_REGNUM); return fp - p->frame_ptr_offset; } else { CORE_ADDR sp - = get_frame_register_unsigned (this_frame, MEP_SP_REGNUM); + = get_frame_register_unsigned (this_frame, MEP_SP_REGNUM); return sp - p->frame_size; } } @@ -1963,17 +1963,17 @@ mep_frame_base (struct frame_info *this_frame, static void mep_frame_this_id (struct frame_info *this_frame, - void **this_prologue_cache, - struct frame_id *this_id) + void **this_prologue_cache, + struct frame_id *this_id) { *this_id = frame_id_build (mep_frame_base (this_frame, this_prologue_cache), - get_frame_func (this_frame)); + get_frame_func (this_frame)); } static struct value * mep_frame_prev_register (struct frame_info *this_frame, - void **this_prologue_cache, int regnum) + void **this_prologue_cache, int regnum) { struct mep_prologue *p = mep_analyze_frame_prologue (this_frame, this_prologue_cache); @@ -2017,35 +2017,35 @@ mep_frame_prev_register (struct frame_info *this_frame, return frame_unwind_got_constant (this_frame, regnum, frame_base); /* If prologue analysis says we saved this register somewhere, - return a description of the stack slot holding it. */ + return a description of the stack slot holding it. */ if (p->reg_offset[regnum] != 1) value = frame_unwind_got_memory (this_frame, regnum, frame_base + p->reg_offset[regnum]); /* Otherwise, presume we haven't changed the value of this - register, and get it from the next frame. */ + register, and get it from the next frame. */ else value = frame_unwind_got_register (this_frame, regnum, regnum); /* If we need to toggle the operating mode, do so. */ if (regnum == MEP_PSW_REGNUM) - { + { CORE_ADDR psw, lp; psw = value_as_long (value); release_value (value); - /* Get the LP's value, too. */ + /* Get the LP's value, too. */ value = get_frame_register_value (this_frame, MEP_LP_REGNUM); lp = value_as_long (value); release_value (value); - /* If LP.LTOM is set, then toggle PSW.OM. */ + /* If LP.LTOM is set, then toggle PSW.OM. */ if (lp & 0x1) psw ^= 0x1000; return frame_unwind_got_constant (this_frame, regnum, psw); - } + } return value; } @@ -2074,9 +2074,9 @@ mep_use_struct_convention (struct type *type) static void mep_extract_return_value (struct gdbarch *arch, - struct type *type, - struct regcache *regcache, - gdb_byte *valbuf) + struct type *type, + struct regcache *regcache, + gdb_byte *valbuf) { int byte_order = gdbarch_byte_order (arch); @@ -2102,9 +2102,9 @@ mep_extract_return_value (struct gdbarch *arch, static void mep_store_return_value (struct gdbarch *arch, - struct type *type, - struct regcache *regcache, - const gdb_byte *valbuf) + struct type *type, + struct regcache *regcache, + const gdb_byte *valbuf) { int byte_order = gdbarch_byte_order (arch); @@ -2112,14 +2112,14 @@ mep_store_return_value (struct gdbarch *arch, if (TYPE_LENGTH (type) <= MEP_GPR_SIZE) { /* Values that don't occupy a full register appear at the least - significant end of the value. This is the offset to where the - value starts. */ + significant end of the value. This is the offset to where the + value starts. */ int offset; if (byte_order == BFD_ENDIAN_BIG) - offset = MEP_GPR_SIZE - TYPE_LENGTH (type); + offset = MEP_GPR_SIZE - TYPE_LENGTH (type); else - offset = 0; + offset = 0; regcache->cooked_write_part (MEP_R0_REGNUM, offset, TYPE_LENGTH (type), valbuf); @@ -2215,7 +2215,7 @@ mep_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp) new stack pointer. */ static CORE_ADDR push_large_arguments (CORE_ADDR sp, int argc, struct value **argv, - CORE_ADDR copy[]) + CORE_ADDR copy[]) { int i; @@ -2224,13 +2224,13 @@ push_large_arguments (CORE_ADDR sp, int argc, struct value **argv, unsigned arg_len = TYPE_LENGTH (value_type (argv[i])); if (arg_len > MEP_GPR_SIZE) - { - /* Reserve space for the copy, and then round the SP down, to - make sure it's all aligned properly. */ - sp = (sp - arg_len) & -4; - write_memory (sp, value_contents (argv[i]), arg_len); - copy[i] = sp; - } + { + /* Reserve space for the copy, and then round the SP down, to + make sure it's all aligned properly. */ + sp = (sp - arg_len) & -4; + write_memory (sp, value_contents (argv[i]), arg_len); + copy[i] = sp; + } } return sp; @@ -2239,10 +2239,10 @@ push_large_arguments (CORE_ADDR sp, int argc, struct value **argv, static CORE_ADDR mep_push_dummy_call (struct gdbarch *gdbarch, struct value *function, - struct regcache *regcache, CORE_ADDR bp_addr, - int argc, struct value **argv, CORE_ADDR sp, + struct regcache *regcache, CORE_ADDR bp_addr, + int argc, struct value **argv, CORE_ADDR sp, function_call_return_method return_method, - CORE_ADDR struct_addr) + CORE_ADDR struct_addr) { enum bfd_endian byte_order = gdbarch_byte_order (gdbarch); CORE_ADDR *copy = (CORE_ADDR *) alloca (argc * sizeof (copy[0])); @@ -2282,28 +2282,28 @@ mep_push_dummy_call (struct gdbarch *gdbarch, struct value *function, /* Arguments that fit in a GPR get expanded to fill the GPR. */ if (TYPE_LENGTH (value_type (argv[i])) <= MEP_GPR_SIZE) - value = extract_unsigned_integer (value_contents (argv[i]), - TYPE_LENGTH (value_type (argv[i])), + value = extract_unsigned_integer (value_contents (argv[i]), + TYPE_LENGTH (value_type (argv[i])), byte_order); /* Arguments too large to fit in a GPR get copied to the stack, - and we pass a pointer to the copy. */ + and we pass a pointer to the copy. */ else - value = copy[i]; + value = copy[i]; /* We use $1 -- $4 for passing arguments, then use the stack. */ if (arg_reg <= MEP_R4_REGNUM) - { - regcache_cooked_write_unsigned (regcache, arg_reg, value); - arg_reg++; - } + { + regcache_cooked_write_unsigned (regcache, arg_reg, value); + arg_reg++; + } else - { - gdb_byte buf[MEP_GPR_SIZE]; - store_unsigned_integer (buf, MEP_GPR_SIZE, byte_order, value); - write_memory (arg_stack, buf, MEP_GPR_SIZE); - arg_stack += MEP_GPR_SIZE; - } + { + gdb_byte buf[MEP_GPR_SIZE]; + store_unsigned_integer (buf, MEP_GPR_SIZE, byte_order, value); + write_memory (arg_stack, buf, MEP_GPR_SIZE); + arg_stack += MEP_GPR_SIZE; + } } gdb_assert (arg_stack <= arg_stack_end); @@ -2335,14 +2335,14 @@ mep_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) if (info.abfd) { /* The way to get the me_module code depends on the object file - format. At the moment, we only know how to handle ELF. */ + format. At the moment, we only know how to handle ELF. */ if (bfd_get_flavour (info.abfd) == bfd_target_elf_flavour) { int flag = elf_elfheader (info.abfd)->e_flags & EF_MEP_INDEX_MASK; me_module = (CONFIG_ATTR) flag; } else - me_module = CONFIG_NONE; + me_module = CONFIG_NONE; } else me_module = CONFIG_NONE; @@ -2352,28 +2352,28 @@ mep_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) if (info.abfd) { /* The negations on either side make the comparison treat all - non-zero (true) values as equal. */ + non-zero (true) values as equal. */ if (! bfd_big_endian (info.abfd) != ! me_module_big_endian (me_module)) - { - const char *module_name = me_module_name (me_module); - const char *module_endianness - = me_module_big_endian (me_module) ? "big" : "little"; - const char *file_name = bfd_get_filename (info.abfd); - const char *file_endianness - = bfd_big_endian (info.abfd) ? "big" : "little"; - - fputc_unfiltered ('\n', gdb_stderr); - if (module_name) - warning (_("the MeP module '%s' is %s-endian, but the executable\n" + { + const char *module_name = me_module_name (me_module); + const char *module_endianness + = me_module_big_endian (me_module) ? "big" : "little"; + const char *file_name = bfd_get_filename (info.abfd); + const char *file_endianness + = bfd_big_endian (info.abfd) ? "big" : "little"; + + fputc_unfiltered ('\n', gdb_stderr); + if (module_name) + warning (_("the MeP module '%s' is %s-endian, but the executable\n" "%s is %s-endian."), - module_name, module_endianness, - file_name, file_endianness); - else - warning (_("the selected MeP module is %s-endian, but the " + module_name, module_endianness, + file_name, file_endianness); + else + warning (_("the selected MeP module is %s-endian, but the " "executable\n" "%s is %s-endian."), - module_endianness, file_name, file_endianness); - } + module_endianness, file_name, file_endianness); + } } /* Find a candidate among the list of architectures we've created @@ -2393,12 +2393,12 @@ mep_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) { const char *mach_name = info.bfd_arch_info->printable_name; enum cgen_endian endian = (info.byte_order == BFD_ENDIAN_BIG - ? CGEN_ENDIAN_BIG - : CGEN_ENDIAN_LITTLE); + ? CGEN_ENDIAN_BIG + : CGEN_ENDIAN_LITTLE); tdep->cpu_desc = mep_cgen_cpu_open (CGEN_CPU_OPEN_BFDMACH, mach_name, - CGEN_CPU_OPEN_ENDIAN, endian, - CGEN_CPU_OPEN_END); + CGEN_CPU_OPEN_ENDIAN, endian, + CGEN_CPU_OPEN_END); } tdep->me_module = me_module; |