From: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
To: qemu-ppc@nongnu.org, david@gibson.dropbear.id.au, rth@twiddle.net
Cc: qemu-devel@nongnu.org, nikunj@linux.vnet.ibm.com,
benh@kernel.crashing.org,
Ravi Bangoria <ravi.bangoria@linux.vnet.ibm.com>
Subject: [Qemu-devel] [PATCH 2/6] target-ppc: Implement darn instruction
Date: Sun, 7 Aug 2016 23:06:51 +0530 [thread overview]
Message-ID: <1470591415-3268-3-git-send-email-nikunj@linux.vnet.ibm.com> (raw)
In-Reply-To: <1470591415-3268-1-git-send-email-nikunj@linux.vnet.ibm.com>
From: Ravi Bangoria <ravi.bangoria@linux.vnet.ibm.com>
darn: Deliver A Random Number
For both CRN and RRN, returning 64-bit random number.
Signed-off-by: Ravi Bangoria <ravi.bangoria@linux.vnet.ibm.com>
Signed-off-by: Nikunj A Dadhania <nikunj@linux.vnet.ibm.com>
---
target-ppc/helper.h | 1 +
target-ppc/int_helper.c | 14 ++++++++++++++
target-ppc/translate.c | 11 +++++++++++
3 files changed, 26 insertions(+)
diff --git a/target-ppc/helper.h b/target-ppc/helper.h
index 8eada2f..257bfca 100644
--- a/target-ppc/helper.h
+++ b/target-ppc/helper.h
@@ -50,6 +50,7 @@ DEF_HELPER_FLAGS_1(cnttzd, TCG_CALL_NO_RWG_SE, tl, tl)
DEF_HELPER_FLAGS_1(popcntd, TCG_CALL_NO_RWG_SE, tl, tl)
DEF_HELPER_FLAGS_2(bpermd, TCG_CALL_NO_RWG_SE, i64, i64, i64)
DEF_HELPER_3(srad, tl, env, tl, tl)
+DEF_HELPER_1(darn, tl, i32)
#endif
DEF_HELPER_FLAGS_1(cntlsw32, TCG_CALL_NO_RWG_SE, i32, i32)
diff --git a/target-ppc/int_helper.c b/target-ppc/int_helper.c
index 552b2e0..2b9fe13 100644
--- a/target-ppc/int_helper.c
+++ b/target-ppc/int_helper.c
@@ -182,6 +182,20 @@ target_ulong helper_cnttzd(target_ulong t)
{
return ctz64(t);
}
+
+target_ulong helper_darn(uint32_t l)
+{
+ target_ulong r = UINT64_MAX;
+
+ if (l <= 2) {
+ do {
+ r = random() * random();
+ r &= l ? UINT64_MAX : UINT32_MAX;
+ } while (r == UINT64_MAX);
+ }
+
+ return r;
+}
#endif
#if defined(TARGET_PPC64)
diff --git a/target-ppc/translate.c b/target-ppc/translate.c
index 2a87d1a..6a79fc1 100644
--- a/target-ppc/translate.c
+++ b/target-ppc/translate.c
@@ -526,6 +526,8 @@ EXTRACT_HELPER(FPW, 16, 1);
/* addpcis */
EXTRACT_HELPER_DXFORM(DX, 10, 6, 6, 5, 16, 1, 1, 0, 0)
+/* darn */
+EXTRACT_HELPER(L, 16, 2);
/*** Jump target decoding ***/
/* Immediate address */
@@ -1893,6 +1895,14 @@ static void gen_cnttzd(DisasContext *ctx)
gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]);
}
}
+
+/* darn */
+static void gen_darn(DisasContext *ctx)
+{
+ TCGv_i32 l = tcg_const_i32(L(ctx->opcode));
+ gen_helper_darn(cpu_gpr[rD(ctx->opcode)], l);
+ tcg_temp_free_i32(l);
+}
#endif
/*** Integer rotate ***/
@@ -6238,6 +6248,7 @@ GEN_HANDLER_E(prtyw, 0x1F, 0x1A, 0x04, 0x0000F801, PPC_NONE, PPC2_ISA205),
GEN_HANDLER(popcntd, 0x1F, 0x1A, 0x0F, 0x0000F801, PPC_POPCNTWD),
GEN_HANDLER(cntlzd, 0x1F, 0x1A, 0x01, 0x00000000, PPC_64B),
GEN_HANDLER_E(cnttzd, 0x1F, 0x1A, 0x11, 0x00000000, PPC_NONE, PPC2_ISA300),
+GEN_HANDLER_E(darn, 0x1F, 0x13, 0x17, 0x001CF801, PPC_NONE, PPC2_ISA300),
GEN_HANDLER_E(prtyd, 0x1F, 0x1A, 0x05, 0x0000F801, PPC_NONE, PPC2_ISA205),
GEN_HANDLER_E(bpermd, 0x1F, 0x1C, 0x07, 0x00000001, PPC_NONE, PPC2_PERM_ISA206),
#endif
--
2.7.4
next prev parent reply other threads:[~2016-08-07 17:37 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-08-07 17:36 [Qemu-devel] [PATCH 0/6] POWER9 TCG enablements - part4 Nikunj A Dadhania
2016-08-07 17:36 ` [Qemu-devel] [PATCH 1/6] target-ppc: add xxspltib instruction Nikunj A Dadhania
2016-08-08 4:43 ` Richard Henderson
2016-08-08 6:19 ` Nikunj A Dadhania
2016-08-07 17:36 ` Nikunj A Dadhania [this message]
2016-08-07 21:33 ` [Qemu-devel] [PATCH 2/6] target-ppc: Implement darn instruction Benjamin Herrenschmidt
2016-08-08 1:52 ` Nikunj A Dadhania
2016-08-08 3:22 ` Benjamin Herrenschmidt
2016-08-08 3:32 ` Nikunj A Dadhania
2016-08-09 3:28 ` David Gibson
2016-08-09 4:54 ` Nikunj A Dadhania
2016-08-09 9:17 ` [Qemu-devel] [Qemu-ppc] " Nikunj A Dadhania
2016-08-12 6:29 ` David Gibson
2016-08-12 6:43 ` Nikunj A Dadhania
2016-08-12 6:56 ` David Gibson
2016-08-12 7:13 ` Nikunj A Dadhania
2016-08-12 7:29 ` Thomas Huth
2016-08-12 7:39 ` Nikunj A Dadhania
2016-08-12 7:55 ` Thomas Huth
2016-08-12 8:41 ` Nikunj A Dadhania
2016-08-12 9:29 ` Thomas Huth
2016-08-12 9:51 ` Nikunj A Dadhania
2016-08-12 13:26 ` Richard Henderson
2016-08-12 13:39 ` Nikunj A Dadhania
2016-08-15 10:28 ` David Gibson
2016-08-08 5:01 ` [Qemu-devel] " Richard Henderson
2016-08-08 6:20 ` Nikunj A Dadhania
2016-08-07 17:36 ` [Qemu-devel] [PATCH 3/6] target-ppc: add lxsi[bw]zx instruction Nikunj A Dadhania
2016-08-08 5:08 ` Richard Henderson
2016-08-08 6:21 ` Nikunj A Dadhania
2016-08-07 17:36 ` [Qemu-devel] [PATCH 4/6] target-ppc: add stxsi[bh]x instruction Nikunj A Dadhania
2016-08-08 5:08 ` Richard Henderson
2016-08-07 17:36 ` [Qemu-devel] [PATCH 5/6] target-ppc: add lxvb16x and lxvh8x Nikunj A Dadhania
2016-08-08 5:27 ` Richard Henderson
2016-08-08 6:35 ` Richard Henderson
2016-08-10 9:21 ` Nikunj A Dadhania
2016-08-10 10:12 ` Richard Henderson
2016-08-10 10:33 ` Nikunj A Dadhania
2016-08-10 15:21 ` Nikunj A Dadhania
2016-08-07 17:36 ` [Qemu-devel] [PATCH 6/6] target-ppc: add stxvb16x and stxvh8x Nikunj A Dadhania
2016-08-08 5:27 ` Richard Henderson
2016-08-09 3:30 ` [Qemu-devel] [PATCH 0/6] POWER9 TCG enablements - part4 David Gibson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1470591415-3268-3-git-send-email-nikunj@linux.vnet.ibm.com \
--to=nikunj@linux.vnet.ibm.com \
--cc=benh@kernel.crashing.org \
--cc=david@gibson.dropbear.id.au \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
--cc=ravi.bangoria@linux.vnet.ibm.com \
--cc=rth@twiddle.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.