From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from [140.186.70.92] (port=59783 helo=eggs.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1Q2xau-0001V4-KL for qemu-devel@nongnu.org; Thu, 24 Mar 2011 23:21:49 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Q2xat-0006c6-Cm for qemu-devel@nongnu.org; Thu, 24 Mar 2011 23:21:48 -0400 Received: from ozlabs.org ([203.10.76.45]:56748) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Q2xat-0006bY-3R for qemu-devel@nongnu.org; Thu, 24 Mar 2011 23:21:47 -0400 From: David Gibson Date: Fri, 25 Mar 2011 14:21:10 +1100 Message-Id: <1301023292-24977-6-git-send-email-david@gibson.dropbear.id.au> In-Reply-To: <1301023292-24977-1-git-send-email-david@gibson.dropbear.id.au> References: <1301023292-24977-1-git-send-email-david@gibson.dropbear.id.au> Subject: [Qemu-devel] [PATCH 05/27] Implement missing parts of the logic for the POWER PURR List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: agraf@suse.de, qemu-devel@nongnu.org Cc: paulus@samba.org, anton@samba.org The PURR (Processor Utilization Resource Register) is a register found on recent POWER CPUs. The guts of implementing it at least enough to get by are already present in qemu, however some of the helper functions needed to actually wire it up are missing. This patch adds the necessary glue, so that the PURR can be wired up when we implement newer POWER CPU targets which include it. Signed-off-by: David Gibson --- target-ppc/helper.h | 1 + target-ppc/op_helper.c | 7 +++++++ target-ppc/translate_init.c | 8 ++++++++ 3 files changed, 16 insertions(+), 0 deletions(-) diff --git a/target-ppc/helper.h b/target-ppc/helper.h index 1a69cf8..2b4744d 100644 --- a/target-ppc/helper.h +++ b/target-ppc/helper.h @@ -376,6 +376,7 @@ DEF_HELPER_0(load_601_rtcu, tl) #if !defined(CONFIG_USER_ONLY) #if defined(TARGET_PPC64) DEF_HELPER_1(store_asr, void, tl) +DEF_HELPER_0(load_purr, tl) #endif DEF_HELPER_1(store_sdr1, void, tl) DEF_HELPER_1(store_tbl, void, tl) diff --git a/target-ppc/op_helper.c b/target-ppc/op_helper.c index bdb1f17..aa2e8ba 100644 --- a/target-ppc/op_helper.c +++ b/target-ppc/op_helper.c @@ -86,6 +86,13 @@ target_ulong helper_load_atbu (void) return cpu_ppc_load_atbu(env); } +#if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY) +target_ulong helper_load_purr (void) +{ + return (target_ulong)cpu_ppc_load_purr(env); +} +#endif + target_ulong helper_load_601_rtcl (void) { return cpu_ppc601_load_rtcl(env); diff --git a/target-ppc/translate_init.c b/target-ppc/translate_init.c index 7c08b1c..bca85d5 100644 --- a/target-ppc/translate_init.c +++ b/target-ppc/translate_init.c @@ -251,6 +251,14 @@ static void spr_write_atbu (void *opaque, int sprn, int gprn) { gen_helper_store_atbu(cpu_gpr[gprn]); } + +#if defined(TARGET_PPC64) +__attribute__ (( unused )) +static void spr_read_purr (void *opaque, int gprn, int sprn) +{ + gen_helper_load_purr(cpu_gpr[gprn]); +} +#endif #endif #if !defined(CONFIG_USER_ONLY) -- 1.7.1