From: jamesbowman Date: Tue, 29 Sep 2015 16:06:29 +0000 (-0700) Subject: [FT32] Replace hard-coded instruction patterns with macros X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=86feccb92092506f2a23a32345bc0f562ac4042b;p=binutils-gdb.git [FT32] Replace hard-coded instruction patterns with macros The stack unwinder can now use FT32_*() macros to interpet binary instructions instead of local definitions. 2015-09-29 James Bowman * ft32-tdep.c: #include "opcode/ft32.h". Delete local macros IS_PUSH, PUSH_REG, IS_LINK, LINK_SIZE. (ft32_analyze_prologue): Use FT32_* macros. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index e548e314202..de4606d5132 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2015-09-29 James Bowman + + * ft32-tdep.c: #include "opcode/ft32.h". + Delete local macros IS_PUSH, PUSH_REG, IS_LINK, LINK_SIZE. + (ft32_analyze_prologue): Use FT32_* macros. + 2015-09-28 Simon Marchi * cli/cli-script.c (read_next_line): Fix stdout -> stdin in diff --git a/gdb/ft32-tdep.c b/gdb/ft32-tdep.c index e83427983c4..00cf847f762 100644 --- a/gdb/ft32-tdep.c +++ b/gdb/ft32-tdep.c @@ -37,6 +37,8 @@ #include "dis-asm.h" #include "record.h" +#include "opcode/ft32.h" + #include "ft32-tdep.h" #include "gdb/sim-ft32.h" @@ -153,11 +155,6 @@ ft32_store_return_value (struct type *type, struct regcache *regcache, Returns the address of the first instruction after the prologue. */ -#define IS_PUSH(inst) (((inst) & 0xfff00000) == 0x84000000) -#define PUSH_REG(inst) (FT32_R0_REGNUM + (((inst) >> 15) & 0x1f)) -#define IS_LINK(inst) (((inst) & 0xffff0000) == 0x95d00000) -#define LINK_SIZE(inst) ((inst) & 0xffff) - static CORE_ADDR ft32_analyze_prologue (CORE_ADDR start_addr, CORE_ADDR end_addr, struct ft32_frame_cache *cache, @@ -180,9 +177,9 @@ ft32_analyze_prologue (CORE_ADDR start_addr, CORE_ADDR end_addr, { inst = read_memory_unsigned_integer (next_addr, 4, byte_order); - if (IS_PUSH (inst)) + if (FT32_IS_PUSH (inst)) { - regnum = PUSH_REG (inst); + regnum = FT32_R0_REGNUM + FT32_PUSH_REG (inst); cache->framesize += 4; cache->saved_regs[regnum] = cache->framesize; next_addr += 4; @@ -201,7 +198,7 @@ ft32_analyze_prologue (CORE_ADDR start_addr, CORE_ADDR end_addr, if (next_addr < end_addr) { inst = read_memory_unsigned_integer (next_addr, 4, byte_order); - if (IS_LINK (inst)) + if (FT32_IS_LINK (inst)) { cache->established = 1; for (regnum = FT32_R0_REGNUM; regnum < FT32_PC_REGNUM; regnum++) @@ -211,7 +208,7 @@ ft32_analyze_prologue (CORE_ADDR start_addr, CORE_ADDR end_addr, } cache->saved_regs[FT32_PC_REGNUM] = cache->framesize + 4; cache->saved_regs[FT32_FP_REGNUM] = 0; - cache->framesize += LINK_SIZE (inst); + cache->framesize += FT32_LINK_SIZE (inst); next_addr += 4; } }