From nobody Mon Feb 9 08:09:58 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zoho.com; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1488422650220290.4774326486271; Wed, 1 Mar 2017 18:44:10 -0800 (PST) Received: from localhost ([::1]:49877 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cjGiv-0008Mz-20 for importer@patchew.org; Wed, 01 Mar 2017 21:44:09 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:50881) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cjGgf-00072l-H4 for qemu-devel@nongnu.org; Wed, 01 Mar 2017 21:41:50 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1cjGgb-0006lo-6o for qemu-devel@nongnu.org; Wed, 01 Mar 2017 21:41:49 -0500 Received: from mail-qk0-x242.google.com ([2607:f8b0:400d:c09::242]:34148) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1cjGgb-0006lc-2Q for qemu-devel@nongnu.org; Wed, 01 Mar 2017 21:41:45 -0500 Received: by mail-qk0-x242.google.com with SMTP id s186so15732612qkb.1 for ; Wed, 01 Mar 2017 18:41:44 -0800 (PST) Received: from bigtime.twiddle.net.com (mail.taphouse.com.au. [180.214.90.195]) by smtp.gmail.com with ESMTPSA id s3sm4459321qte.57.2017.03.01.18.41.41 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 01 Mar 2017 18:41:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references; bh=Y1DsJiDQ4Q3vllvMcro6WzuUuwqJIVerukDSYELM6oQ=; b=FJDZjZpITdEFw0492N8eGqhg/IPvNU+4XnSAZx1h6Cip9fqKgeVCO65nd4PqXUkrof f0QiB4z7Fsw5r9PRW6cw/ZaUMdjCUb7zJR1OZ/YQ4amqO+hl7qpzhoXfm9Heb9t3I3xM W0Z6APX/2vGqdJp8l1t3kE2SZe0Tv0jtrCxCAbnrgooXpgIdDETLRcvOCjKKb/hEeXKU SAYn0+mjC8Z/3SLir2+bjsA/M4fwtWyhPdVzJ6wvmRcPTC+pe6M7vWfsTBDf8Y7hqkNn EBoeMEtB8bYKs06LoU9l0BM26YHck6wI2mqcWwxoUD4Au1yTEK8FrLEmy9yhZxdyP7BH sMPg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references; bh=Y1DsJiDQ4Q3vllvMcro6WzuUuwqJIVerukDSYELM6oQ=; b=CLpbk2wdODo5wqniGYxn1cgGB9FxOlKVcnfNQVwSXVzRhAQuojIvXw85rEYpqZiV5O lATwi0lGQBydihGRlYTmNauzrbaxLT+2RwXasxoxl3iLGmE/AksrWYf9P/JMbXFE+Mqt FycMJ4i7pt0oUyAqXCJku6SUOjPXHvBVAokq3O6cuIV5QtdOJLDxzr3UqHHdvb2ecU3O fWMOFZ1XAXtB6Jmi/p8ZORrpzrKzZUX1XdB+cHv1W9e0kpU+pQyAiqkNLnQhIWI+QyMH 3f6yJeIGPWfeYrM4PREMdN4G2JuvVCMngif62pvpl6OuQvhbjvOISQGBXMYK7biP7OR/ e2QQ== X-Gm-Message-State: AMke39mDVavlg3ZaUIXVmtJWVFtwavgvJTOqP9SZmJYr93gGC7pev4rzTSgiJXZ9CnQH7Q== X-Received: by 10.55.99.69 with SMTP id x66mr13001215qkb.317.1488422504224; Wed, 01 Mar 2017 18:41:44 -0800 (PST) From: Richard Henderson To: qemu-devel@nongnu.org Date: Thu, 2 Mar 2017 13:41:08 +1100 Message-Id: <20170302024110.3978-5-rth@twiddle.net> X-Mailer: git-send-email 2.9.3 In-Reply-To: <20170302024110.3978-1-rth@twiddle.net> References: <20170302024110.3978-1-rth@twiddle.net> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 2607:f8b0:400d:c09::242 Subject: [Qemu-devel] [PATCH 4/6] target/s390x: Implement LOAD PAIR DISJOINT X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Eric Bischoff Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail: RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Eric Bischoff Signed-off-by: Eric Bischoff Message-Id: <20170228120134.7921-1-ebischoff@suse.com> [rth: Combine the two via insn->data; free the address temps.] Signed-off-by: Richard Henderson --- target/s390x/insn-data.def | 4 +++- target/s390x/translate.c | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/target/s390x/insn-data.def b/target/s390x/insn-data.def index 43c5707..0909060 100644 --- a/target/s390x/insn-data.def +++ b/target/s390x/insn-data.def @@ -504,7 +504,9 @@ C(0xb9e2, LOCGR, RRF_c, LOC, r1, r2, r1, 0, loc, 0) C(0xebf2, LOC, RSY_b, LOC, r1, m2_32u, new, r1_32, loc, 0) C(0xebe2, LOCG, RSY_b, LOC, r1, m2_64, r1, 0, loc, 0) -/* LOAD PAIR DISJOINT TODO */ +/* LOAD PAIR DISJOINT */ + D(0xc804, LPD, SSF, ILA, 0, 0, new_P, r3_P32, lpd, 0, MO_TEUL) + D(0xc805, LPDG, SSF, ILA, 0, 0, new_P, r3_P64, lpd, 0, MO_TEQ) /* LOAD POSITIVE */ C(0x1000, LPR, RR_a, Z, 0, r2_32s, new, r1_32, abs, abs32) C(0xb900, LPGR, RRE, Z, 0, r2, r1, 0, abs, abs64) diff --git a/target/s390x/translate.c b/target/s390x/translate.c index 2b66a4e..8de0177 100644 --- a/target/s390x/translate.c +++ b/target/s390x/translate.c @@ -2559,6 +2559,7 @@ static ExitStatus op_lctlg(DisasContext *s, DisasOps = *o) tcg_temp_free_i32(r3); return NO_EXIT; } + static ExitStatus op_lra(DisasContext *s, DisasOps *o) { check_privileged(s); @@ -2759,6 +2760,31 @@ static ExitStatus op_lm64(DisasContext *s, DisasOps = *o) return NO_EXIT; } =20 +static ExitStatus op_lpd(DisasContext *s, DisasOps *o) +{ + TCGv_i64 a1, a2; + TCGMemOp mop =3D s->insn->data; + + /* In a parallel context, stop the world and single step. */ + if (parallel_cpus) { + potential_page_fault(s); + gen_helper_exit_atomic(cpu_env); + return EXIT_NORETURN; + } + + /* In a serial context, perform the two loads ... */ + a1 =3D get_address(s, 0, get_field(s->fields, b1), get_field(s->fields= , d1)); + a2 =3D get_address(s, 0, get_field(s->fields, b2), get_field(s->fields= , d2)); + tcg_gen_qemu_ld_i64(o->out, a1, get_mem_index(s), mop | MO_ALIGN); + tcg_gen_qemu_ld_i64(o->out2, a2, get_mem_index(s), mop | MO_ALIGN); + tcg_temp_free_i64(a1); + tcg_temp_free_i64(a2); + + /* ... and indicate that we performed them while interlocked. */ + gen_op_movi_cc(s, 0); + return NO_EXIT; +} + #ifndef CONFIG_USER_ONLY static ExitStatus op_lura(DisasContext *s, DisasOps *o) { @@ -4430,6 +4456,22 @@ static void wout_r1_D32(DisasContext *s, DisasFields= *f, DisasOps *o) } #define SPEC_wout_r1_D32 SPEC_r1_even =20 +static void wout_r3_P32(DisasContext *s, DisasFields *f, DisasOps *o) +{ + int r3 =3D get_field(f, r3); + store_reg32_i64(r3, o->out); + store_reg32_i64(r3 + 1, o->out2); +} +#define SPEC_wout_r3_P32 SPEC_r3_even + +static void wout_r3_P64(DisasContext *s, DisasFields *f, DisasOps *o) +{ + int r3 =3D get_field(f, r3); + store_reg(r3, o->out); + store_reg(r3 + 1, o->out2); +} +#define SPEC_wout_r3_P64 SPEC_r3_even + static void wout_e1(DisasContext *s, DisasFields *f, DisasOps *o) { store_freg32_i64(get_field(f, r1), o->out); --=20 2.9.3