X-Git-Url: https://git.efficios.com/?a=blobdiff_plain;f=gdb%2Fppc-ravenscar-thread.c;h=d65cc4d7c089a0db79bd30df8ac851e7db4230e8;hb=86e57d1b233e15f7d72b39dbd381a7e5a9d1b026;hp=ae5ad24579f1fe4d924e4385eb33f7256ccf5f83;hpb=73e1c03f93f0294b464dc2b67de1f9aaae84838d;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/ppc-ravenscar-thread.c b/gdb/ppc-ravenscar-thread.c index ae5ad24579..d65cc4d7c0 100644 --- a/gdb/ppc-ravenscar-thread.c +++ b/gdb/ppc-ravenscar-thread.c @@ -1,6 +1,6 @@ /* Ravenscar PowerPC target support. - Copyright (C) 2011-2018 Free Software Foundation, Inc. + Copyright (C) 2011-2020 Free Software Foundation, Inc. This file is part of GDB. @@ -154,7 +154,7 @@ ppc_ravenscar_generic_fetch_registers CORE_ADDR thread_descriptor_address; /* The tid is the thread_id field, which is a pointer to the thread. */ - thread_descriptor_address = (CORE_ADDR) ptid_get_tid (inferior_ptid); + thread_descriptor_address = (CORE_ADDR) inferior_ptid.tid (); /* Read registers. */ for (current_regnum = 0; current_regnum < num_regs; current_regnum++) @@ -169,15 +169,6 @@ ppc_ravenscar_generic_fetch_registers } } -/* to_prepare_to_store when inferior_ptid is different from the running - thread. */ - -static void -ppc_ravenscar_generic_prepare_to_store (struct regcache *regcache) -{ - /* Nothing to do. */ -} - /* to_store_registers when inferior_ptid is different from the running thread. */ @@ -193,11 +184,11 @@ ppc_ravenscar_generic_store_registers if (register_in_thread_descriptor_p (reg_info, regnum)) register_address - = ptid_get_tid (inferior_ptid) + reg_info->context_offsets [regnum]; + = inferior_ptid.tid () + reg_info->context_offsets [regnum]; else return; - regcache_raw_collect (regcache, regnum, buf); + regcache->raw_collect (regnum, buf); write_memory (register_address, buf, buf_size); @@ -211,32 +202,27 @@ static const struct ravenscar_reg_info ppc_reg_info = ARRAY_SIZE (powerpc_context_offsets), }; -/* Implement the to_fetch_registers ravenscar_arch_ops method - for most PowerPC targets. */ +struct ppc_ravenscar_powerpc_ops : public ravenscar_arch_ops +{ + void fetch_registers (struct regcache *, int) override; + void store_registers (struct regcache *, int) override; +}; -static void -ppc_ravenscar_powerpc_fetch_registers (struct regcache *regcache, int regnum) +void +ppc_ravenscar_powerpc_ops::fetch_registers (struct regcache *regcache, int regnum) { ppc_ravenscar_generic_fetch_registers (&ppc_reg_info, regcache, regnum); } -/* Implement the to_store_registers ravenscar_arch_ops method - for most PowerPC targets. */ - -static void -ppc_ravenscar_powerpc_store_registers (struct regcache *regcache, int regnum) +void +ppc_ravenscar_powerpc_ops::store_registers (struct regcache *regcache, int regnum) { ppc_ravenscar_generic_store_registers (&ppc_reg_info, regcache, regnum); } /* The ravenscar_arch_ops vector for most PowerPC targets. */ -static struct ravenscar_arch_ops ppc_ravenscar_powerpc_ops = -{ - ppc_ravenscar_powerpc_fetch_registers, - ppc_ravenscar_powerpc_store_registers, - ppc_ravenscar_generic_prepare_to_store -}; +static struct ppc_ravenscar_powerpc_ops ppc_ravenscar_powerpc_ops; /* Register ppc_ravenscar_powerpc_ops in GDBARCH. */ @@ -254,11 +240,14 @@ static const struct ravenscar_reg_info e500_reg_info = ARRAY_SIZE (e500_context_offsets), }; -/* Implement the to_fetch_registers ravenscar_arch_ops method - for E500 targets. */ +struct ppc_ravenscar_e500_ops : public ravenscar_arch_ops +{ + void fetch_registers (struct regcache *, int) override; + void store_registers (struct regcache *, int) override; +}; -static void -ppc_ravenscar_e500_fetch_registers (struct regcache *regcache, int regnum) +void +ppc_ravenscar_e500_ops::fetch_registers (struct regcache *regcache, int regnum) { ppc_ravenscar_generic_fetch_registers (&e500_reg_info, regcache, regnum); } @@ -266,20 +255,15 @@ ppc_ravenscar_e500_fetch_registers (struct regcache *regcache, int regnum) /* Implement the to_store_registers ravenscar_arch_ops method for E500 targets. */ -static void -ppc_ravenscar_e500_store_registers (struct regcache *regcache, int regnum) +void +ppc_ravenscar_e500_ops::store_registers (struct regcache *regcache, int regnum) { ppc_ravenscar_generic_store_registers (&e500_reg_info, regcache, regnum); } /* The ravenscar_arch_ops vector for E500 targets. */ -static struct ravenscar_arch_ops ppc_ravenscar_e500_ops = -{ - ppc_ravenscar_e500_fetch_registers, - ppc_ravenscar_e500_store_registers, - ppc_ravenscar_generic_prepare_to_store -}; +static struct ppc_ravenscar_e500_ops ppc_ravenscar_e500_ops; /* Register ppc_ravenscar_e500_ops in GDBARCH. */