From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423732820330.92283571285975; Fri, 25 Jan 2019 05:42:12 -0800 (PST) Received: from localhost ([127.0.0.1]:44806 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1k9-0002YZ-L7 for importer@patchew.org; Fri, 25 Jan 2019 08:42:01 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46454) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aJ-0002lD-OW for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aH-0002Vu-As for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:51 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:35832 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aH-0002Uv-2M for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:49 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 0734D1A23FF; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id BFDEE1A21CC; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:25 +0100 Message-Id: <1548423098-31864-2-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 01/14] target/mips: nanoMIPS: Remove duplicate macro definitions 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Several macros were defined twice, with identical values, so remove duplicates. Previously added in 80845edf37b. This reverts commit 6bfa9f4c9cf24d6cfaaa227722e9cdcca1ad6fe9. Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Aleksandar Markovic --- target/mips/translate.c | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/target/mips/translate.c b/target/mips/translate.c index ab307c4..6002d1c 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -18502,16 +18502,6 @@ static inline int decode_gpr_gpr4_zero(int r) } =20 =20 -/* extraction utilities */ - -#define NANOMIPS_EXTRACT_RD(op) ((op >> 7) & 0x7) -#define NANOMIPS_EXTRACT_RS(op) ((op >> 4) & 0x7) -#define NANOMIPS_EXTRACT_RS2(op) uMIPS_RS(op) -#define NANOMIPS_EXTRACT_RS1(op) ((op >> 1) & 0x7) -#define NANOMIPS_EXTRACT_RD5(op) ((op >> 5) & 0x1f) -#define NANOMIPS_EXTRACT_RS5(op) (op & 0x1f) - - static void gen_adjust_sp(DisasContext *ctx, int u) { gen_op_addr_addi(ctx, cpu_gpr[29], cpu_gpr[29], u); --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423252980645.3649317467252; Fri, 25 Jan 2019 05:34:12 -0800 (PST) Received: from localhost ([127.0.0.1]:44672 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1cU-0003zj-7z for importer@patchew.org; Fri, 25 Jan 2019 08:34:06 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46418) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aI-0002kT-Ds for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:51 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aH-0002Vp-AR for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:35821 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aH-0002Uu-2Q for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:49 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id F3FE21A23F9; Fri, 25 Jan 2019 14:31:46 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id C74211A21F3; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:26 +0100 Message-Id: <1548423098-31864-3-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 02/14] target/mips: nanoMIPS: Remove an unused macro 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Remove a macro that is never used. Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Aleksandar Markovic --- target/mips/translate.c | 1 - 1 file changed, 1 deletion(-) diff --git a/target/mips/translate.c b/target/mips/translate.c index 6002d1c..06e7bc6 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -18462,7 +18462,6 @@ enum { =20 #define NANOMIPS_EXTRACT_RD(op) ((op >> 7) & 0x7) #define NANOMIPS_EXTRACT_RS(op) ((op >> 4) & 0x7) -#define NANOMIPS_EXTRACT_RS2(op) uMIPS_RS(op) #define NANOMIPS_EXTRACT_RS1(op) ((op >> 1) & 0x7) #define NANOMIPS_EXTRACT_RD5(op) ((op >> 5) & 0x1f) #define NANOMIPS_EXTRACT_RS5(op) (op & 0x1f) --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423593383774.6126524184723; Fri, 25 Jan 2019 05:39:53 -0800 (PST) Received: from localhost ([127.0.0.1]:44754 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1hu-0000ZY-5e for importer@patchew.org; Fri, 25 Jan 2019 08:39:42 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46422) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aI-0002kc-Jf for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aH-0002W0-Cu for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:35915 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aH-0002V1-21 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:49 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 08C031A2405; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id CE66C1A2215; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:27 +0100 Message-Id: <1548423098-31864-4-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 03/14] target/mips: nanoMIPS: Rename macros for extracting 3-bit-coded GPR numbers 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Rename macros for extracting 3-bit-coded GPR numbers, to achieve better consistency with the nanoMIPS documentation. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- target/mips/translate.c | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/target/mips/translate.c b/target/mips/translate.c index 06e7bc6..2140ecd 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -18460,9 +18460,9 @@ enum { =20 /* extraction utilities */ =20 -#define NANOMIPS_EXTRACT_RD(op) ((op >> 7) & 0x7) -#define NANOMIPS_EXTRACT_RS(op) ((op >> 4) & 0x7) -#define NANOMIPS_EXTRACT_RS1(op) ((op >> 1) & 0x7) +#define NANOMIPS_EXTRACT_RT3(op) ((op >> 7) & 0x7) +#define NANOMIPS_EXTRACT_RS3(op) ((op >> 4) & 0x7) +#define NANOMIPS_EXTRACT_RD3(op) ((op >> 1) & 0x7) #define NANOMIPS_EXTRACT_RD5(op) ((op >> 5) & 0x1f) #define NANOMIPS_EXTRACT_RS5(op) (op & 0x1f) =20 @@ -18559,8 +18559,8 @@ static void gen_restore(DisasContext *ctx, uint8_t = rt, uint8_t count, =20 static void gen_pool16c_nanomips_insn(DisasContext *ctx) { - int rt =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RD(ctx->opcode)); - int rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS(ctx->opcode)); + int rt =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RT3(ctx->opcode)); + int rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS3(ctx->opcode)); =20 switch (extract32(ctx->opcode, 2, 2)) { case NM_NOT16: @@ -21861,9 +21861,9 @@ static int decode_nanomips_32_48_opc(CPUMIPSState *= env, DisasContext *ctx) static int decode_nanomips_opc(CPUMIPSState *env, DisasContext *ctx) { uint32_t op; - int rt =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RD(ctx->opcode)); - int rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS(ctx->opcode)); - int rd =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS1(ctx->opcode)); + int rt =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RT3(ctx->opcode)); + int rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS3(ctx->opcode)); + int rd =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RD3(ctx->opcode)); int offset; int imm; =20 @@ -22026,7 +22026,7 @@ static int decode_nanomips_opc(CPUMIPSState *env, D= isasContext *ctx) break; case NM_SB16: rt =3D decode_gpr_gpr3_src_store( - NANOMIPS_EXTRACT_RD(ctx->opcode)); + NANOMIPS_EXTRACT_RT3(ctx->opcode)); gen_st(ctx, OPC_SB, rt, rs, offset); break; case NM_LBU16: @@ -22045,7 +22045,7 @@ static int decode_nanomips_opc(CPUMIPSState *env, D= isasContext *ctx) break; case NM_SH16: rt =3D decode_gpr_gpr3_src_store( - NANOMIPS_EXTRACT_RD(ctx->opcode)); + NANOMIPS_EXTRACT_RT3(ctx->opcode)); gen_st(ctx, OPC_SH, rt, rs, offset); break; case NM_LHU16: @@ -22100,14 +22100,14 @@ static int decode_nanomips_opc(CPUMIPSState *env,= DisasContext *ctx) break; case NM_SW16: rt =3D decode_gpr_gpr3_src_store( - NANOMIPS_EXTRACT_RD(ctx->opcode)); - rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS(ctx->opcode)); + NANOMIPS_EXTRACT_RT3(ctx->opcode)); + rs =3D decode_gpr_gpr3(NANOMIPS_EXTRACT_RS3(ctx->opcode)); offset =3D extract32(ctx->opcode, 0, 4) << 2; gen_st(ctx, OPC_SW, rt, rs, offset); break; case NM_SWGP16: rt =3D decode_gpr_gpr3_src_store( - NANOMIPS_EXTRACT_RD(ctx->opcode)); + NANOMIPS_EXTRACT_RT3(ctx->opcode)); offset =3D extract32(ctx->opcode, 0, 7) << 2; gen_st(ctx, OPC_SW, rt, 28, offset); break; --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423422998293.53060875120127; Fri, 25 Jan 2019 05:37:02 -0800 (PST) Received: from localhost ([127.0.0.1]:44727 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1f9-0006Nh-NP for importer@patchew.org; Fri, 25 Jan 2019 08:36:51 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46416) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aI-0002kN-8y for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:51 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aH-0002Vk-A3 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:35980 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aH-0002V4-1y for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:49 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 209391A23D3; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id D6A2B1A23D1; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:28 +0100 Message-Id: <1548423098-31864-5-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 04/14] target/mips: Correct the second argument type of cpu_supports_isa() 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic "insn_flags" bitfield was expanded from 32-bit to 64-bit in commit f9c9cd63e3. However, this was not reflected on the second argument of the function cpu_supports_isa(). By chance, this did not create some wrong behavior, since the left-most halves of all instances of the second argument are currently all zeros. However, this is still a bug waiting to happen. Correct this by changing the type of the second argument to be always 64-bit. Reviewed-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Aleksandar Markovic --- target/mips/cpu.h | 2 +- target/mips/translate.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/target/mips/cpu.h b/target/mips/cpu.h index c4da7df..473d26d 100644 --- a/target/mips/cpu.h +++ b/target/mips/cpu.h @@ -1173,7 +1173,7 @@ int cpu_mips_signal_handler(int host_signum, void *pi= nfo, void *puc); #define CPU_RESOLVING_TYPE TYPE_MIPS_CPU =20 bool cpu_supports_cps_smp(const char *cpu_type); -bool cpu_supports_isa(const char *cpu_type, unsigned int isa); +bool cpu_supports_isa(const char *cpu_type, uint64_t isa); void cpu_set_exception_base(int vp_index, target_ulong address); =20 /* mips_int.c */ diff --git a/target/mips/translate.c b/target/mips/translate.c index 2140ecd..b362b03 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -29883,7 +29883,7 @@ bool cpu_supports_cps_smp(const char *cpu_type) return (mcc->cpu_def->CP0_Config3 & (1 << CP0C3_CMGCR)) !=3D 0; } =20 -bool cpu_supports_isa(const char *cpu_type, unsigned int isa) +bool cpu_supports_isa(const char *cpu_type, uint64_t isa) { const MIPSCPUClass *mcc =3D MIPS_CPU_CLASS(object_class_by_name(cpu_ty= pe)); return (mcc->cpu_def->insn_flags & isa) !=3D 0; --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423595046687.012978883052; Fri, 25 Jan 2019 05:39:55 -0800 (PST) Received: from localhost ([127.0.0.1]:44756 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1hx-0000cW-QQ for importer@patchew.org; Fri, 25 Jan 2019 08:39:45 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46530) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aT-0002tf-Ut for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:02 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aS-0002eh-Nn for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:01 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36390 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aS-0002W6-HD for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:00 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 4DAAC1A20C8; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id DEE7E1A22D0; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:29 +0100 Message-Id: <1548423098-31864-6-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 05/14] target/mips: Extend gen_scwp() functionality to support EVA 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Extend gen_scwp() functionality to support EVA by adding an additional argument, modify internals of the function to handle new functionality, and accordingly change its invocations. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- target/mips/translate.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/target/mips/translate.c b/target/mips/translate.c index b362b03..aaf7dff 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -3714,7 +3714,7 @@ static void gen_st_cond (DisasContext *ctx, uint32_t = opc, int rt, } =20 static void gen_scwp(DisasContext *ctx, uint32_t base, int16_t offset, - uint32_t reg1, uint32_t reg2) + uint32_t reg1, uint32_t reg2, bool eva) { TCGv taddr =3D tcg_temp_local_new(); TCGv lladdr =3D tcg_temp_local_new(); @@ -3742,7 +3742,7 @@ static void gen_scwp(DisasContext *ctx, uint32_t base= , int16_t offset, =20 tcg_gen_ld_i64(llval, cpu_env, offsetof(CPUMIPSState, llval_wp)); tcg_gen_atomic_cmpxchg_i64(val, taddr, llval, tval, - ctx->mem_idx, MO_64); + eva ? MIPS_HFLAG_UM : ctx->mem_idx, MO_64); if (reg1 !=3D 0) { tcg_gen_movi_tl(cpu_gpr[reg1], 1); } @@ -21550,7 +21550,8 @@ static int decode_nanomips_32_48_opc(CPUMIPSState *= env, DisasContext *ctx) break; case NM_SCWP: check_xnp(ctx); - gen_scwp(ctx, rs, 0, rt, extract32(ctx->opcode, 3,= 5)); + gen_scwp(ctx, rs, 0, rt, extract32(ctx->opcode, 3,= 5), + false); break; } break; @@ -21654,7 +21655,8 @@ static int decode_nanomips_32_48_opc(CPUMIPSState *= env, DisasContext *ctx) check_xnp(ctx); check_eva(ctx); check_cp0_enabled(ctx); - gen_scwp(ctx, rs, 0, rt, extract32(ctx->opcode, 3,= 5)); + gen_scwp(ctx, rs, 0, rt, extract32(ctx->opcode, 3,= 5), + true); break; default: generate_exception_end(ctx, EXCP_RI); --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=pass (zoho.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423856249100.14107052482984; Fri, 25 Jan 2019 05:44:16 -0800 (PST) Received: from localhost ([127.0.0.1]:44835 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1mC-0004Fg-5O for importer@patchew.org; Fri, 25 Jan 2019 08:44:08 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46546) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aU-0002tu-Ru for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:04 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aS-0002et-T9 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:02 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36391 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aS-0002W7-Hh for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:00 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 566211A23D1; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id E84091A23E6; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:30 +0100 Message-Id: <1548423098-31864-7-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 06/14] disas: nanoMIPS: Amend DSP instructions related comments 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Amend some DSP instructions related comments. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- disas/nanomips.cpp | 119 +++++++++++++++++++++++++++++++++----------------= ---- 1 file changed, 75 insertions(+), 44 deletions(-) diff --git a/disas/nanomips.cpp b/disas/nanomips.cpp index 17f4c22..f90f1a9 100644 --- a/disas/nanomips.cpp +++ b/disas/nanomips.cpp @@ -1836,7 +1836,8 @@ std::string NMD::ABS_S(uint64 instruction) =20 =20 /* - * ABSQ_S.PH rt, rs - Find Absolute Value of Two Fractional Halfwords + * [DSP] ABSQ_S.PH rt, rs - Find absolute value of two fractional halfwords + * with 16-bit saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -1857,7 +1858,8 @@ std::string NMD::ABSQ_S_PH(uint64 instruction) =20 =20 /* - * ABSQ_S.QB rt, rs - Find Absolute Value of Four Fractional Byte Values + * [DSP] ABSQ_S.QB rt, rs - Find absolute value of four fractional byte va= lues + * with 8-bit saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -1878,7 +1880,8 @@ std::string NMD::ABSQ_S_QB(uint64 instruction) =20 =20 /* - * + * [DSP] ABSQ_S.W rt, rs - Find absolute value of fractional word with 32-= bit + * saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -2233,7 +2236,7 @@ std::string NMD::ADDIUPC_48_(uint64 instruction) =20 =20 /* - * ADDQ.PH rd, rt, rs - Add Fractional Halfword Vectors + * [DSP] ADDQ.PH rd, rt, rs - Add fractional halfword vectors * * 3 2 1 * 10987654321098765432109876543210 @@ -2257,7 +2260,8 @@ std::string NMD::ADDQ_PH(uint64 instruction) =20 =20 /* - * ADDQ_S.PH rd, rt, rs - Add Fractional Halfword Vectors + * [DSP] ADDQ_S.PH rd, rt, rs - Add fractional halfword vectors with 16-bit + * saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -2281,7 +2285,7 @@ std::string NMD::ADDQ_S_PH(uint64 instruction) =20 =20 /* - * ADDQ_S.W rd, rt, rs - Add Fractional Words + * [DSP] ADDQ_S.W rd, rt, rs - Add fractional words with 32-bit saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -2305,8 +2309,8 @@ std::string NMD::ADDQ_S_W(uint64 instruction) =20 =20 /* - * ADDQH.PH rd, rt, rs - Add Fractional Halfword Vectors And Shift Right - * to Halve Results + * [DSP] ADDQH.PH rd, rt, rs - Add fractional halfword vectors and shift + * right to halve results * * 3 2 1 * 10987654321098765432109876543210 @@ -2330,8 +2334,8 @@ std::string NMD::ADDQH_PH(uint64 instruction) =20 =20 /* - * ADDQH_R.PH rd, rt, rs - Add Fractional Halfword Vectors And Shift Right - * to Halve Results + * [DSP] ADDQH_R.PH rd, rt, rs - Add fractional halfword vectors and shift + * right to halve results with rounding * * 3 2 1 * 10987654321098765432109876543210 @@ -2355,7 +2359,8 @@ std::string NMD::ADDQH_R_PH(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] ADDQH_R.W rd, rt, rs - Add fractional words and shift right to ha= lve + * results with rounding * * 3 2 1 * 10987654321098765432109876543210 @@ -2379,7 +2384,8 @@ std::string NMD::ADDQH_R_W(uint64 instruction) =20 =20 /* - * ADDQH.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Resu= lts + * [DSP] ADDQH.W rd, rt, rs - Add fractional words and shift right to halve + * results * * 3 2 1 * 10987654321098765432109876543210 @@ -2403,7 +2409,7 @@ std::string NMD::ADDQH_W(uint64 instruction) =20 =20 /* - * ADDSC rd, rt, rs - Add Signed Word and Set Carry Bit + * [DSP] ADDSC rd, rt, rs - Add two signed words and set carry bit * * 3 2 1 * 10987654321098765432109876543210 @@ -2496,7 +2502,7 @@ std::string NMD::ADDU_4X4_(uint64 instruction) =20 =20 /* - * ADDU.PH rd, rt, rs - Unsigned Add Integer Halfwords + * [DSP] ADDU.PH rd, rt, rs - Add two pairs of unsigned halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -2544,7 +2550,8 @@ std::string NMD::ADDU_QB(uint64 instruction) =20 =20 /* - * ADDU_S.PH rd, rt, rs - Unsigned Add Integer Halfwords + * [DSP] ADDU_S.PH rd, rt, rs - Add two pairs of unsigned halfwords with 1= 6-bit + * saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -7848,7 +7855,7 @@ std::string NMD::INS(uint64 instruction) =20 =20 /* - * + * [DSP] INSV - Insert bit field variable * * 3 2 1 * 10987654321098765432109876543210 @@ -9698,7 +9705,8 @@ std::string NMD::LWXS_32_(uint64 instruction) =20 =20 /* - * + * [DSP] MADD ac, rs, rt - Multiply two words and add to the specified + * accumulator * * 3 2 1 * 10987654321098765432109876543210 @@ -9770,7 +9778,8 @@ std::string NMD::MADDF_S(uint64 instruction) =20 =20 /* - * + * [DSP] MADDU ac, rs, rt - Multiply two unsigned words and add to the + * specified accumulator * * 3 2 1 * 10987654321098765432109876543210 @@ -9794,7 +9803,8 @@ std::string NMD::MADDU_DSP_(uint64 instruction) =20 =20 /* - * + * [DSP] MAQ_S.W.PHL ac, rs, rt - Multiply the left-most single vector + * fractional halfword elements with accumulation * * 3 2 1 * 10987654321098765432109876543210 @@ -9818,7 +9828,8 @@ std::string NMD::MAQ_S_W_PHL(uint64 instruction) =20 =20 /* - * + * [DSP] MAQ_S.W.PHR ac, rs, rt - Multiply the right-most single vector + * fractional halfword elements with accumulation * * 3 2 1 * 10987654321098765432109876543210 @@ -9842,7 +9853,8 @@ std::string NMD::MAQ_S_W_PHR(uint64 instruction) =20 =20 /* - * + * [DSP] MAQ_SA.W.PHL ac, rs, rt - Multiply the left-most single vector + * fractional halfword elements with saturating accumulation * * 3 2 1 * 10987654321098765432109876543210 @@ -9866,7 +9878,8 @@ std::string NMD::MAQ_SA_W_PHL(uint64 instruction) =20 =20 /* - * + * [DSP] MAQ_SA.W.PHR ac, rs, rt - Multiply the right-most single vector + * fractional halfword elements with saturating accumulation * * 3 2 1 * 10987654321098765432109876543210 @@ -11722,7 +11735,8 @@ std::string NMD::ORI(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PACKRL.PH rd, rs, rt - Pack a word using the right halfword from = one + * source register and left halfword from another source register * * 3 2 1 * 10987654321098765432109876543210 @@ -11764,7 +11778,8 @@ std::string NMD::PAUSE(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PICK.PH rd, rs, rt - Pick a vector of halfwords based on condition + * code bits * * 3 2 1 * 10987654321098765432109876543210 @@ -11788,7 +11803,8 @@ std::string NMD::PICK_PH(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PICK.QB rd, rs, rt - Pick a vector of byte values based on condit= ion + * code bits * * 3 2 1 * 10987654321098765432109876543210 @@ -11812,7 +11828,8 @@ std::string NMD::PICK_QB(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQ.W.PHL rt, rs - Expand the precision of the left-most eleme= nt + * of a paired halfword * * 3 2 1 * 10987654321098765432109876543210 @@ -11834,7 +11851,8 @@ std::string NMD::PRECEQ_W_PHL(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQ.W.PHR rt, rs - Expand the precision of the right-most elem= ent + * of a paired halfword * * 3 2 1 * 10987654321098765432109876543210 @@ -11856,7 +11874,8 @@ std::string NMD::PRECEQ_W_PHR(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQU.PH.QBLA rt, rs - Expand the precision of the two + * left-alternate elements of a quad byte vector * * 3 2 1 * 10987654321098765432109876543210 @@ -11878,7 +11897,8 @@ std::string NMD::PRECEQU_PH_QBLA(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQU.PH.QBL rt, rs - Expand the precision of the two left-most + * elements of a quad byte vector * * 3 2 1 * 10987654321098765432109876543210 @@ -11900,7 +11920,8 @@ std::string NMD::PRECEQU_PH_QBL(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQU.PH.QBRA rt, rs - Expand the precision of the two + * right-alternate elements of a quad byte vector * * 3 2 1 * 10987654321098765432109876543210 @@ -11922,7 +11943,8 @@ std::string NMD::PRECEQU_PH_QBRA(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEQU.PH.QBR rt, rs - Expand the precision of the two right-most + * elements of a quad byte vector * * 3 2 1 * 10987654321098765432109876543210 @@ -11944,7 +11966,9 @@ std::string NMD::PRECEQU_PH_QBR(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEU.PH.QBLA rt, rs - Expand the precision of the two + * left-alternate elements of a quad byte vector to four unsigned + * halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -11966,7 +11990,8 @@ std::string NMD::PRECEU_PH_QBLA(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEU.PH.QBL rt, rs - Expand the precision of the two left-most + * elements of a quad byte vector to form unsigned halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -11988,7 +12013,9 @@ std::string NMD::PRECEU_PH_QBL(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEU.PH.QBRA rt, rs - Expand the precision of the two + * right-alternate elements of a quad byte vector to form four + * unsigned halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -12010,7 +12037,8 @@ std::string NMD::PRECEU_PH_QBRA(uint64 instruction) =20 =20 /* - * ADDQH_R.W rd, rt, rs - Add Fractional Words And Shift Right to Halve Re= sults + * [DSP] PRECEU.PH.QBR rt, rs - Expand the precision of the two right-most + * elements of a quad byte vector to form unsigned halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -15202,7 +15230,7 @@ std::string NMD::SUBU_32_(uint64 instruction) =20 =20 /* - * SUBU.PH rd, rs, rt - Subtract Unsigned Integer Halfwords + * [DSP] SUBU.PH rd, rs, rt - Subtract unsigned unsigned halfwords * * 3 2 1 * 10987654321098765432109876543210 @@ -15226,7 +15254,7 @@ std::string NMD::SUBU_PH(uint64 instruction) =20 =20 /* - * SUBU.QB rd, rs, rt - Subtract Unsigned Quad Byte Vector + * [DSP] SUBU.QB rd, rs, rt - Subtract unsigned quad byte vectors * * 3 2 1 * 10987654321098765432109876543210 @@ -15250,7 +15278,8 @@ std::string NMD::SUBU_QB(uint64 instruction) =20 =20 /* - * SUBU_S.PH rd, rs, rt - Subtract Unsigned Integer Halfwords (saturating) + * [DSP] SUBU_S.PH rd, rs, rt - Subtract unsigned unsigned halfwords with + * 8-bit saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -15274,7 +15303,8 @@ std::string NMD::SUBU_S_PH(uint64 instruction) =20 =20 /* - * SUBU_S.QB rd, rs, rt - Subtract Unsigned Quad Byte Vector (saturating) + * [DSP] SUBU_S.QB rd, rs, rt - Subtract unsigned quad byte vectors with + * 8-bit saturation * * 3 2 1 * 10987654321098765432109876543210 @@ -15298,8 +15328,8 @@ std::string NMD::SUBU_S_QB(uint64 instruction) =20 =20 /* - * SUBUH.QB rd, rs, rt - Subtract Unsigned Bytes And Right Shift to Halve - * Results + * [DSP] SUBUH.QB rd, rs, rt - Subtract unsigned bytes and right shift + * to halve results * * 3 2 1 * 10987654321098765432109876543210 @@ -15323,8 +15353,8 @@ std::string NMD::SUBUH_QB(uint64 instruction) =20 =20 /* - * SUBUH_R.QB rd, rs, rt - Subtract Unsigned Bytes And Right Shift to Halve - * Results (rounding) + * [DSP] SUBUH_R.QB rd, rs, rt - Subtract unsigned bytes and right shift + * to halve results with rounding * * 3 2 1 * 10987654321098765432109876543210 @@ -16412,7 +16442,8 @@ std::string NMD::WAIT(uint64 instruction) =20 =20 /* - * WRDSP rt, mask - Write Fields to DSPControl Register from a GPR + * [DSP] WRDSP rt, mask - Write selected fields from a GPR to the DSPContr= ol + * register * * 3 2 1 * 10987654321098765432109876543210 --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 154842326547443.13989085164212; Fri, 25 Jan 2019 05:34:25 -0800 (PST) Received: from localhost ([127.0.0.1]:44676 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1cc-00045g-TK for importer@patchew.org; Fri, 25 Jan 2019 08:34:14 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46458) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aJ-0002lP-Ru for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aI-0002XS-MI for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:51 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36394 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002WB-Bo for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 70A741A22D0; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id F3E4B1A23E2; Fri, 25 Jan 2019 14:31:46 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:31 +0100 Message-Id: <1548423098-31864-8-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 07/14] target/mips: nanoMIPS: Fix branch handling 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Stefan Markovic Fix nanoMIPS branch handling. Reviewed-by: Aleksandar Rikalo Signed-off-by: Stefan Markovic Signed-off-by: Aleksandar Markovic --- target/mips/translate.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/target/mips/translate.c b/target/mips/translate.c index aaf7dff..e9b5d1d 100644 --- a/target/mips/translate.c +++ b/target/mips/translate.c @@ -19758,6 +19758,10 @@ static void gen_compute_imm_branch(DisasContext *c= tx, uint32_t opc, goto out; } =20 + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp =3D DISAS_NORETURN; + if (bcond_compute =3D=3D 0) { /* Uncoditional compact branch */ gen_goto_tb(ctx, 0, ctx->btarget); @@ -19798,6 +19802,10 @@ static void gen_compute_nanomips_pbalrsc_branch(Di= sasContext *ctx, int rs, tcg_gen_movi_tl(t1, ctx->base.pc_next + 4); gen_op_addr_add(ctx, btarget, t1, t0); =20 + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp =3D DISAS_NORETURN; + /* unconditional branch to register */ tcg_gen_mov_tl(cpu_PC, btarget); tcg_gen_lookup_and_goto_ptr(); @@ -19936,6 +19944,10 @@ static void gen_compute_compact_branch_nm(DisasCon= text *ctx, uint32_t opc, goto out; } =20 + /* branch completion */ + clear_branch_hflags(ctx); + ctx->base.is_jmp =3D DISAS_NORETURN; + /* Generating branch here as compact branches don't have delay slo= t */ gen_goto_tb(ctx, 1, ctx->btarget); gen_set_label(fs); --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423429705172.2453044806498; Fri, 25 Jan 2019 05:37:09 -0800 (PST) Received: from localhost ([127.0.0.1]:44729 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1fG-0006Th-KK for importer@patchew.org; Fri, 25 Jan 2019 08:36:58 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46484) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aK-0002lq-LH for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:53 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aJ-0002YG-9g for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36395 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002WG-IO for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:51 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 598F31A2423; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id 0702B1A23FE; Fri, 25 Jan 2019 14:31:47 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:32 +0100 Message-Id: <1548423098-31864-9-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 08/14] target/mips: Add I6500 core configuration 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Yongbok Kim Add I6500 core configuration. Note that this configuration is supported only on best-effort basis due to the lack of certain features in QEMU. Reviewed-by: Aleksandar Rikalo Signed-off-by: Yongbok Kim Signed-off-by: Aleksandar Markovic --- target/mips/translate_init.inc.c | 40 ++++++++++++++++++++++++++++++++++++= ++++ 1 file changed, 40 insertions(+) diff --git a/target/mips/translate_init.inc.c b/target/mips/translate_init.= inc.c index acab097..bf559af 100644 --- a/target/mips/translate_init.inc.c +++ b/target/mips/translate_init.inc.c @@ -722,6 +722,46 @@ const mips_def_t mips_defs[] =3D .mmu_type =3D MMU_TYPE_R4000, }, { + .name =3D "I6500", + .CP0_PRid =3D 0x1B000, + .CP0_Config0 =3D MIPS_CONFIG0 | (0x2 << CP0C0_AR) | (0x2 << CP0C0_= AT) | + (MMU_TYPE_R4000 << CP0C0_MT), + .CP0_Config1 =3D MIPS_CONFIG1 | (1 << CP0C1_FP) | (15 << CP0C1_MMU= ) | + (2 << CP0C1_IS) | (5 << CP0C1_IL) | (3 << CP0C1_IA)= | + (2 << CP0C1_DS) | (5 << CP0C1_DL) | (3 << CP0C1_DA)= | + (0 << CP0C1_PC) | (1 << CP0C1_WR) | (1 << CP0C1_EP), + .CP0_Config2 =3D MIPS_CONFIG2, + .CP0_Config3 =3D MIPS_CONFIG3 | (1U << CP0C3_M) | + (1 << CP0C3_CMGCR) | (1 << CP0C3_MSAP) | + (1 << CP0C3_BP) | (1 << CP0C3_BI) | (1 << CP0C3_ULR= I) | + (1 << CP0C3_RXI) | (1 << CP0C3_LPA) | (1 << CP0C3_V= Int), + .CP0_Config4 =3D MIPS_CONFIG4 | (1U << CP0C4_M) | (3 << CP0C4_IE) | + (1 << CP0C4_AE) | (0xfc << CP0C4_KScrExist), + .CP0_Config5 =3D MIPS_CONFIG5 | (1 << CP0C5_XNP) | (1 << CP0C5_VP)= | + (1 << CP0C5_LLB) | (1 << CP0C5_MRP), + .CP0_Config5_rw_bitmask =3D (1 << CP0C5_MSAEn) | (1 << CP0C5_SBRI)= | + (1 << CP0C5_FRE) | (1 << CP0C5_UFE), + .CP0_LLAddr_rw_bitmask =3D 0, + .CP0_LLAddr_shift =3D 0, + .SYNCI_Step =3D 64, + .CCRes =3D 2, + .CP0_Status_rw_bitmask =3D 0x30D8FFFF, + .CP0_PageGrain =3D (1 << CP0PG_IEC) | (1 << CP0PG_XIE) | + (1U << CP0PG_RIE), + .CP0_PageGrain_rw_bitmask =3D (1 << CP0PG_ELPA), + .CP0_EBaseWG_rw_bitmask =3D (1 << CP0EBase_WG), + .CP1_fcr0 =3D (1 << FCR0_FREP) | (1 << FCR0_HAS2008) | (1 << FCR0_= F64) | + (1 << FCR0_L) | (1 << FCR0_W) | (1 << FCR0_D) | + (1 << FCR0_S) | (0x03 << FCR0_PRID) | (0x0 << FCR0_REV= ), + .CP1_fcr31 =3D (1 << FCR31_ABS2008) | (1 << FCR31_NAN2008), + .CP1_fcr31_rw_bitmask =3D 0x0103FFFF, + .MSAIR =3D 0x03 << MSAIR_ProcID, + .SEGBITS =3D 48, + .PABITS =3D 48, + .insn_flags =3D CPU_MIPS64R6 | ASE_MSA, + .mmu_type =3D MMU_TYPE_R4000, + }, + { .name =3D "Loongson-2E", .CP0_PRid =3D 0x6302, /* 64KB I-cache and d-cache. 4 way with 32 bit cache line size. */ --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423259913880.4151190566266; Fri, 25 Jan 2019 05:34:19 -0800 (PST) Received: from localhost ([127.0.0.1]:44674 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1cW-00041y-UB for importer@patchew.org; Fri, 25 Jan 2019 08:34:08 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46464) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aK-0002lZ-5f for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:54 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aI-0002Xa-Mp for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36392 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002W8-D7 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 675521A21CC; Fri, 25 Jan 2019 14:31:47 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id 0ECFD1A23D7; Fri, 25 Jan 2019 14:31:47 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:33 +0100 Message-Id: <1548423098-31864-10-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 09/14] MAINTAINERS: Update MIPS sections 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Remove Stefan Markovic as a reviewer for MIPS directories and files, as he left Wave Computing. Reviewed-by: Philippe Mathieu-Daud=C3=A9 Tested-by: Philippe Mathieu-Daud=C3=A9 Signed-off-by: Aleksandar Markovic --- MAINTAINERS | 9 --------- 1 file changed, 9 deletions(-) diff --git a/MAINTAINERS b/MAINTAINERS index af339b8..060db23 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -206,7 +206,6 @@ MIPS M: Aurelien Jarno M: Aleksandar Markovic R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: target/mips/ F: default-configs/*mips* @@ -365,7 +364,6 @@ F: target/arm/kvm.c MIPS M: James Hogan R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: target/mips/kvm.c =20 @@ -890,7 +888,6 @@ MIPS Machines Jazz M: Herv=C3=A9 Poussineau R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: hw/mips/mips_jazz.c F: hw/display/jazz_led.c @@ -899,14 +896,12 @@ F: hw/dma/rc4030.c Malta M: Aurelien Jarno R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: hw/mips/mips_malta.c =20 Mipssim M: Aleksandar Markovic R: Aleksandar Rikalo -R: Stefan Markovic S: Odd Fixes F: hw/mips/mips_mipssim.c F: hw/net/mipsnet.c @@ -914,14 +909,12 @@ F: hw/net/mipsnet.c R4000 M: Aurelien Jarno R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: hw/mips/mips_r4k.c =20 Fulong 2E M: Aleksandar Markovic R: Aleksandar Rikalo -R: Stefan Markovic S: Odd Fixes F: hw/mips/mips_fulong2e.c F: hw/isa/vt82c686.c @@ -931,7 +924,6 @@ F: include/hw/isa/vt82c686.h Boston M: Paul Burton R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: hw/core/loader-fit.c F: hw/mips/boston.c @@ -2203,7 +2195,6 @@ F: disas/i386.c MIPS target M: Aurelien Jarno R: Aleksandar Rikalo -R: Stefan Markovic S: Maintained F: tcg/mips/ F: disas/mips.c --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423477743322.15812161957217; Fri, 25 Jan 2019 05:37:57 -0800 (PST) Received: from localhost ([127.0.0.1]:44733 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1g1-0006y5-U4 for importer@patchew.org; Fri, 25 Jan 2019 08:37:46 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46596) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aw-0003Dd-85 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:58 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aL-0002ZK-AZ for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:26 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36398 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002WI-Eh for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:53 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id CE2131A2422; Fri, 25 Jan 2019 14:31:48 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id 178611A21F3; Fri, 25 Jan 2019 14:31:47 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:34 +0100 Message-Id: <1548423098-31864-11-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 10/14] tests: tcg: mips: Move source files to new locations 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic MIPS TCG test will be organized by ISAs and ASEs in future. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- tests/tcg/mips/mips32-dsp/absq_s_ph.c | 31 ----- tests/tcg/mips/mips32-dsp/absq_s_w.c | 37 ------ tests/tcg/mips/mips32-dsp/addq_ph.c | 46 -------- tests/tcg/mips/mips32-dsp/addq_s_ph.c | 69 ------------ tests/tcg/mips/mips32-dsp/addq_s_w.c | 44 -------- tests/tcg/mips/mips32-dsp/addsc.c | 33 ------ tests/tcg/mips/mips32-dsp/addu_qb.c | 35 ------ tests/tcg/mips/mips32-dsp/addu_s_qb.c | 35 ------ tests/tcg/mips/mips32-dsp/addwc.c | 49 -------- tests/tcg/mips/mips32-dsp/bitrev.c | 20 ---- tests/tcg/mips/mips32-dsp/bposge32.c | 44 -------- tests/tcg/mips/mips32-dsp/cmp_eq_ph.c | 35 ------ tests/tcg/mips/mips32-dsp/cmp_le_ph.c | 35 ------ tests/tcg/mips/mips32-dsp/cmp_lt_ph.c | 35 ------ tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c | 31 ----- tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c | 31 ----- tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c | 31 ----- tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c | 35 ------ tests/tcg/mips/mips32-dsp/cmpu_le_qb.c | 35 ------ tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c | 35 ------ tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c | 31 ----- tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c | 125 -----------------= ---- tests/tcg/mips/mips32-dsp/dpau_h_qbl.c | 27 ----- tests/tcg/mips/mips32-dsp/dpau_h_qbr.c | 27 ----- tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c | 45 -------- tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c | 55 --------- tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c | 27 ----- tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c | 27 ----- tests/tcg/mips/mips32-dsp/extp.c | 62 ---------- tests/tcg/mips/mips32-dsp/extpdp.c | 64 ----------- tests/tcg/mips/mips32-dsp/extpdpv.c | 47 -------- tests/tcg/mips/mips32-dsp/extpv.c | 45 -------- tests/tcg/mips/mips32-dsp/extr_r_w.c | 94 ---------------- tests/tcg/mips/mips32-dsp/extr_rs_w.c | 117 -----------------= -- tests/tcg/mips/mips32-dsp/extr_s_h.c | 86 -------------- tests/tcg/mips/mips32-dsp/extr_w.c | 94 ---------------- tests/tcg/mips/mips32-dsp/extrv_r_w.c | 79 ------------- tests/tcg/mips/mips32-dsp/extrv_rs_w.c | 77 ------------- tests/tcg/mips/mips32-dsp/extrv_s_h.c | 88 --------------- tests/tcg/mips/mips32-dsp/extrv_w.c | 80 ------------- tests/tcg/mips/mips32-dsp/insv.c | 36 ------ tests/tcg/mips/mips32-dsp/lbux.c | 25 ----- tests/tcg/mips/mips32-dsp/lhx.c | 25 ----- tests/tcg/mips/mips32-dsp/lwx.c | 25 ----- tests/tcg/mips/mips32-dsp/madd.c | 31 ----- tests/tcg/mips/mips32-dsp/maddu.c | 31 ----- tests/tcg/mips/mips32-dsp/main.c | 6 - tests/tcg/mips/mips32-dsp/maq_s_w_phl.c | 55 --------- tests/tcg/mips/mips32-dsp/maq_s_w_phr.c | 55 --------- tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c | 55 --------- tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c | 55 --------- tests/tcg/mips/mips32-dsp/mfhi.c | 21 ---- tests/tcg/mips/mips32-dsp/mflo.c | 21 ---- tests/tcg/mips/mips32-dsp/modsub.c | 30 ----- tests/tcg/mips/mips32-dsp/msub.c | 30 ----- tests/tcg/mips/mips32-dsp/msubu.c | 30 ----- tests/tcg/mips/mips32-dsp/mthi.c | 21 ---- tests/tcg/mips/mips32-dsp/mthlip.c | 58 ---------- tests/tcg/mips/mips32-dsp/mtlo.c | 21 ---- tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c | 41 ------- tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c | 40 ------- tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c | 25 ----- tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c | 25 ----- tests/tcg/mips/mips32-dsp/mulq_rs_ph.c | 42 ------- tests/tcg/mips/mips32-dsp/mult.c | 24 ---- tests/tcg/mips/mips32-dsp/multu.c | 24 ---- tests/tcg/mips/mips32-dsp/packrl_ph.c | 21 ---- tests/tcg/mips/mips32-dsp/pick_ph.c | 49 -------- tests/tcg/mips/mips32-dsp/pick_qb.c | 36 ------ tests/tcg/mips/mips32-dsp/preceq_w_phl.c | 20 ---- tests/tcg/mips/mips32-dsp/preceq_w_phr.c | 20 ---- tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c | 20 ---- tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c | 20 ---- tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c | 20 ---- tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c | 20 ---- tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c | 20 ---- tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c | 20 ---- tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c | 20 ---- tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c | 20 ---- tests/tcg/mips/mips32-dsp/precrq_ph_w.c | 21 ---- tests/tcg/mips/mips32-dsp/precrq_qb_ph.c | 21 ---- tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c | 51 --------- tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c | 24 ---- tests/tcg/mips/mips32-dsp/raddu_w_qb.c | 20 ---- tests/tcg/mips/mips32-dsp/rddsp.c | 46 -------- tests/tcg/mips/mips32-dsp/repl_ph.c | 23 ---- tests/tcg/mips/mips32-dsp/repl_qb.c | 16 --- tests/tcg/mips/mips32-dsp/replv_ph.c | 19 ---- tests/tcg/mips/mips32-dsp/replv_qb.c | 19 ---- tests/tcg/mips/mips32-dsp/shilo.c | 45 -------- tests/tcg/mips/mips32-dsp/shilov.c | 49 -------- tests/tcg/mips/mips32-dsp/shll_ph.c | 55 --------- tests/tcg/mips/mips32-dsp/shll_qb.c | 55 --------- tests/tcg/mips/mips32-dsp/shll_s_ph.c | 24 ---- tests/tcg/mips/mips32-dsp/shll_s_w.c | 52 --------- tests/tcg/mips/mips32-dsp/shllv_ph.c | 40 ------- tests/tcg/mips/mips32-dsp/shllv_qb.c | 38 ------- tests/tcg/mips/mips32-dsp/shllv_s_ph.c | 40 ------- tests/tcg/mips/mips32-dsp/shllv_s_w.c | 40 ------- tests/tcg/mips/mips32-dsp/shra_ph.c | 30 ----- tests/tcg/mips/mips32-dsp/shra_r_ph.c | 30 ----- tests/tcg/mips/mips32-dsp/shra_r_w.c | 30 ----- tests/tcg/mips/mips32-dsp/shrav_ph.c | 32 ------ tests/tcg/mips/mips32-dsp/shrav_r_ph.c | 32 ------ tests/tcg/mips/mips32-dsp/shrav_r_w.c | 32 ------ tests/tcg/mips/mips32-dsp/shrl_qb.c | 31 ----- tests/tcg/mips/mips32-dsp/shrlv_qb.c | 32 ------ tests/tcg/mips/mips32-dsp/subq_ph.c | 40 ------- tests/tcg/mips/mips32-dsp/subq_s_ph.c | 58 ---------- tests/tcg/mips/mips32-dsp/subq_s_w.c | 74 ------------ tests/tcg/mips/mips32-dsp/subu_qb.c | 25 ----- tests/tcg/mips/mips32-dsp/subu_s_qb.c | 25 ----- tests/tcg/mips/mips32-dsp/wrdsp.c | 46 -------- tests/tcg/mips/mips32-dspr2/absq_s_qb.c | 35 ------ tests/tcg/mips/mips32-dspr2/addqh_ph.c | 30 ----- tests/tcg/mips/mips32-dspr2/addqh_r_ph.c | 30 ----- tests/tcg/mips/mips32-dspr2/addqh_r_w.c | 34 ------ tests/tcg/mips/mips32-dspr2/addqh_w.c | 34 ------ tests/tcg/mips/mips32-dspr2/addu_ph.c | 33 ------ tests/tcg/mips/mips32-dspr2/addu_s_ph.c | 33 ------ tests/tcg/mips/mips32-dspr2/adduh_qb.c | 30 ----- tests/tcg/mips/mips32-dspr2/adduh_r_qb.c | 30 ----- tests/tcg/mips/mips32-dspr2/append.c | 30 ----- tests/tcg/mips/mips32-dspr2/balign.c | 30 ----- tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c | 37 ------ tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c | 37 ------ tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c | 37 ------ tests/tcg/mips/mips32-dspr2/dpa_w_ph.c | 44 -------- tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c | 79 ------------- tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c | 57 ---------- tests/tcg/mips/mips32-dspr2/dpax_w_ph.c | 44 -------- tests/tcg/mips/mips32-dspr2/dps_w_ph.c | 44 -------- tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c | 54 --------- tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c | 53 --------- tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c | 27 ----- tests/tcg/mips/mips32-dspr2/mul_ph.c | 47 -------- tests/tcg/mips/mips32-dspr2/mul_s_ph.c | 62 ---------- tests/tcg/mips/mips32-dspr2/mulq_rs_w.c | 36 ------ tests/tcg/mips/mips32-dspr2/mulq_s_ph.c | 40 ------- tests/tcg/mips/mips32-dspr2/mulq_s_w.c | 36 ------ tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c | 29 ----- tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c | 29 ----- tests/tcg/mips/mips32-dspr2/precr_qb_ph.c | 21 ---- tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c | 32 ------ tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c | 32 ------ tests/tcg/mips/mips32-dspr2/prepend.c | 30 ----- tests/tcg/mips/mips32-dspr2/shra_qb.c | 30 ----- tests/tcg/mips/mips32-dspr2/shra_r_qb.c | 30 ----- tests/tcg/mips/mips32-dspr2/shrav_qb.c | 32 ------ tests/tcg/mips/mips32-dspr2/shrav_r_qb.c | 32 ------ tests/tcg/mips/mips32-dspr2/shrl_ph.c | 20 ---- tests/tcg/mips/mips32-dspr2/shrlv_ph.c | 21 ---- tests/tcg/mips/mips32-dspr2/subqh_ph.c | 21 ---- tests/tcg/mips/mips32-dspr2/subqh_r_ph.c | 21 ---- tests/tcg/mips/mips32-dspr2/subqh_r_w.c | 21 ---- tests/tcg/mips/mips32-dspr2/subqh_w.c | 21 ---- tests/tcg/mips/mips32-dspr2/subu_ph.c | 40 ------- tests/tcg/mips/mips32-dspr2/subu_s_ph.c | 25 ----- tests/tcg/mips/mips32-dspr2/subuh_qb.c | 21 ---- tests/tcg/mips/mips32-dspr2/subuh_r_qb.c | 32 ------ tests/tcg/mips/mipsr5900/div1.c | 73 ------------ tests/tcg/mips/mipsr5900/divu1.c | 48 -------- tests/tcg/mips/mipsr5900/madd.c | 78 ------------- tests/tcg/mips/mipsr5900/maddu.c | 70 ------------ tests/tcg/mips/mipsr5900/mflohi1.c | 35 ------ tests/tcg/mips/mipsr5900/mtlohi1.c | 40 ------- tests/tcg/mips/mipsr5900/mult.c | 76 ------------- tests/tcg/mips/mipsr5900/multu.c | 68 ----------- .../tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_ph.c | 31 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_w.c | 37 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_ph.c | 46 ++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_ph.c | 69 ++++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_w.c | 44 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_addsc.c | 33 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_qb.c | 35 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_addu_s_qb.c | 35 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_addwc.c | 49 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_bitrev.c | 20 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_bposge32.c | 44 ++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmp_eq_ph.c | 35 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmp_le_ph.c | 35 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmp_lt_ph.c | 35 ++++++ .../mips/user/ase/dsp/test_dsp_r1_cmpgu_eq_qb.c | 31 +++++ .../mips/user/ase/dsp/test_dsp_r1_cmpgu_le_qb.c | 31 +++++ .../mips/user/ase/dsp/test_dsp_r1_cmpgu_lt_qb.c | 31 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_eq_qb.c | 35 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_le_qb.c | 35 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_lt_qb.c | 35 ++++++ .../mips/user/ase/dsp/test_dsp_r1_dpaq_s_w_ph.c | 31 +++++ .../mips/user/ase/dsp/test_dsp_r1_dpaq_sa_l_w.c | 125 +++++++++++++++++= ++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbl.c | 27 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbr.c | 27 +++++ .../mips/user/ase/dsp/test_dsp_r1_dpsq_s_w_ph.c | 45 ++++++++ .../mips/user/ase/dsp/test_dsp_r1_dpsq_sa_l_w.c | 55 +++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbl.c | 27 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbr.c | 27 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extp.c | 62 ++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdp.c | 64 +++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdpv.c | 47 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpv.c | 45 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_r_w.c | 94 ++++++++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_extr_rs_w.c | 117 +++++++++++++++++= ++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_s_h.c | 86 ++++++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_w.c | 94 ++++++++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_extrv_r_w.c | 79 +++++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_extrv_rs_w.c | 77 +++++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_extrv_s_h.c | 88 +++++++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_w.c | 80 +++++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_insv.c | 36 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_lbux.c | 25 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_lhx.c | 25 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_lwx.c | 25 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_madd.c | 31 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_maddu.c | 31 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_main.c | 6 + .../mips/user/ase/dsp/test_dsp_r1_maq_s_w_phl.c | 55 +++++++++ .../mips/user/ase/dsp/test_dsp_r1_maq_s_w_phr.c | 55 +++++++++ .../mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phl.c | 55 +++++++++ .../mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phr.c | 55 +++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mfhi.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mflo.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_modsub.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_msub.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_msubu.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthi.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthlip.c | 58 ++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mtlo.c | 21 ++++ .../mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phl.c | 41 +++++++ .../mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phr.c | 40 +++++++ .../mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbl.c | 25 +++++ .../mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbr.c | 25 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_mulq_rs_ph.c | 42 +++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_mult.c | 24 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_multu.c | 24 ++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_packrl_ph.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_ph.c | 49 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_qb.c | 36 ++++++ .../mips/user/ase/dsp/test_dsp_r1_preceq_w_phl.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_preceq_w_phr.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbl.c | 20 ++++ .../user/ase/dsp/test_dsp_r1_precequ_ph_qbla.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbr.c | 20 ++++ .../user/ase/dsp/test_dsp_r1_precequ_ph_qbra.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbl.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbla.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbr.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbra.c | 20 ++++ .../mips/user/ase/dsp/test_dsp_r1_precrq_ph_w.c | 21 ++++ .../mips/user/ase/dsp/test_dsp_r1_precrq_qb_ph.c | 21 ++++ .../mips/user/ase/dsp/test_dsp_r1_precrq_rs_ph_w.c | 51 +++++++++ .../user/ase/dsp/test_dsp_r1_precrqu_s_qb_ph.c | 24 ++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_raddu_w_qb.c | 20 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_rddsp.c | 46 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_ph.c | 23 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_qb.c | 16 +++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_ph.c | 19 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_qb.c | 19 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilo.c | 45 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilov.c | 49 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_ph.c | 55 +++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_qb.c | 55 +++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_ph.c | 24 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_w.c | 52 +++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_ph.c | 40 +++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_qb.c | 38 +++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_ph.c | 40 +++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_w.c | 40 +++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_ph.c | 30 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_ph.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_w.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_ph.c | 32 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_ph.c | 32 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_w.c | 32 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrl_qb.c | 31 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrlv_qb.c | 32 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_ph.c | 40 +++++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_ph.c | 58 ++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_w.c | 74 ++++++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_qb.c | 25 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r1_subu_s_qb.c | 25 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r1_wrdsp.c | 46 ++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_absq_s_qb.c | 35 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_ph.c | 30 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_ph.c | 30 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_w.c | 34 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_w.c | 34 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_ph.c | 33 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_addu_s_ph.c | 33 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_qb.c | 30 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_adduh_r_qb.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_append.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_balign.c | 30 +++++ .../mips/user/ase/dsp/test_dsp_r2_cmpgdu_eq_qb.c | 37 ++++++ .../mips/user/ase/dsp/test_dsp_r2_cmpgdu_le_qb.c | 37 ++++++ .../mips/user/ase/dsp/test_dsp_r2_cmpgdu_lt_qb.c | 37 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpa_w_ph.c | 44 ++++++++ .../mips/user/ase/dsp/test_dsp_r2_dpaqx_s_w_ph.c | 79 +++++++++++++ .../mips/user/ase/dsp/test_dsp_r2_dpaqx_sa_w_ph.c | 57 ++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_dpax_w_ph.c | 44 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_dps_w_ph.c | 44 ++++++++ .../mips/user/ase/dsp/test_dsp_r2_dpsqx_s_w_ph.c | 54 +++++++++ .../mips/user/ase/dsp/test_dsp_r2_dpsqx_sa_w_ph.c | 53 +++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_dpsx_w_ph.c | 27 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_ph.c | 47 ++++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_s_ph.c | 62 ++++++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_mulq_rs_w.c | 36 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_ph.c | 40 +++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_w.c | 36 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_mulsa_w_ph.c | 29 +++++ .../mips/user/ase/dsp/test_dsp_r2_mulsaq_s_w_ph.c | 29 +++++ .../mips/user/ase/dsp/test_dsp_r2_precr_qb_ph.c | 21 ++++ .../mips/user/ase/dsp/test_dsp_r2_precr_sra_ph_w.c | 32 ++++++ .../user/ase/dsp/test_dsp_r2_precr_sra_r_ph_w.c | 32 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_prepend.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_qb.c | 30 +++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_shra_r_qb.c | 30 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_qb.c | 32 ++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_shrav_r_qb.c | 32 ++++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrl_ph.c | 20 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrlv_ph.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_ph.c | 21 ++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_ph.c | 21 ++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_w.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_w.c | 21 ++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_ph.c | 40 +++++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_subu_s_ph.c | 25 +++++ tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_qb.c | 21 ++++ .../tcg/mips/user/ase/dsp/test_dsp_r2_subuh_r_qb.c | 32 ++++++ tests/tcg/mips/user/isa/r5900/test_r5900_div1.c | 73 ++++++++++++ tests/tcg/mips/user/isa/r5900/test_r5900_divu1.c | 48 ++++++++ tests/tcg/mips/user/isa/r5900/test_r5900_madd.c | 78 +++++++++++++ tests/tcg/mips/user/isa/r5900/test_r5900_maddu.c | 70 ++++++++++++ tests/tcg/mips/user/isa/r5900/test_r5900_mflohi1.c | 35 ++++++ tests/tcg/mips/user/isa/r5900/test_r5900_mtlohi1.c | 40 +++++++ tests/tcg/mips/user/isa/r5900/test_r5900_mult.c | 76 +++++++++++++ tests/tcg/mips/user/isa/r5900/test_r5900_multu.c | 68 +++++++++++ 336 files changed, 6527 insertions(+), 6527 deletions(-) delete mode 100644 tests/tcg/mips/mips32-dsp/absq_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/absq_s_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/addq_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/addq_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/addq_s_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/addsc.c delete mode 100644 tests/tcg/mips/mips32-dsp/addu_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/addu_s_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/addwc.c delete mode 100644 tests/tcg/mips/mips32-dsp/bitrev.c delete mode 100644 tests/tcg/mips/mips32-dsp/bposge32.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmp_eq_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmp_le_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmp_lt_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpu_le_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpau_h_qbl.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpau_h_qbr.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c delete mode 100644 tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c delete mode 100644 tests/tcg/mips/mips32-dsp/extp.c delete mode 100644 tests/tcg/mips/mips32-dsp/extpdp.c delete mode 100644 tests/tcg/mips/mips32-dsp/extpdpv.c delete mode 100644 tests/tcg/mips/mips32-dsp/extpv.c delete mode 100644 tests/tcg/mips/mips32-dsp/extr_r_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/extr_rs_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/extr_s_h.c delete mode 100644 tests/tcg/mips/mips32-dsp/extr_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/extrv_r_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/extrv_rs_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/extrv_s_h.c delete mode 100644 tests/tcg/mips/mips32-dsp/extrv_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/insv.c delete mode 100644 tests/tcg/mips/mips32-dsp/lbux.c delete mode 100644 tests/tcg/mips/mips32-dsp/lhx.c delete mode 100644 tests/tcg/mips/mips32-dsp/lwx.c delete mode 100644 tests/tcg/mips/mips32-dsp/madd.c delete mode 100644 tests/tcg/mips/mips32-dsp/maddu.c delete mode 100644 tests/tcg/mips/mips32-dsp/main.c delete mode 100644 tests/tcg/mips/mips32-dsp/maq_s_w_phl.c delete mode 100644 tests/tcg/mips/mips32-dsp/maq_s_w_phr.c delete mode 100644 tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c delete mode 100644 tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c delete mode 100644 tests/tcg/mips/mips32-dsp/mfhi.c delete mode 100644 tests/tcg/mips/mips32-dsp/mflo.c delete mode 100644 tests/tcg/mips/mips32-dsp/modsub.c delete mode 100644 tests/tcg/mips/mips32-dsp/msub.c delete mode 100644 tests/tcg/mips/mips32-dsp/msubu.c delete mode 100644 tests/tcg/mips/mips32-dsp/mthi.c delete mode 100644 tests/tcg/mips/mips32-dsp/mthlip.c delete mode 100644 tests/tcg/mips/mips32-dsp/mtlo.c delete mode 100644 tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c delete mode 100644 tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c delete mode 100644 tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c delete mode 100644 tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c delete mode 100644 tests/tcg/mips/mips32-dsp/mulq_rs_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/mult.c delete mode 100644 tests/tcg/mips/mips32-dsp/multu.c delete mode 100644 tests/tcg/mips/mips32-dsp/packrl_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/pick_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/pick_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceq_w_phl.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceq_w_phr.c delete mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c delete mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c delete mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c delete mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c delete mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c delete mode 100644 tests/tcg/mips/mips32-dsp/precrq_ph_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/precrq_qb_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/raddu_w_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/rddsp.c delete mode 100644 tests/tcg/mips/mips32-dsp/repl_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/repl_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/replv_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/replv_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/shilo.c delete mode 100644 tests/tcg/mips/mips32-dsp/shilov.c delete mode 100644 tests/tcg/mips/mips32-dsp/shll_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shll_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/shll_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shll_s_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/shllv_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shllv_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/shllv_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shllv_s_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/shra_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shra_r_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shra_r_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/shrav_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shrav_r_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/shrav_r_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/shrl_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/shrlv_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/subq_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/subq_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dsp/subq_s_w.c delete mode 100644 tests/tcg/mips/mips32-dsp/subu_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/subu_s_qb.c delete mode 100644 tests/tcg/mips/mips32-dsp/wrdsp.c delete mode 100644 tests/tcg/mips/mips32-dspr2/absq_s_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addqh_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addqh_r_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addqh_r_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addqh_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addu_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/addu_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/adduh_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/adduh_r_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/append.c delete mode 100644 tests/tcg/mips/mips32-dspr2/balign.c delete mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpa_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpax_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dps_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mul_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mul_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mulq_rs_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mulq_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mulq_s_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/precr_qb_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/prepend.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shra_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shra_r_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shrav_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shrav_r_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shrl_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/shrlv_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subqh_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subqh_r_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subqh_r_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subqh_w.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subu_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subu_s_ph.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subuh_qb.c delete mode 100644 tests/tcg/mips/mips32-dspr2/subuh_r_qb.c delete mode 100644 tests/tcg/mips/mipsr5900/div1.c delete mode 100644 tests/tcg/mips/mipsr5900/divu1.c delete mode 100644 tests/tcg/mips/mipsr5900/madd.c delete mode 100644 tests/tcg/mips/mipsr5900/maddu.c delete mode 100644 tests/tcg/mips/mipsr5900/mflohi1.c delete mode 100644 tests/tcg/mips/mipsr5900/mtlohi1.c delete mode 100644 tests/tcg/mips/mipsr5900/mult.c delete mode 100644 tests/tcg/mips/mipsr5900/multu.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addsc.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_s_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_addwc.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_bitrev.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_bposge32.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_eq_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_le_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_lt_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_eq_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_le_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_lt_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_eq_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_le_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_lt_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_s_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_sa_l_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_s_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_sa_l_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extp.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdp.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdpv.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpv.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_rs_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_s_h.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_rs_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_s_h.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_insv.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_lbux.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_lhx.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_lwx.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_madd.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_maddu.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_main.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mfhi.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mflo.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_modsub.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_msub.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_msubu.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthi.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthlip.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mtlo.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mulq_rs_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_mult.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_multu.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_packrl_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbla= .c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbra= .c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbl.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbla.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbr.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbra.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_ph_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_qb_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_rs_ph_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrqu_s_qb_ph= .c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_raddu_w_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_rddsp.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilo.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilov.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrl_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrlv_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_s_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r1_wrdsp.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_absq_s_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_r_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_append.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_balign.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_eq_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_le_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_lt_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpa_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_s_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_sa_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpax_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dps_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_s_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_sa_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsx_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_rs_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsa_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsaq_s_w_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_qb_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_ph_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_r_ph_= w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_prepend.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_r_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_r_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrl_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrlv_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_w.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_s_ph.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_qb.c create mode 100644 tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_r_qb.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_div1.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_divu1.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_madd.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_maddu.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_mflohi1.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_mtlohi1.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_mult.c create mode 100644 tests/tcg/mips/user/isa/r5900/test_r5900_multu.c diff --git a/tests/tcg/mips/mips32-dsp/absq_s_ph.c b/tests/tcg/mips/mips32-= dsp/absq_s_ph.c deleted file mode 100644 index aa84112..0000000 --- a/tests/tcg/mips/mips32-dsp/absq_s_ph.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x10017EFD; - result =3D 0x10017EFD; - - __asm - ("absq_s.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x8000A536; - result =3D 0x7FFF5ACA; - - __asm - ("absq_s.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/absq_s_w.c b/tests/tcg/mips/mips32-d= sp/absq_s_w.c deleted file mode 100644 index 3f52a48..0000000 --- a/tests/tcg/mips/mips32-dsp/absq_s_w.c +++ /dev/null @@ -1,37 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x80030000; - result =3D 0x7FFD0000; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x31036080; - result =3D 0x31036080; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addq_ph.c b/tests/tcg/mips/mips32-ds= p/addq_ph.c deleted file mode 100644 index 96a5496..0000000 --- a/tests/tcg/mips/mips32-dsp/addq_ph.c +++ /dev/null @@ -1,46 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x10101010; - result =3D 0x100F100F; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - rs =3D 0x3712847D; - rt =3D 0x0031AF2D; - result =3D 0x374333AA; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - rs =3D 0x7fff847D; - rt =3D 0x0031AF2D; - result =3D 0x803033AA; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - __asm("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addq_s_ph.c b/tests/tcg/mips/mips32-= dsp/addq_s_ph.c deleted file mode 100644 index 5f865f6..0000000 --- a/tests/tcg/mips/mips32-dsp/addq_s_ph.c +++ /dev/null @@ -1,69 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x10101010; - result =3D 0x100F100F; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - rs =3D 0x3712847D; - rt =3D 0x0031AF2D; - result =3D 0x37438000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - rs =3D 0x7fff847D; - rt =3D 0x0031AF2D; - result =3D 0x7fff8000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - rs =3D 0x8030847D; - rt =3D 0x8a00AF2D; - result =3D 0x80008000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addq_s_w.c b/tests/tcg/mips/mips32-d= sp/addq_s_w.c deleted file mode 100644 index 1e13acf..0000000 --- a/tests/tcg/mips/mips32-dsp/addq_s_w.c +++ /dev/null @@ -1,44 +0,0 @@ -#include -#include - - -int main() -{ - int rd, rs, rt; - int result; - - rt =3D 0x10017EFD; - rs =3D 0x11111111; - result =3D 0x2112900e; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x80017EFD; - rs =3D 0x81111111; - result =3D 0x80000000; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x7fffffff; - rs =3D 0x01111111; - result =3D 0x7fffffff; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addsc.c b/tests/tcg/mips/mips32-dsp/= addsc.c deleted file mode 100644 index ace749f..0000000 --- a/tests/tcg/mips/mips32-dsp/addsc.c +++ /dev/null @@ -1,33 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x0000000F; - rt =3D 0x00000001; - result =3D 0x00000010; - __asm - ("addsc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x00001110; - __asm - ("addsc %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 13) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addu_qb.c b/tests/tcg/mips/mips32-ds= p/addu_qb.c deleted file mode 100644 index 23ba2e9..0000000 --- a/tests/tcg/mips/mips32-dsp/addu_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x00FF00FF; - rt =3D 0x00010001; - result =3D 0x00000000; - __asm - ("addu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0xFF011112; - __asm - ("addu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addu_s_qb.c b/tests/tcg/mips/mips32-= dsp/addu_s_qb.c deleted file mode 100644 index fe7fd3e..0000000 --- a/tests/tcg/mips/mips32-dsp/addu_s_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x10FF01FF; - rt =3D 0x10010001; - result =3D 0x20FF01FF; - __asm - ("addu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x1) =3D=3D 1); - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0xFFFF1112; - __asm - ("addu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x1) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/addwc.c b/tests/tcg/mips/mips32-dsp/= addwc.c deleted file mode 100644 index 8a8d81f..0000000 --- a/tests/tcg/mips/mips32-dsp/addwc.c +++ /dev/null @@ -1,49 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dspi, dspo; - int result; - - rs =3D 0x10FF01FF; - rt =3D 0x10010001; - dspi =3D 0x00002000; - result =3D 0x21000201; - __asm - ("wrdsp %3\n" - "addwc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dspi) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - dspi =3D 0x00; - result =3D 0x00011112; - __asm - ("wrdsp %3\n" - "addwc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dspi) - ); - assert(rd =3D=3D result); - - rs =3D 0x8FFF1111; - rt =3D 0x80020001; - dspi =3D 0x00; - result =3D 0x10011112; - __asm - ("wrdsp %4\n" - "addwc %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspo) - : "r"(rs), "r"(rt), "r"(dspi) - ); - assert(rd =3D=3D result); - assert(((dspo >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/bitrev.c b/tests/tcg/mips/mips32-dsp= /bitrev.c deleted file mode 100644 index 04d8a38..0000000 --- a/tests/tcg/mips/mips32-dsp/bitrev.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x00001E6A; - - __asm - ("bitrev %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/bposge32.c b/tests/tcg/mips/mips32-d= sp/bposge32.c deleted file mode 100644 index d25417e..0000000 --- a/tests/tcg/mips/mips32-dsp/bposge32.c +++ /dev/null @@ -1,44 +0,0 @@ -#include -#include - -int main() -{ - int dsp, sum; - int result; - - dsp =3D 0x20; - sum =3D 0x01; - result =3D 0x02; - - __asm - ("wrdsp %1\n\t" - "bposge32 test1\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test1:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - assert(sum =3D=3D result); - - dsp =3D 0x10; - sum =3D 0x01; - result =3D 0xA4; - - __asm - ("wrdsp %1\n\t" - "bposge32 test2\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test2:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - assert(sum =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmp_eq_ph.c b/tests/tcg/mips/mips32-= dsp/cmp_eq_ph.c deleted file mode 100644 index 957bd88..0000000 --- a/tests/tcg/mips/mips32-dsp/cmp_eq_ph.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x00; - __asm - ("cmp.eq.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x03; - __asm - ("cmp.eq.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmp_le_ph.c b/tests/tcg/mips/mips32-= dsp/cmp_le_ph.c deleted file mode 100644 index 356f156..0000000 --- a/tests/tcg/mips/mips32-dsp/cmp_le_ph.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x02; - __asm - ("cmp.le.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x03; - __asm - ("cmp.le.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmp_lt_ph.c b/tests/tcg/mips/mips32-= dsp/cmp_lt_ph.c deleted file mode 100644 index 3fb4827..0000000 --- a/tests/tcg/mips/mips32-dsp/cmp_lt_ph.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x02; - __asm - ("cmp.lt.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmp.lt.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c b/tests/tcg/mips/mips3= 2-dsp/cmpgu_eq_qb.c deleted file mode 100644 index 2615c84..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpgu.eq.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpgu.eq.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c b/tests/tcg/mips/mips3= 2-dsp/cmpgu_le_qb.c deleted file mode 100644 index 65d0813..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpgu.le.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11766066; - result =3D 0x09; - __asm - ("cmpgu.le.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c b/tests/tcg/mips/mips3= 2-dsp/cmpgu_lt_qb.c deleted file mode 100644 index 7dddad9..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpgu.lt.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11766066; - result =3D 0x00; - __asm - ("cmpgu.lt.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c b/tests/tcg/mips/mips32= -dsp/cmpu_eq_qb.c deleted file mode 100644 index 680f2a1..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpu.eq.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpu.eq.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpu_le_qb.c b/tests/tcg/mips/mips32= -dsp/cmpu_le_qb.c deleted file mode 100644 index 43cfa50..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpu_le_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpu.le.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpu.le.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c b/tests/tcg/mips/mips32= -dsp/cmpu_lt_qb.c deleted file mode 100644 index 074ca5b..0000000 --- a/tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpu.lt.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmpu.lt.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c b/tests/tcg/mips/mips3= 2-dsp/dpaq_s_w_ph.c deleted file mode 100644 index a6425b6..0000000 --- a/tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 0, acl =3D 0; - int resulth, resultl, resultdsp; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x00; - resultl =3D 0x800003FB; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D dsp >> 17 & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c b/tests/tcg/mips/mips3= 2-dsp/dpaq_sa_l_w.c deleted file mode 100644 index cbf9007..0000000 --- a/tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c +++ /dev/null @@ -1,125 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 0, acl =3D 0; - int resulth, resultl, resultdsp; - - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x7FFFFFFF; - resultl =3D 0xFFFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x00000012; - acl =3D 0x00000048; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0x7FFFFFFF; - resultl =3D 0xFFFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x741532A0; - acl =3D 0xFCEABB08; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0x7FFFFFFF; - resultl =3D 0xFFFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0; - acl =3D 0; - rs =3D 0xC0000000; - rt =3D 0x7FFFFFFF; - - resulth =3D 0xC0000000; - resultl =3D 0x80000000; - resultdsp =3D 0; - __asm - ("wrdsp $0\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x20000000; - acl =3D 0; - rs =3D 0xE0000000; - rt =3D 0x7FFFFFFF; - - resulth =3D 0; - resultl =3D 0x40000000; - resultdsp =3D 0; - __asm - ("wrdsp $0\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpau_h_qbl.c b/tests/tcg/mips/mips32= -dsp/dpau_h_qbl.c deleted file mode 100644 index 6017b5e..0000000 --- a/tests/tcg/mips/mips32-dsp/dpau_h_qbl.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 3; - int resulth, resultl; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x05; - resultl =3D 0x4003; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpau.h.qbl $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpau_h_qbr.c b/tests/tcg/mips/mips32= -dsp/dpau_h_qbr.c deleted file mode 100644 index e4abb2e..0000000 --- a/tests/tcg/mips/mips32-dsp/dpau_h_qbr.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 3; - int resulth, resultl; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x05; - resultl =3D 0x0201; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpau.h.qbr $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c b/tests/tcg/mips/mips3= 2-dsp/dpsq_s_w_ph.c deleted file mode 100644 index 74058fe..0000000 --- a/tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c +++ /dev/null @@ -1,45 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x00000004; - resultl =3D 0xF15F94A3; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x1424EF1F; - acl =3D 0x1035219A; - rs =3D 0x800083AD; - rt =3D 0x80003721; - resulth =3D 0x1424EF1E; - resultl =3D 0xC5C0D901; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c b/tests/tcg/mips/mips3= 2-dsp/dpsq_sa_l_w.c deleted file mode 100644 index eda3b14..0000000 --- a/tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 5, acl =3D 5; - int resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x00BD3A22; - resultl =3D 0xD138776B; - resultdsp =3D 0x00; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x54321123; - acl =3D 5; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0xd4321123; - resultl =3D 0x06; - resultdsp =3D 0x01; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c b/tests/tcg/mips/mips32= -dsp/dpsu_h_qbl.c deleted file mode 100644 index 94e2bf6..0000000 --- a/tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFEE5; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.qbl $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c b/tests/tcg/mips/mips32= -dsp/dpsu_h_qbr.c deleted file mode 100644 index a1e6635..0000000 --- a/tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFE233; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.qbr $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extp.c b/tests/tcg/mips/mips32-dsp/e= xtp.c deleted file mode 100644 index b18bdb3..0000000 --- a/tests/tcg/mips/mips32-dsp/extp.c +++ /dev/null @@ -1,62 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 14) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 14) & 0x01; - assert(dsp =3D=3D 1); - - ach =3D 0; - acl =3D 0x80000001; - dsp =3D 0x1F; - result =3D 0x80000001; - - __asm - ("wrdsp %1\n\t" - "mthi %2, $ac2\n\t" - "mtlo %3, $ac2\n\t" - "extp %0, $ac2, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 14) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extpdp.c b/tests/tcg/mips/mips32-dsp= /extpdp.c deleted file mode 100644 index 79ee16e..0000000 --- a/tests/tcg/mips/mips32-dsp/extpdp.c +++ /dev/null @@ -1,64 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp, pos, efi; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - pos =3D dsp & 0x3F; - efi =3D (dsp >> 14) & 0x01; - assert(pos =3D=3D 3); - assert(efi =3D=3D 0); - assert(result =3D=3D rt); - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - efi =3D (dsp >> 14) & 0x01; - assert(efi =3D=3D 1); - - - ach =3D 0; - acl =3D 0; - dsp =3D 0; - result =3D 0; - - __asm - ("wrdsp %1\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdp %0, $ac1, 0x00\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - assert(dsp =3D=3D 0x3F); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extpdpv.c b/tests/tcg/mips/mips32-ds= p/extpdpv.c deleted file mode 100644 index f5774ee..0000000 --- a/tests/tcg/mips/mips32-dsp/extpdpv.c +++ /dev/null @@ -1,47 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, ach, acl, dsp, pos, efi; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(rs) - ); - pos =3D dsp & 0x3F; - efi =3D (dsp >> 14) & 0x01; - assert(pos =3D=3D 3); - assert(efi =3D=3D 0); - assert(result =3D=3D rt); - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(rs) - ); - efi =3D (dsp >> 14) & 0x01; - assert(efi =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extpv.c b/tests/tcg/mips/mips32-dsp/= extpv.c deleted file mode 100644 index 401b94a..0000000 --- a/tests/tcg/mips/mips32-dsp/extpv.c +++ /dev/null @@ -1,45 +0,0 @@ -#include -#include - -int main() -{ - int rt, ac, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - ac =3D 0x03; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(ac) - ); - dsp =3D (dsp >> 14) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(ac) - ); - dsp =3D (dsp >> 14) & 0x01; - assert(dsp =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extr_r_w.c b/tests/tcg/mips/mips32-d= sp/extr_r_w.c deleted file mode 100644 index 489c193..0000000 --- a/tests/tcg/mips/mips32-dsp/extr_r_w.c +++ /dev/null @@ -1,94 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0xA0001699; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0xFFFFFFFF; - acl =3D 0xFFFFFFFF; - result =3D 0; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extr_rs_w.c b/tests/tcg/mips/mips32-= dsp/extr_rs_w.c deleted file mode 100644 index f9d2ed6..0000000 --- a/tests/tcg/mips/mips32-dsp/extr_rs_w.c +++ /dev/null @@ -1,117 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0x7FFFFFFF; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x80000000; - acl =3D 0x00000000; - result =3D 0x80000000; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0xFFFFFFFF; - acl =3D 0xFFFFFFFF; - result =3D 0; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extr_s_h.c b/tests/tcg/mips/mips32-d= sp/extr_s_h.c deleted file mode 100644 index 9bc2a63..0000000 --- a/tests/tcg/mips/mips32-dsp/extr_s_h.c +++ /dev/null @@ -1,86 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0x00007FFF; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - ach =3D 0xffffffff; - acl =3D 0x12344321; - result =3D 0xFFFF8000; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x08\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dsp */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x00; - acl =3D 0x4321; - result =3D 0x432; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dsp */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x123; - acl =3D 0x87654321; - result =3D 0x1238; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 28\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extr_w.c b/tests/tcg/mips/mips32-dsp= /extr_w.c deleted file mode 100644 index cf92614..0000000 --- a/tests/tcg/mips/mips32-dsp/extr_w.c +++ /dev/null @@ -1,94 +0,0 @@ -#include -#include - -int main() -{ - int rt, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0xA0001699; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4C; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0xFFFFFFFF; - acl =3D 0xFFFFFFFF; - result =3D 0xFFFFFFFF; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x1F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extrv_r_w.c b/tests/tcg/mips/mips32-= dsp/extrv_r_w.c deleted file mode 100644 index 2403b3a..0000000 --- a/tests/tcg/mips/mips32-dsp/extrv_r_w.c +++ /dev/null @@ -1,79 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0xA0001699; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_r.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 4; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_r.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 31; - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_r.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extrv_rs_w.c b/tests/tcg/mips/mips32= -dsp/extrv_rs_w.c deleted file mode 100644 index ccceeb9..0000000 --- a/tests/tcg/mips/mips32-dsp/extrv_rs_w.c +++ /dev/null @@ -1,77 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, ach, acl, dsp; - int result; - - rs =3D 0x03; - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0x7FFFFFFF; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_rs.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x04; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_rs.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x1F; - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_rs.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extrv_s_h.c b/tests/tcg/mips/mips32-= dsp/extrv_s_h.c deleted file mode 100644 index feac3e2..0000000 --- a/tests/tcg/mips/mips32-dsp/extrv_s_h.c +++ /dev/null @@ -1,88 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0x00007FFF; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - rs =3D 0x08; - ach =3D 0xffffffff; - acl =3D 0x12344321; - result =3D 0xFFFF8000; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dsp */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x04; - ach =3D 0x00; - acl =3D 0x4321; - result =3D 0x432; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - rs =3D 0x1C; - ach =3D 0x123; - acl =3D 0x87654321; - result =3D 0x1238; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/extrv_w.c b/tests/tcg/mips/mips32-ds= p/extrv_w.c deleted file mode 100644 index 9e8b238..0000000 --- a/tests/tcg/mips/mips32-dsp/extrv_w.c +++ /dev/null @@ -1,80 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, ach, acl, dsp; - int result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0xA0001699; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 4; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4C; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 31; - ach =3D 0x3fffffff; - acl =3D 0x2bcdef01; - result =3D 0x7ffffffe; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - assert(dsp =3D=3D 0); - assert(result =3D=3D rt); - - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/insv.c b/tests/tcg/mips/mips32-dsp/i= nsv.c deleted file mode 100644 index 9d67469..0000000 --- a/tests/tcg/mips/mips32-dsp/insv.c +++ /dev/null @@ -1,36 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs, dsp; - int result; - - /* msb =3D 10, lsb =3D 5 */ - dsp =3D 0x305; - rt =3D 0x12345678; - rs =3D 0x87654321; - result =3D 0x12345438; - __asm - ("wrdsp %2, 0x03\n\t" - "insv %0, %1\n\t" - : "+r"(rt) - : "r"(rs), "r"(dsp) - ); - assert(rt =3D=3D result); - - dsp =3D 0x1000; - rt =3D 0xF0F0F0F0; - rs =3D 0xA5A5A5A5; - result =3D 0xA5A5A5A5; - - __asm - ("wrdsp %2\n\t" - "insv %0, %1\n\t" - : "+r"(rt) - : "r"(rs), "r"(dsp) - ); - assert(rt =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/lbux.c b/tests/tcg/mips/mips32-dsp/l= bux.c deleted file mode 100644 index 2337abe..0000000 --- a/tests/tcg/mips/mips32-dsp/lbux.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main(void) -{ - int value, rd; - int *p; - unsigned long addr, index; - int result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long)p; - index =3D 0; - result =3D value & 0xFF; - __asm - ("lbux %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/lhx.c b/tests/tcg/mips/mips32-dsp/lh= x.c deleted file mode 100644 index 10be3b3..0000000 --- a/tests/tcg/mips/mips32-dsp/lhx.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main(void) -{ - int value, rd; - int *p; - unsigned long addr, index; - int result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long)p; - index =3D 0; - result =3D 0xFFFFF389; - __asm - ("lhx %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/lwx.c b/tests/tcg/mips/mips32-dsp/lw= x.c deleted file mode 100644 index e6543c9..0000000 --- a/tests/tcg/mips/mips32-dsp/lwx.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main(void) -{ - int value, rd; - int *p; - unsigned long addr, index; - int result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long)p; - index =3D 0; - result =3D 0xBCDEF389; - __asm - ("lwx %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/madd.c b/tests/tcg/mips/mips32-dsp/m= add.c deleted file mode 100644 index af4bfcf..0000000 --- a/tests/tcg/mips/mips32-dsp/madd.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int acho, aclo; - int resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x01; - rt =3D 0x01; - resulth =3D 0x05; - resultl =3D 0xB4CC; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "madd $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/maddu.c b/tests/tcg/mips/mips32-dsp/= maddu.c deleted file mode 100644 index af4bfcf..0000000 --- a/tests/tcg/mips/mips32-dsp/maddu.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int acho, aclo; - int resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x01; - rt =3D 0x01; - resulth =3D 0x05; - resultl =3D 0xB4CC; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "madd $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/main.c b/tests/tcg/mips/mips32-dsp/m= ain.c deleted file mode 100644 index b296b20..0000000 --- a/tests/tcg/mips/mips32-dsp/main.c +++ /dev/null @@ -1,6 +0,0 @@ -#include - -int main() -{ - printf("hello world\n"); -} diff --git a/tests/tcg/mips/mips32-dsp/maq_s_w_phl.c b/tests/tcg/mips/mips3= 2-dsp/maq_s_w_phl.c deleted file mode 100644 index 0f7c070..0000000 --- a/tests/tcg/mips/mips32-dsp/maq_s_w_phl.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int dsp; - int acho, aclo; - int resulth, resultl; - int resdsp; - - achi =3D 0x00000005; - acli =3D 0x0000B4CB; - rs =3D 0xFF060000; - rt =3D 0xCB000000; - resulth =3D 0x00000005; - resultl =3D 0x006838CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.phl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - achi =3D 0x00000006; - acli =3D 0x0000B4CB; - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x00000006; - resultl =3D 0x8000B4CA; - resdsp =3D 1; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.phl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - assert(((dsp >> 17) & 0x01) =3D=3D resdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/maq_s_w_phr.c b/tests/tcg/mips/mips3= 2-dsp/maq_s_w_phr.c deleted file mode 100644 index 942722a..0000000 --- a/tests/tcg/mips/mips32-dsp/maq_s_w_phr.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int dsp; - int acho, aclo; - int resulth, resultl; - int resdsp; - - achi =3D 0x00000005; - acli =3D 0x0000B4CB; - rs =3D 0x0000FF06; - rt =3D 0x0000CB00; - resulth =3D 0x00000005; - resultl =3D 0x006838CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.phr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - achi =3D 0x00000006; - acli =3D 0x0000B4CB; - rs =3D 0x00008000; - rt =3D 0x00008000; - resulth =3D 0x00000006; - resultl =3D 0x8000B4CA; - resdsp =3D 1; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.phr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - assert(((dsp >> 17) & 0x01) =3D=3D resdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c b/tests/tcg/mips/mips= 32-dsp/maq_sa_w_phl.c deleted file mode 100644 index d83dce6..0000000 --- a/tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int dsp; - int acho, aclo; - int resulth, resultl; - int resdsp; - - achi =3D 0x00000000; - acli =3D 0x0000B4CB; - rs =3D 0xFF060000; - rt =3D 0xCB000000; - resulth =3D 0x00000000; - resultl =3D 0x006838CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_sa.w.phl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - achi =3D 0x00000000; - acli =3D 0x0000B4CB; - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x00; - resultl =3D 0x7fffffff; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.phl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - assert(((dsp >> 17) & 0x01) =3D=3D 0x01); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c b/tests/tcg/mips/mips= 32-dsp/maq_sa_w_phr.c deleted file mode 100644 index d233111..0000000 --- a/tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rt, rs; - int achi, acli; - int dsp; - int acho, aclo; - int resulth, resultl; - int resdsp; - - achi =3D 0x00000000; - acli =3D 0x0000B4CB; - rs =3D 0x0000FF06; - rt =3D 0x0000CB00; - resulth =3D 0x00000000; - resultl =3D 0x006838CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_sa.w.phr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - - achi =3D 0x00000000; - acli =3D 0x0000B4CB; - rs =3D 0x00008000; - rt =3D 0x00008000; - resulth =3D 0x00000000; - resultl =3D 0x7FFFFFFF; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.phr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(resulth =3D=3D acho); - assert(resultl =3D=3D aclo); - assert(((dsp >> 17) & 0x01) =3D=3D 0x01); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mfhi.c b/tests/tcg/mips/mips32-dsp/m= fhi.c deleted file mode 100644 index 43a8066..0000000 --- a/tests/tcg/mips/mips32-dsp/mfhi.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int achi, acho; - int result; - - achi =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(acho) - : "r"(achi) - ); - assert(result =3D=3D acho); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mflo.c b/tests/tcg/mips/mips32-dsp/m= flo.c deleted file mode 100644 index caeafdb..0000000 --- a/tests/tcg/mips/mips32-dsp/mflo.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int acli, aclo; - int result; - - acli =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(aclo) - : "r"(acli) - ); - assert(result =3D=3D aclo); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/modsub.c b/tests/tcg/mips/mips32-dsp= /modsub.c deleted file mode 100644 index c294eeb..0000000 --- a/tests/tcg/mips/mips32-dsp/modsub.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x000000FF; - result =3D 0xFFFFFF00; - __asm - ("modsub %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - rs =3D 0x00000000; - rt =3D 0x00CD1FFF; - result =3D 0x0000CD1F; - __asm - ("modsub %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/msub.c b/tests/tcg/mips/mips32-dsp/m= sub.c deleted file mode 100644 index 5779e6f..0000000 --- a/tests/tcg/mips/mips32-dsp/msub.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int achi, acli, rs, rt; - int acho, aclo; - int resulth, resultl; - - rs =3D 0x00BBAACC; - rt =3D 0x0B1C3D2F; - achi =3D 0x00004433; - acli =3D 0xFFCC0011; - resulth =3D 0xFFF81F29; - resultl =3D 0xB355089D; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "msub $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(acho =3D=3D resulth); - assert(aclo =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/msubu.c b/tests/tcg/mips/mips32-dsp/= msubu.c deleted file mode 100644 index e0f9b5a..0000000 --- a/tests/tcg/mips/mips32-dsp/msubu.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int achi, acli, rs, rt; - int acho, aclo; - int resulth, resultl; - - rs =3D 0x00BBAACC; - rt =3D 0x0B1C3D2F; - achi =3D 0x00004433; - acli =3D 0xFFCC0011; - resulth =3D 0xFFF81F29; - resultl =3D 0xB355089D; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "msubu $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - assert(acho =3D=3D resulth); - assert(aclo =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mthi.c b/tests/tcg/mips/mips32-dsp/m= thi.c deleted file mode 100644 index 43a8066..0000000 --- a/tests/tcg/mips/mips32-dsp/mthi.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int achi, acho; - int result; - - achi =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(acho) - : "r"(achi) - ); - assert(result =3D=3D acho); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mthlip.c b/tests/tcg/mips/mips32-dsp= /mthlip.c deleted file mode 100644 index 85f94d8..0000000 --- a/tests/tcg/mips/mips32-dsp/mthlip.c +++ /dev/null @@ -1,58 +0,0 @@ -#include -#include - -int main() -{ - int rs, ach, acl, dsp; - int result, resulth, resultl; - - dsp =3D 0x07; - ach =3D 0x05; - acl =3D 0xB4CB; - rs =3D 0x00FFBBAA; - resulth =3D 0xB4CB; - resultl =3D 0x00FFBBAA; - result =3D 0x27; - - __asm - ("wrdsp %0, 0x01\n\t" - "mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "mthlip %3, $ac1\n\t" - "mfhi %1, $ac1\n\t" - "mflo %2, $ac1\n\t" - "rddsp %0\n\t" - : "+r"(dsp), "+r"(ach), "+r"(acl) - : "r"(rs) - ); - dsp =3D dsp & 0x3F; - assert(dsp =3D=3D result); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - dsp =3D 0x1f; - ach =3D 0x05; - acl =3D 0xB4CB; - rs =3D 0x00FFBBAA; - resulth =3D 0xB4CB; - resultl =3D 0x00FFBBAA; - result =3D 0x3f; - - __asm - ("wrdsp %0, 0x01\n\t" - "mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "mthlip %3, $ac1\n\t" - "mfhi %1, $ac1\n\t" - "mflo %2, $ac1\n\t" - "rddsp %0\n\t" - : "+r"(dsp), "+r"(ach), "+r"(acl) - : "r"(rs) - ); - dsp =3D dsp & 0x3F; - assert(dsp =3D=3D result); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mtlo.c b/tests/tcg/mips/mips32-dsp/m= tlo.c deleted file mode 100644 index caeafdb..0000000 --- a/tests/tcg/mips/mips32-dsp/mtlo.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int acli, aclo; - int result; - - acli =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(aclo) - : "r"(acli) - ); - assert(result =3D=3D aclo); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c b/tests/tcg/mips/mip= s32-dsp/muleq_s_w_phl.c deleted file mode 100644 index b3a5370..0000000 --- a/tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c +++ /dev/null @@ -1,41 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80001234; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - rs =3D 0x12349988; - rt =3D 0x43219988; - result =3D 0x98be968; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} - diff --git a/tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c b/tests/tcg/mips/mip= s32-dsp/muleq_s_w_phr.c deleted file mode 100644 index 8066d7d..0000000 --- a/tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x8000; - rt =3D 0x8000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - rs =3D 0x1234; - rt =3D 0x4321; - result =3D 0x98be968; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c b/tests/tcg/mips/mi= ps32-dsp/muleu_s_ph_qbl.c deleted file mode 100644 index 66a3828..0000000 --- a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0xFFFF0000; - resultdsp =3D 1; - - __asm - ("muleu_s.ph.qbl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c b/tests/tcg/mips/mi= ps32-dsp/muleu_s_ph_qbr.c deleted file mode 100644 index 4cc6c8f..0000000 --- a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x8000; - rt =3D 0x80004321; - result =3D 0xFFFF0000; - resultdsp =3D 1; - - __asm - ("muleu_s.ph.qbr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mulq_rs_ph.c b/tests/tcg/mips/mips32= -dsp/mulq_rs_ph.c deleted file mode 100644 index 370c2a8..0000000 --- a/tests/tcg/mips/mips32-dsp/mulq_rs_ph.c +++ /dev/null @@ -1,42 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFF098C; - resultdsp =3D 1; - - __asm - ("wrdsp $0\n\t" - "mulq_rs.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - rs =3D 0x80011234; - rt =3D 0x80024321; - result =3D 0x7FFD098C; - resultdsp =3D 0; - - __asm - ("wrdsp $0\n\t" - "mulq_rs.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/mult.c b/tests/tcg/mips/mips32-dsp/m= ult.c deleted file mode 100644 index 15e6fde..0000000 --- a/tests/tcg/mips/mips32-dsp/mult.c +++ /dev/null @@ -1,24 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, ach, acl; - int result, resulth, resultl; - - rs =3D 0x00FFBBAA; - rt =3D 0x4B231000; - resulth =3D 0x4b0f01; - resultl =3D 0x71f8a000; - __asm - ("mult $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(ach), "=3Dr"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/multu.c b/tests/tcg/mips/mips32-dsp/= multu.c deleted file mode 100644 index 85d36c1..0000000 --- a/tests/tcg/mips/mips32-dsp/multu.c +++ /dev/null @@ -1,24 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, ach, acl; - int result, resulth, resultl; - - rs =3D 0x00FFBBAA; - rt =3D 0x4B231000; - resulth =3D 0x4b0f01; - resultl =3D 0x71f8a000; - __asm - ("multu $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(ach), "=3Dr"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/packrl_ph.c b/tests/tcg/mips/mips32-= dsp/packrl_ph.c deleted file mode 100644 index 1f8e699..0000000 --- a/tests/tcg/mips/mips32-dsp/packrl_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x56788765; - - __asm - ("packrl.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/pick_ph.c b/tests/tcg/mips/mips32-ds= p/pick_ph.c deleted file mode 100644 index 929a002..0000000 --- a/tests/tcg/mips/mips32-dsp/pick_ph.c +++ /dev/null @@ -1,49 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x0A000000; - result =3D 0x12344321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - assert(rd =3D=3D result); - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x03000000; - result =3D 0x12345678; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - assert(rd =3D=3D result); - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x00000000; - result =3D 0x87654321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/pick_qb.c b/tests/tcg/mips/mips32-ds= p/pick_qb.c deleted file mode 100644 index a790475..0000000 --- a/tests/tcg/mips/mips32-dsp/pick_qb.c +++ /dev/null @@ -1,36 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x0f000000; - result =3D 0x12345678; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - assert(rd =3D=3D result); - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x00000000; - result =3D 0x87654321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceq_w_phl.c b/tests/tcg/mips/mips= 32-dsp/preceq_w_phl.c deleted file mode 100644 index bf70bf7..0000000 --- a/tests/tcg/mips/mips32-dsp/preceq_w_phl.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x87650000; - - __asm - ("preceq.w.phl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceq_w_phr.c b/tests/tcg/mips/mips= 32-dsp/preceq_w_phr.c deleted file mode 100644 index 3f885ef..0000000 --- a/tests/tcg/mips/mips32-dsp/preceq_w_phr.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x43210000; - - __asm - ("preceq.w.phr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c b/tests/tcg/mips/mi= ps32-dsp/precequ_ph_qbl.c deleted file mode 100644 index 63b7a95..0000000 --- a/tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x43803280; - - __asm - ("precequ.ph.qbl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c b/tests/tcg/mips/m= ips32-dsp/precequ_ph_qbla.c deleted file mode 100644 index 31627f0..0000000 --- a/tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x43802180; - - __asm - ("precequ.ph.qbla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c b/tests/tcg/mips/mi= ps32-dsp/precequ_ph_qbr.c deleted file mode 100644 index b6f72d3..0000000 --- a/tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x21801080; - - __asm - ("precequ.ph.qbr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c b/tests/tcg/mips/m= ips32-dsp/precequ_ph_qbra.c deleted file mode 100644 index 4764fd0..0000000 --- a/tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x32801080; - - __asm - ("precequ.ph.qbra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c b/tests/tcg/mips/mip= s32-dsp/preceu_ph_qbl.c deleted file mode 100644 index fa95c26..0000000 --- a/tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x00870065; - - __asm - ("preceu.ph.qbl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c b/tests/tcg/mips/mi= ps32-dsp/preceu_ph_qbla.c deleted file mode 100644 index 021f21a..0000000 --- a/tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x00870043; - - __asm - ("preceu.ph.qbla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c b/tests/tcg/mips/mip= s32-dsp/preceu_ph_qbr.c deleted file mode 100644 index 03df18c..0000000 --- a/tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x00430021; - - __asm - ("preceu.ph.qbr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c b/tests/tcg/mips/mi= ps32-dsp/preceu_ph_qbra.c deleted file mode 100644 index 6343276..0000000 --- a/tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0x00650021; - - __asm - ("preceu.ph.qbra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precrq_ph_w.c b/tests/tcg/mips/mips3= 2-dsp/precrq_ph_w.c deleted file mode 100644 index 25d45f1..0000000 --- a/tests/tcg/mips/mips32-dsp/precrq_ph_w.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12348765; - - __asm - ("precrq.ph.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precrq_qb_ph.c b/tests/tcg/mips/mips= 32-dsp/precrq_qb_ph.c deleted file mode 100644 index fe23acc..0000000 --- a/tests/tcg/mips/mips32-dsp/precrq_qb_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12568743; - - __asm - ("precrq.qb.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c b/tests/tcg/mips/mi= ps32-dsp/precrq_rs_ph_w.c deleted file mode 100644 index da6845b..0000000 --- a/tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c +++ /dev/null @@ -1,51 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12348765; - - __asm - ("wrdsp $0\n\t" - "precrq_rs.ph.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - rs =3D 0x7FFFC678; - rt =3D 0x865432A0; - result =3D 0x7FFF8654; - - __asm - ("wrdsp $0\n\t" - "precrq_rs.ph.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(((dsp >> 22) & 0x01) =3D=3D 1); - assert(result =3D=3D rd); - - rs =3D 0xBEEFFEED; - rt =3D 0x7FFF8000; - result =3D 0xBEF07FFF; - - __asm - ("wrdsp $0\n\t" - "precrq_rs.ph.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(((dsp >> 22) & 0x01) =3D=3D 1); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c b/tests/tcg/mips/m= ips32-dsp/precrqu_s_qb_ph.c deleted file mode 100644 index 7481d5a..0000000 --- a/tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x12345678; - rt =3D 0x87657FFF; - result =3D 0x24AC00FF; - - __asm - ("precrqu_s.qb.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - assert(((dsp >> 22) & 0x01) =3D=3D 0x01); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/raddu_w_qb.c b/tests/tcg/mips/mips32= -dsp/raddu_w_qb.c deleted file mode 100644 index 77a983c..0000000 --- a/tests/tcg/mips/mips32-dsp/raddu_w_qb.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs; - int result; - - rs =3D 0x12345678; - result =3D 0x114; - - __asm - ("raddu.w.qb %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/rddsp.c b/tests/tcg/mips/mips32-dsp/= rddsp.c deleted file mode 100644 index 2f30285..0000000 --- a/tests/tcg/mips/mips32-dsp/rddsp.c +++ /dev/null @@ -1,46 +0,0 @@ -#include -#include - -int main() -{ - int dsp_i, dsp_o; - int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; - int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; - - ccond_i =3D 0x0000000C; /* 4 */ - outflag_i =3D 0x0000001B; /* 3 */ - efi_i =3D 0x00000001; /* 5 */ - c_i =3D 0x00000001; /* 2 */ - scount_i =3D 0x0000000F; /* 1 */ - pos_i =3D 0x0000000C; /* 0 */ - - dsp_i =3D (ccond_i << 24) | \ - (outflag_i << 16) | \ - (efi_i << 14) | \ - (c_i << 13) | \ - (scount_i << 7) | \ - pos_i; - - __asm - ("wrdsp %1, 0x3F\n\t" - "rddsp %0, 0x3F\n\t" - : "=3Dr"(dsp_o) - : "r"(dsp_i) - ); - - ccond_o =3D (dsp_o >> 24) & 0xFF; - outflag_o =3D (dsp_o >> 16) & 0xFF; - efi_o =3D (dsp_o >> 14) & 0x01; - c_o =3D (dsp_o >> 14) & 0x01; - scount_o =3D (dsp_o >> 7) & 0x3F; - pos_o =3D dsp_o & 0x1F; - - assert(ccond_o =3D=3D ccond_i); - assert(outflag_o =3D=3D outflag_i); - assert(efi_o =3D=3D efi_i); - assert(c_o =3D=3D c_i); - assert(scount_o =3D=3D scount_i); - assert(pos_o =3D=3D pos_i); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/repl_ph.c b/tests/tcg/mips/mips32-ds= p/repl_ph.c deleted file mode 100644 index 2107495..0000000 --- a/tests/tcg/mips/mips32-dsp/repl_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include -#include - -int main() -{ - int rd, result; - - result =3D 0x01BF01BF; - __asm - ("repl.ph %0, 0x1BF\n\t" - : "=3Dr"(rd) - ); - assert(rd =3D=3D result); - - result =3D 0x01FF01FF; - __asm - ("repl.ph %0, 0x01FF\n\t" - : "=3Dr"(rd) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/repl_qb.c b/tests/tcg/mips/mips32-ds= p/repl_qb.c deleted file mode 100644 index 6631393..0000000 --- a/tests/tcg/mips/mips32-dsp/repl_qb.c +++ /dev/null @@ -1,16 +0,0 @@ -#include -#include - -int main() -{ - int rd, result; - - result =3D 0xBFBFBFBF; - __asm - ("repl.qb %0, 0xBF\n\t" - : "=3Dr"(rd) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/replv_ph.c b/tests/tcg/mips/mips32-d= sp/replv_ph.c deleted file mode 100644 index 07fb15f..0000000 --- a/tests/tcg/mips/mips32-dsp/replv_ph.c +++ /dev/null @@ -1,19 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x56785678; - __asm - ("replv.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/replv_qb.c b/tests/tcg/mips/mips32-d= sp/replv_qb.c deleted file mode 100644 index dd1271f..0000000 --- a/tests/tcg/mips/mips32-dsp/replv_qb.c +++ /dev/null @@ -1,19 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x78787878; - __asm - ("replv.qb %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shilo.c b/tests/tcg/mips/mips32-dsp/= shilo.c deleted file mode 100644 index ce8ebc6..0000000 --- a/tests/tcg/mips/mips32-dsp/shilo.c +++ /dev/null @@ -1,45 +0,0 @@ -#include -#include - -int main() -{ - int ach, acl; - int resulth, resultl; - - ach =3D 0xBBAACCFF; - acl =3D 0x1C3B001D; - - resulth =3D 0x17755; - resultl =3D 0x99fe3876; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilo $ac1, 0x0F\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - - ach =3D 0x1; - acl =3D 0x80000000; - - resulth =3D 0x3; - resultl =3D 0x0; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilo $ac1, -1\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shilov.c b/tests/tcg/mips/mips32-dsp= /shilov.c deleted file mode 100644 index e1d6cea..0000000 --- a/tests/tcg/mips/mips32-dsp/shilov.c +++ /dev/null @@ -1,49 +0,0 @@ -#include -#include - -int main() -{ - int rs, ach, acl; - int resulth, resultl; - - rs =3D 0x0F; - ach =3D 0xBBAACCFF; - acl =3D 0x1C3B001D; - - resulth =3D 0x17755; - resultl =3D 0x99fe3876; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilov $ac1, %2\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - - rs =3D 0xffffffff; - ach =3D 0x1; - acl =3D 0x80000000; - - resulth =3D 0x3; - resultl =3D 0x0; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilov $ac1, %2\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shll_ph.c b/tests/tcg/mips/mips32-ds= p/shll_ph.c deleted file mode 100644 index 5fa58cc..0000000 --- a/tests/tcg/mips/mips32-dsp/shll_ph.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt, dsp; - int result, resultdsp; - - rt =3D 0x12345678; - result =3D 0xA000C000; - resultdsp =3D 1; - - __asm - ("wrdsp $0\n\t" - "shll.ph %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x7fff8000; - result =3D 0xfffe0000; - resultdsp =3D 1; - - __asm - ("wrdsp $0\n\t" - "shll.ph %0, %2, 0x01\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x00000001; - result =3D 0x00008000; - resultdsp =3D 1; - - __asm - ("wrdsp $0\n\t" - "shll.ph %0, %2, 0x0F\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shll_qb.c b/tests/tcg/mips/mips32-ds= p/shll_qb.c deleted file mode 100644 index 729716d..0000000 --- a/tests/tcg/mips/mips32-dsp/shll_qb.c +++ /dev/null @@ -1,55 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt, dsp; - int result, resultdsp; - - rt =3D 0x87654321; - result =3D 0x87654321; - resultdsp =3D 0x00; - - __asm - ("wrdsp $0\n\t" - "shll.qb %0, %2, 0x00\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0x38281808; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "shll.qb %0, %2, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x00000001; - result =3D 0x00000080; - resultdsp =3D 0x00; - - __asm - ("wrdsp $0\n\t" - "shll.qb %0, %2, 0x07\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shll_s_ph.c b/tests/tcg/mips/mips32-= dsp/shll_s_ph.c deleted file mode 100644 index 910fea3..0000000 --- a/tests/tcg/mips/mips32-dsp/shll_s_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt, dsp; - int result, resultdsp; - - rt =3D 0x12345678; - result =3D 0x7FFF7FFF; - resultdsp =3D 0x01; - - __asm - ("shll_s.ph %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shll_s_w.c b/tests/tcg/mips/mips32-d= sp/shll_s_w.c deleted file mode 100644 index 628c752..0000000 --- a/tests/tcg/mips/mips32-dsp/shll_s_w.c +++ /dev/null @@ -1,52 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt, dsp; - int result, resultdsp; - - rt =3D 0x82345678; - result =3D 0x82345678; - resultdsp =3D 0x00; - - __asm - ("shll_s.w %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x82345678; - result =3D 0x80000000; - resultdsp =3D 0x01; - - __asm - ("shll_s.w %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rt =3D 0x12345678; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("shll_s.w %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shllv_ph.c b/tests/tcg/mips/mips32-d= sp/shllv_ph.c deleted file mode 100644 index f98a632..0000000 --- a/tests/tcg/mips/mips32-dsp/shllv_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x0; - rt =3D 0x12345678; - result =3D 0x12345678; - resultdsp =3D 0; - - __asm - ("shllv.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0xA000C000; - resultdsp =3D 1; - - __asm - ("shllv.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shllv_qb.c b/tests/tcg/mips/mips32-d= sp/shllv_qb.c deleted file mode 100644 index 6d8ff4a..0000000 --- a/tests/tcg/mips/mips32-dsp/shllv_qb.c +++ /dev/null @@ -1,38 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0x38281808; - resultdsp =3D 0x01; - - __asm - ("shllv.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(rd =3D=3D result); - - rs =3D 0x00; - rt =3D 0x87654321; - result =3D 0x87654321; - resultdsp =3D 0x01; - - __asm - ("shllv.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shllv_s_ph.c b/tests/tcg/mips/mips32= -dsp/shllv_s_ph.c deleted file mode 100644 index fc9bd32..0000000 --- a/tests/tcg/mips/mips32-dsp/shllv_s_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x0; - rt =3D 0x12345678; - result =3D 0x12345678; - resultdsp =3D 0x0; - - __asm - ("shllv_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0x7FFF7FFF; - resultdsp =3D 0x01; - - __asm - ("shllv_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shllv_s_w.c b/tests/tcg/mips/mips32-= dsp/shllv_s_w.c deleted file mode 100644 index 350c256..0000000 --- a/tests/tcg/mips/mips32-dsp/shllv_s_w.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("shllv_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x0; - rt =3D 0x12345678; - result =3D 0x12345678; - resultdsp =3D 0x01; - - __asm - ("shllv_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shra_ph.c b/tests/tcg/mips/mips32-ds= p/shra_ph.c deleted file mode 100644 index 5b2d840..0000000 --- a/tests/tcg/mips/mips32-dsp/shra_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0xF0EC0864; - - __asm - ("shra.ph %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0x87654321; - - __asm - ("shra.ph %0, %1, 0x00\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shra_r_ph.c b/tests/tcg/mips/mips32-= dsp/shra_r_ph.c deleted file mode 100644 index adc4ae6..0000000 --- a/tests/tcg/mips/mips32-dsp/shra_r_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0xF0ED0864; - - __asm - ("shra_r.ph %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0x87654321; - - __asm - ("shra_r.ph %0, %1, 0x00\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shra_r_w.c b/tests/tcg/mips/mips32-d= sp/shra_r_w.c deleted file mode 100644 index ec0cf2c..0000000 --- a/tests/tcg/mips/mips32-dsp/shra_r_w.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x87654321; - result =3D 0xF0ECA864; - - __asm - ("shra_r.w %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0x87654321; - - __asm - ("shra_r.w %0, %1, 0x0\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shrav_ph.c b/tests/tcg/mips/mips32-d= sp/shrav_ph.c deleted file mode 100644 index 6e42aaf..0000000 --- a/tests/tcg/mips/mips32-dsp/shrav_ph.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xF0EC0864; - - __asm - ("shrav.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x00; - rt =3D 0x87654321; - result =3D 0x87654321; - - __asm - ("shrav.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shrav_r_ph.c b/tests/tcg/mips/mips32= -dsp/shrav_r_ph.c deleted file mode 100644 index f03b978..0000000 --- a/tests/tcg/mips/mips32-dsp/shrav_r_ph.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xF0ED0864; - - __asm - ("shrav_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x00; - rt =3D 0x87654321; - result =3D 0x87654321; - - __asm - ("shrav_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shrav_r_w.c b/tests/tcg/mips/mips32-= dsp/shrav_r_w.c deleted file mode 100644 index 2ab03bb..0000000 --- a/tests/tcg/mips/mips32-dsp/shrav_r_w.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xF0ECA864; - - __asm - ("shrav_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x00; - rt =3D 0x40000000; - result =3D 0x40000000; - - __asm - ("shrav_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - assert(rd =3D=3D result); - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shrl_qb.c b/tests/tcg/mips/mips32-ds= p/shrl_qb.c deleted file mode 100644 index a7e4e6a..0000000 --- a/tests/tcg/mips/mips32-dsp/shrl_qb.c +++ /dev/null @@ -1,31 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x00010203; - - __asm - ("shrl.qb %0, %1, 0x05\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x12345678; - result =3D 0x12345678; - - __asm - ("shrl.qb %0, %1, 0x0\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/shrlv_qb.c b/tests/tcg/mips/mips32-d= sp/shrlv_qb.c deleted file mode 100644 index db77f6d..0000000 --- a/tests/tcg/mips/mips32-dsp/shrlv_qb.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x05; - rt =3D 0x12345678; - result =3D 0x00010203; - - __asm - ("shrlv.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x00; - rt =3D 0x12345678; - result =3D 0x12345678; - - __asm - ("shrlv.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/subq_ph.c b/tests/tcg/mips/mips32-ds= p/subq_ph.c deleted file mode 100644 index fdd7b38..0000000 --- a/tests/tcg/mips/mips32-dsp/subq_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x77777777; - rt =3D 0x67654321; - result =3D 0x10123456; - resultdsp =3D 0x0; - - __asm - ("subq.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x8ACF1357; - resultdsp =3D 0x01; - - __asm - ("subq.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/subq_s_ph.c b/tests/tcg/mips/mips32-= dsp/subq_s_ph.c deleted file mode 100644 index 64c89eb..0000000 --- a/tests/tcg/mips/mips32-dsp/subq_s_ph.c +++ /dev/null @@ -1,58 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x7FFF1357; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "subq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x12348000; - rt =3D 0x87657000; - result =3D 0x7FFF8000; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "subq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x12340000; - rt =3D 0x87658000; - result =3D 0x7FFF7FFF; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "subq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/subq_s_w.c b/tests/tcg/mips/mips32-d= sp/subq_s_w.c deleted file mode 100644 index 9d456a9..0000000 --- a/tests/tcg/mips/mips32-dsp/subq_s_w.c +++ /dev/null @@ -1,74 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "subq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x66666; - rt =3D 0x55555; - result =3D 0x11111; - resultdsp =3D 0x0; - - __asm - ("wrdsp $0\n\t" - "subq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x0; - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("wrdsp $0\n\t" - "subq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x80000000; - rt =3D 0x80000000; - result =3D 0; - resultdsp =3D 0x00; - - __asm - ("wrdsp $0\n\t" - "subq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/subu_qb.c b/tests/tcg/mips/mips32-ds= p/subu_qb.c deleted file mode 100644 index 4209096..0000000 --- a/tests/tcg/mips/mips32-dsp/subu_qb.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x8BCF1357; - resultdsp =3D 0x01; - - __asm - ("subu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/subu_s_qb.c b/tests/tcg/mips/mips32-= dsp/subu_s_qb.c deleted file mode 100644 index 3d65053..0000000 --- a/tests/tcg/mips/mips32-dsp/subu_s_qb.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x00001357; - resultdsp =3D 0x01; - - __asm - ("subu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dsp/wrdsp.c b/tests/tcg/mips/mips32-dsp/= wrdsp.c deleted file mode 100644 index dc54943..0000000 --- a/tests/tcg/mips/mips32-dsp/wrdsp.c +++ /dev/null @@ -1,46 +0,0 @@ -#include -#include - -int main() -{ - int dsp_i, dsp_o; - int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; - int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; - - ccond_i =3D 0x000000BC; /* 4 */ - outflag_i =3D 0x0000001B; /* 3 */ - efi_i =3D 0x00000001; /* 5 */ - c_i =3D 0x00000001; /* 2 */ - scount_i =3D 0x0000000F; /* 1 */ - pos_i =3D 0x0000000C; /* 0 */ - - dsp_i =3D (ccond_i << 24) | \ - (outflag_i << 16) | \ - (efi_i << 14) | \ - (c_i << 13) | \ - (scount_i << 7) | \ - pos_i; - - __asm - ("wrdsp %1, 0x3F\n\t" - "rddsp %0, 0x3F\n\t" - : "=3Dr"(dsp_o) - : "r"(dsp_i) - ); - - ccond_o =3D (dsp_o >> 24) & 0xFF; - outflag_o =3D (dsp_o >> 16) & 0xFF; - efi_o =3D (dsp_o >> 14) & 0x01; - c_o =3D (dsp_o >> 14) & 0x01; - scount_o =3D (dsp_o >> 7) & 0x3F; - pos_o =3D dsp_o & 0x1F; - - assert(ccond_o =3D=3D (ccond_i & 0x0F)); - assert(outflag_o =3D=3D outflag_i); - assert(efi_o =3D=3D efi_i); - assert(c_o =3D=3D c_i); - assert(scount_o =3D=3D scount_i); - assert(pos_o =3D=3D pos_i); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/absq_s_qb.c b/tests/tcg/mips/mips3= 2-dspr2/absq_s_qb.c deleted file mode 100644 index af4683f..0000000 --- a/tests/tcg/mips/mips32-dspr2/absq_s_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include -#include - -int main() -{ - int input, result, dsp; - int hope; - - input =3D 0x701BA35E; - hope =3D 0x701B5D5E; - - __asm - ("absq_s.qb %0, %1\n\t" - : "=3Dr"(result) - : "r"(input) - ); - assert(result =3D=3D hope); - - - input =3D 0x801BA35E; - hope =3D 0x7F1B5D5E; - - __asm - ("absq_s.qb %0, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(result), "=3Dr"(dsp) - : "r"(input) - ); - dsp =3D dsp >> 20; - dsp &=3D 0x01; - assert(dsp =3D=3D 1); - assert(result =3D=3D hope); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addqh_ph.c b/tests/tcg/mips/mips32= -dspr2/addqh_ph.c deleted file mode 100644 index 921f0ea..0000000 --- a/tests/tcg/mips/mips32-dspr2/addqh_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x706A13FE; - rt =3D 0x13065174; - result =3D 0x41B832B9; - __asm - ("addqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0x81000100; - rt =3D 0xc2000100; - result =3D 0xa1800100; - __asm - ("addqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addqh_r_ph.c b/tests/tcg/mips/mips= 32-dspr2/addqh_r_ph.c deleted file mode 100644 index 213ba37..0000000 --- a/tests/tcg/mips/mips32-dspr2/addqh_r_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x706A13FE; - rt =3D 0x13065174; - result =3D 0x41B832B9; - __asm - ("addqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0x81010100; - rt =3D 0xc2000100; - result =3D 0xa1810100; - __asm - ("addqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addqh_r_w.c b/tests/tcg/mips/mips3= 2-dspr2/addqh_r_w.c deleted file mode 100644 index 75a75c5..0000000 --- a/tests/tcg/mips/mips32-dspr2/addqh_r_w.c +++ /dev/null @@ -1,34 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x00000010; - rt =3D 0x00000001; - result =3D 0x00000009; - - __asm - ("addqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - rs =3D 0xFFFFFFFE; - rt =3D 0x00000001; - result =3D 0x00000000; - - __asm - ("addqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addqh_w.c b/tests/tcg/mips/mips32-= dspr2/addqh_w.c deleted file mode 100644 index de6926e..0000000 --- a/tests/tcg/mips/mips32-dspr2/addqh_w.c +++ /dev/null @@ -1,34 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x00000010; - rt =3D 0x00000001; - result =3D 0x00000008; - - __asm - ("addqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - rs =3D 0xFFFFFFFE; - rt =3D 0x00000001; - result =3D 0xFFFFFFFF; - - __asm - ("addqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addu_ph.c b/tests/tcg/mips/mips32-= dspr2/addu_ph.c deleted file mode 100644 index 1d7a25a..0000000 --- a/tests/tcg/mips/mips32-dspr2/addu_ph.c +++ /dev/null @@ -1,33 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x00FF00FF; - rt =3D 0x00010001; - result =3D 0x01000100; - __asm - ("addu.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0x00011112; - __asm - ("addu.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/addu_s_ph.c b/tests/tcg/mips/mips3= 2-dspr2/addu_s_ph.c deleted file mode 100644 index 979651b..0000000 --- a/tests/tcg/mips/mips32-dspr2/addu_s_ph.c +++ /dev/null @@ -1,33 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x00FE00FE; - rt =3D 0x00020001; - result =3D 0x010000FF; - __asm - ("addu_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0xFFFF1112; - __asm - ("addu_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - assert(((dsp >> 20) & 0x01) =3D=3D 1); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/adduh_qb.c b/tests/tcg/mips/mips32= -dspr2/adduh_qb.c deleted file mode 100644 index a1f5d63..0000000 --- a/tests/tcg/mips/mips32-dspr2/adduh_qb.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0x80094B62; - __asm - ("adduh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x7F800888; - __asm - ("adduh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/adduh_r_qb.c b/tests/tcg/mips/mips= 32-dspr2/adduh_r_qb.c deleted file mode 100644 index 81e98c1..0000000 --- a/tests/tcg/mips/mips32-dspr2/adduh_r_qb.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0xFF0055AA; - rt =3D 0x01112211; - result =3D 0x80093C5E; - __asm - ("adduh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x80800888; - __asm - ("adduh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/append.c b/tests/tcg/mips/mips32-d= spr2/append.c deleted file mode 100644 index 9a91e16..0000000 --- a/tests/tcg/mips/mips32-dspr2/append.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0x02268436; - __asm - ("append %0, %1, 0x01\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x0010111F; - __asm - ("append %0, %1, 0x04\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/balign.c b/tests/tcg/mips/mips32-d= spr2/balign.c deleted file mode 100644 index 537cf04..0000000 --- a/tests/tcg/mips/mips32-dspr2/balign.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0x13421BFF; - __asm - ("balign %0, %1, 0x01\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x11FFFF0F; - __asm - ("balign %0, %1, 0x03\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c b/tests/tcg/mips/mi= ps32-dspr2/cmpgdu_eq_qb.c deleted file mode 100644 index 2d6340d..0000000 --- a/tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpgdu.eq.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpgdu.eq.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c b/tests/tcg/mips/mi= ps32-dspr2/cmpgdu_le_qb.c deleted file mode 100644 index a0ecdca..0000000 --- a/tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpgdu.le.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11707066; - result =3D 0x0B; - __asm - ("cmpgdu.le.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c b/tests/tcg/mips/mi= ps32-dspr2/cmpgdu_lt_qb.c deleted file mode 100644 index dba99e3..0000000 --- a/tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int dsp; - int result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpgdu.lt.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmpgdu.lt.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - assert(rd =3D=3D result); - assert(dsp =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpa_w_ph.c b/tests/tcg/mips/mips32= -dspr2/dpa_w_ph.c deleted file mode 100644 index fae49f1..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpa_w_ph.c +++ /dev/null @@ -1,44 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x0302; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 6, acl =3D 7; - rs =3D 0xFFFF00FF; - rt =3D 0xFFFF0002; - resulth =3D 0x06; - resultl =3D 0x206; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c b/tests/tcg/mips/mi= ps32-dspr2/dpaqx_s_w_ph.c deleted file mode 100644 index ce87830..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c +++ /dev/null @@ -1,79 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 5, acl =3D 5; - int resulth, resultl, resultdsp; - - rs =3D 0x800000FF; - rt =3D 0x00018000; - resulth =3D 0x05; - resultl =3D 0x80000202; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 5; - acl =3D 5; - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x05FF; - /*********************************************************** - * Because of we set outflag at last time, although this - * time we set nothing, but it is stay the last time value. - **********************************************************/ - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 5; - acl =3D 5; - rs =3D 0x800000FF; - rt =3D 0x00028000; - resulth =3D 0x05; - resultl =3D 0x80000400; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c b/tests/tcg/mips/m= ips32-dspr2/dpaqx_sa_w_ph.c deleted file mode 100644 index d551d64..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c +++ /dev/null @@ -1,57 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach, acl; - int resulth, resultl, resultdsp; - - ach =3D 0x00000005; - acl =3D 0x00000005; - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x00; - resultl =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - dsp =3D 0; - __asm - ("wrdsp %2\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - assert(dsp >> (16 + 1) =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x00000009; - acl =3D 0x0000000B; - rs =3D 0x800000FF; - rt =3D 0x00018000; - resulth =3D 0x00; - resultl =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - dsp =3D 0; - __asm - ("wrdsp %2\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - assert(dsp >> (16 + 1) =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpax_w_ph.c b/tests/tcg/mips/mips3= 2-dspr2/dpax_w_ph.c deleted file mode 100644 index 514797c..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpax_w_ph.c +++ /dev/null @@ -1,44 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x0302; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpax.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 6, acl =3D 7; - rs =3D 0xFFFF00FF; - rt =3D 0xFFFF0002; - resulth =3D 0x05; - resultl =3D 0xFFFFFF06; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpax.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dps_w_ph.c b/tests/tcg/mips/mips32= -dspr2/dps_w_ph.c deleted file mode 100644 index f51f9b9..0000000 --- a/tests/tcg/mips/mips32-dspr2/dps_w_ph.c +++ /dev/null @@ -1,44 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x04; - resultl =3D 0xFFFFFD08; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dps.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 6, acl =3D 7; - rs =3D 0xFFFF00FF; - rt =3D 0xFFFF0002; - resulth =3D 0x05; - resultl =3D 0xFFFFFE08; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dps.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c b/tests/tcg/mips/mi= ps32-dspr2/dpsqx_s_w_ph.c deleted file mode 100644 index e40543f..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c +++ /dev/null @@ -1,54 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 5, acl =3D 5; - int resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x00000005; - resultl =3D 0x1CE5E09B; - resultdsp =3D 0x00; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x99F13005; - acl =3D 0x51730062; - rs =3D 0x80008000; - rt =3D 0x80008000; - - resulth =3D 0x99F13004; - resultl =3D 0x51730064; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c b/tests/tcg/mips/m= ips32-dspr2/dpsqx_sa_w_ph.c deleted file mode 100644 index 7da278e..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c +++ /dev/null @@ -1,53 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, dsp; - int ach =3D 5, acl =3D 5; - int resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x00; - resultl =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - ach =3D 0x8c0b354A; - acl =3D 0xbbc02249; - rs =3D 0x800023AD; - rt =3D 0x01648000; - resulth =3D 0xffffffff; - resultl =3D 0x80000000; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c b/tests/tcg/mips/mips3= 2-dspr2/dpsx_w_ph.c deleted file mode 100644 index bb49a40..0000000 --- a/tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int ach =3D 5, acl =3D 5; - int resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x05; - resultl =3D 0xE72F050; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsx.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mul_ph.c b/tests/tcg/mips/mips32-d= spr2/mul_ph.c deleted file mode 100644 index c7e9d60..0000000 --- a/tests/tcg/mips/mips32-dspr2/mul_ph.c +++ /dev/null @@ -1,47 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x03FB1234; - rt =3D 0x0BCC4321; - result =3D 0xF504F4B4; - resultdsp =3D 1; - - __asm - ("mul.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x00210010; - rt =3D 0x00110005; - result =3D 0x2310050; - resultdsp =3D 0; - - __asm - ("mul.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mul_s_ph.c b/tests/tcg/mips/mips32= -dspr2/mul_s_ph.c deleted file mode 100644 index 33da110..0000000 --- a/tests/tcg/mips/mips32-dspr2/mul_s_ph.c +++ /dev/null @@ -1,62 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x03FB1234; - rt =3D 0x0BCC4321; - result =3D 0x7fff7FFF; - resultdsp =3D 1; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - rs =3D 0x7fffff00; - rt =3D 0xff007fff; - result =3D 0x80008000; - resultdsp =3D 1; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x00320001; - rt =3D 0x00210002; - result =3D 0x06720002; - resultdsp =3D 0; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mulq_rs_w.c b/tests/tcg/mips/mips3= 2-dspr2/mulq_rs_w.c deleted file mode 100644 index 7ba633b..0000000 --- a/tests/tcg/mips/mips32-dspr2/mulq_rs_w.c +++ /dev/null @@ -1,36 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFFAAAB; - - __asm - ("mulq_rs.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0x80000000; - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("mulq_rs.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mulq_s_ph.c b/tests/tcg/mips/mips3= 2-dspr2/mulq_s_ph.c deleted file mode 100644 index 00e0155..0000000 --- a/tests/tcg/mips/mips32-dspr2/mulq_s_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80000000; - rt =3D 0x0ffc0000; - result =3D 0xF0040000; - resultdsp =3D 0; - - __asm - ("mulq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFF098B; - resultdsp =3D 1; - - __asm - ("mulq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mulq_s_w.c b/tests/tcg/mips/mips32= -dspr2/mulq_s_w.c deleted file mode 100644 index 9c2be06..0000000 --- a/tests/tcg/mips/mips32-dspr2/mulq_s_w.c +++ /dev/null @@ -1,36 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFFAAAB; - - __asm - ("mulq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0x80000000; - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("mulq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - assert(rd =3D=3D result); - assert(dsp =3D=3D resultdsp); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c b/tests/tcg/mips/mips= 32-dspr2/mulsa_w_ph.c deleted file mode 100644 index a694093..0000000 --- a/tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c +++ /dev/null @@ -1,29 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, ach, acl; - int resulth, resultl; - - ach =3D 0x05; - acl =3D 0x00BBDDCC; - rs =3D 0x80001234; - rt =3D 0x80004321; - resulth =3D 0x05; - resultl =3D 0x3BF5E918; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "mulsa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c b/tests/tcg/mips/m= ips32-dspr2/mulsaq_s_w_ph.c deleted file mode 100644 index 06c91a4..0000000 --- a/tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c +++ /dev/null @@ -1,29 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt, ach, acl; - int resulth, resultl; - - ach =3D 0x05; - acl =3D 0x00BBDDCC; - rs =3D 0x80001234; - rt =3D 0x80004321; - resulth =3D 0x05; - resultl =3D 0x772ff463; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "mulsaq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - assert(ach =3D=3D resulth); - assert(acl =3D=3D resultl); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/precr_qb_ph.c b/tests/tcg/mips/mip= s32-dspr2/precr_qb_ph.c deleted file mode 100644 index 3a2b3fd..0000000 --- a/tests/tcg/mips/mips32-dspr2/precr_qb_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x34786521; - - __asm - ("precr.qb.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(result =3D=3D rd); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c b/tests/tcg/mips/= mips32-dspr2/precr_sra_ph_w.c deleted file mode 100644 index 5c9baab..0000000 --- a/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x43215678; - - __asm - ("precr_sra.ph.w %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(result =3D=3D rt); - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFF0000; - - __asm - ("precr_sra.ph.w %0, %1, 0x1F\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c b/tests/tcg/mip= s/mips32-dspr2/precr_sra_r_ph_w.c deleted file mode 100644 index 6474a10..0000000 --- a/tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x43215678; - - __asm - ("precr_sra_r.ph.w %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(result =3D=3D rt); - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFF0000; - - __asm - ("precr_sra_r.ph.w %0, %1, 0x1F\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(result =3D=3D rt); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/prepend.c b/tests/tcg/mips/mips32-= dspr2/prepend.c deleted file mode 100644 index f6bcd47..0000000 --- a/tests/tcg/mips/mips32-dspr2/prepend.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x87654321; - __asm - ("prepend %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xACF10ECA; - __asm - ("prepend %0, %1, 0x0F\n\t" - : "+r"(rt) - : "r"(rs) - ); - assert(rt =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shra_qb.c b/tests/tcg/mips/mips32-= dspr2/shra_qb.c deleted file mode 100644 index 48193de..0000000 --- a/tests/tcg/mips/mips32-dspr2/shra_qb.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x02060A0F; - - __asm - ("shra.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0xF00C0804; - - __asm - ("shra.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shra_r_qb.c b/tests/tcg/mips/mips3= 2-dspr2/shra_r_qb.c deleted file mode 100644 index 29afa0e..0000000 --- a/tests/tcg/mips/mips32-dspr2/shra_r_qb.c +++ /dev/null @@ -1,30 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x02070B0F; - - __asm - ("shra_r.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - rt =3D 0x87654321; - result =3D 0xF10D0804; - - __asm - ("shra_r.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shrav_qb.c b/tests/tcg/mips/mips32= -dspr2/shrav_qb.c deleted file mode 100644 index b21e1b7..0000000 --- a/tests/tcg/mips/mips32-dspr2/shrav_qb.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x03; - rt =3D 0x12345678; - result =3D 0x02060A0F; - - __asm - ("shrav.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xF00C0804; - - __asm - ("shrav.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shrav_r_qb.c b/tests/tcg/mips/mips= 32-dspr2/shrav_r_qb.c deleted file mode 100644 index 9ea8aa0..0000000 --- a/tests/tcg/mips/mips32-dspr2/shrav_r_qb.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x03; - rt =3D 0x12345678; - result =3D 0x02070B0F; - - __asm - ("shrav_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xF10D0804; - - __asm - ("shrav_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shrl_ph.c b/tests/tcg/mips/mips32-= dspr2/shrl_ph.c deleted file mode 100644 index 724b9a7..0000000 --- a/tests/tcg/mips/mips32-dspr2/shrl_ph.c +++ /dev/null @@ -1,20 +0,0 @@ -#include -#include - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x009102B3; - - __asm - ("shrl.ph %0, %1, 0x05\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/shrlv_ph.c b/tests/tcg/mips/mips32= -dspr2/shrlv_ph.c deleted file mode 100644 index ac79aa6..0000000 --- a/tests/tcg/mips/mips32-dspr2/shrlv_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x05; - rt =3D 0x12345678; - result =3D 0x009102B3; - - __asm - ("shrlv.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subqh_ph.c b/tests/tcg/mips/mips32= -dspr2/subqh_ph.c deleted file mode 100644 index dbc0967..0000000 --- a/tests/tcg/mips/mips32-dspr2/subqh_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456709AB; - - __asm - ("subqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subqh_r_ph.c b/tests/tcg/mips/mips= 32-dspr2/subqh_r_ph.c deleted file mode 100644 index 24ef0f1..0000000 --- a/tests/tcg/mips/mips32-dspr2/subqh_r_ph.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456809AC; - - __asm - ("subqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subqh_r_w.c b/tests/tcg/mips/mips3= 2-dspr2/subqh_r_w.c deleted file mode 100644 index d460f86..0000000 --- a/tests/tcg/mips/mips32-dspr2/subqh_r_w.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456789AC; - - __asm - ("subqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subqh_w.c b/tests/tcg/mips/mips32-= dspr2/subqh_w.c deleted file mode 100644 index 42be3de..0000000 --- a/tests/tcg/mips/mips32-dspr2/subqh_w.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456789AB; - - __asm - ("subqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subu_ph.c b/tests/tcg/mips/mips32-= dspr2/subu_ph.c deleted file mode 100644 index 0d39a01..0000000 --- a/tests/tcg/mips/mips32-dspr2/subu_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x87654321; - rt =3D 0x11111111; - result =3D 0x76543210; - resultdsp =3D 0x00; - - __asm - ("subu.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - rs =3D 0x87654321; - rt =3D 0x12345678; - result =3D 0x7531ECA9; - resultdsp =3D 0x01; - - __asm - ("subu.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subu_s_ph.c b/tests/tcg/mips/mips3= 2-dspr2/subu_s_ph.c deleted file mode 100644 index 8e4da4f..0000000 --- a/tests/tcg/mips/mips32-dspr2/subu_s_ph.c +++ /dev/null @@ -1,25 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt, dsp; - int result, resultdsp; - - rs =3D 0x87654321; - rt =3D 0x12345678; - result =3D 0x75310000; - resultdsp =3D 0x01; - - __asm - ("subu_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - assert(dsp =3D=3D resultdsp); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subuh_qb.c b/tests/tcg/mips/mips32= -dspr2/subuh_qb.c deleted file mode 100644 index 92cfc76..0000000 --- a/tests/tcg/mips/mips32-dspr2/subuh_qb.c +++ /dev/null @@ -1,21 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xC5E7092B; - - __asm - ("subuh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mips32-dspr2/subuh_r_qb.c b/tests/tcg/mips/mips= 32-dspr2/subuh_r_qb.c deleted file mode 100644 index dac81d4..0000000 --- a/tests/tcg/mips/mips32-dspr2/subuh_r_qb.c +++ /dev/null @@ -1,32 +0,0 @@ -#include -#include - -int main() -{ - int rd, rs, rt; - int result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xC6E80A2C; - - __asm - ("subuh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - rs =3D 0xBEFC292A; - rt =3D 0x9205C1B4; - result =3D 0x167cb4bb; - - __asm - ("subuh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - assert(rd =3D=3D result); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/div1.c b/tests/tcg/mips/mipsr5900/div= 1.c deleted file mode 100644 index 83dafa0..0000000 --- a/tests/tcg/mips/mipsr5900/div1.c +++ /dev/null @@ -1,73 +0,0 @@ -/* - * Test R5900-specific DIV1. - */ - -#include -#include -#include - -struct quotient_remainder { int32_t quotient, remainder; }; - -static struct quotient_remainder div1(int32_t rs, int32_t rt) -{ - int32_t lo, hi; - - __asm__ __volatile__ ( - " div1 $0, %2, %3\n" - " mflo1 %0\n" - " mfhi1 %1\n" - : "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - - assert(rs / rt =3D=3D lo); - assert(rs % rt =3D=3D hi); - - return (struct quotient_remainder) { .quotient =3D lo, .remainder =3D = hi }; -} - -static void verify_div1(int32_t rs, int32_t rt, - int32_t expected_quotient, - int32_t expected_remainder) -{ - struct quotient_remainder qr =3D div1(rs, rt); - - assert(qr.quotient =3D=3D expected_quotient); - assert(qr.remainder =3D=3D expected_remainder); -} - -static void verify_div1_negations(int32_t rs, int32_t rt, - int32_t expected_quotient, - int32_t expected_remainder) -{ - verify_div1(rs, rt, expected_quotient, expected_remainder); - verify_div1(rs, -rt, -expected_quotient, expected_remainder); - verify_div1(-rs, rt, -expected_quotient, -expected_remainder); - verify_div1(-rs, -rt, expected_quotient, -expected_remainder); -} - -int main() -{ - verify_div1_negations(0, 1, 0, 0); - verify_div1_negations(1, 1, 1, 0); - verify_div1_negations(1, 2, 0, 1); - verify_div1_negations(17, 19, 0, 17); - verify_div1_negations(19, 17, 1, 2); - verify_div1_negations(77773, 101, 770, 3); - - verify_div1(-0x80000000, 1, -0x80000000, 0); - - /* - * Supplementary explanation from the Toshiba TX System RISC TX79 Core - * Architecture manual, A-38 and B-7, https://wiki.qemu.org/File:C790.= pdf - * - * Normally, when 0x80000000 (-2147483648) the signed minimum value is - * divided by 0xFFFFFFFF (-1), the operation will result in an overflo= w. - * However, in this instruction an overflow exception doesn't occur and - * the result will be as follows: - * - * Quotient is 0x80000000 (-2147483648), and remainder is 0x00000000 (= 0). - */ - verify_div1(-0x80000000, -1, -0x80000000, 0); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/divu1.c b/tests/tcg/mips/mipsr5900/di= vu1.c deleted file mode 100644 index 72aeed3..0000000 --- a/tests/tcg/mips/mipsr5900/divu1.c +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Test R5900-specific DIVU1. - */ - -#include -#include -#include - -struct quotient_remainder { uint32_t quotient, remainder; }; - -static struct quotient_remainder divu1(uint32_t rs, uint32_t rt) -{ - uint32_t lo, hi; - - __asm__ __volatile__ ( - " divu1 $0, %2, %3\n" - " mflo1 %0\n" - " mfhi1 %1\n" - : "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - - assert(rs / rt =3D=3D lo); - assert(rs % rt =3D=3D hi); - - return (struct quotient_remainder) { .quotient =3D lo, .remainder =3D = hi }; -} - -static void verify_divu1(uint32_t rs, uint32_t rt, - uint32_t expected_quotient, - uint32_t expected_remainder) -{ - struct quotient_remainder qr =3D divu1(rs, rt); - - assert(qr.quotient =3D=3D expected_quotient); - assert(qr.remainder =3D=3D expected_remainder); -} - -int main() -{ - verify_divu1(0, 1, 0, 0); - verify_divu1(1, 1, 1, 0); - verify_divu1(1, 2, 0, 1); - verify_divu1(17, 19, 0, 17); - verify_divu1(19, 17, 1, 2); - verify_divu1(77773, 101, 770, 3); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/madd.c b/tests/tcg/mips/mipsr5900/mad= d.c deleted file mode 100644 index f6f215e..0000000 --- a/tests/tcg/mips/mipsr5900/madd.c +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Test R5900-specific three-operand MADD and MADD1. - */ - -#include -#include -#include - -int64_t madd(int64_t a, int32_t rs, int32_t rt) -{ - int32_t lo =3D a; - int32_t hi =3D a >> 32; - int32_t rd; - int64_t r; - - __asm__ __volatile__ ( - " mtlo %5\n" - " mthi %6\n" - " madd %0, %3, %4\n" - " mflo %1\n" - " mfhi %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); - r =3D ((int64_t)hi << 32) | (uint32_t)lo; - - assert(a + (int64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -int64_t madd1(int64_t a, int32_t rs, int32_t rt) -{ - int32_t lo =3D a; - int32_t hi =3D a >> 32; - int32_t rd; - int64_t r; - - __asm__ __volatile__ ( - " mtlo1 %5\n" - " mthi1 %6\n" - " madd1 %0, %3, %4\n" - " mflo1 %1\n" - " mfhi1 %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); - r =3D ((int64_t)hi << 32) | (uint32_t)lo; - - assert(a + (int64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static int64_t madd_variants(int64_t a, int32_t rs, int32_t rt) -{ - int64_t rd =3D madd(a, rs, rt); - int64_t rd1 =3D madd1(a, rs, rt); - - assert(rd =3D=3D rd1); - - return rd; -} - -static void verify_madd(int64_t a, int32_t rs, int32_t rt, int64_t expecte= d) -{ - assert(madd_variants(a, rs, rt) =3D=3D expected); - assert(madd_variants(a, -rs, rt) =3D=3D a + a - expected); - assert(madd_variants(a, rs, -rt) =3D=3D a + a - expected); - assert(madd_variants(a, -rs, -rt) =3D=3D expected); -} - -int main() -{ - verify_madd(13, 17, 19, 336); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/maddu.c b/tests/tcg/mips/mipsr5900/ma= ddu.c deleted file mode 100644 index 30936fb..0000000 --- a/tests/tcg/mips/mipsr5900/maddu.c +++ /dev/null @@ -1,70 +0,0 @@ -/* - * Test R5900-specific three-operand MADDU and MADDU1. - */ - -#include -#include -#include - -uint64_t maddu(uint64_t a, uint32_t rs, uint32_t rt) -{ - uint32_t lo =3D a; - uint32_t hi =3D a >> 32; - uint32_t rd; - uint64_t r; - - __asm__ __volatile__ ( - " mtlo %5\n" - " mthi %6\n" - " maddu %0, %3, %4\n" - " mflo %1\n" - " mfhi %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); - r =3D ((uint64_t)hi << 32) | (uint32_t)lo; - - assert(a + (uint64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -uint64_t maddu1(uint64_t a, uint32_t rs, uint32_t rt) -{ - uint32_t lo =3D a; - uint32_t hi =3D a >> 32; - uint32_t rd; - uint64_t r; - - __asm__ __volatile__ ( - " mtlo1 %5\n" - " mthi1 %6\n" - " maddu1 %0, %3, %4\n" - " mflo1 %1\n" - " mfhi1 %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); - r =3D ((uint64_t)hi << 32) | (uint32_t)lo; - - assert(a + (uint64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static int64_t maddu_variants(int64_t a, int32_t rs, int32_t rt) -{ - int64_t rd =3D maddu(a, rs, rt); - int64_t rd1 =3D maddu1(a, rs, rt); - - assert(rd =3D=3D rd1); - - return rd; -} - -int main() -{ - assert(maddu_variants(13, 17, 19) =3D=3D 336); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/mflohi1.c b/tests/tcg/mips/mipsr5900/= mflohi1.c deleted file mode 100644 index eed3683..0000000 --- a/tests/tcg/mips/mipsr5900/mflohi1.c +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Test R5900-specific MFLO1 and MFHI1. - */ - -#include -#include -#include - -int main() -{ - int32_t rs =3D 12207031, rt =3D 305175781; - int32_t rs1 =3D 32452867, rt1 =3D 49979687; - int64_t lo, hi, lo1, hi1; - int64_t r, r1; - - /* Test both LO/HI and LO1/HI1 to verify separation. */ - __asm__ __volatile__ ( - " mult $0, %4, %5\n" - " mult1 $0, %6, %7\n" - " mflo %0\n" - " mfhi %1\n" - " mflo1 %2\n" - " mfhi1 %3\n" - : "=3Dr" (lo), "=3Dr" (hi), - "=3Dr" (lo1), "=3Dr" (hi1) - : "r" (rs), "r" (rt), - "r" (rs1), "r" (rt1)); - r =3D ((int64_t)hi << 32) | (uint32_t)lo; - r1 =3D ((int64_t)hi1 << 32) | (uint32_t)lo1; - - assert(r =3D=3D 3725290219116211); - assert(r1 =3D=3D 1621984134912629); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/mtlohi1.c b/tests/tcg/mips/mipsr5900/= mtlohi1.c deleted file mode 100644 index 7f3e728..0000000 --- a/tests/tcg/mips/mipsr5900/mtlohi1.c +++ /dev/null @@ -1,40 +0,0 @@ -/* - * Test R5900-specific MTLO1 and MTHI1. - */ - -#include -#include -#include - -int main() -{ - int32_t tlo =3D 12207031, thi =3D 305175781; - int32_t tlo1 =3D 32452867, thi1 =3D 49979687; - int32_t flo, fhi, flo1, fhi1; - - /* Test both LO/HI and LO1/HI1 to verify separation. */ - __asm__ __volatile__ ( - " mtlo %4\n" - " mthi %5\n" - " mtlo1 %6\n" - " mthi1 %7\n" - " move %0, $0\n" - " move %1, $0\n" - " move %2, $0\n" - " move %3, $0\n" - " mflo %0\n" - " mfhi %1\n" - " mflo1 %2\n" - " mfhi1 %3\n" - : "=3Dr" (flo), "=3Dr" (fhi), - "=3Dr" (flo1), "=3Dr" (fhi1) - : "r" (tlo), "r" (thi), - "r" (tlo1), "r" (thi1)); - - assert(flo =3D=3D 12207031); - assert(fhi =3D=3D 305175781); - assert(flo1 =3D=3D 32452867); - assert(fhi1 =3D=3D 49979687); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/mult.c b/tests/tcg/mips/mipsr5900/mul= t.c deleted file mode 100644 index 5710b39..0000000 --- a/tests/tcg/mips/mipsr5900/mult.c +++ /dev/null @@ -1,76 +0,0 @@ -/* - * Test R5900-specific three-operand MULT and MULT1. - */ - -#include -#include -#include - -static int64_t mult(int32_t rs, int32_t rt) -{ - int32_t rd, lo, hi; - int64_t r; - - __asm__ __volatile__ ( - " mult %0, %3, %4\n" - " mflo %1\n" - " mfhi %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - r =3D ((int64_t)hi << 32) | (uint32_t)lo; - - assert((int64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static int64_t mult1(int32_t rs, int32_t rt) -{ - int32_t rd, lo, hi; - int64_t r; - - __asm__ __volatile__ ( - " mult1 %0, %3, %4\n" - " mflo1 %1\n" - " mfhi1 %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - r =3D ((int64_t)hi << 32) | (uint32_t)lo; - - assert((int64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static int64_t mult_variants(int32_t rs, int32_t rt) -{ - int64_t rd =3D mult(rs, rt); - int64_t rd1 =3D mult1(rs, rt); - - assert(rd =3D=3D rd1); - - return rd; -} - -static void verify_mult_negations(int32_t rs, int32_t rt, int64_t expected) -{ - assert(mult_variants(rs, rt) =3D=3D expected); - assert(mult_variants(-rs, rt) =3D=3D -expected); - assert(mult_variants(rs, -rt) =3D=3D -expected); - assert(mult_variants(-rs, -rt) =3D=3D expected); -} - -int main() -{ - verify_mult_negations(17, 19, 323); - verify_mult_negations(77773, 99991, 7776600043); - verify_mult_negations(12207031, 305175781, 3725290219116211); - - assert(mult_variants(-0x80000000, 0x7FFFFFFF) =3D=3D -0x3FFFFFFF80000= 000); - assert(mult_variants(-0x80000000, -0x7FFFFFFF) =3D=3D 0x3FFFFFFF80000= 000); - assert(mult_variants(-0x80000000, -0x80000000) =3D=3D 0x4000000000000= 000); - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/multu.c b/tests/tcg/mips/mipsr5900/mu= ltu.c deleted file mode 100644 index f043904..0000000 --- a/tests/tcg/mips/mipsr5900/multu.c +++ /dev/null @@ -1,68 +0,0 @@ -/* - * Test R5900-specific three-operand MULTU and MULTU1. - */ - -#include -#include -#include - -static uint64_t multu(uint32_t rs, uint32_t rt) -{ - uint32_t rd, lo, hi; - uint64_t r; - - __asm__ __volatile__ ( - " multu %0, %3, %4\n" - " mflo %1\n" - " mfhi %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - r =3D ((uint64_t)hi << 32) | (uint32_t)lo; - - assert((uint64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static uint64_t multu1(uint32_t rs, uint32_t rt) -{ - uint32_t rd, lo, hi; - uint64_t r; - - __asm__ __volatile__ ( - " multu1 %0, %3, %4\n" - " mflo1 %1\n" - " mfhi1 %2\n" - : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) - : "r" (rs), "r" (rt)); - r =3D ((uint64_t)hi << 32) | (uint32_t)lo; - - assert((uint64_t)rs * rt =3D=3D r); - assert(rd =3D=3D lo); - - return r; -} - -static uint64_t multu_variants(uint32_t rs, uint32_t rt) -{ - uint64_t rd =3D multu(rs, rt); - uint64_t rd1 =3D multu1(rs, rt); - - assert(rd =3D=3D rd1); - - return rd; -} - -int main() -{ - assert(multu_variants(17, 19) =3D=3D 323); - assert(multu_variants(77773, 99991) =3D=3D 7776600043); - assert(multu_variants(12207031, 305175781) =3D=3D 3725290219116211); - - assert(multu_variants(0x80000000U, 0x7FFFFFFF) =3D=3D 0x3FFFFFFF800000= 00); - assert(multu_variants(0x80000000U, 0x80000000U) =3D=3D 0x400000000000= 0000); - assert(multu_variants(0xFFFFFFFFU, 0xFFFFFFFFU) =3D=3D 0xFFFFFFFE0000= 0001U); - - return 0; -} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_absq_s_ph.c new file mode 100644 index 0000000..aa84112 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_ph.c @@ -0,0 +1,31 @@ +#include +#include + + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x10017EFD; + result =3D 0x10017EFD; + + __asm + ("absq_s.ph %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x8000A536; + result =3D 0x7FFF5ACA; + + __asm + ("absq_s.ph %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_absq_s_w.c new file mode 100644 index 0000000..3f52a48 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_absq_s_w.c @@ -0,0 +1,37 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x80000000; + result =3D 0x7FFFFFFF; + __asm + ("absq_s.w %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x80030000; + result =3D 0x7FFD0000; + __asm + ("absq_s.w %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x31036080; + result =3D 0x31036080; + __asm + ("absq_s.w %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_addq_ph.c new file mode 100644 index 0000000..96a5496 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_ph.c @@ -0,0 +1,46 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0xFFFFFFFF; + rt =3D 0x10101010; + result =3D 0x100F100F; + __asm + ("addq.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + rs =3D 0x3712847D; + rt =3D 0x0031AF2D; + result =3D 0x374333AA; + __asm + ("addq.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + rs =3D 0x7fff847D; + rt =3D 0x0031AF2D; + result =3D 0x803033AA; + __asm + ("addq.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + __asm("rddsp %0\n\t" + : "=3Dr"(dsp) + ); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_addq_s_ph.c new file mode 100644 index 0000000..5f865f6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_ph.c @@ -0,0 +1,69 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0xFFFFFFFF; + rt =3D 0x10101010; + result =3D 0x100F100F; + __asm + ("addq_s.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + rs =3D 0x3712847D; + rt =3D 0x0031AF2D; + result =3D 0x37438000; + __asm + ("addq_s.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + __asm + ("rddsp %0\n\t" + : "=3Dr"(dsp) + ); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + rs =3D 0x7fff847D; + rt =3D 0x0031AF2D; + result =3D 0x7fff8000; + __asm + ("addq_s.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + __asm + ("rddsp %0\n\t" + : "=3Dr"(dsp) + ); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + rs =3D 0x8030847D; + rt =3D 0x8a00AF2D; + result =3D 0x80008000; + __asm + ("addq_s.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + __asm + ("rddsp %0\n\t" + : "=3Dr"(dsp) + ); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_addq_s_w.c new file mode 100644 index 0000000..1e13acf --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addq_s_w.c @@ -0,0 +1,44 @@ +#include +#include + + +int main() +{ + int rd, rs, rt; + int result; + + rt =3D 0x10017EFD; + rs =3D 0x11111111; + result =3D 0x2112900e; + + __asm + ("addq_s.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x80017EFD; + rs =3D 0x81111111; + result =3D 0x80000000; + + __asm + ("addq_s.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x7fffffff; + rs =3D 0x01111111; + result =3D 0x7fffffff; + + __asm + ("addq_s.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addsc.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_addsc.c new file mode 100644 index 0000000..ace749f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addsc.c @@ -0,0 +1,33 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x0000000F; + rt =3D 0x00000001; + result =3D 0x00000010; + __asm + ("addsc %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF0FFF; + rt =3D 0x00010111; + result =3D 0x00001110; + __asm + ("addsc %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 13) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_addu_qb.c new file mode 100644 index 0000000..23ba2e9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x00FF00FF; + rt =3D 0x00010001; + result =3D 0x00000000; + __asm + ("addu.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + rs =3D 0xFFFF1111; + rt =3D 0x00020001; + result =3D 0xFF011112; + __asm + ("addu.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_s_qb.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_addu_s_qb.c new file mode 100644 index 0000000..fe7fd3e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addu_s_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x10FF01FF; + rt =3D 0x10010001; + result =3D 0x20FF01FF; + __asm + ("addu_s.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x1) =3D=3D 1); + + rs =3D 0xFFFF1111; + rt =3D 0x00020001; + result =3D 0xFFFF1112; + __asm + ("addu_s.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x1) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addwc.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_addwc.c new file mode 100644 index 0000000..8a8d81f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_addwc.c @@ -0,0 +1,49 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dspi, dspo; + int result; + + rs =3D 0x10FF01FF; + rt =3D 0x10010001; + dspi =3D 0x00002000; + result =3D 0x21000201; + __asm + ("wrdsp %3\n" + "addwc %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dspi) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF1111; + rt =3D 0x00020001; + dspi =3D 0x00; + result =3D 0x00011112; + __asm + ("wrdsp %3\n" + "addwc %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dspi) + ); + assert(rd =3D=3D result); + + rs =3D 0x8FFF1111; + rt =3D 0x80020001; + dspi =3D 0x00; + result =3D 0x10011112; + __asm + ("wrdsp %4\n" + "addwc %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dspo) + : "r"(rs), "r"(rt), "r"(dspi) + ); + assert(rd =3D=3D result); + assert(((dspo >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_bitrev.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_bitrev.c new file mode 100644 index 0000000..04d8a38 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_bitrev.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x00001E6A; + + __asm + ("bitrev %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_bposge32.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_bposge32.c new file mode 100644 index 0000000..d25417e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_bposge32.c @@ -0,0 +1,44 @@ +#include +#include + +int main() +{ + int dsp, sum; + int result; + + dsp =3D 0x20; + sum =3D 0x01; + result =3D 0x02; + + __asm + ("wrdsp %1\n\t" + "bposge32 test1\n\t" + "nop\n\t" + "addi %0, 0xA2\n\t" + "nop\n\t" + "test1:\n\t" + "addi %0, 0x01\n\t" + : "+r"(sum) + : "r"(dsp) + ); + assert(sum =3D=3D result); + + dsp =3D 0x10; + sum =3D 0x01; + result =3D 0xA4; + + __asm + ("wrdsp %1\n\t" + "bposge32 test2\n\t" + "nop\n\t" + "addi %0, 0xA2\n\t" + "nop\n\t" + "test2:\n\t" + "addi %0, 0x01\n\t" + : "+r"(sum) + : "r"(dsp) + ); + assert(sum =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_eq_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_cmp_eq_ph.c new file mode 100644 index 0000000..957bd88 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_eq_ph.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA33FF; + result =3D 0x00; + __asm + ("cmp.eq.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x03; + __asm + ("cmp.eq.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_le_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_cmp_le_ph.c new file mode 100644 index 0000000..356f156 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_le_ph.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA33FF; + result =3D 0x02; + __asm + ("cmp.le.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x03; + __asm + ("cmp.le.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_lt_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_cmp_lt_ph.c new file mode 100644 index 0000000..3fb4827 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmp_lt_ph.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA33FF; + result =3D 0x02; + __asm + ("cmp.lt.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x00; + __asm + ("cmp.lt.ph %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + rd =3D (rd >> 24) & 0x03; + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_eq_qb.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_eq_qb.c new file mode 100644 index 0000000..2615c84 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_eq_qb.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x02; + __asm + ("cmpgu.eq.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x0F; + __asm + ("cmpgu.eq.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_le_qb.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_le_qb.c new file mode 100644 index 0000000..65d0813 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_le_qb.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0F; + __asm + ("cmpgu.le.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11766066; + result =3D 0x09; + __asm + ("cmpgu.le.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_lt_qb.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_lt_qb.c new file mode 100644 index 0000000..7dddad9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpgu_lt_qb.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0D; + __asm + ("cmpgu.lt.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11766066; + result =3D 0x00; + __asm + ("cmpgu.lt.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_eq_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_cmpu_eq_qb.c new file mode 100644 index 0000000..680f2a1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_eq_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x02; + __asm + ("cmpu.eq.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x0F; + __asm + ("cmpu.eq.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_le_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_cmpu_le_qb.c new file mode 100644 index 0000000..43cfa50 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_le_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0F; + __asm + ("cmpu.le.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x0F; + __asm + ("cmpu.le.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_lt_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_cmpu_lt_qb.c new file mode 100644 index 0000000..074ca5b --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_cmpu_lt_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0D; + __asm + ("cmpu.lt.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x00; + __asm + ("cmpu.lt.qb %1, %2\n\t" + "rddsp %0\n\t" + : "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_s_w_ph.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_s_w_ph.c new file mode 100644 index 0000000..a6425b6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_s_w_ph.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 0, acl =3D 0; + int resulth, resultl, resultdsp; + + rs =3D 0x800000FF; + rt =3D 0x80000002; + resulth =3D 0x00; + resultl =3D 0x800003FB; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D dsp >> 17 & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_sa_l_w.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_sa_l_w.c new file mode 100644 index 0000000..cbf9007 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpaq_sa_l_w.c @@ -0,0 +1,125 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 0, acl =3D 0; + int resulth, resultl, resultdsp; + + rs =3D 0x80000000; + rt =3D 0x80000000; + resulth =3D 0x7FFFFFFF; + resultl =3D 0xFFFFFFFF; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x00000012; + acl =3D 0x00000048; + rs =3D 0x80000000; + rt =3D 0x80000000; + + resulth =3D 0x7FFFFFFF; + resultl =3D 0xFFFFFFFF; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x741532A0; + acl =3D 0xFCEABB08; + rs =3D 0x80000000; + rt =3D 0x80000000; + + resulth =3D 0x7FFFFFFF; + resultl =3D 0xFFFFFFFF; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0; + acl =3D 0; + rs =3D 0xC0000000; + rt =3D 0x7FFFFFFF; + + resulth =3D 0xC0000000; + resultl =3D 0x80000000; + resultdsp =3D 0; + __asm + ("wrdsp $0\n\t" + "mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x20000000; + acl =3D 0; + rs =3D 0xE0000000; + rt =3D 0x7FFFFFFF; + + resulth =3D 0; + resultl =3D 0x40000000; + resultdsp =3D 0; + __asm + ("wrdsp $0\n\t" + "mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbl.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbl.c new file mode 100644 index 0000000..6017b5e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbl.c @@ -0,0 +1,27 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 3; + int resulth, resultl; + + rs =3D 0x800000FF; + rt =3D 0x80000002; + resulth =3D 0x05; + resultl =3D 0x4003; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpau.h.qbl $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbr.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbr.c new file mode 100644 index 0000000..e4abb2e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpau_h_qbr.c @@ -0,0 +1,27 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 3; + int resulth, resultl; + + rs =3D 0x800000FF; + rt =3D 0x80000002; + resulth =3D 0x05; + resultl =3D 0x0201; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpau.h.qbr $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_s_w_ph.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_s_w_ph.c new file mode 100644 index 0000000..74058fe --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_s_w_ph.c @@ -0,0 +1,45 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x00000004; + resultl =3D 0xF15F94A3; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsq_s.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x1424EF1F; + acl =3D 0x1035219A; + rs =3D 0x800083AD; + rt =3D 0x80003721; + resulth =3D 0x1424EF1E; + resultl =3D 0xC5C0D901; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsq_s.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_sa_l_w.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_sa_l_w.c new file mode 100644 index 0000000..eda3b14 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsq_sa_l_w.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 5, acl =3D 5; + int resulth, resultl, resultdsp; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x00BD3A22; + resultl =3D 0xD138776B; + resultdsp =3D 0x00; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x54321123; + acl =3D 5; + rs =3D 0x80000000; + rt =3D 0x80000000; + + resulth =3D 0xd4321123; + resultl =3D 0x06; + resultdsp =3D 0x01; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsq_sa.l.w $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbl.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbl.c new file mode 100644 index 0000000..94e2bf6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbl.c @@ -0,0 +1,27 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x04; + resultl =3D 0xFFFFFEE5; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsu.h.qbl $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbr.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbr.c new file mode 100644 index 0000000..a1e6635 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_dpsu_h_qbr.c @@ -0,0 +1,27 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x04; + resultl =3D 0xFFFFE233; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsu.h.qbr $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extp.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_extp.c new file mode 100644 index 0000000..b18bdb3 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extp.c @@ -0,0 +1,62 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + result =3D 0x000C; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extp %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 14) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x01; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extp %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 14) & 0x01; + assert(dsp =3D=3D 1); + + ach =3D 0; + acl =3D 0x80000001; + dsp =3D 0x1F; + result =3D 0x80000001; + + __asm + ("wrdsp %1\n\t" + "mthi %2, $ac2\n\t" + "mtlo %3, $ac2\n\t" + "extp %0, $ac2, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 14) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdp.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_extpdp.c new file mode 100644 index 0000000..79ee16e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdp.c @@ -0,0 +1,64 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp, pos, efi; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + result =3D 0x000C; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpdp %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + pos =3D dsp & 0x3F; + efi =3D (dsp >> 14) & 0x01; + assert(pos =3D=3D 3); + assert(efi =3D=3D 0); + assert(result =3D=3D rt); + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x01; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpdp %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + efi =3D (dsp >> 14) & 0x01; + assert(efi =3D=3D 1); + + + ach =3D 0; + acl =3D 0; + dsp =3D 0; + result =3D 0; + + __asm + ("wrdsp %1\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpdp %0, $ac1, 0x00\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl) + ); + assert(dsp =3D=3D 0x3F); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdpv.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_extpdpv.c new file mode 100644 index 0000000..f5774ee --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpdpv.c @@ -0,0 +1,47 @@ +#include +#include + +int main() +{ + int rt, rs, ach, acl, dsp, pos, efi; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + rs =3D 0x03; + result =3D 0x000C; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpdpv %0, $ac1, %4\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl), "r"(rs) + ); + pos =3D dsp & 0x3F; + efi =3D (dsp >> 14) & 0x01; + assert(pos =3D=3D 3); + assert(efi =3D=3D 0); + assert(result =3D=3D rt); + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x01; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpdpv %0, $ac1, %4\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl), "r"(rs) + ); + efi =3D (dsp >> 14) & 0x01; + assert(efi =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpv.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_extpv.c new file mode 100644 index 0000000..401b94a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extpv.c @@ -0,0 +1,45 @@ +#include +#include + +int main() +{ + int rt, ac, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + ac =3D 0x03; + result =3D 0x000C; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpv %0, $ac1, %4\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl), "r"(ac) + ); + dsp =3D (dsp >> 14) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x01; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extpv %0, $ac1, %4\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(ach), "r"(acl), "r"(ac) + ); + dsp =3D (dsp >> 14) & 0x01; + assert(dsp =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_r_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_extr_r_w.c new file mode 100644 index 0000000..489c193 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_r_w.c @@ -0,0 +1,94 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + result =3D 0xA0001699; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_r.w %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4D; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_r.w %0, $ac1, 0x04\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_r.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0xFFFFFFFF; + acl =3D 0xFFFFFFFF; + result =3D 0; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_r.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_rs_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_extr_rs_w.c new file mode 100644 index 0000000..f9d2ed6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_rs_w.c @@ -0,0 +1,117 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + result =3D 0x7FFFFFFF; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_rs.w %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4D; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_rs.w %0, $ac1, 0x04\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_rs.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x80000000; + acl =3D 0x00000000; + result =3D 0x80000000; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_rs.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0xFFFFFFFF; + acl =3D 0xFFFFFFFF; + result =3D 0; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_rs.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_s_h.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_extr_s_h.c new file mode 100644 index 0000000..9bc2a63 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_s_h.c @@ -0,0 +1,86 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + result =3D 0x00007FFF; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_s.h %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + ach =3D 0xffffffff; + acl =3D 0x12344321; + result =3D 0xFFFF8000; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_s.h %0, $ac1, 0x08\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dsp */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x00; + acl =3D 0x4321; + result =3D 0x432; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_s.h %0, $ac1, 0x04\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dsp */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x123; + acl =3D 0x87654321; + result =3D 0x1238; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr_s.h %0, $ac1, 28\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_w.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_extr_w.c new file mode 100644 index 0000000..cf92614 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extr_w.c @@ -0,0 +1,94 @@ +#include +#include + +int main() +{ + int rt, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + result =3D 0xA0001699; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr.w %0, $ac1, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4C; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr.w %0, $ac1, 0x04\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + ach =3D 0xFFFFFFFF; + acl =3D 0xFFFFFFFF; + result =3D 0xFFFFFFFF; + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "extr.w %0, $ac1, 0x1F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "=3Dr"(dsp) + : "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_r_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_extrv_r_w.c new file mode 100644 index 0000000..2403b3a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_r_w.c @@ -0,0 +1,79 @@ +#include +#include + +int main() +{ + int rt, rs, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + rs =3D 0x03; + result =3D 0xA0001699; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_r.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 4; + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4D; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_r.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 31; + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_r.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_rs_w.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_extrv_rs_w.c new file mode 100644 index 0000000..ccceeb9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_rs_w.c @@ -0,0 +1,77 @@ +#include +#include + +int main() +{ + int rt, rs, ach, acl, dsp; + int result; + + rs =3D 0x03; + ach =3D 0x05; + acl =3D 0xB4CB; + result =3D 0x7FFFFFFF; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_rs.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 0x04; + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4D; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_rs.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 0x1F; + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_rs.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_s_h.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_extrv_s_h.c new file mode 100644 index 0000000..feac3e2 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_s_h.c @@ -0,0 +1,88 @@ +#include +#include + +int main() +{ + int rt, rs, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + rs =3D 0x03; + result =3D 0x00007FFF; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_s.h %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + rs =3D 0x08; + ach =3D 0xffffffff; + acl =3D 0x12344321; + result =3D 0xFFFF8000; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_s.h %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dsp */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 0x04; + ach =3D 0x00; + acl =3D 0x4321; + result =3D 0x432; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_s.h %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + rs =3D 0x1C; + ach =3D 0x123; + acl =3D 0x87654321; + result =3D 0x1238; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv_s.h %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_w.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_extrv_w.c new file mode 100644 index 0000000..9e8b238 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_extrv_w.c @@ -0,0 +1,80 @@ +#include +#include + +int main() +{ + int rt, rs, ach, acl, dsp; + int result; + + ach =3D 0x05; + acl =3D 0xB4CB; + dsp =3D 0x07; + rs =3D 0x03; + result =3D 0xA0001699; + + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 4; + ach =3D 0x01; + acl =3D 0xB4CB; + result =3D 0x10000B4C; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + /* Clear dspcontrol */ + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 31; + ach =3D 0x3fffffff; + acl =3D 0x2bcdef01; + result =3D 0x7ffffffe; + __asm + ("wrdsp %1, 0x01\n\t" + "mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "extrv.w %0, $ac1, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(rt), "+r"(dsp) + : "r"(rs), "r"(ach), "r"(acl) + ); + dsp =3D (dsp >> 23) & 0x01; + assert(dsp =3D=3D 0); + assert(result =3D=3D rt); + + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_insv.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_insv.c new file mode 100644 index 0000000..9d67469 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_insv.c @@ -0,0 +1,36 @@ +#include +#include + +int main() +{ + int rt, rs, dsp; + int result; + + /* msb =3D 10, lsb =3D 5 */ + dsp =3D 0x305; + rt =3D 0x12345678; + rs =3D 0x87654321; + result =3D 0x12345438; + __asm + ("wrdsp %2, 0x03\n\t" + "insv %0, %1\n\t" + : "+r"(rt) + : "r"(rs), "r"(dsp) + ); + assert(rt =3D=3D result); + + dsp =3D 0x1000; + rt =3D 0xF0F0F0F0; + rs =3D 0xA5A5A5A5; + result =3D 0xA5A5A5A5; + + __asm + ("wrdsp %2\n\t" + "insv %0, %1\n\t" + : "+r"(rt) + : "r"(rs), "r"(dsp) + ); + assert(rt =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lbux.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_lbux.c new file mode 100644 index 0000000..2337abe --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lbux.c @@ -0,0 +1,25 @@ +#include +#include + +int main(void) +{ + int value, rd; + int *p; + unsigned long addr, index; + int result; + + value =3D 0xBCDEF389; + p =3D &value; + addr =3D (unsigned long)p; + index =3D 0; + result =3D value & 0xFF; + __asm + ("lbux %0, %1(%2)\n\t" + : "=3Dr"(rd) + : "r"(index), "r"(addr) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lhx.c b/tests/tcg/mips= /user/ase/dsp/test_dsp_r1_lhx.c new file mode 100644 index 0000000..10be3b3 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lhx.c @@ -0,0 +1,25 @@ +#include +#include + +int main(void) +{ + int value, rd; + int *p; + unsigned long addr, index; + int result; + + value =3D 0xBCDEF389; + p =3D &value; + addr =3D (unsigned long)p; + index =3D 0; + result =3D 0xFFFFF389; + __asm + ("lhx %0, %1(%2)\n\t" + : "=3Dr"(rd) + : "r"(index), "r"(addr) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lwx.c b/tests/tcg/mips= /user/ase/dsp/test_dsp_r1_lwx.c new file mode 100644 index 0000000..e6543c9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_lwx.c @@ -0,0 +1,25 @@ +#include +#include + +int main(void) +{ + int value, rd; + int *p; + unsigned long addr, index; + int result; + + value =3D 0xBCDEF389; + p =3D &value; + addr =3D (unsigned long)p; + index =3D 0; + result =3D 0xBCDEF389; + __asm + ("lwx %0, %1(%2)\n\t" + : "=3Dr"(rd) + : "r"(index), "r"(addr) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_madd.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_madd.c new file mode 100644 index 0000000..af4bfcf --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_madd.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int acho, aclo; + int resulth, resultl; + + achi =3D 0x05; + acli =3D 0xB4CB; + rs =3D 0x01; + rt =3D 0x01; + resulth =3D 0x05; + resultl =3D 0xB4CC; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "madd $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maddu.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_maddu.c new file mode 100644 index 0000000..af4bfcf --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maddu.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int acho, aclo; + int resulth, resultl; + + achi =3D 0x05; + acli =3D 0xB4CB; + rs =3D 0x01; + rt =3D 0x01; + resulth =3D 0x05; + resultl =3D 0xB4CC; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "madd $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_main.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_main.c new file mode 100644 index 0000000..b296b20 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_main.c @@ -0,0 +1,6 @@ +#include + +int main() +{ + printf("hello world\n"); +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phl.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phl.c new file mode 100644 index 0000000..0f7c070 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phl.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int dsp; + int acho, aclo; + int resulth, resultl; + int resdsp; + + achi =3D 0x00000005; + acli =3D 0x0000B4CB; + rs =3D 0xFF060000; + rt =3D 0xCB000000; + resulth =3D 0x00000005; + resultl =3D 0x006838CB; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "maq_s.w.phl $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + achi =3D 0x00000006; + acli =3D 0x0000B4CB; + rs =3D 0x80000000; + rt =3D 0x80000000; + resulth =3D 0x00000006; + resultl =3D 0x8000B4CA; + resdsp =3D 1; + + __asm + ("mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "maq_s.w.phl $ac1, %5, %6\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + assert(((dsp >> 17) & 0x01) =3D=3D resdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phr.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phr.c new file mode 100644 index 0000000..942722a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_s_w_phr.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int dsp; + int acho, aclo; + int resulth, resultl; + int resdsp; + + achi =3D 0x00000005; + acli =3D 0x0000B4CB; + rs =3D 0x0000FF06; + rt =3D 0x0000CB00; + resulth =3D 0x00000005; + resultl =3D 0x006838CB; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "maq_s.w.phr $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + achi =3D 0x00000006; + acli =3D 0x0000B4CB; + rs =3D 0x00008000; + rt =3D 0x00008000; + resulth =3D 0x00000006; + resultl =3D 0x8000B4CA; + resdsp =3D 1; + + __asm + ("mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "maq_s.w.phr $ac1, %5, %6\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + assert(((dsp >> 17) & 0x01) =3D=3D resdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phl.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phl.c new file mode 100644 index 0000000..d83dce6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phl.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int dsp; + int acho, aclo; + int resulth, resultl; + int resdsp; + + achi =3D 0x00000000; + acli =3D 0x0000B4CB; + rs =3D 0xFF060000; + rt =3D 0xCB000000; + resulth =3D 0x00000000; + resultl =3D 0x006838CB; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "maq_sa.w.phl $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + achi =3D 0x00000000; + acli =3D 0x0000B4CB; + rs =3D 0x80000000; + rt =3D 0x80000000; + resulth =3D 0x00; + resultl =3D 0x7fffffff; + resdsp =3D 0x01; + + __asm + ("mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "maq_sa.w.phl $ac1, %5, %6\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + assert(((dsp >> 17) & 0x01) =3D=3D 0x01); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phr.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phr.c new file mode 100644 index 0000000..d233111 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_maq_sa_w_phr.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rt, rs; + int achi, acli; + int dsp; + int acho, aclo; + int resulth, resultl; + int resdsp; + + achi =3D 0x00000000; + acli =3D 0x0000B4CB; + rs =3D 0x0000FF06; + rt =3D 0x0000CB00; + resulth =3D 0x00000000; + resultl =3D 0x006838CB; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "maq_sa.w.phr $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + + achi =3D 0x00000000; + acli =3D 0x0000B4CB; + rs =3D 0x00008000; + rt =3D 0x00008000; + resulth =3D 0x00000000; + resultl =3D 0x7FFFFFFF; + resdsp =3D 0x01; + + __asm + ("mthi %3, $ac1\n\t" + "mtlo %4, $ac1\n\t" + "maq_sa.w.phr $ac1, %5, %6\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(resulth =3D=3D acho); + assert(resultl =3D=3D aclo); + assert(((dsp >> 17) & 0x01) =3D=3D 0x01); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mfhi.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_mfhi.c new file mode 100644 index 0000000..43a8066 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mfhi.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int achi, acho; + int result; + + achi =3D 0x004433; + result =3D 0x004433; + + __asm + ("mthi %1, $ac1\n\t" + "mfhi %0, $ac1\n\t" + : "=3Dr"(acho) + : "r"(achi) + ); + assert(result =3D=3D acho); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mflo.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_mflo.c new file mode 100644 index 0000000..caeafdb --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mflo.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int acli, aclo; + int result; + + acli =3D 0x004433; + result =3D 0x004433; + + __asm + ("mthi %1, $ac1\n\t" + "mfhi %0, $ac1\n\t" + : "=3Dr"(aclo) + : "r"(acli) + ); + assert(result =3D=3D aclo); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_modsub.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_modsub.c new file mode 100644 index 0000000..c294eeb --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_modsub.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0xFFFFFFFF; + rt =3D 0x000000FF; + result =3D 0xFFFFFF00; + __asm + ("modsub %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + rs =3D 0x00000000; + rt =3D 0x00CD1FFF; + result =3D 0x0000CD1F; + __asm + ("modsub %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_msub.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_msub.c new file mode 100644 index 0000000..5779e6f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_msub.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int achi, acli, rs, rt; + int acho, aclo; + int resulth, resultl; + + rs =3D 0x00BBAACC; + rt =3D 0x0B1C3D2F; + achi =3D 0x00004433; + acli =3D 0xFFCC0011; + resulth =3D 0xFFF81F29; + resultl =3D 0xB355089D; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "msub $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(acho =3D=3D resulth); + assert(aclo =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_msubu.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_msubu.c new file mode 100644 index 0000000..e0f9b5a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_msubu.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int achi, acli, rs, rt; + int acho, aclo; + int resulth, resultl; + + rs =3D 0x00BBAACC; + rt =3D 0x0B1C3D2F; + achi =3D 0x00004433; + acli =3D 0xFFCC0011; + resulth =3D 0xFFF81F29; + resultl =3D 0xB355089D; + + __asm + ("mthi %2, $ac1\n\t" + "mtlo %3, $ac1\n\t" + "msubu $ac1, %4, %5\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(acho), "=3Dr"(aclo) + : "r"(achi), "r"(acli), "r"(rs), "r"(rt) + ); + assert(acho =3D=3D resulth); + assert(aclo =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthi.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_mthi.c new file mode 100644 index 0000000..43a8066 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthi.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int achi, acho; + int result; + + achi =3D 0x004433; + result =3D 0x004433; + + __asm + ("mthi %1, $ac1\n\t" + "mfhi %0, $ac1\n\t" + : "=3Dr"(acho) + : "r"(achi) + ); + assert(result =3D=3D acho); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthlip.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_mthlip.c new file mode 100644 index 0000000..85f94d8 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mthlip.c @@ -0,0 +1,58 @@ +#include +#include + +int main() +{ + int rs, ach, acl, dsp; + int result, resulth, resultl; + + dsp =3D 0x07; + ach =3D 0x05; + acl =3D 0xB4CB; + rs =3D 0x00FFBBAA; + resulth =3D 0xB4CB; + resultl =3D 0x00FFBBAA; + result =3D 0x27; + + __asm + ("wrdsp %0, 0x01\n\t" + "mthi %1, $ac1\n\t" + "mtlo %2, $ac1\n\t" + "mthlip %3, $ac1\n\t" + "mfhi %1, $ac1\n\t" + "mflo %2, $ac1\n\t" + "rddsp %0\n\t" + : "+r"(dsp), "+r"(ach), "+r"(acl) + : "r"(rs) + ); + dsp =3D dsp & 0x3F; + assert(dsp =3D=3D result); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + dsp =3D 0x1f; + ach =3D 0x05; + acl =3D 0xB4CB; + rs =3D 0x00FFBBAA; + resulth =3D 0xB4CB; + resultl =3D 0x00FFBBAA; + result =3D 0x3f; + + __asm + ("wrdsp %0, 0x01\n\t" + "mthi %1, $ac1\n\t" + "mtlo %2, $ac1\n\t" + "mthlip %3, $ac1\n\t" + "mfhi %1, $ac1\n\t" + "mflo %2, $ac1\n\t" + "rddsp %0\n\t" + : "+r"(dsp), "+r"(ach), "+r"(acl) + : "r"(rs) + ); + dsp =3D dsp & 0x3F; + assert(dsp =3D=3D result); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mtlo.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_mtlo.c new file mode 100644 index 0000000..caeafdb --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mtlo.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int acli, aclo; + int result; + + acli =3D 0x004433; + result =3D 0x004433; + + __asm + ("mthi %1, $ac1\n\t" + "mfhi %0, $ac1\n\t" + : "=3Dr"(aclo) + : "r"(acli) + ); + assert(result =3D=3D aclo); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phl.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phl.c new file mode 100644 index 0000000..b3a5370 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phl.c @@ -0,0 +1,41 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80001234; + rt =3D 0x80001234; + result =3D 0x7FFFFFFF; + resultdsp =3D 1; + + __asm + ("muleq_s.w.phl %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + rs =3D 0x12349988; + rt =3D 0x43219988; + result =3D 0x98be968; + resultdsp =3D 1; + + __asm + ("muleq_s.w.phl %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} + diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phr.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phr.c new file mode 100644 index 0000000..8066d7d --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleq_s_w_phr.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x8000; + rt =3D 0x8000; + result =3D 0x7FFFFFFF; + resultdsp =3D 1; + + __asm + ("muleq_s.w.phr %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + rs =3D 0x1234; + rt =3D 0x4321; + result =3D 0x98be968; + resultdsp =3D 1; + + __asm + ("muleq_s.w.phr %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbl.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbl.c new file mode 100644 index 0000000..66a3828 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbl.c @@ -0,0 +1,25 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80001234; + rt =3D 0x80004321; + result =3D 0xFFFF0000; + resultdsp =3D 1; + + __asm + ("muleu_s.ph.qbl %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbr.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbr.c new file mode 100644 index 0000000..4cc6c8f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_muleu_s_ph_qbr.c @@ -0,0 +1,25 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x8000; + rt =3D 0x80004321; + result =3D 0xFFFF0000; + resultdsp =3D 1; + + __asm + ("muleu_s.ph.qbr %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mulq_rs_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_mulq_rs_ph.c new file mode 100644 index 0000000..370c2a8 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mulq_rs_ph.c @@ -0,0 +1,42 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80001234; + rt =3D 0x80004321; + result =3D 0x7FFF098C; + resultdsp =3D 1; + + __asm + ("wrdsp $0\n\t" + "mulq_rs.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + rs =3D 0x80011234; + rt =3D 0x80024321; + result =3D 0x7FFD098C; + resultdsp =3D 0; + + __asm + ("wrdsp $0\n\t" + "mulq_rs.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mult.c b/tests/tcg/mip= s/user/ase/dsp/test_dsp_r1_mult.c new file mode 100644 index 0000000..15e6fde --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_mult.c @@ -0,0 +1,24 @@ +#include +#include + +int main() +{ + int rs, rt, ach, acl; + int result, resulth, resultl; + + rs =3D 0x00FFBBAA; + rt =3D 0x4B231000; + resulth =3D 0x4b0f01; + resultl =3D 0x71f8a000; + __asm + ("mult $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(ach), "=3Dr"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_multu.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_multu.c new file mode 100644 index 0000000..85d36c1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_multu.c @@ -0,0 +1,24 @@ +#include +#include + +int main() +{ + int rs, rt, ach, acl; + int result, resulth, resultl; + + rs =3D 0x00FFBBAA; + rt =3D 0x4B231000; + resulth =3D 0x4b0f01; + resultl =3D 0x71f8a000; + __asm + ("multu $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "=3Dr"(ach), "=3Dr"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_packrl_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_packrl_ph.c new file mode 100644 index 0000000..1f8e699 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_packrl_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x56788765; + + __asm + ("packrl.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_pick_ph.c new file mode 100644 index 0000000..929a002 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_ph.c @@ -0,0 +1,49 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + dsp =3D 0x0A000000; + result =3D 0x12344321; + + __asm + ("wrdsp %3, 0x10\n\t" + "pick.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dsp) + ); + assert(rd =3D=3D result); + + rs =3D 0x12345678; + rt =3D 0x87654321; + dsp =3D 0x03000000; + result =3D 0x12345678; + + __asm + ("wrdsp %3, 0x10\n\t" + "pick.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dsp) + ); + assert(rd =3D=3D result); + + rs =3D 0x12345678; + rt =3D 0x87654321; + dsp =3D 0x00000000; + result =3D 0x87654321; + + __asm + ("wrdsp %3, 0x10\n\t" + "pick.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dsp) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_pick_qb.c new file mode 100644 index 0000000..a790475 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_pick_qb.c @@ -0,0 +1,36 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + dsp =3D 0x0f000000; + result =3D 0x12345678; + + __asm + ("wrdsp %3, 0x10\n\t" + "pick.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dsp) + ); + assert(rd =3D=3D result); + + rs =3D 0x12345678; + rt =3D 0x87654321; + dsp =3D 0x00000000; + result =3D 0x87654321; + + __asm + ("wrdsp %3, 0x10\n\t" + "pick.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt), "r"(dsp) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phl.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phl.c new file mode 100644 index 0000000..bf70bf7 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phl.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x87650000; + + __asm + ("preceq.w.phl %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phr.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phr.c new file mode 100644 index 0000000..3f885ef --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceq_w_phr.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x43210000; + + __asm + ("preceq.w.phr %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbl.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbl.c new file mode 100644 index 0000000..63b7a95 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbl.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x43803280; + + __asm + ("precequ.ph.qbl %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbla.c b/te= sts/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbla.c new file mode 100644 index 0000000..31627f0 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbla.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x43802180; + + __asm + ("precequ.ph.qbla %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbr.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbr.c new file mode 100644 index 0000000..b6f72d3 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbr.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x21801080; + + __asm + ("precequ.ph.qbr %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbra.c b/te= sts/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbra.c new file mode 100644 index 0000000..4764fd0 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precequ_ph_qbra.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x32801080; + + __asm + ("precequ.ph.qbra %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbl.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbl.c new file mode 100644 index 0000000..fa95c26 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbl.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x00870065; + + __asm + ("preceu.ph.qbl %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbla.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbla.c new file mode 100644 index 0000000..021f21a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbla.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x00870043; + + __asm + ("preceu.ph.qbla %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbr.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbr.c new file mode 100644 index 0000000..03df18c --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbr.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x00430021; + + __asm + ("preceu.ph.qbr %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbra.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbra.c new file mode 100644 index 0000000..6343276 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_preceu_ph_qbra.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0x00650021; + + __asm + ("preceu.ph.qbra %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_ph_w.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r1_precrq_ph_w.c new file mode 100644 index 0000000..25d45f1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_ph_w.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x12348765; + + __asm + ("precrq.ph.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_qb_ph.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r1_precrq_qb_ph.c new file mode 100644 index 0000000..fe23acc --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_qb_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x12568743; + + __asm + ("precrq.qb.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_rs_ph_w.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_rs_ph_w.c new file mode 100644 index 0000000..da6845b --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrq_rs_ph_w.c @@ -0,0 +1,51 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x12348765; + + __asm + ("wrdsp $0\n\t" + "precrq_rs.ph.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + rs =3D 0x7FFFC678; + rt =3D 0x865432A0; + result =3D 0x7FFF8654; + + __asm + ("wrdsp $0\n\t" + "precrq_rs.ph.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(((dsp >> 22) & 0x01) =3D=3D 1); + assert(result =3D=3D rd); + + rs =3D 0xBEEFFEED; + rt =3D 0x7FFF8000; + result =3D 0xBEF07FFF; + + __asm + ("wrdsp $0\n\t" + "precrq_rs.ph.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(((dsp >> 22) & 0x01) =3D=3D 1); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrqu_s_qb_ph.c b/te= sts/tcg/mips/user/ase/dsp/test_dsp_r1_precrqu_s_qb_ph.c new file mode 100644 index 0000000..7481d5a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_precrqu_s_qb_ph.c @@ -0,0 +1,24 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x12345678; + rt =3D 0x87657FFF; + result =3D 0x24AC00FF; + + __asm + ("precrqu_s.qb.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + assert(((dsp >> 22) & 0x01) =3D=3D 0x01); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_raddu_w_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_raddu_w_qb.c new file mode 100644 index 0000000..77a983c --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_raddu_w_qb.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rs; + int result; + + rs =3D 0x12345678; + result =3D 0x114; + + __asm + ("raddu.w.qb %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_rddsp.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_rddsp.c new file mode 100644 index 0000000..2f30285 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_rddsp.c @@ -0,0 +1,46 @@ +#include +#include + +int main() +{ + int dsp_i, dsp_o; + int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; + int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; + + ccond_i =3D 0x0000000C; /* 4 */ + outflag_i =3D 0x0000001B; /* 3 */ + efi_i =3D 0x00000001; /* 5 */ + c_i =3D 0x00000001; /* 2 */ + scount_i =3D 0x0000000F; /* 1 */ + pos_i =3D 0x0000000C; /* 0 */ + + dsp_i =3D (ccond_i << 24) | \ + (outflag_i << 16) | \ + (efi_i << 14) | \ + (c_i << 13) | \ + (scount_i << 7) | \ + pos_i; + + __asm + ("wrdsp %1, 0x3F\n\t" + "rddsp %0, 0x3F\n\t" + : "=3Dr"(dsp_o) + : "r"(dsp_i) + ); + + ccond_o =3D (dsp_o >> 24) & 0xFF; + outflag_o =3D (dsp_o >> 16) & 0xFF; + efi_o =3D (dsp_o >> 14) & 0x01; + c_o =3D (dsp_o >> 14) & 0x01; + scount_o =3D (dsp_o >> 7) & 0x3F; + pos_o =3D dsp_o & 0x1F; + + assert(ccond_o =3D=3D ccond_i); + assert(outflag_o =3D=3D outflag_i); + assert(efi_o =3D=3D efi_i); + assert(c_o =3D=3D c_i); + assert(scount_o =3D=3D scount_i); + assert(pos_o =3D=3D pos_i); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_repl_ph.c new file mode 100644 index 0000000..2107495 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_ph.c @@ -0,0 +1,23 @@ +#include +#include + +int main() +{ + int rd, result; + + result =3D 0x01BF01BF; + __asm + ("repl.ph %0, 0x1BF\n\t" + : "=3Dr"(rd) + ); + assert(rd =3D=3D result); + + result =3D 0x01FF01FF; + __asm + ("repl.ph %0, 0x01FF\n\t" + : "=3Dr"(rd) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_repl_qb.c new file mode 100644 index 0000000..6631393 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_repl_qb.c @@ -0,0 +1,16 @@ +#include +#include + +int main() +{ + int rd, result; + + result =3D 0xBFBFBFBF; + __asm + ("repl.qb %0, 0xBF\n\t" + : "=3Dr"(rd) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_replv_ph.c new file mode 100644 index 0000000..07fb15f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_ph.c @@ -0,0 +1,19 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x56785678; + __asm + ("replv.ph %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_replv_qb.c new file mode 100644 index 0000000..dd1271f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_replv_qb.c @@ -0,0 +1,19 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x78787878; + __asm + ("replv.qb %0, %1\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilo.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_shilo.c new file mode 100644 index 0000000..ce8ebc6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilo.c @@ -0,0 +1,45 @@ +#include +#include + +int main() +{ + int ach, acl; + int resulth, resultl; + + ach =3D 0xBBAACCFF; + acl =3D 0x1C3B001D; + + resulth =3D 0x17755; + resultl =3D 0x99fe3876; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "shilo $ac1, 0x0F\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + + ach =3D 0x1; + acl =3D 0x80000000; + + resulth =3D 0x3; + resultl =3D 0x0; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "shilo $ac1, -1\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilov.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r1_shilov.c new file mode 100644 index 0000000..e1d6cea --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shilov.c @@ -0,0 +1,49 @@ +#include +#include + +int main() +{ + int rs, ach, acl; + int resulth, resultl; + + rs =3D 0x0F; + ach =3D 0xBBAACCFF; + acl =3D 0x1C3B001D; + + resulth =3D 0x17755; + resultl =3D 0x99fe3876; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "shilov $ac1, %2\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + + rs =3D 0xffffffff; + ach =3D 0x1; + acl =3D 0x80000000; + + resulth =3D 0x3; + resultl =3D 0x0; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "shilov $ac1, %2\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_shll_ph.c new file mode 100644 index 0000000..5fa58cc --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_ph.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rd, rt, dsp; + int result, resultdsp; + + rt =3D 0x12345678; + result =3D 0xA000C000; + resultdsp =3D 1; + + __asm + ("wrdsp $0\n\t" + "shll.ph %0, %2, 0x0B\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x7fff8000; + result =3D 0xfffe0000; + resultdsp =3D 1; + + __asm + ("wrdsp $0\n\t" + "shll.ph %0, %2, 0x01\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x00000001; + result =3D 0x00008000; + resultdsp =3D 1; + + __asm + ("wrdsp $0\n\t" + "shll.ph %0, %2, 0x0F\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_shll_qb.c new file mode 100644 index 0000000..729716d --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_qb.c @@ -0,0 +1,55 @@ +#include +#include + +int main() +{ + int rd, rt, dsp; + int result, resultdsp; + + rt =3D 0x87654321; + result =3D 0x87654321; + resultdsp =3D 0x00; + + __asm + ("wrdsp $0\n\t" + "shll.qb %0, %2, 0x00\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0x38281808; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "shll.qb %0, %2, 0x03\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x00000001; + result =3D 0x00000080; + resultdsp =3D 0x00; + + __asm + ("wrdsp $0\n\t" + "shll.qb %0, %2, 0x07\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_shll_s_ph.c new file mode 100644 index 0000000..910fea3 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_ph.c @@ -0,0 +1,24 @@ +#include +#include + +int main() +{ + int rd, rt, dsp; + int result, resultdsp; + + rt =3D 0x12345678; + result =3D 0x7FFF7FFF; + resultdsp =3D 0x01; + + __asm + ("shll_s.ph %0, %2, 0x0B\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shll_s_w.c new file mode 100644 index 0000000..628c752 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shll_s_w.c @@ -0,0 +1,52 @@ +#include +#include + +int main() +{ + int rd, rt, dsp; + int result, resultdsp; + + rt =3D 0x82345678; + result =3D 0x82345678; + resultdsp =3D 0x00; + + __asm + ("shll_s.w %0, %2, 0x0\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x82345678; + result =3D 0x80000000; + resultdsp =3D 0x01; + + __asm + ("shll_s.w %0, %2, 0x0B\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rt =3D 0x12345678; + result =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + + __asm + ("shll_s.w %0, %2, 0x0B\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shllv_ph.c new file mode 100644 index 0000000..f98a632 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_ph.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x0; + rt =3D 0x12345678; + result =3D 0x12345678; + resultdsp =3D 0; + + __asm + ("shllv.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x0B; + rt =3D 0x12345678; + result =3D 0xA000C000; + resultdsp =3D 1; + + __asm + ("shllv.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shllv_qb.c new file mode 100644 index 0000000..6d8ff4a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_qb.c @@ -0,0 +1,38 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0x38281808; + resultdsp =3D 0x01; + + __asm + ("shllv.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(rd =3D=3D result); + + rs =3D 0x00; + rt =3D 0x87654321; + result =3D 0x87654321; + resultdsp =3D 0x01; + + __asm + ("shllv.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_shllv_s_ph.c new file mode 100644 index 0000000..fc9bd32 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_ph.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x0; + rt =3D 0x12345678; + result =3D 0x12345678; + resultdsp =3D 0x0; + + __asm + ("shllv_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x0B; + rt =3D 0x12345678; + result =3D 0x7FFF7FFF; + resultdsp =3D 0x01; + + __asm + ("shllv_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_shllv_s_w.c new file mode 100644 index 0000000..350c256 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shllv_s_w.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x0B; + rt =3D 0x12345678; + result =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + + __asm + ("shllv_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x0; + rt =3D 0x12345678; + result =3D 0x12345678; + resultdsp =3D 0x01; + + __asm + ("shllv_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rt), "r"(rs) + ); + dsp =3D (dsp >> 22) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_shra_ph.c new file mode 100644 index 0000000..5b2d840 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_ph.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0xF0EC0864; + + __asm + ("shra.ph %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0x87654321; + + __asm + ("shra.ph %0, %1, 0x00\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_shra_r_ph.c new file mode 100644 index 0000000..adc4ae6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_ph.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0xF0ED0864; + + __asm + ("shra_r.ph %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0x87654321; + + __asm + ("shra_r.ph %0, %1, 0x00\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shra_r_w.c new file mode 100644 index 0000000..ec0cf2c --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shra_r_w.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x87654321; + result =3D 0xF0ECA864; + + __asm + ("shra_r.w %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0x87654321; + + __asm + ("shra_r.w %0, %1, 0x0\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shrav_ph.c new file mode 100644 index 0000000..6e42aaf --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_ph.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0xF0EC0864; + + __asm + ("shrav.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x00; + rt =3D 0x87654321; + result =3D 0x87654321; + + __asm + ("shrav.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r1_shrav_r_ph.c new file mode 100644 index 0000000..f03b978 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_ph.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0xF0ED0864; + + __asm + ("shrav_r.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x00; + rt =3D 0x87654321; + result =3D 0x87654321; + + __asm + ("shrav_r.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_shrav_r_w.c new file mode 100644 index 0000000..2ab03bb --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrav_r_w.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0xF0ECA864; + + __asm + ("shrav_r.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x00; + rt =3D 0x40000000; + result =3D 0x40000000; + + __asm + ("shrav_r.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + + assert(rd =3D=3D result); + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrl_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_shrl_qb.c new file mode 100644 index 0000000..a7e4e6a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrl_qb.c @@ -0,0 +1,31 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x00010203; + + __asm + ("shrl.qb %0, %1, 0x05\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x12345678; + result =3D 0x12345678; + + __asm + ("shrl.qb %0, %1, 0x0\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrlv_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_shrlv_qb.c new file mode 100644 index 0000000..db77f6d --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_shrlv_qb.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x05; + rt =3D 0x12345678; + result =3D 0x00010203; + + __asm + ("shrlv.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x00; + rt =3D 0x12345678; + result =3D 0x12345678; + + __asm + ("shrlv.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_subq_ph.c new file mode 100644 index 0000000..fdd7b38 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_ph.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x77777777; + rt =3D 0x67654321; + result =3D 0x10123456; + resultdsp =3D 0x0; + + __asm + ("subq.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x8ACF1357; + resultdsp =3D 0x01; + + __asm + ("subq.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_subq_s_ph.c new file mode 100644 index 0000000..64c89eb --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_ph.c @@ -0,0 +1,58 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x7FFF1357; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "subq_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x12348000; + rt =3D 0x87657000; + result =3D 0x7FFF8000; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "subq_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x12340000; + rt =3D 0x87658000; + result =3D 0x7FFF7FFF; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "subq_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r1_subq_s_w.c new file mode 100644 index 0000000..9d456a9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subq_s_w.c @@ -0,0 +1,74 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "subq_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x66666; + rt =3D 0x55555; + result =3D 0x11111; + resultdsp =3D 0x0; + + __asm + ("wrdsp $0\n\t" + "subq_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x0; + rt =3D 0x80000000; + result =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + + __asm + ("wrdsp $0\n\t" + "subq_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x80000000; + rt =3D 0x80000000; + result =3D 0; + resultdsp =3D 0x00; + + __asm + ("wrdsp $0\n\t" + "subq_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r1_subu_qb.c new file mode 100644 index 0000000..4209096 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_qb.c @@ -0,0 +1,25 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x8BCF1357; + resultdsp =3D 0x01; + + __asm + ("subu.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_s_qb.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r1_subu_s_qb.c new file mode 100644 index 0000000..3d65053 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_subu_s_qb.c @@ -0,0 +1,25 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x00001357; + resultdsp =3D 0x01; + + __asm + ("subu_s.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r1_wrdsp.c b/tests/tcg/mi= ps/user/ase/dsp/test_dsp_r1_wrdsp.c new file mode 100644 index 0000000..dc54943 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r1_wrdsp.c @@ -0,0 +1,46 @@ +#include +#include + +int main() +{ + int dsp_i, dsp_o; + int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; + int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; + + ccond_i =3D 0x000000BC; /* 4 */ + outflag_i =3D 0x0000001B; /* 3 */ + efi_i =3D 0x00000001; /* 5 */ + c_i =3D 0x00000001; /* 2 */ + scount_i =3D 0x0000000F; /* 1 */ + pos_i =3D 0x0000000C; /* 0 */ + + dsp_i =3D (ccond_i << 24) | \ + (outflag_i << 16) | \ + (efi_i << 14) | \ + (c_i << 13) | \ + (scount_i << 7) | \ + pos_i; + + __asm + ("wrdsp %1, 0x3F\n\t" + "rddsp %0, 0x3F\n\t" + : "=3Dr"(dsp_o) + : "r"(dsp_i) + ); + + ccond_o =3D (dsp_o >> 24) & 0xFF; + outflag_o =3D (dsp_o >> 16) & 0xFF; + efi_o =3D (dsp_o >> 14) & 0x01; + c_o =3D (dsp_o >> 14) & 0x01; + scount_o =3D (dsp_o >> 7) & 0x3F; + pos_o =3D dsp_o & 0x1F; + + assert(ccond_o =3D=3D (ccond_i & 0x0F)); + assert(outflag_o =3D=3D outflag_i); + assert(efi_o =3D=3D efi_i); + assert(c_o =3D=3D c_i); + assert(scount_o =3D=3D scount_i); + assert(pos_o =3D=3D pos_i); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_absq_s_qb.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_absq_s_qb.c new file mode 100644 index 0000000..af4683f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_absq_s_qb.c @@ -0,0 +1,35 @@ +#include +#include + +int main() +{ + int input, result, dsp; + int hope; + + input =3D 0x701BA35E; + hope =3D 0x701B5D5E; + + __asm + ("absq_s.qb %0, %1\n\t" + : "=3Dr"(result) + : "r"(input) + ); + assert(result =3D=3D hope); + + + input =3D 0x801BA35E; + hope =3D 0x7F1B5D5E; + + __asm + ("absq_s.qb %0, %2\n\t" + "rddsp %1\n\t" + : "=3Dr"(result), "=3Dr"(dsp) + : "r"(input) + ); + dsp =3D dsp >> 20; + dsp &=3D 0x01; + assert(dsp =3D=3D 1); + assert(result =3D=3D hope); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_addqh_ph.c new file mode 100644 index 0000000..921f0ea --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_ph.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x706A13FE; + rt =3D 0x13065174; + result =3D 0x41B832B9; + __asm + ("addqh.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0x81000100; + rt =3D 0xc2000100; + result =3D 0xa1800100; + __asm + ("addqh.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_addqh_r_ph.c new file mode 100644 index 0000000..213ba37 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_ph.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x706A13FE; + rt =3D 0x13065174; + result =3D 0x41B832B9; + __asm + ("addqh_r.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0x81010100; + rt =3D 0xc2000100; + result =3D 0xa1810100; + __asm + ("addqh_r.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_addqh_r_w.c new file mode 100644 index 0000000..75a75c5 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_r_w.c @@ -0,0 +1,34 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x00000010; + rt =3D 0x00000001; + result =3D 0x00000009; + + __asm + ("addqh_r.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + rs =3D 0xFFFFFFFE; + rt =3D 0x00000001; + result =3D 0x00000000; + + __asm + ("addqh_r.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_w.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_addqh_w.c new file mode 100644 index 0000000..de6926e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addqh_w.c @@ -0,0 +1,34 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x00000010; + rt =3D 0x00000001; + result =3D 0x00000008; + + __asm + ("addqh.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + rs =3D 0xFFFFFFFE; + rt =3D 0x00000001; + result =3D 0xFFFFFFFF; + + __asm + ("addqh.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_addu_ph.c new file mode 100644 index 0000000..1d7a25a --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_ph.c @@ -0,0 +1,33 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x00FF00FF; + rt =3D 0x00010001; + result =3D 0x01000100; + __asm + ("addu.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF1111; + rt =3D 0x00020001; + result =3D 0x00011112; + __asm + ("addu.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_addu_s_ph.c new file mode 100644 index 0000000..979651b --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_addu_s_ph.c @@ -0,0 +1,33 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x00FE00FE; + rt =3D 0x00020001; + result =3D 0x010000FF; + __asm + ("addu_s.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF1111; + rt =3D 0x00020001; + result =3D 0xFFFF1112; + __asm + ("addu_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + assert(((dsp >> 20) & 0x01) =3D=3D 1); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_adduh_qb.c new file mode 100644 index 0000000..a1f5d63 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_qb.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0xFF0055AA; + rt =3D 0x0113421B; + result =3D 0x80094B62; + __asm + ("adduh.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF0FFF; + rt =3D 0x00010111; + result =3D 0x7F800888; + __asm + ("adduh.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_r_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_adduh_r_qb.c new file mode 100644 index 0000000..81e98c1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_adduh_r_qb.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0xFF0055AA; + rt =3D 0x01112211; + result =3D 0x80093C5E; + __asm + ("adduh_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xFFFF0FFF; + rt =3D 0x00010111; + result =3D 0x80800888; + __asm + ("adduh_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_append.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r2_append.c new file mode 100644 index 0000000..9a91e16 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_append.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rs, rt; + int result; + + rs =3D 0xFF0055AA; + rt =3D 0x0113421B; + result =3D 0x02268436; + __asm + ("append %0, %1, 0x01\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + rs =3D 0xFFFF0FFF; + rt =3D 0x00010111; + result =3D 0x0010111F; + __asm + ("append %0, %1, 0x04\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_balign.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r2_balign.c new file mode 100644 index 0000000..537cf04 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_balign.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rs, rt; + int result; + + rs =3D 0xFF0055AA; + rt =3D 0x0113421B; + result =3D 0x13421BFF; + __asm + ("balign %0, %1, 0x01\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + rs =3D 0xFFFF0FFF; + rt =3D 0x00010111; + result =3D 0x11FFFF0F; + __asm + ("balign %0, %1, 0x03\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_eq_qb.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_eq_qb.c new file mode 100644 index 0000000..2d6340d --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_eq_qb.c @@ -0,0 +1,37 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x02; + __asm + ("cmpgdu.eq.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x0F; + __asm + ("cmpgdu.eq.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_le_qb.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_le_qb.c new file mode 100644 index 0000000..a0ecdca --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_le_qb.c @@ -0,0 +1,37 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0F; + __asm + ("cmpgdu.le.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11707066; + result =3D 0x0B; + __asm + ("cmpgdu.le.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_lt_qb.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_lt_qb.c new file mode 100644 index 0000000..dba99e3 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_cmpgdu_lt_qb.c @@ -0,0 +1,37 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int dsp; + int result; + + rs =3D 0x11777066; + rt =3D 0x55AA70FF; + result =3D 0x0D; + __asm + ("cmpgdu.lt.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + rs =3D 0x11777066; + rt =3D 0x11777066; + result =3D 0x00; + __asm + ("cmpgdu.lt.qb %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 24) & 0x0F; + assert(rd =3D=3D result); + assert(dsp =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpa_w_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_dpa_w_ph.c new file mode 100644 index 0000000..fae49f1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpa_w_ph.c @@ -0,0 +1,44 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0x00FF00FF; + rt =3D 0x00010002; + resulth =3D 0x05; + resultl =3D 0x0302; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpa.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 6, acl =3D 7; + rs =3D 0xFFFF00FF; + rt =3D 0xFFFF0002; + resulth =3D 0x06; + resultl =3D 0x206; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpa.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_s_w_ph.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_s_w_ph.c new file mode 100644 index 0000000..ce87830 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_s_w_ph.c @@ -0,0 +1,79 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 5, acl =3D 5; + int resulth, resultl, resultdsp; + + rs =3D 0x800000FF; + rt =3D 0x00018000; + resulth =3D 0x05; + resultl =3D 0x80000202; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaqx_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 5; + acl =3D 5; + rs =3D 0x00FF00FF; + rt =3D 0x00010002; + resulth =3D 0x05; + resultl =3D 0x05FF; + /*********************************************************** + * Because of we set outflag at last time, although this + * time we set nothing, but it is stay the last time value. + **********************************************************/ + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaqx_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 5; + acl =3D 5; + rs =3D 0x800000FF; + rt =3D 0x00028000; + resulth =3D 0x05; + resultl =3D 0x80000400; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaqx_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_sa_w_ph.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_sa_w_ph.c new file mode 100644 index 0000000..d551d64 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpaqx_sa_w_ph.c @@ -0,0 +1,57 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach, acl; + int resulth, resultl, resultdsp; + + ach =3D 0x00000005; + acl =3D 0x00000005; + rs =3D 0x00FF00FF; + rt =3D 0x00010002; + resulth =3D 0x00; + resultl =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + dsp =3D 0; + __asm + ("wrdsp %2\n\t" + "mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaqx_sa.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "+r"(dsp) + : "r"(rs), "r"(rt) + ); + assert(dsp >> (16 + 1) =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x00000009; + acl =3D 0x0000000B; + rs =3D 0x800000FF; + rt =3D 0x00018000; + resulth =3D 0x00; + resultl =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + dsp =3D 0; + __asm + ("wrdsp %2\n\t" + "mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpaqx_sa.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "+r"(dsp) + : "r"(rs), "r"(rt) + ); + assert(dsp >> (16 + 1) =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpax_w_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_dpax_w_ph.c new file mode 100644 index 0000000..514797c --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpax_w_ph.c @@ -0,0 +1,44 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0x00FF00FF; + rt =3D 0x00010002; + resulth =3D 0x05; + resultl =3D 0x0302; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpax.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 6, acl =3D 7; + rs =3D 0xFFFF00FF; + rt =3D 0xFFFF0002; + resulth =3D 0x05; + resultl =3D 0xFFFFFF06; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpax.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dps_w_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_dps_w_ph.c new file mode 100644 index 0000000..f51f9b9 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dps_w_ph.c @@ -0,0 +1,44 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0x00FF00FF; + rt =3D 0x00010002; + resulth =3D 0x04; + resultl =3D 0xFFFFFD08; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dps.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 6, acl =3D 7; + rs =3D 0xFFFF00FF; + rt =3D 0xFFFF0002; + resulth =3D 0x05; + resultl =3D 0xFFFFFE08; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dps.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_s_w_ph.c b/tests= /tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_s_w_ph.c new file mode 100644 index 0000000..e40543f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_s_w_ph.c @@ -0,0 +1,54 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 5, acl =3D 5; + int resulth, resultl, resultdsp; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x00000005; + resultl =3D 0x1CE5E09B; + resultdsp =3D 0x00; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsqx_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x99F13005; + acl =3D 0x51730062; + rs =3D 0x80008000; + rt =3D 0x80008000; + + resulth =3D 0x99F13004; + resultl =3D 0x51730064; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsqx_s.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_sa_w_ph.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_sa_w_ph.c new file mode 100644 index 0000000..7da278e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsqx_sa_w_ph.c @@ -0,0 +1,53 @@ +#include +#include + +int main() +{ + int rs, rt, dsp; + int ach =3D 5, acl =3D 5; + int resulth, resultl, resultdsp; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x00; + resultl =3D 0x7FFFFFFF; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsqx_sa.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + ach =3D 0x8c0b354A; + acl =3D 0xbbc02249; + rs =3D 0x800023AD; + rt =3D 0x01648000; + resulth =3D 0xffffffff; + resultl =3D 0x80000000; + resultdsp =3D 0x01; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsqx_sa.w.ph $ac1, %3, %4\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + "rddsp %2\n\t" + : "+r"(ach), "+r"(acl), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 17) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsx_w_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_dpsx_w_ph.c new file mode 100644 index 0000000..bb49a40 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_dpsx_w_ph.c @@ -0,0 +1,27 @@ +#include +#include + +int main() +{ + int rs, rt; + int ach =3D 5, acl =3D 5; + int resulth, resultl; + + rs =3D 0xBC0123AD; + rt =3D 0x01643721; + resulth =3D 0x05; + resultl =3D 0xE72F050; + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "dpsx.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_ph.c b/tests/tcg/m= ips/user/ase/dsp/test_dsp_r2_mul_ph.c new file mode 100644 index 0000000..c7e9d60 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_ph.c @@ -0,0 +1,47 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x03FB1234; + rt =3D 0x0BCC4321; + result =3D 0xF504F4B4; + resultdsp =3D 1; + + __asm + ("mul.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 0x00210010; + rt =3D 0x00110005; + result =3D 0x2310050; + resultdsp =3D 0; + + __asm + ("mul.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_s_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_mul_s_ph.c new file mode 100644 index 0000000..33da110 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mul_s_ph.c @@ -0,0 +1,62 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x03FB1234; + rt =3D 0x0BCC4321; + result =3D 0x7fff7FFF; + resultdsp =3D 1; + + __asm + ("mul_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + rs =3D 0x7fffff00; + rt =3D 0xff007fff; + result =3D 0x80008000; + resultdsp =3D 1; + + __asm + ("mul_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + dsp =3D 0; + __asm + ("wrdsp %0\n\t" + : + : "r"(dsp) + ); + + rs =3D 0x00320001; + rt =3D 0x00210002; + result =3D 0x06720002; + resultdsp =3D 0; + + __asm + ("mul_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_rs_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_mulq_rs_w.c new file mode 100644 index 0000000..7ba633b --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_rs_w.c @@ -0,0 +1,36 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80001234; + rt =3D 0x80004321; + result =3D 0x7FFFAAAB; + + __asm + ("mulq_rs.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0x80000000; + rt =3D 0x80000000; + result =3D 0x7FFFFFFF; + resultdsp =3D 1; + + __asm + ("mulq_rs.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_mulq_s_ph.c new file mode 100644 index 0000000..00e0155 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_ph.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80000000; + rt =3D 0x0ffc0000; + result =3D 0xF0040000; + resultdsp =3D 0; + + __asm + ("mulq_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + rs =3D 0x80001234; + rt =3D 0x80004321; + result =3D 0x7FFF098B; + resultdsp =3D 1; + + __asm + ("mulq_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_w.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_mulq_s_w.c new file mode 100644 index 0000000..9c2be06 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulq_s_w.c @@ -0,0 +1,36 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x80001234; + rt =3D 0x80004321; + result =3D 0x7FFFAAAB; + + __asm + ("mulq_s.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0x80000000; + rt =3D 0x80000000; + result =3D 0x7FFFFFFF; + resultdsp =3D 1; + + __asm + ("mulq_s.w %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 21) & 0x01; + assert(rd =3D=3D result); + assert(dsp =3D=3D resultdsp); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsa_w_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_mulsa_w_ph.c new file mode 100644 index 0000000..a694093 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsa_w_ph.c @@ -0,0 +1,29 @@ +#include +#include + +int main() +{ + int rs, rt, ach, acl; + int resulth, resultl; + + ach =3D 0x05; + acl =3D 0x00BBDDCC; + rs =3D 0x80001234; + rt =3D 0x80004321; + resulth =3D 0x05; + resultl =3D 0x3BF5E918; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "mulsa.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsaq_s_w_ph.c b/test= s/tcg/mips/user/ase/dsp/test_dsp_r2_mulsaq_s_w_ph.c new file mode 100644 index 0000000..06c91a4 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_mulsaq_s_w_ph.c @@ -0,0 +1,29 @@ +#include +#include + +int main() +{ + int rs, rt, ach, acl; + int resulth, resultl; + + ach =3D 0x05; + acl =3D 0x00BBDDCC; + rs =3D 0x80001234; + rt =3D 0x80004321; + resulth =3D 0x05; + resultl =3D 0x772ff463; + + __asm + ("mthi %0, $ac1\n\t" + "mtlo %1, $ac1\n\t" + "mulsaq_s.w.ph $ac1, %2, %3\n\t" + "mfhi %0, $ac1\n\t" + "mflo %1, $ac1\n\t" + : "+r"(ach), "+r"(acl) + : "r"(rs), "r"(rt) + ); + assert(ach =3D=3D resulth); + assert(acl =3D=3D resultl); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_qb_ph.c b/tests/= tcg/mips/user/ase/dsp/test_dsp_r2_precr_qb_ph.c new file mode 100644 index 0000000..3a2b3fd --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_qb_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x34786521; + + __asm + ("precr.qb.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(result =3D=3D rd); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_ph_w.c b/tes= ts/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_ph_w.c new file mode 100644 index 0000000..5c9baab --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_ph_w.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x43215678; + + __asm + ("precr_sra.ph.w %0, %1, 0x00\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(result =3D=3D rt); + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0xFFFF0000; + + __asm + ("precr_sra.ph.w %0, %1, 0x1F\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_r_ph_w.c b/t= ests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_r_ph_w.c new file mode 100644 index 0000000..6474a10 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_precr_sra_r_ph_w.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x43215678; + + __asm + ("precr_sra_r.ph.w %0, %1, 0x00\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(result =3D=3D rt); + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0xFFFF0000; + + __asm + ("precr_sra_r.ph.w %0, %1, 0x1F\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(result =3D=3D rt); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_prepend.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_prepend.c new file mode 100644 index 0000000..f6bcd47 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_prepend.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x87654321; + __asm + ("prepend %0, %1, 0x00\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0xACF10ECA; + __asm + ("prepend %0, %1, 0x0F\n\t" + : "+r"(rt) + : "r"(rs) + ); + assert(rt =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_qb.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_shra_qb.c new file mode 100644 index 0000000..48193de --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_qb.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x02060A0F; + + __asm + ("shra.qb %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0xF00C0804; + + __asm + ("shra.qb %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_r_qb.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_shra_r_qb.c new file mode 100644 index 0000000..29afa0e --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shra_r_qb.c @@ -0,0 +1,30 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x02070B0F; + + __asm + ("shra_r.qb %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + rt =3D 0x87654321; + result =3D 0xF10D0804; + + __asm + ("shra_r.qb %0, %1, 0x03\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_shrav_qb.c new file mode 100644 index 0000000..b21e1b7 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_qb.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x03; + rt =3D 0x12345678; + result =3D 0x02060A0F; + + __asm + ("shrav.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0xF00C0804; + + __asm + ("shrav.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_r_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_shrav_r_qb.c new file mode 100644 index 0000000..9ea8aa0 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrav_r_qb.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x03; + rt =3D 0x12345678; + result =3D 0x02070B0F; + + __asm + ("shrav_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + rs =3D 0x03; + rt =3D 0x87654321; + result =3D 0xF10D0804; + + __asm + ("shrav_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrl_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_shrl_ph.c new file mode 100644 index 0000000..724b9a7 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrl_ph.c @@ -0,0 +1,20 @@ +#include +#include + +int main() +{ + int rd, rt; + int result; + + rt =3D 0x12345678; + result =3D 0x009102B3; + + __asm + ("shrl.ph %0, %1, 0x05\n\t" + : "=3Dr"(rd) + : "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrlv_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_shrlv_ph.c new file mode 100644 index 0000000..ac79aa6 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_shrlv_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x05; + rt =3D 0x12345678; + result =3D 0x009102B3; + + __asm + ("shrlv.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rt), "r"(rs) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_ph.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_subqh_ph.c new file mode 100644 index 0000000..dbc0967 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x456709AB; + + __asm + ("subqh.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_ph.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_subqh_r_ph.c new file mode 100644 index 0000000..24ef0f1 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_ph.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x456809AC; + + __asm + ("subqh_r.ph %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_w.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_subqh_r_w.c new file mode 100644 index 0000000..d460f86 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_r_w.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x456789AC; + + __asm + ("subqh_r.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_w.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_subqh_w.c new file mode 100644 index 0000000..42be3de --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subqh_w.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0x456789AB; + + __asm + ("subqh.w %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_ph.c b/tests/tcg/= mips/user/ase/dsp/test_dsp_r2_subu_ph.c new file mode 100644 index 0000000..0d39a01 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_ph.c @@ -0,0 +1,40 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x87654321; + rt =3D 0x11111111; + result =3D 0x76543210; + resultdsp =3D 0x00; + + __asm + ("subu.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + rs =3D 0x87654321; + rt =3D 0x12345678; + result =3D 0x7531ECA9; + resultdsp =3D 0x01; + + __asm + ("subu.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_s_ph.c b/tests/tc= g/mips/user/ase/dsp/test_dsp_r2_subu_s_ph.c new file mode 100644 index 0000000..8e4da4f --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subu_s_ph.c @@ -0,0 +1,25 @@ +#include +#include + +int main() +{ + int rd, rs, rt, dsp; + int result, resultdsp; + + rs =3D 0x87654321; + rt =3D 0x12345678; + result =3D 0x75310000; + resultdsp =3D 0x01; + + __asm + ("subu_s.ph %0, %2, %3\n\t" + "rddsp %1\n\t" + : "=3Dr"(rd), "=3Dr"(dsp) + : "r"(rs), "r"(rt) + ); + dsp =3D (dsp >> 20) & 0x01; + assert(dsp =3D=3D resultdsp); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_qb.c b/tests/tcg= /mips/user/ase/dsp/test_dsp_r2_subuh_qb.c new file mode 100644 index 0000000..92cfc76 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_qb.c @@ -0,0 +1,21 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0xC5E7092B; + + __asm + ("subuh.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_r_qb.c b/tests/t= cg/mips/user/ase/dsp/test_dsp_r2_subuh_r_qb.c new file mode 100644 index 0000000..dac81d4 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/test_dsp_r2_subuh_r_qb.c @@ -0,0 +1,32 @@ +#include +#include + +int main() +{ + int rd, rs, rt; + int result; + + rs =3D 0x12345678; + rt =3D 0x87654321; + result =3D 0xC6E80A2C; + + __asm + ("subuh_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + rs =3D 0xBEFC292A; + rt =3D 0x9205C1B4; + result =3D 0x167cb4bb; + + __asm + ("subuh_r.qb %0, %1, %2\n\t" + : "=3Dr"(rd) + : "r"(rs), "r"(rt) + ); + assert(rd =3D=3D result); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_div1.c b/tests/tcg/mi= ps/user/isa/r5900/test_r5900_div1.c new file mode 100644 index 0000000..83dafa0 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_div1.c @@ -0,0 +1,73 @@ +/* + * Test R5900-specific DIV1. + */ + +#include +#include +#include + +struct quotient_remainder { int32_t quotient, remainder; }; + +static struct quotient_remainder div1(int32_t rs, int32_t rt) +{ + int32_t lo, hi; + + __asm__ __volatile__ ( + " div1 $0, %2, %3\n" + " mflo1 %0\n" + " mfhi1 %1\n" + : "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + + assert(rs / rt =3D=3D lo); + assert(rs % rt =3D=3D hi); + + return (struct quotient_remainder) { .quotient =3D lo, .remainder =3D = hi }; +} + +static void verify_div1(int32_t rs, int32_t rt, + int32_t expected_quotient, + int32_t expected_remainder) +{ + struct quotient_remainder qr =3D div1(rs, rt); + + assert(qr.quotient =3D=3D expected_quotient); + assert(qr.remainder =3D=3D expected_remainder); +} + +static void verify_div1_negations(int32_t rs, int32_t rt, + int32_t expected_quotient, + int32_t expected_remainder) +{ + verify_div1(rs, rt, expected_quotient, expected_remainder); + verify_div1(rs, -rt, -expected_quotient, expected_remainder); + verify_div1(-rs, rt, -expected_quotient, -expected_remainder); + verify_div1(-rs, -rt, expected_quotient, -expected_remainder); +} + +int main() +{ + verify_div1_negations(0, 1, 0, 0); + verify_div1_negations(1, 1, 1, 0); + verify_div1_negations(1, 2, 0, 1); + verify_div1_negations(17, 19, 0, 17); + verify_div1_negations(19, 17, 1, 2); + verify_div1_negations(77773, 101, 770, 3); + + verify_div1(-0x80000000, 1, -0x80000000, 0); + + /* + * Supplementary explanation from the Toshiba TX System RISC TX79 Core + * Architecture manual, A-38 and B-7, https://wiki.qemu.org/File:C790.= pdf + * + * Normally, when 0x80000000 (-2147483648) the signed minimum value is + * divided by 0xFFFFFFFF (-1), the operation will result in an overflo= w. + * However, in this instruction an overflow exception doesn't occur and + * the result will be as follows: + * + * Quotient is 0x80000000 (-2147483648), and remainder is 0x00000000 (= 0). + */ + verify_div1(-0x80000000, -1, -0x80000000, 0); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_divu1.c b/tests/tcg/m= ips/user/isa/r5900/test_r5900_divu1.c new file mode 100644 index 0000000..72aeed3 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_divu1.c @@ -0,0 +1,48 @@ +/* + * Test R5900-specific DIVU1. + */ + +#include +#include +#include + +struct quotient_remainder { uint32_t quotient, remainder; }; + +static struct quotient_remainder divu1(uint32_t rs, uint32_t rt) +{ + uint32_t lo, hi; + + __asm__ __volatile__ ( + " divu1 $0, %2, %3\n" + " mflo1 %0\n" + " mfhi1 %1\n" + : "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + + assert(rs / rt =3D=3D lo); + assert(rs % rt =3D=3D hi); + + return (struct quotient_remainder) { .quotient =3D lo, .remainder =3D = hi }; +} + +static void verify_divu1(uint32_t rs, uint32_t rt, + uint32_t expected_quotient, + uint32_t expected_remainder) +{ + struct quotient_remainder qr =3D divu1(rs, rt); + + assert(qr.quotient =3D=3D expected_quotient); + assert(qr.remainder =3D=3D expected_remainder); +} + +int main() +{ + verify_divu1(0, 1, 0, 0); + verify_divu1(1, 1, 1, 0); + verify_divu1(1, 2, 0, 1); + verify_divu1(17, 19, 0, 17); + verify_divu1(19, 17, 1, 2); + verify_divu1(77773, 101, 770, 3); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_madd.c b/tests/tcg/mi= ps/user/isa/r5900/test_r5900_madd.c new file mode 100644 index 0000000..f6f215e --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_madd.c @@ -0,0 +1,78 @@ +/* + * Test R5900-specific three-operand MADD and MADD1. + */ + +#include +#include +#include + +int64_t madd(int64_t a, int32_t rs, int32_t rt) +{ + int32_t lo =3D a; + int32_t hi =3D a >> 32; + int32_t rd; + int64_t r; + + __asm__ __volatile__ ( + " mtlo %5\n" + " mthi %6\n" + " madd %0, %3, %4\n" + " mflo %1\n" + " mfhi %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); + r =3D ((int64_t)hi << 32) | (uint32_t)lo; + + assert(a + (int64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +int64_t madd1(int64_t a, int32_t rs, int32_t rt) +{ + int32_t lo =3D a; + int32_t hi =3D a >> 32; + int32_t rd; + int64_t r; + + __asm__ __volatile__ ( + " mtlo1 %5\n" + " mthi1 %6\n" + " madd1 %0, %3, %4\n" + " mflo1 %1\n" + " mfhi1 %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); + r =3D ((int64_t)hi << 32) | (uint32_t)lo; + + assert(a + (int64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static int64_t madd_variants(int64_t a, int32_t rs, int32_t rt) +{ + int64_t rd =3D madd(a, rs, rt); + int64_t rd1 =3D madd1(a, rs, rt); + + assert(rd =3D=3D rd1); + + return rd; +} + +static void verify_madd(int64_t a, int32_t rs, int32_t rt, int64_t expecte= d) +{ + assert(madd_variants(a, rs, rt) =3D=3D expected); + assert(madd_variants(a, -rs, rt) =3D=3D a + a - expected); + assert(madd_variants(a, rs, -rt) =3D=3D a + a - expected); + assert(madd_variants(a, -rs, -rt) =3D=3D expected); +} + +int main() +{ + verify_madd(13, 17, 19, 336); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_maddu.c b/tests/tcg/m= ips/user/isa/r5900/test_r5900_maddu.c new file mode 100644 index 0000000..30936fb --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_maddu.c @@ -0,0 +1,70 @@ +/* + * Test R5900-specific three-operand MADDU and MADDU1. + */ + +#include +#include +#include + +uint64_t maddu(uint64_t a, uint32_t rs, uint32_t rt) +{ + uint32_t lo =3D a; + uint32_t hi =3D a >> 32; + uint32_t rd; + uint64_t r; + + __asm__ __volatile__ ( + " mtlo %5\n" + " mthi %6\n" + " maddu %0, %3, %4\n" + " mflo %1\n" + " mfhi %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); + r =3D ((uint64_t)hi << 32) | (uint32_t)lo; + + assert(a + (uint64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +uint64_t maddu1(uint64_t a, uint32_t rs, uint32_t rt) +{ + uint32_t lo =3D a; + uint32_t hi =3D a >> 32; + uint32_t rd; + uint64_t r; + + __asm__ __volatile__ ( + " mtlo1 %5\n" + " mthi1 %6\n" + " maddu1 %0, %3, %4\n" + " mflo1 %1\n" + " mfhi1 %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt), "r" (lo), "r" (hi)); + r =3D ((uint64_t)hi << 32) | (uint32_t)lo; + + assert(a + (uint64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static int64_t maddu_variants(int64_t a, int32_t rs, int32_t rt) +{ + int64_t rd =3D maddu(a, rs, rt); + int64_t rd1 =3D maddu1(a, rs, rt); + + assert(rd =3D=3D rd1); + + return rd; +} + +int main() +{ + assert(maddu_variants(13, 17, 19) =3D=3D 336); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_mflohi1.c b/tests/tcg= /mips/user/isa/r5900/test_r5900_mflohi1.c new file mode 100644 index 0000000..eed3683 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_mflohi1.c @@ -0,0 +1,35 @@ +/* + * Test R5900-specific MFLO1 and MFHI1. + */ + +#include +#include +#include + +int main() +{ + int32_t rs =3D 12207031, rt =3D 305175781; + int32_t rs1 =3D 32452867, rt1 =3D 49979687; + int64_t lo, hi, lo1, hi1; + int64_t r, r1; + + /* Test both LO/HI and LO1/HI1 to verify separation. */ + __asm__ __volatile__ ( + " mult $0, %4, %5\n" + " mult1 $0, %6, %7\n" + " mflo %0\n" + " mfhi %1\n" + " mflo1 %2\n" + " mfhi1 %3\n" + : "=3Dr" (lo), "=3Dr" (hi), + "=3Dr" (lo1), "=3Dr" (hi1) + : "r" (rs), "r" (rt), + "r" (rs1), "r" (rt1)); + r =3D ((int64_t)hi << 32) | (uint32_t)lo; + r1 =3D ((int64_t)hi1 << 32) | (uint32_t)lo1; + + assert(r =3D=3D 3725290219116211); + assert(r1 =3D=3D 1621984134912629); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_mtlohi1.c b/tests/tcg= /mips/user/isa/r5900/test_r5900_mtlohi1.c new file mode 100644 index 0000000..7f3e728 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_mtlohi1.c @@ -0,0 +1,40 @@ +/* + * Test R5900-specific MTLO1 and MTHI1. + */ + +#include +#include +#include + +int main() +{ + int32_t tlo =3D 12207031, thi =3D 305175781; + int32_t tlo1 =3D 32452867, thi1 =3D 49979687; + int32_t flo, fhi, flo1, fhi1; + + /* Test both LO/HI and LO1/HI1 to verify separation. */ + __asm__ __volatile__ ( + " mtlo %4\n" + " mthi %5\n" + " mtlo1 %6\n" + " mthi1 %7\n" + " move %0, $0\n" + " move %1, $0\n" + " move %2, $0\n" + " move %3, $0\n" + " mflo %0\n" + " mfhi %1\n" + " mflo1 %2\n" + " mfhi1 %3\n" + : "=3Dr" (flo), "=3Dr" (fhi), + "=3Dr" (flo1), "=3Dr" (fhi1) + : "r" (tlo), "r" (thi), + "r" (tlo1), "r" (thi1)); + + assert(flo =3D=3D 12207031); + assert(fhi =3D=3D 305175781); + assert(flo1 =3D=3D 32452867); + assert(fhi1 =3D=3D 49979687); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_mult.c b/tests/tcg/mi= ps/user/isa/r5900/test_r5900_mult.c new file mode 100644 index 0000000..5710b39 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_mult.c @@ -0,0 +1,76 @@ +/* + * Test R5900-specific three-operand MULT and MULT1. + */ + +#include +#include +#include + +static int64_t mult(int32_t rs, int32_t rt) +{ + int32_t rd, lo, hi; + int64_t r; + + __asm__ __volatile__ ( + " mult %0, %3, %4\n" + " mflo %1\n" + " mfhi %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + r =3D ((int64_t)hi << 32) | (uint32_t)lo; + + assert((int64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static int64_t mult1(int32_t rs, int32_t rt) +{ + int32_t rd, lo, hi; + int64_t r; + + __asm__ __volatile__ ( + " mult1 %0, %3, %4\n" + " mflo1 %1\n" + " mfhi1 %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + r =3D ((int64_t)hi << 32) | (uint32_t)lo; + + assert((int64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static int64_t mult_variants(int32_t rs, int32_t rt) +{ + int64_t rd =3D mult(rs, rt); + int64_t rd1 =3D mult1(rs, rt); + + assert(rd =3D=3D rd1); + + return rd; +} + +static void verify_mult_negations(int32_t rs, int32_t rt, int64_t expected) +{ + assert(mult_variants(rs, rt) =3D=3D expected); + assert(mult_variants(-rs, rt) =3D=3D -expected); + assert(mult_variants(rs, -rt) =3D=3D -expected); + assert(mult_variants(-rs, -rt) =3D=3D expected); +} + +int main() +{ + verify_mult_negations(17, 19, 323); + verify_mult_negations(77773, 99991, 7776600043); + verify_mult_negations(12207031, 305175781, 3725290219116211); + + assert(mult_variants(-0x80000000, 0x7FFFFFFF) =3D=3D -0x3FFFFFFF80000= 000); + assert(mult_variants(-0x80000000, -0x7FFFFFFF) =3D=3D 0x3FFFFFFF80000= 000); + assert(mult_variants(-0x80000000, -0x80000000) =3D=3D 0x4000000000000= 000); + + return 0; +} diff --git a/tests/tcg/mips/user/isa/r5900/test_r5900_multu.c b/tests/tcg/m= ips/user/isa/r5900/test_r5900_multu.c new file mode 100644 index 0000000..f043904 --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/test_r5900_multu.c @@ -0,0 +1,68 @@ +/* + * Test R5900-specific three-operand MULTU and MULTU1. + */ + +#include +#include +#include + +static uint64_t multu(uint32_t rs, uint32_t rt) +{ + uint32_t rd, lo, hi; + uint64_t r; + + __asm__ __volatile__ ( + " multu %0, %3, %4\n" + " mflo %1\n" + " mfhi %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + r =3D ((uint64_t)hi << 32) | (uint32_t)lo; + + assert((uint64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static uint64_t multu1(uint32_t rs, uint32_t rt) +{ + uint32_t rd, lo, hi; + uint64_t r; + + __asm__ __volatile__ ( + " multu1 %0, %3, %4\n" + " mflo1 %1\n" + " mfhi1 %2\n" + : "=3Dr" (rd), "=3Dr" (lo), "=3Dr" (hi) + : "r" (rs), "r" (rt)); + r =3D ((uint64_t)hi << 32) | (uint32_t)lo; + + assert((uint64_t)rs * rt =3D=3D r); + assert(rd =3D=3D lo); + + return r; +} + +static uint64_t multu_variants(uint32_t rs, uint32_t rt) +{ + uint64_t rd =3D multu(rs, rt); + uint64_t rd1 =3D multu1(rs, rt); + + assert(rd =3D=3D rd1); + + return rd; +} + +int main() +{ + assert(multu_variants(17, 19) =3D=3D 323); + assert(multu_variants(77773, 99991) =3D=3D 7776600043); + assert(multu_variants(12207031, 305175781) =3D=3D 3725290219116211); + + assert(multu_variants(0x80000000U, 0x7FFFFFFF) =3D=3D 0x3FFFFFFF800000= 00); + assert(multu_variants(0x80000000U, 0x80000000U) =3D=3D 0x400000000000= 0000); + assert(multu_variants(0xFFFFFFFFU, 0xFFFFFFFFU) =3D=3D 0xFFFFFFFE0000= 0001U); + + return 0; +} --=20 2.7.4 From nobody Fri Nov 7 14:35:24 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423430113776.8939768776075; Fri, 25 Jan 2019 05:37:10 -0800 (PST) Received: from localhost ([127.0.0.1]:44731 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1fJ-0006WS-3y for importer@patchew.org; Fri, 25 Jan 2019 08:37:01 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46493) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aK-0002m7-W8 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:54 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aI-0002Xw-QC for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36393 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002W9-Cc for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 1AA021A23E7; Fri, 25 Jan 2019 14:31:48 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id DBAB31A229E; Fri, 25 Jan 2019 14:31:47 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:35 +0100 Message-Id: <1548423098-31864-12-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 11/14] tests: tcg: mips: Add two new Makefiles 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Add Makefiles for two new direcitories. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- tests/tcg/mips/user/ase/dsp/Makefile | 184 +++++++++++++++++++++++++++++= ++++ tests/tcg/mips/user/isa/r5900/Makefile | 32 ++++++ 2 files changed, 216 insertions(+) create mode 100644 tests/tcg/mips/user/ase/dsp/Makefile create mode 100644 tests/tcg/mips/user/isa/r5900/Makefile diff --git a/tests/tcg/mips/user/ase/dsp/Makefile b/tests/tcg/mips/user/ase= /dsp/Makefile new file mode 100644 index 0000000..5c6da96 --- /dev/null +++ b/tests/tcg/mips/user/ase/dsp/Makefile @@ -0,0 +1,184 @@ +-include ../../../../config-host.mak + +CROSS=3Dmips64el-unknown-linux-gnu- + +SIM=3Dqemu-mipsel +SIM_FLAGS=3D-cpu 74Kf + +CC =3D $(CROSS)gcc +CFLAGS =3D -EL -mabi=3D32 -march=3Dmips32r2 -mgp32 -mdsp -mdspr2 -static + +TESTCASES =3D test_dsp_r1_absq_s_ph.tst +TESTCASES +=3D test_dsp_r1_absq_s_w.tst +TESTCASES +=3D test_dsp_r1_addq_ph.tst +TESTCASES +=3D test_dsp_r1_addq_s_ph.tst +TESTCASES +=3D test_dsp_r1_addq_s_w.tst +TESTCASES +=3D test_dsp_r1_addsc.tst +TESTCASES +=3D test_dsp_r1_addu_qb.tst +TESTCASES +=3D test_dsp_r1_addu_s_qb.tst +TESTCASES +=3D test_dsp_r1_addwc.tst +TESTCASES +=3D test_dsp_r1_bitrev.tst +TESTCASES +=3D test_dsp_r1_bposge32.tst +TESTCASES +=3D test_dsp_r1_cmp_eq_ph.tst +TESTCASES +=3D test_dsp_r1_cmpgu_eq_qb.tst +TESTCASES +=3D test_dsp_r1_cmpgu_le_qb.tst +TESTCASES +=3D test_dsp_r1_cmpgu_lt_qb.tst +TESTCASES +=3D test_dsp_r1_cmp_le_ph.tst +TESTCASES +=3D test_dsp_r1_cmp_lt_ph.tst +TESTCASES +=3D test_dsp_r1_cmpu_eq_qb.tst +TESTCASES +=3D test_dsp_r1_cmpu_le_qb.tst +TESTCASES +=3D test_dsp_r1_cmpu_lt_qb.tst +TESTCASES +=3D test_dsp_r1_dpaq_sa_l_w.tst +TESTCASES +=3D test_dsp_r1_dpaq_s_w_ph.tst +TESTCASES +=3D test_dsp_r1_dpau_h_qbl.tst +TESTCASES +=3D test_dsp_r1_dpau_h_qbr.tst +TESTCASES +=3D test_dsp_r1_dpsq_sa_l_w.tst +TESTCASES +=3D test_dsp_r1_dpsq_s_w_ph.tst +TESTCASES +=3D test_dsp_r1_dpsu_h_qbl.tst +TESTCASES +=3D test_dsp_r1_dpsu_h_qbr.tst +TESTCASES +=3D test_dsp_r1_extp.tst +TESTCASES +=3D test_dsp_r1_extpdp.tst +TESTCASES +=3D test_dsp_r1_extpdpv.tst +TESTCASES +=3D test_dsp_r1_extpv.tst +TESTCASES +=3D test_dsp_r1_extr_rs_w.tst +TESTCASES +=3D test_dsp_r1_extr_r_w.tst +TESTCASES +=3D test_dsp_r1_extr_s_h.tst +TESTCASES +=3D test_dsp_r1_extrv_rs_w.tst +TESTCASES +=3D test_dsp_r1_extrv_r_w.tst +TESTCASES +=3D test_dsp_r1_extrv_s_h.tst +TESTCASES +=3D test_dsp_r1_extrv_w.tst +TESTCASES +=3D test_dsp_r1_extr_w.tst +TESTCASES +=3D test_dsp_r1_insv.tst +TESTCASES +=3D test_dsp_r1_lbux.tst +TESTCASES +=3D test_dsp_r1_lhx.tst +TESTCASES +=3D test_dsp_r1_lwx.tst +TESTCASES +=3D test_dsp_r1_madd.tst +TESTCASES +=3D test_dsp_r1_maddu.tst +TESTCASES +=3D test_dsp_r1_maq_sa_w_phl.tst +TESTCASES +=3D test_dsp_r1_maq_sa_w_phr.tst +TESTCASES +=3D test_dsp_r1_maq_s_w_phl.tst +TESTCASES +=3D test_dsp_r1_maq_s_w_phr.tst +TESTCASES +=3D test_dsp_r1_mfhi.tst +TESTCASES +=3D test_dsp_r1_mflo.tst +TESTCASES +=3D test_dsp_r1_modsub.tst +TESTCASES +=3D test_dsp_r1_msub.tst +TESTCASES +=3D test_dsp_r1_msubu.tst +TESTCASES +=3D test_dsp_r1_mthi.tst +TESTCASES +=3D test_dsp_r1_mthlip.tst +TESTCASES +=3D test_dsp_r1_mtlo.tst +TESTCASES +=3D test_dsp_r1_muleq_s_w_phl.tst +TESTCASES +=3D test_dsp_r1_muleq_s_w_phr.tst +TESTCASES +=3D test_dsp_r1_muleu_s_ph_qbl.tst +TESTCASES +=3D test_dsp_r1_muleu_s_ph_qbr.tst +TESTCASES +=3D test_dsp_r1_mulq_rs_ph.tst +TESTCASES +=3D test_dsp_r1_mult.tst +TESTCASES +=3D test_dsp_r1_multu.tst +TESTCASES +=3D test_dsp_r1_packrl_ph.tst +TESTCASES +=3D test_dsp_r1_pick_ph.tst +TESTCASES +=3D test_dsp_r1_pick_qb.tst +TESTCASES +=3D test_dsp_r1_precequ_ph_qbla.tst +TESTCASES +=3D test_dsp_r1_precequ_ph_qbl.tst +TESTCASES +=3D test_dsp_r1_precequ_ph_qbra.tst +TESTCASES +=3D test_dsp_r1_precequ_ph_qbr.tst +TESTCASES +=3D test_dsp_r1_preceq_w_phl.tst +TESTCASES +=3D test_dsp_r1_preceq_w_phr.tst +TESTCASES +=3D test_dsp_r1_preceu_ph_qbla.tst +TESTCASES +=3D test_dsp_r1_preceu_ph_qbl.tst +TESTCASES +=3D test_dsp_r1_preceu_ph_qbra.tst +TESTCASES +=3D test_dsp_r1_preceu_ph_qbr.tst +TESTCASES +=3D test_dsp_r1_precrq_ph_w.tst +TESTCASES +=3D test_dsp_r1_precrq_qb_ph.tst +TESTCASES +=3D test_dsp_r1_precrq_rs_ph_w.tst +TESTCASES +=3D test_dsp_r1_precrqu_s_qb_ph.tst +TESTCASES +=3D test_dsp_r1_raddu_w_qb.tst +TESTCASES +=3D test_dsp_r1_rddsp.tst +TESTCASES +=3D test_dsp_r1_repl_ph.tst +TESTCASES +=3D test_dsp_r1_repl_qb.tst +TESTCASES +=3D test_dsp_r1_replv_ph.tst +TESTCASES +=3D test_dsp_r1_replv_qb.tst +TESTCASES +=3D test_dsp_r1_shilo.tst +TESTCASES +=3D test_dsp_r1_shilov.tst +TESTCASES +=3D test_dsp_r1_shll_ph.tst +TESTCASES +=3D test_dsp_r1_shll_qb.tst +TESTCASES +=3D test_dsp_r1_shll_s_ph.tst +TESTCASES +=3D test_dsp_r1_shll_s_w.tst +TESTCASES +=3D test_dsp_r1_shllv_ph.tst +TESTCASES +=3D test_dsp_r1_shllv_qb.tst +TESTCASES +=3D test_dsp_r1_shllv_s_ph.tst +TESTCASES +=3D test_dsp_r1_shllv_s_w.tst +TESTCASES +=3D test_dsp_r1_shra_ph.tst +TESTCASES +=3D test_dsp_r1_shra_r_ph.tst +TESTCASES +=3D test_dsp_r1_shra_r_w.tst +TESTCASES +=3D test_dsp_r1_shrav_ph.tst +TESTCASES +=3D test_dsp_r1_shrav_r_ph.tst +TESTCASES +=3D test_dsp_r1_shrav_r_w.tst +TESTCASES +=3D test_dsp_r1_shrl_qb.tst +TESTCASES +=3D test_dsp_r1_shrlv_qb.tst +TESTCASES +=3D test_dsp_r1_subq_ph.tst +TESTCASES +=3D test_dsp_r1_subq_s_ph.tst +TESTCASES +=3D test_dsp_r1_subq_s_w.tst +TESTCASES +=3D test_dsp_r1_subu_qb.tst +TESTCASES +=3D test_dsp_r1_subu_s_qb.tst +TESTCASES +=3D test_dsp_r1_wrdsp.tst +TESTCASES +=3D test_dsp_r2_absq_s_qb.tst +TESTCASES +=3D test_dsp_r2_addqh_ph.tst +TESTCASES +=3D test_dsp_r2_addqh_r_ph.tst +TESTCASES +=3D test_dsp_r2_addqh_r_w.tst +TESTCASES +=3D test_dsp_r2_addqh_w.tst +TESTCASES +=3D test_dsp_r2_adduh_qb.tst +TESTCASES +=3D test_dsp_r2_adduh_r_qb.tst +TESTCASES +=3D test_dsp_r2_addu_ph.tst +TESTCASES +=3D test_dsp_r2_addu_s_ph.tst +TESTCASES +=3D test_dsp_r2_append.tst +TESTCASES +=3D test_dsp_r2_balign.tst +TESTCASES +=3D test_dsp_r2_cmpgdu_eq_qb.tst +TESTCASES +=3D test_dsp_r2_cmpgdu_le_qb.tst +TESTCASES +=3D test_dsp_r2_cmpgdu_lt_qb.tst +TESTCASES +=3D test_dsp_r2_dpaqx_sa_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpa_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpax_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpaqx_s_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpsqx_sa_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpsqx_s_w_ph.tst +TESTCASES +=3D test_dsp_r2_dps_w_ph.tst +TESTCASES +=3D test_dsp_r2_dpsx_w_ph.tst +TESTCASES +=3D test_dsp_r2_mul_ph.tst +TESTCASES +=3D test_dsp_r2_mulq_rs_w.tst +TESTCASES +=3D test_dsp_r2_mulq_s_ph.tst +TESTCASES +=3D test_dsp_r2_mulq_s_w.tst +TESTCASES +=3D test_dsp_r2_mulsaq_s_w_ph.tst +TESTCASES +=3D test_dsp_r2_mulsa_w_ph.tst +TESTCASES +=3D test_dsp_r2_mul_s_ph.tst +TESTCASES +=3D test_dsp_r2_precr_qb_ph.tst +TESTCASES +=3D test_dsp_r2_precr_sra_ph_w.tst +TESTCASES +=3D test_dsp_r2_precr_sra_r_ph_w.tst +TESTCASES +=3D test_dsp_r2_prepend.tst +TESTCASES +=3D test_dsp_r2_shra_qb.tst +TESTCASES +=3D test_dsp_r2_shra_r_qb.tst +TESTCASES +=3D test_dsp_r2_shrav_qb.tst +TESTCASES +=3D test_dsp_r2_shrav_r_qb.tst +TESTCASES +=3D test_dsp_r2_shrl_ph.tst +TESTCASES +=3D test_dsp_r2_shrlv_ph.tst +TESTCASES +=3D test_dsp_r2_subqh_ph.tst +TESTCASES +=3D test_dsp_r2_subqh_r_ph.tst +TESTCASES +=3D test_dsp_r2_subqh_r_w.tst +TESTCASES +=3D test_dsp_r2_subqh_w.tst +TESTCASES +=3D test_dsp_r2_subuh_qb.tst +TESTCASES +=3D test_dsp_r2_subuh_r_qb.tst +TESTCASES +=3D test_dsp_r2_subu_ph.tst +TESTCASES +=3D test_dsp_r2_subu_s_ph.tst + + +all: $(TESTCASES) + +%.tst: %.c + $(CC) $(CFLAGS) $< -o $@ + +check: $(TESTCASES) + @for case in $(TESTCASES); do \ + echo $(SIM) $(SIM_FLAGS) ./$$case;\ + $(SIM) $(SIM_FLAGS) ./$$case; \ + done + +clean: + $(RM) -rf $(TESTCASES) diff --git a/tests/tcg/mips/user/isa/r5900/Makefile b/tests/tcg/mips/user/i= sa/r5900/Makefile new file mode 100644 index 0000000..bff360d --- /dev/null +++ b/tests/tcg/mips/user/isa/r5900/Makefile @@ -0,0 +1,32 @@ +-include ../../../../config-host.mak + +CROSS=3Dmipsr5900el-unknown-linux-gnu- + +SIM=3Dqemu-mipsel +SIM_FLAGS=3D-cpu R5900 + +CC =3D $(CROSS)gcc +CFLAGS =3D -Wall -mabi=3D32 -march=3Dr5900 -static + +TESTCASES =3D test_r5900_div1.tst +TESTCASES +=3D test_r5900_divu1.tst +TESTCASES +=3D test_r5900_madd.tst +TESTCASES +=3D test_r5900_maddu.tst +TESTCASES +=3D test_r5900_mflohi1.tst +TESTCASES +=3D test_r5900_mtlohi1.tst +TESTCASES +=3D test_r5900_mult.tst +TESTCASES +=3D test_r5900_multu.tst + +all: $(TESTCASES) + +%.tst: %.c + $(CC) $(CFLAGS) $< -o $@ + +check: $(TESTCASES) + @for case in $(TESTCASES); do \ + echo $(SIM) $(SIM_FLAGS) ./$$case;\ + $(SIM) $(SIM_FLAGS) ./$$case; \ + done + +clean: + $(RM) -rf $(TESTCASES) --=20 2.7.4 From nobody Fri Nov 7 14:35:25 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423953301693.2195097504266; Fri, 25 Jan 2019 05:45:53 -0800 (PST) Received: from localhost ([127.0.0.1]:44879 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1nn-0005Eo-LZ for importer@patchew.org; Fri, 25 Jan 2019 08:45:47 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46610) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1b1-0003II-U3 for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:33:03 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aW-0002gK-IS for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:34 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36570 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aS-0002Wt-Sn for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:04 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 421A61A229E; Fri, 25 Jan 2019 14:31:49 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id E4DC21A23D7; Fri, 25 Jan 2019 14:31:47 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:36 +0100 Message-Id: <1548423098-31864-13-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 12/14] tests: tcg: mips: Remove old directories 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Aleksandar Markovic Remove old test directories. Reviewed-by: Aleksandar Rikalo Signed-off-by: Aleksandar Markovic --- tests/tcg/mips/mips32-dsp/Makefile | 136 ----------- tests/tcg/mips/mips32-dspr2/Makefile | 71 ------ tests/tcg/mips/mips64-dsp/Makefile | 306 ---------------------= ---- tests/tcg/mips/mips64-dsp/absq_s_ob.c | 63 ----- tests/tcg/mips/mips64-dsp/absq_s_ph.c | 37 --- tests/tcg/mips/mips64-dsp/absq_s_pw.c | 66 ------ tests/tcg/mips/mips64-dsp/absq_s_qh.c | 40 ---- tests/tcg/mips/mips64-dsp/absq_s_w.c | 48 ---- tests/tcg/mips/mips64-dsp/addq_ph.c | 57 ----- tests/tcg/mips/mips64-dsp/addq_pw.c | 46 ---- tests/tcg/mips/mips64-dsp/addq_qh.c | 28 --- tests/tcg/mips/mips64-dsp/addq_s_ph.c | 84 ------- tests/tcg/mips/mips64-dsp/addq_s_pw.c | 45 ---- tests/tcg/mips/mips64-dsp/addq_s_qh.c | 26 --- tests/tcg/mips/mips64-dsp/addq_s_w.c | 48 ---- tests/tcg/mips/mips64-dsp/addsc.c | 39 ---- tests/tcg/mips/mips64-dsp/addu_ob.c | 28 --- tests/tcg/mips/mips64-dsp/addu_qb.c | 40 ---- tests/tcg/mips/mips64-dsp/addu_s_ob.c | 27 --- tests/tcg/mips/mips64-dsp/addu_s_qb.c | 40 ---- tests/tcg/mips/mips64-dsp/addwc.c | 59 ----- tests/tcg/mips/mips64-dsp/bitrev.c | 23 -- tests/tcg/mips/mips64-dsp/bposge32.c | 50 ---- tests/tcg/mips/mips64-dsp/bposge64.c | 50 ---- tests/tcg/mips/mips64-dsp/cmp_eq_ph.c | 42 ---- tests/tcg/mips/mips64-dsp/cmp_eq_pw.c | 46 ---- tests/tcg/mips/mips64-dsp/cmp_eq_qh.c | 46 ---- tests/tcg/mips/mips64-dsp/cmp_le_ph.c | 40 ---- tests/tcg/mips/mips64-dsp/cmp_le_pw.c | 46 ---- tests/tcg/mips/mips64-dsp/cmp_le_qh.c | 46 ---- tests/tcg/mips/mips64-dsp/cmp_lt_ph.c | 41 ---- tests/tcg/mips/mips64-dsp/cmp_lt_pw.c | 46 ---- tests/tcg/mips/mips64-dsp/cmp_lt_qh.c | 46 ---- tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c | 40 ---- tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c | 38 --- tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c | 40 ---- tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c | 37 --- tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c | 40 ---- tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c | 38 --- tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c | 46 ---- tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c | 42 ---- tests/tcg/mips/mips64-dsp/cmpu_le_ob.c | 44 ---- tests/tcg/mips/mips64-dsp/cmpu_le_qb.c | 41 ---- tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c | 44 ---- tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c | 42 ---- tests/tcg/mips/mips64-dsp/dappend.c | 37 --- tests/tcg/mips/mips64-dsp/dextp.c | 54 ----- tests/tcg/mips/mips64-dsp/dextpdp.c | 59 ----- tests/tcg/mips/mips64-dsp/dextpdpv.c | 63 ----- tests/tcg/mips/mips64-dsp/dextpv.c | 58 ----- tests/tcg/mips/mips64-dsp/dextr_l.c | 44 ---- tests/tcg/mips/mips64-dsp/dextr_r_l.c | 54 ----- tests/tcg/mips/mips64-dsp/dextr_r_w.c | 54 ----- tests/tcg/mips/mips64-dsp/dextr_rs_l.c | 52 ----- tests/tcg/mips/mips64-dsp/dextr_rs_w.c | 52 ----- tests/tcg/mips/mips64-dsp/dextr_s_h.c | 73 ------ tests/tcg/mips/mips64-dsp/dextr_w.c | 44 ---- tests/tcg/mips/mips64-dsp/dextrv_l.c | 46 ---- tests/tcg/mips/mips64-dsp/dextrv_r_l.c | 56 ----- tests/tcg/mips/mips64-dsp/dextrv_r_w.c | 56 ----- tests/tcg/mips/mips64-dsp/dextrv_rs_l.c | 54 ----- tests/tcg/mips/mips64-dsp/dextrv_rs_w.c | 54 ----- tests/tcg/mips/mips64-dsp/dextrv_s_h.c | 32 --- tests/tcg/mips/mips64-dsp/dextrv_w.c | 46 ---- tests/tcg/mips/mips64-dsp/dinsv.c | 26 --- tests/tcg/mips/mips64-dsp/dmadd.c | 57 ----- tests/tcg/mips/mips64-dsp/dmaddu.c | 56 ----- tests/tcg/mips/mips64-dsp/dmsub.c | 59 ----- tests/tcg/mips/mips64-dsp/dmsubu.c | 59 ----- tests/tcg/mips/mips64-dsp/dmthlip.c | 41 ---- tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c | 32 --- tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c | 57 ----- tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c | 88 ------- tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c | 82 ------- tests/tcg/mips/mips64-dsp/dpau_h_obl.c | 59 ----- tests/tcg/mips/mips64-dsp/dpau_h_obr.c | 59 ----- tests/tcg/mips/mips64-dsp/dpau_h_qbl.c | 29 --- tests/tcg/mips/mips64-dsp/dpau_h_qbr.c | 29 --- tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c | 51 ----- tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c | 56 ----- tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c | 76 ------ tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c | 59 ----- tests/tcg/mips/mips64-dsp/dpsu_h_obl.c | 32 --- tests/tcg/mips/mips64-dsp/dpsu_h_obr.c | 32 --- tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c | 29 --- tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c | 29 --- tests/tcg/mips/mips64-dsp/dshilo.c | 52 ----- tests/tcg/mips/mips64-dsp/dshilov.c | 54 ----- tests/tcg/mips/mips64-dsp/extp.c | 50 ---- tests/tcg/mips/mips64-dsp/extpdp.c | 51 ----- tests/tcg/mips/mips64-dsp/extpdpv.c | 52 ----- tests/tcg/mips/mips64-dsp/extpv.c | 51 ----- tests/tcg/mips/mips64-dsp/extr_r_w.c | 53 ----- tests/tcg/mips/mips64-dsp/extr_rs_w.c | 53 ----- tests/tcg/mips/mips64-dsp/extr_s_h.c | 71 ------ tests/tcg/mips/mips64-dsp/extr_w.c | 53 ----- tests/tcg/mips/mips64-dsp/extrv_r_w.c | 59 ----- tests/tcg/mips/mips64-dsp/extrv_rs_w.c | 59 ----- tests/tcg/mips/mips64-dsp/extrv_s_h.c | 79 ------- tests/tcg/mips/mips64-dsp/extrv_w.c | 59 ----- tests/tcg/mips/mips64-dsp/head.S | 16 -- tests/tcg/mips/mips64-dsp/insv.c | 26 --- tests/tcg/mips/mips64-dsp/io.h | 22 -- tests/tcg/mips/mips64-dsp/lbux.c | 27 --- tests/tcg/mips/mips64-dsp/ldx.c | 27 --- tests/tcg/mips/mips64-dsp/lhx.c | 27 --- tests/tcg/mips/mips64-dsp/lwx.c | 27 --- tests/tcg/mips/mips64-dsp/madd.c | 33 --- tests/tcg/mips/mips64-dsp/maddu.c | 33 --- tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c | 56 ----- tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c | 56 ----- tests/tcg/mips/mips64-dsp/maq_s_w_phl.c | 60 ----- tests/tcg/mips/mips64-dsp/maq_s_w_phr.c | 60 ----- tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c | 62 ----- tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c | 62 ----- tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c | 63 ----- tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c | 63 ----- tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c | 60 ----- tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c | 60 ----- tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c | 62 ----- tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c | 64 ------ tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c | 64 ------ tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c | 64 ------ tests/tcg/mips/mips64-dsp/mfhi.c | 24 -- tests/tcg/mips/mips64-dsp/mflo.c | 24 -- tests/tcg/mips/mips64-dsp/mips_boot.lds | 31 --- tests/tcg/mips/mips64-dsp/modsub.c | 37 --- tests/tcg/mips/mips64-dsp/msub.c | 32 --- tests/tcg/mips/mips64-dsp/msubu.c | 32 --- tests/tcg/mips/mips64-dsp/mthi.c | 24 -- tests/tcg/mips/mips64-dsp/mthlip.c | 61 ----- tests/tcg/mips/mips64-dsp/mtlo.c | 22 -- tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c | 56 ----- tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c | 57 ----- tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c | 46 ---- tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c | 45 ---- tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c | 27 --- tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c | 27 --- tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c | 30 --- tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c | 31 --- tests/tcg/mips/mips64-dsp/mulq_rs_ph.c | 27 --- tests/tcg/mips/mips64-dsp/mulq_rs_qh.c | 33 --- tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c | 59 ----- tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c | 57 ----- tests/tcg/mips/mips64-dsp/mult.c | 26 --- tests/tcg/mips/mips64-dsp/multu.c | 26 --- tests/tcg/mips/mips64-dsp/packrl_ph.c | 24 -- tests/tcg/mips/mips64-dsp/packrl_pw.c | 24 -- tests/tcg/mips/mips64-dsp/pick_ob.c | 66 ------ tests/tcg/mips/mips64-dsp/pick_ph.c | 60 ----- tests/tcg/mips/mips64-dsp/pick_pw.c | 48 ---- tests/tcg/mips/mips64-dsp/pick_qb.c | 43 ---- tests/tcg/mips/mips64-dsp/pick_qh.c | 48 ---- tests/tcg/mips/mips64-dsp/preceq_l_pwl.c | 24 -- tests/tcg/mips/mips64-dsp/preceq_l_pwr.c | 24 -- tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c | 21 -- tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c | 23 -- tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c | 21 -- tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c | 23 -- tests/tcg/mips/mips64-dsp/preceq_w_phl.c | 23 -- tests/tcg/mips/mips64-dsp/preceq_w_phr.c | 23 -- tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c | 23 -- tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c | 23 -- tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c | 23 -- tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c | 23 -- tests/tcg/mips/mips64-dsp/precequ_qh_obl.c | 22 -- tests/tcg/mips/mips64-dsp/precequ_qh_obla.c | 22 -- tests/tcg/mips/mips64-dsp/precequ_qh_obr.c | 24 -- tests/tcg/mips/mips64-dsp/precequ_qh_obra.c | 24 -- tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c | 23 -- tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c | 23 -- tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c | 23 -- tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c | 23 -- tests/tcg/mips/mips64-dsp/preceu_qh_obl.c | 22 -- tests/tcg/mips/mips64-dsp/preceu_qh_obla.c | 22 -- tests/tcg/mips/mips64-dsp/preceu_qh_obr.c | 23 -- tests/tcg/mips/mips64-dsp/preceu_qh_obra.c | 23 -- tests/tcg/mips/mips64-dsp/precr_ob_qh.c | 25 -- tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c | 40 ---- tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c | 40 ---- tests/tcg/mips/mips64-dsp/precrq_ob_qh.c | 25 -- tests/tcg/mips/mips64-dsp/precrq_ph_w.c | 24 -- tests/tcg/mips/mips64-dsp/precrq_pw_l.c | 25 -- tests/tcg/mips/mips64-dsp/precrq_qb_ph.c | 24 -- tests/tcg/mips/mips64-dsp/precrq_qh_pw.c | 25 -- tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c | 41 ---- tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c | 43 ---- tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c | 27 --- tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c | 26 --- tests/tcg/mips/mips64-dsp/prependd.c | 37 --- tests/tcg/mips/mips64-dsp/prependw.c | 37 --- tests/tcg/mips/mips64-dsp/printf.c | 266 --------------------- tests/tcg/mips/mips64-dsp/raddu_l_ob.c | 22 -- tests/tcg/mips/mips64-dsp/raddu_w_qb.c | 23 -- tests/tcg/mips/mips64-dsp/rddsp.c | 53 ----- tests/tcg/mips/mips64-dsp/repl_ob.c | 21 -- tests/tcg/mips/mips64-dsp/repl_ph.c | 30 --- tests/tcg/mips/mips64-dsp/repl_pw.c | 34 --- tests/tcg/mips/mips64-dsp/repl_qb.c | 19 -- tests/tcg/mips/mips64-dsp/repl_qh.c | 34 --- tests/tcg/mips/mips64-dsp/replv_ob.c | 23 -- tests/tcg/mips/mips64-dsp/replv_ph.c | 22 -- tests/tcg/mips/mips64-dsp/replv_pw.c | 23 -- tests/tcg/mips/mips64-dsp/replv_qb.c | 22 -- tests/tcg/mips/mips64-dsp/shilo.c | 29 --- tests/tcg/mips/mips64-dsp/shilov.c | 31 --- tests/tcg/mips/mips64-dsp/shll_ob.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_ph.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_pw.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_qb.c | 26 --- tests/tcg/mips/mips64-dsp/shll_qh.c | 42 ---- tests/tcg/mips/mips64-dsp/shll_s_ph.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_s_pw.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_s_qh.c | 43 ---- tests/tcg/mips/mips64-dsp/shll_s_w.c | 26 --- tests/tcg/mips/mips64-dsp/shllv_ob.c | 45 ---- tests/tcg/mips/mips64-dsp/shllv_ph.c | 27 --- tests/tcg/mips/mips64-dsp/shllv_pw.c | 45 ---- tests/tcg/mips/mips64-dsp/shllv_qb.c | 27 --- tests/tcg/mips/mips64-dsp/shllv_qh.c | 45 ---- tests/tcg/mips/mips64-dsp/shllv_s_ph.c | 27 --- tests/tcg/mips/mips64-dsp/shllv_s_pw.c | 45 ---- tests/tcg/mips/mips64-dsp/shllv_s_qh.c | 45 ---- tests/tcg/mips/mips64-dsp/shllv_s_w.c | 27 --- tests/tcg/mips/mips64-dsp/shra_ob.c | 23 -- tests/tcg/mips/mips64-dsp/shra_ph.c | 23 -- tests/tcg/mips/mips64-dsp/shra_pw.c | 36 --- tests/tcg/mips/mips64-dsp/shra_qh.c | 37 --- tests/tcg/mips/mips64-dsp/shra_r_ob.c | 22 -- tests/tcg/mips/mips64-dsp/shra_r_ph.c | 23 -- tests/tcg/mips/mips64-dsp/shra_r_pw.c | 36 --- tests/tcg/mips/mips64-dsp/shra_r_qh.c | 37 --- tests/tcg/mips/mips64-dsp/shra_r_w.c | 23 -- tests/tcg/mips/mips64-dsp/shrav_ph.c | 24 -- tests/tcg/mips/mips64-dsp/shrav_pw.c | 38 --- tests/tcg/mips/mips64-dsp/shrav_qh.c | 39 ---- tests/tcg/mips/mips64-dsp/shrav_r_ph.c | 24 -- tests/tcg/mips/mips64-dsp/shrav_r_pw.c | 37 --- tests/tcg/mips/mips64-dsp/shrav_r_qh.c | 39 ---- tests/tcg/mips/mips64-dsp/shrav_r_w.c | 24 -- tests/tcg/mips/mips64-dsp/shrl_ob.c | 38 --- tests/tcg/mips/mips64-dsp/shrl_qb.c | 23 -- tests/tcg/mips/mips64-dsp/shrl_qh.c | 22 -- tests/tcg/mips/mips64-dsp/shrlv_ob.c | 39 ---- tests/tcg/mips/mips64-dsp/shrlv_qb.c | 24 -- tests/tcg/mips/mips64-dsp/shrlv_qh.c | 23 -- tests/tcg/mips/mips64-dsp/subq_ph.c | 27 --- tests/tcg/mips/mips64-dsp/subq_pw.c | 44 ---- tests/tcg/mips/mips64-dsp/subq_qh.c | 26 --- tests/tcg/mips/mips64-dsp/subq_s_ph.c | 27 --- tests/tcg/mips/mips64-dsp/subq_s_pw.c | 63 ----- tests/tcg/mips/mips64-dsp/subq_s_qh.c | 61 ----- tests/tcg/mips/mips64-dsp/subq_s_w.c | 27 --- tests/tcg/mips/mips64-dsp/subu_ob.c | 26 --- tests/tcg/mips/mips64-dsp/subu_qb.c | 27 --- tests/tcg/mips/mips64-dsp/subu_s_ob.c | 26 --- tests/tcg/mips/mips64-dsp/subu_s_qb.c | 27 --- tests/tcg/mips/mips64-dsp/wrdsp.c | 48 ---- tests/tcg/mips/mips64-dspr2/Makefile | 116 ---------- tests/tcg/mips/mips64-dspr2/absq_s_qb.c | 42 ---- tests/tcg/mips/mips64-dspr2/addqh_ph.c | 35 --- tests/tcg/mips/mips64-dspr2/addqh_r_ph.c | 35 --- tests/tcg/mips/mips64-dspr2/addqh_r_w.c | 38 --- tests/tcg/mips/mips64-dspr2/addqh_w.c | 39 ---- tests/tcg/mips/mips64-dspr2/addu_ph.c | 37 --- tests/tcg/mips/mips64-dspr2/addu_qh.c | 43 ---- tests/tcg/mips/mips64-dspr2/addu_s_ph.c | 37 --- tests/tcg/mips/mips64-dspr2/addu_s_qh.c | 43 ---- tests/tcg/mips/mips64-dspr2/adduh_ob.c | 35 --- tests/tcg/mips/mips64-dspr2/adduh_qb.c | 35 --- tests/tcg/mips/mips64-dspr2/adduh_r_ob.c | 35 --- tests/tcg/mips/mips64-dspr2/adduh_r_qb.c | 35 --- tests/tcg/mips/mips64-dspr2/append.c | 35 --- tests/tcg/mips/mips64-dspr2/balign.c | 35 --- tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c | 44 ---- tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c | 41 ---- tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c | 44 ---- tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c | 48 ---- tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c | 44 ---- tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c | 48 ---- tests/tcg/mips/mips64-dspr2/dbalign.c | 39 ---- tests/tcg/mips/mips64-dspr2/dpa_w_ph.c | 47 ---- tests/tcg/mips/mips64-dspr2/dpa_w_qh.c | 56 ----- tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c | 97 -------- tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c | 54 ----- tests/tcg/mips/mips64-dspr2/dpax_w_ph.c | 32 --- tests/tcg/mips/mips64-dspr2/dps_w_ph.c | 28 --- tests/tcg/mips/mips64-dspr2/dps_w_qh.c | 55 ----- tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c | 55 ----- tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c | 53 ----- tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c | 28 --- tests/tcg/mips/mips64-dspr2/head.S | 16 -- tests/tcg/mips/mips64-dspr2/io.h | 22 -- tests/tcg/mips/mips64-dspr2/mips_boot.lds | 31 --- tests/tcg/mips/mips64-dspr2/mul_ph.c | 50 ---- tests/tcg/mips/mips64-dspr2/mul_s_ph.c | 67 ------ tests/tcg/mips/mips64-dspr2/mulq_rs_w.c | 40 ---- tests/tcg/mips/mips64-dspr2/mulq_s_ph.c | 26 --- tests/tcg/mips/mips64-dspr2/mulq_s_w.c | 40 ---- tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c | 30 --- tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c | 30 --- tests/tcg/mips/mips64-dspr2/precr_qb_ph.c | 23 -- tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c | 37 --- tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c | 37 --- tests/tcg/mips/mips64-dspr2/prepend.c | 35 --- tests/tcg/mips/mips64-dspr2/printf.c | 266 --------------------- tests/tcg/mips/mips64-dspr2/shra_qb.c | 35 --- tests/tcg/mips/mips64-dspr2/shra_r_qb.c | 35 --- tests/tcg/mips/mips64-dspr2/shrav_ob.c | 22 -- tests/tcg/mips/mips64-dspr2/shrav_qb.c | 37 --- tests/tcg/mips/mips64-dspr2/shrav_r_ob.c | 22 -- tests/tcg/mips/mips64-dspr2/shrav_r_qb.c | 37 --- tests/tcg/mips/mips64-dspr2/shrl_ph.c | 22 -- tests/tcg/mips/mips64-dspr2/shrlv_ph.c | 23 -- tests/tcg/mips/mips64-dspr2/subqh_ph.c | 23 -- tests/tcg/mips/mips64-dspr2/subqh_r_ph.c | 23 -- tests/tcg/mips/mips64-dspr2/subqh_r_w.c | 23 -- tests/tcg/mips/mips64-dspr2/subqh_w.c | 23 -- tests/tcg/mips/mips64-dspr2/subu_ph.c | 26 --- tests/tcg/mips/mips64-dspr2/subu_qh.c | 24 -- tests/tcg/mips/mips64-dspr2/subu_s_ph.c | 25 -- tests/tcg/mips/mips64-dspr2/subu_s_qh.c | 42 ---- tests/tcg/mips/mips64-dspr2/subuh_ob.c | 36 --- tests/tcg/mips/mips64-dspr2/subuh_qb.c | 23 -- tests/tcg/mips/mips64-dspr2/subuh_r_ob.c | 23 -- tests/tcg/mips/mips64-dspr2/subuh_r_qb.c | 37 --- tests/tcg/mips/mipsr5900/Makefile | 32 --- 327 files changed, 13708 deletions(-) delete mode 100644 tests/tcg/mips/mips32-dsp/Makefile delete mode 100644 tests/tcg/mips/mips32-dspr2/Makefile delete mode 100644 tests/tcg/mips/mips64-dsp/Makefile delete mode 100644 tests/tcg/mips/mips64-dsp/absq_s_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/absq_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/absq_s_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/absq_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/absq_s_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_s_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/addq_s_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/addsc.c delete mode 100644 tests/tcg/mips/mips64-dsp/addu_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/addu_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/addu_s_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/addu_s_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/addwc.c delete mode 100644 tests/tcg/mips/mips64-dsp/bitrev.c delete mode 100644 tests/tcg/mips/mips64-dsp/bposge32.c delete mode 100644 tests/tcg/mips/mips64-dsp/bposge64.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_le_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_le_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/dappend.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextp.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextpdp.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextpdpv.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextpv.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_r_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_rs_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_rs_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_s_h.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextr_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_r_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_rs_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_rs_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_s_h.c delete mode 100644 tests/tcg/mips/mips64-dsp/dextrv_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dinsv.c delete mode 100644 tests/tcg/mips/mips64-dsp/dmadd.c delete mode 100644 tests/tcg/mips/mips64-dsp/dmaddu.c delete mode 100644 tests/tcg/mips/mips64-dsp/dmsub.c delete mode 100644 tests/tcg/mips/mips64-dsp/dmsubu.c delete mode 100644 tests/tcg/mips/mips64-dsp/dmthlip.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_obl.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_obr.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_qbl.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_qbr.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_obl.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_obr.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c delete mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c delete mode 100644 tests/tcg/mips/mips64-dsp/dshilo.c delete mode 100644 tests/tcg/mips/mips64-dsp/dshilov.c delete mode 100644 tests/tcg/mips/mips64-dsp/extp.c delete mode 100644 tests/tcg/mips/mips64-dsp/extpdp.c delete mode 100644 tests/tcg/mips/mips64-dsp/extpdpv.c delete mode 100644 tests/tcg/mips/mips64-dsp/extpv.c delete mode 100644 tests/tcg/mips/mips64-dsp/extr_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/extr_rs_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/extr_s_h.c delete mode 100644 tests/tcg/mips/mips64-dsp/extr_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/extrv_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/extrv_rs_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/extrv_s_h.c delete mode 100644 tests/tcg/mips/mips64-dsp/extrv_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/head.S delete mode 100644 tests/tcg/mips/mips64-dsp/insv.c delete mode 100644 tests/tcg/mips/mips64-dsp/io.h delete mode 100644 tests/tcg/mips/mips64-dsp/lbux.c delete mode 100644 tests/tcg/mips/mips64-dsp/ldx.c delete mode 100644 tests/tcg/mips/mips64-dsp/lhx.c delete mode 100644 tests/tcg/mips/mips64-dsp/lwx.c delete mode 100644 tests/tcg/mips/mips64-dsp/madd.c delete mode 100644 tests/tcg/mips/mips64-dsp/maddu.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_phl.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_phr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c delete mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c delete mode 100644 tests/tcg/mips/mips64-dsp/mfhi.c delete mode 100644 tests/tcg/mips/mips64-dsp/mflo.c delete mode 100644 tests/tcg/mips/mips64-dsp/mips_boot.lds delete mode 100644 tests/tcg/mips/mips64-dsp/modsub.c delete mode 100644 tests/tcg/mips/mips64-dsp/msub.c delete mode 100644 tests/tcg/mips/mips64-dsp/msubu.c delete mode 100644 tests/tcg/mips/mips64-dsp/mthi.c delete mode 100644 tests/tcg/mips/mips64-dsp/mthlip.c delete mode 100644 tests/tcg/mips/mips64-dsp/mtlo.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c delete mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c delete mode 100644 tests/tcg/mips/mips64-dsp/mulq_rs_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/mulq_rs_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/mult.c delete mode 100644 tests/tcg/mips/mips64-dsp/multu.c delete mode 100644 tests/tcg/mips/mips64-dsp/packrl_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/packrl_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/pick_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/pick_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/pick_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/pick_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/pick_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_l_pwl.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_l_pwr.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_w_phl.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceq_w_phr.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obl.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obla.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obr.c delete mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obra.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obl.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obla.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obr.c delete mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obra.c delete mode 100644 tests/tcg/mips/mips64-dsp/precr_ob_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_ob_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_ph_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_pw_l.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_qb_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_qh_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/prependd.c delete mode 100644 tests/tcg/mips/mips64-dsp/prependw.c delete mode 100644 tests/tcg/mips/mips64-dsp/printf.c delete mode 100644 tests/tcg/mips/mips64-dsp/raddu_l_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/raddu_w_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/rddsp.c delete mode 100644 tests/tcg/mips/mips64-dsp/repl_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/repl_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/repl_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/repl_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/repl_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/replv_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/replv_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/replv_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/replv_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/shilo.c delete mode 100644 tests/tcg/mips/mips64-dsp/shilov.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_s_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shll_s_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_r_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_r_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_r_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_r_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shra_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrl_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrl_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrl_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrlv_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrlv_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/shrlv_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_s_pw.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dsp/subq_s_w.c delete mode 100644 tests/tcg/mips/mips64-dsp/subu_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/subu_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/subu_s_ob.c delete mode 100644 tests/tcg/mips/mips64-dsp/subu_s_qb.c delete mode 100644 tests/tcg/mips/mips64-dsp/wrdsp.c delete mode 100644 tests/tcg/mips/mips64-dspr2/Makefile delete mode 100644 tests/tcg/mips/mips64-dspr2/absq_s_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addqh_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addqh_r_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addqh_r_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addqh_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addu_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addu_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addu_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/addu_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/adduh_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/adduh_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/adduh_r_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/adduh_r_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/append.c delete mode 100644 tests/tcg/mips/mips64-dspr2/balign.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dbalign.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpa_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpa_w_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpax_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dps_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dps_w_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/head.S delete mode 100644 tests/tcg/mips/mips64-dspr2/io.h delete mode 100644 tests/tcg/mips/mips64-dspr2/mips_boot.lds delete mode 100644 tests/tcg/mips/mips64-dspr2/mul_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mul_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mulq_rs_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mulq_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mulq_s_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/precr_qb_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/prepend.c delete mode 100644 tests/tcg/mips/mips64-dspr2/printf.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shra_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shra_r_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrav_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrav_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrav_r_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrav_r_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrl_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/shrlv_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subqh_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subqh_r_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subqh_r_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subqh_w.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subu_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subu_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subu_s_ph.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subu_s_qh.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subuh_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subuh_qb.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subuh_r_ob.c delete mode 100644 tests/tcg/mips/mips64-dspr2/subuh_r_qb.c delete mode 100644 tests/tcg/mips/mipsr5900/Makefile diff --git a/tests/tcg/mips/mips32-dsp/Makefile b/tests/tcg/mips/mips32-dsp= /Makefile deleted file mode 100644 index c3a0a00..0000000 --- a/tests/tcg/mips/mips32-dsp/Makefile +++ /dev/null @@ -1,136 +0,0 @@ --include ../../config-host.mak - -CROSS=3Dmips64el-unknown-linux-gnu- - -SIM=3Dqemu-mipsel -SIM_FLAGS=3D-cpu 74Kf - -CC =3D $(CROSS)gcc -CFLAGS =3D -mabi=3D32 -march=3Dmips32r2 -mgp32 -mdsp -static - -TESTCASES =3D absq_s_ph.tst -TESTCASES +=3D absq_s_w.tst -TESTCASES +=3D addq_ph.tst -TESTCASES +=3D addq_s_ph.tst -TESTCASES +=3D addq_s_w.tst -TESTCASES +=3D addsc.tst -TESTCASES +=3D addu_qb.tst -TESTCASES +=3D addu_s_qb.tst -TESTCASES +=3D addwc.tst -TESTCASES +=3D bitrev.tst -TESTCASES +=3D bposge32.tst -TESTCASES +=3D cmp_eq_ph.tst -TESTCASES +=3D cmpgu_eq_qb.tst -TESTCASES +=3D cmpgu_le_qb.tst -TESTCASES +=3D cmpgu_lt_qb.tst -TESTCASES +=3D cmp_le_ph.tst -TESTCASES +=3D cmp_lt_ph.tst -TESTCASES +=3D cmpu_eq_qb.tst -TESTCASES +=3D cmpu_le_qb.tst -TESTCASES +=3D cmpu_lt_qb.tst -TESTCASES +=3D dpaq_sa_l_w.tst -TESTCASES +=3D dpaq_s_w_ph.tst -TESTCASES +=3D dpau_h_qbl.tst -TESTCASES +=3D dpau_h_qbr.tst -TESTCASES +=3D dpsq_sa_l_w.tst -TESTCASES +=3D dpsq_s_w_ph.tst -TESTCASES +=3D dpsu_h_qbl.tst -TESTCASES +=3D dpsu_h_qbr.tst -TESTCASES +=3D extp.tst -TESTCASES +=3D extpdp.tst -TESTCASES +=3D extpdpv.tst -TESTCASES +=3D extpv.tst -TESTCASES +=3D extr_rs_w.tst -TESTCASES +=3D extr_r_w.tst -TESTCASES +=3D extr_s_h.tst -TESTCASES +=3D extrv_rs_w.tst -TESTCASES +=3D extrv_r_w.tst -TESTCASES +=3D extrv_s_h.tst -TESTCASES +=3D extrv_w.tst -TESTCASES +=3D extr_w.tst -TESTCASES +=3D insv.tst -TESTCASES +=3D lbux.tst -TESTCASES +=3D lhx.tst -TESTCASES +=3D lwx.tst -TESTCASES +=3D madd.tst -TESTCASES +=3D maddu.tst -TESTCASES +=3D maq_sa_w_phl.tst -TESTCASES +=3D maq_sa_w_phr.tst -TESTCASES +=3D maq_s_w_phl.tst -TESTCASES +=3D maq_s_w_phr.tst -TESTCASES +=3D mfhi.tst -TESTCASES +=3D mflo.tst -TESTCASES +=3D modsub.tst -TESTCASES +=3D msub.tst -TESTCASES +=3D msubu.tst -TESTCASES +=3D mthi.tst -TESTCASES +=3D mthlip.tst -TESTCASES +=3D mtlo.tst -TESTCASES +=3D muleq_s_w_phl.tst -TESTCASES +=3D muleq_s_w_phr.tst -TESTCASES +=3D muleu_s_ph_qbl.tst -TESTCASES +=3D muleu_s_ph_qbr.tst -TESTCASES +=3D mulq_rs_ph.tst -TESTCASES +=3D mult.tst -TESTCASES +=3D multu.tst -TESTCASES +=3D packrl_ph.tst -TESTCASES +=3D pick_ph.tst -TESTCASES +=3D pick_qb.tst -TESTCASES +=3D precequ_ph_qbla.tst -TESTCASES +=3D precequ_ph_qbl.tst -TESTCASES +=3D precequ_ph_qbra.tst -TESTCASES +=3D precequ_ph_qbr.tst -TESTCASES +=3D preceq_w_phl.tst -TESTCASES +=3D preceq_w_phr.tst -TESTCASES +=3D preceu_ph_qbla.tst -TESTCASES +=3D preceu_ph_qbl.tst -TESTCASES +=3D preceu_ph_qbra.tst -TESTCASES +=3D preceu_ph_qbr.tst -TESTCASES +=3D precrq_ph_w.tst -TESTCASES +=3D precrq_qb_ph.tst -TESTCASES +=3D precrq_rs_ph_w.tst -TESTCASES +=3D precrqu_s_qb_ph.tst -TESTCASES +=3D raddu_w_qb.tst -TESTCASES +=3D rddsp.tst -TESTCASES +=3D repl_ph.tst -TESTCASES +=3D repl_qb.tst -TESTCASES +=3D replv_ph.tst -TESTCASES +=3D replv_qb.tst -TESTCASES +=3D shilo.tst -TESTCASES +=3D shilov.tst -TESTCASES +=3D shll_ph.tst -TESTCASES +=3D shll_qb.tst -TESTCASES +=3D shll_s_ph.tst -TESTCASES +=3D shll_s_w.tst -TESTCASES +=3D shllv_ph.tst -TESTCASES +=3D shllv_qb.tst -TESTCASES +=3D shllv_s_ph.tst -TESTCASES +=3D shllv_s_w.tst -TESTCASES +=3D shra_ph.tst -TESTCASES +=3D shra_r_ph.tst -TESTCASES +=3D shra_r_w.tst -TESTCASES +=3D shrav_ph.tst -TESTCASES +=3D shrav_r_ph.tst -TESTCASES +=3D shrav_r_w.tst -TESTCASES +=3D shrl_qb.tst -TESTCASES +=3D shrlv_qb.tst -TESTCASES +=3D subq_ph.tst -TESTCASES +=3D subq_s_ph.tst -TESTCASES +=3D subq_s_w.tst -TESTCASES +=3D subu_qb.tst -TESTCASES +=3D subu_s_qb.tst -TESTCASES +=3D wrdsp.tst - -all: $(TESTCASES) - -%.tst: %.c - $(CC) $(CFLAGS) $< -o $@ - -check: $(TESTCASES) - @for case in $(TESTCASES); do \ - echo $(SIM) $(SIM_FLAGS) ./$$case;\ - $(SIM) $(SIM_FLAGS) ./$$case; \ - done - -clean: - $(RM) -rf $(TESTCASES) diff --git a/tests/tcg/mips/mips32-dspr2/Makefile b/tests/tcg/mips/mips32-d= spr2/Makefile deleted file mode 100644 index ed19581..0000000 --- a/tests/tcg/mips/mips32-dspr2/Makefile +++ /dev/null @@ -1,71 +0,0 @@ --include ../../config-host.mak - -CROSS=3Dmips64el-unknown-linux-gnu- - -SIM=3Dqemu-mipsel -SIM_FLAGS=3D-cpu 74Kf - -CC =3D $(CROSS)gcc -CFLAGS =3D -mabi=3D32 -march=3Dmips32r2 -mgp32 -mdspr2 -static - -TESTCASES =3D absq_s_qb.tst -TESTCASES +=3D addqh_ph.tst -TESTCASES +=3D addqh_r_ph.tst -TESTCASES +=3D addqh_r_w.tst -TESTCASES +=3D addqh_w.tst -TESTCASES +=3D adduh_qb.tst -TESTCASES +=3D adduh_r_qb.tst -TESTCASES +=3D addu_ph.tst -TESTCASES +=3D addu_s_ph.tst -TESTCASES +=3D append.tst -TESTCASES +=3D balign.tst -TESTCASES +=3D cmpgdu_eq_qb.tst -TESTCASES +=3D cmpgdu_le_qb.tst -TESTCASES +=3D cmpgdu_lt_qb.tst -TESTCASES +=3D dpaqx_sa_w_ph.tst -TESTCASES +=3D dpa_w_ph.tst -TESTCASES +=3D dpax_w_ph.tst -TESTCASES +=3D dpaqx_s_w_ph.tst -TESTCASES +=3D dpsqx_sa_w_ph.tst -TESTCASES +=3D dpsqx_s_w_ph.tst -TESTCASES +=3D dps_w_ph.tst -TESTCASES +=3D dpsx_w_ph.tst -TESTCASES +=3D mul_ph.tst -TESTCASES +=3D mulq_rs_w.tst -TESTCASES +=3D mulq_s_ph.tst -TESTCASES +=3D mulq_s_w.tst -TESTCASES +=3D mulsaq_s_w_ph.tst -TESTCASES +=3D mulsa_w_ph.tst -TESTCASES +=3D mul_s_ph.tst -TESTCASES +=3D precr_qb_ph.tst -TESTCASES +=3D precr_sra_ph_w.tst -TESTCASES +=3D precr_sra_r_ph_w.tst -TESTCASES +=3D prepend.tst -TESTCASES +=3D shra_qb.tst -TESTCASES +=3D shra_r_qb.tst -TESTCASES +=3D shrav_qb.tst -TESTCASES +=3D shrav_r_qb.tst -TESTCASES +=3D shrl_ph.tst -TESTCASES +=3D shrlv_ph.tst -TESTCASES +=3D subqh_ph.tst -TESTCASES +=3D subqh_r_ph.tst -TESTCASES +=3D subqh_r_w.tst -TESTCASES +=3D subqh_w.tst -TESTCASES +=3D subuh_qb.tst -TESTCASES +=3D subuh_r_qb.tst -TESTCASES +=3D subu_ph.tst -TESTCASES +=3D subu_s_ph.tst - -all: $(TESTCASES) - -%.tst: %.c - $(CC) $(CFLAGS) $< -o $@ - -check: $(TESTCASES) - @for case in $(TESTCASES); do \ - echo $(SIM) $(SIM_FLAGS) ./$$case;\ - $(SIM) $(SIM_FLAGS) ./$$case; \ - done - -clean: - $(RM) -rf $(TESTCASES) diff --git a/tests/tcg/mips/mips64-dsp/Makefile b/tests/tcg/mips/mips64-dsp= /Makefile deleted file mode 100644 index b2ac6b3..0000000 --- a/tests/tcg/mips/mips64-dsp/Makefile +++ /dev/null @@ -1,306 +0,0 @@ - -CROSS_COMPILE ?=3D mips64el-unknown-linux-gnu- - -SIM =3D qemu-system-mips64el -SIMFLAGS =3D -nographic -cpu mips64dspr2 -kernel - -AS =3D $(CROSS_COMPILE)as -LD =3D $(CROSS_COMPILE)ld -CC =3D $(CROSS_COMPILE)gcc -AR =3D $(CROSS_COMPILE)ar -NM =3D $(CROSS_COMPILE)nm -STRIP =3D $(CROSS_COMPILE)strip -RANLIB =3D $(CROSS_COMPILE)ranlib -OBJCOPY =3D $(CROSS_COMPILE)objcopy -OBJDUMP =3D $(CROSS_COMPILE)objdump - -VECTORS_OBJ ?=3D ./head.o ./printf.o - -HEAD_FLAGS ?=3D -nostdinc -mabi=3D64 -G 0 -mno-abicalls -fno-pic -pipe \ - -msoft-float -march=3Dmips64 -Wa,-mips64 -Wa,--trap \ - -msym32 -DKBUILD_64BIT_SYM32 -I./ - -CFLAGS ?=3D -nostdinc -mabi=3D64 -G 0 -mno-abicalls -fno-pic -fno-builtin = \ - -pipe -march=3Dmips64r2 -mgp64 -mdsp -static -Wa,--trap -msym32 \ - -DKBUILD_64BIT_SYM32 -I./ - -LDFLAGS =3D -T./mips_boot.lds -L./ -FLAGS =3D -nostdlib -mabi=3D64 -march=3Dmips64r2 -mgp64 -mdsp - - -#TESTCASES =3D absq_s_ob.tst -TESTCASES =3D absq_s_ph.tst -TESTCASES +=3D absq_s_pw.tst -TESTCASES +=3D absq_s_qh.tst -TESTCASES +=3D absq_s_w.tst -TESTCASES +=3D addq_ph.tst -TESTCASES +=3D addq_pw.tst -TESTCASES +=3D addq_qh.tst -TESTCASES +=3D addq_s_ph.tst -TESTCASES +=3D addq_s_pw.tst -TESTCASES +=3D addq_s_qh.tst -TESTCASES +=3D addq_s_w.tst -TESTCASES +=3D addsc.tst -TESTCASES +=3D addu_ob.tst -TESTCASES +=3D addu_qb.tst -TESTCASES +=3D addu_s_ob.tst -TESTCASES +=3D addu_s_qb.tst -TESTCASES +=3D addwc.tst -TESTCASES +=3D bitrev.tst -TESTCASES +=3D bposge32.tst -TESTCASES +=3D bposge64.tst -TESTCASES +=3D cmp_eq_ph.tst -TESTCASES +=3D cmp_eq_pw.tst -TESTCASES +=3D cmp_eq_qh.tst -TESTCASES +=3D cmpgu_eq_ob.tst -TESTCASES +=3D cmpgu_eq_qb.tst -TESTCASES +=3D cmpgu_le_ob.tst -TESTCASES +=3D cmpgu_le_qb.tst -TESTCASES +=3D cmpgu_lt_ob.tst -TESTCASES +=3D cmpgu_lt_qb.tst -TESTCASES +=3D cmp_le_ph.tst -TESTCASES +=3D cmp_le_pw.tst -TESTCASES +=3D cmp_le_qh.tst -TESTCASES +=3D cmp_lt_ph.tst -TESTCASES +=3D cmp_lt_pw.tst -TESTCASES +=3D cmp_lt_qh.tst -TESTCASES +=3D cmpu_eq_ob.tst -TESTCASES +=3D cmpu_eq_qb.tst -TESTCASES +=3D cmpu_le_ob.tst -TESTCASES +=3D cmpu_le_qb.tst -TESTCASES +=3D cmpu_lt_ob.tst -TESTCASES +=3D cmpu_lt_qb.tst -#TESTCASES +=3D dappend.tst -TESTCASES +=3D dextp.tst -TESTCASES +=3D dextpdp.tst -TESTCASES +=3D dextpdpv.tst -TESTCASES +=3D dextpv.tst -TESTCASES +=3D dextr_l.tst -TESTCASES +=3D dextr_r_l.tst -TESTCASES +=3D dextr_rs_l.tst -TESTCASES +=3D dextr_rs_w.tst -TESTCASES +=3D dextr_r_w.tst -TESTCASES +=3D dextr_s_h.tst -TESTCASES +=3D dextrv_l.tst -TESTCASES +=3D dextrv_r_l.tst -TESTCASES +=3D dextrv_rs_l.tst -TESTCASES +=3D dextrv_rs_w.tst -TESTCASES +=3D dextrv_r_w.tst -TESTCASES +=3D dextrv_s_h.tst -TESTCASES +=3D dextrv_w.tst -TESTCASES +=3D dextr_w.tst -TESTCASES +=3D dinsv.tst -TESTCASES +=3D dmadd.tst -TESTCASES +=3D dmaddu.tst -TESTCASES +=3D dmsub.tst -TESTCASES +=3D dmsubu.tst -TESTCASES +=3D dmthlip.tst -TESTCASES +=3D dpaq_sa_l_pw.tst -TESTCASES +=3D dpaq_sa_l_w.tst -TESTCASES +=3D dpaq_s_w_ph.tst -TESTCASES +=3D dpaq_s_w_qh.tst -TESTCASES +=3D dpau_h_obl.tst -TESTCASES +=3D dpau_h_obr.tst -TESTCASES +=3D dpau_h_qbl.tst -TESTCASES +=3D dpau_h_qbr.tst -TESTCASES +=3D dpsq_sa_l_pw.tst -TESTCASES +=3D dpsq_sa_l_w.tst -TESTCASES +=3D dpsq_s_w_ph.tst -TESTCASES +=3D dpsq_s_w_qh.tst -TESTCASES +=3D dpsu_h_obl.tst -TESTCASES +=3D dpsu_h_obr.tst -TESTCASES +=3D dpsu_h_qbl.tst -TESTCASES +=3D dpsu_h_qbr.tst -TESTCASES +=3D dshilo.tst -TESTCASES +=3D dshilov.tst -TESTCASES +=3D extp.tst -TESTCASES +=3D extpdp.tst -TESTCASES +=3D extpdpv.tst -TESTCASES +=3D extpv.tst -TESTCASES +=3D extr_rs_w.tst -TESTCASES +=3D extr_r_w.tst -TESTCASES +=3D extr_s_h.tst -TESTCASES +=3D extrv_rs_w.tst -TESTCASES +=3D extrv_r_w.tst -TESTCASES +=3D extrv_s_h.tst -TESTCASES +=3D extrv_w.tst -TESTCASES +=3D extr_w.tst -TESTCASES +=3D insv.tst -TESTCASES +=3D lbux.tst -TESTCASES +=3D lhx.tst -TESTCASES +=3D lwx.tst -TESTCASES +=3D ldx.tst -TESTCASES +=3D madd.tst -TESTCASES +=3D maddu.tst -TESTCASES +=3D maq_sa_w_phl.tst -TESTCASES +=3D maq_sa_w_phr.tst -TESTCASES +=3D maq_sa_w_qhll.tst -TESTCASES +=3D maq_sa_w_qhlr.tst -TESTCASES +=3D maq_sa_w_qhrl.tst -TESTCASES +=3D maq_sa_w_qhrr.tst -TESTCASES +=3D maq_s_l_pwl.tst -TESTCASES +=3D maq_s_l_pwr.tst -TESTCASES +=3D maq_s_w_phl.tst -TESTCASES +=3D maq_s_w_phr.tst -TESTCASES +=3D maq_s_w_qhll.tst -TESTCASES +=3D maq_s_w_qhlr.tst -TESTCASES +=3D maq_s_w_qhrl.tst -TESTCASES +=3D maq_s_w_qhrr.tst -TESTCASES +=3D mfhi.tst -TESTCASES +=3D mflo.tst -TESTCASES +=3D modsub.tst -TESTCASES +=3D msub.tst -TESTCASES +=3D msubu.tst -TESTCASES +=3D mthi.tst -TESTCASES +=3D mthlip.tst -TESTCASES +=3D mtlo.tst -TESTCASES +=3D muleq_s_pw_qhl.tst -TESTCASES +=3D muleq_s_pw_qhr.tst -TESTCASES +=3D muleq_s_w_phl.tst -TESTCASES +=3D muleq_s_w_phr.tst -TESTCASES +=3D muleu_s_ph_qbl.tst -TESTCASES +=3D muleu_s_ph_qbr.tst -TESTCASES +=3D muleu_s_qh_obl.tst -TESTCASES +=3D muleu_s_qh_obr.tst -TESTCASES +=3D mulq_rs_ph.tst -TESTCASES +=3D mulq_rs_qh.tst -TESTCASES +=3D mulsaq_s_l_pw.tst -TESTCASES +=3D mulsaq_s_w_qh.tst -TESTCASES +=3D mult.tst -TESTCASES +=3D multu.tst -TESTCASES +=3D packrl_ph.tst -TESTCASES +=3D packrl_pw.tst -TESTCASES +=3D pick_ob.tst -TESTCASES +=3D pick_ph.tst -TESTCASES +=3D pick_pw.tst -TESTCASES +=3D pick_qb.tst -TESTCASES +=3D pick_qh.tst -#TESTCASES +=3D preceq_l_pwl.tst -#TESTCASES +=3D preceq_l_pwr.tst -TESTCASES +=3D preceq_pw_qhla.tst -TESTCASES +=3D preceq_pw_qhl.tst -TESTCASES +=3D preceq_pw_qhra.tst -TESTCASES +=3D preceq_pw_qhr.tst -TESTCASES +=3D precequ_ph_qbla.tst -TESTCASES +=3D precequ_ph_qbl.tst -TESTCASES +=3D precequ_ph_qbra.tst -TESTCASES +=3D precequ_ph_qbr.tst -#TESTCASES +=3D precequ_qh_obla.tst -#TESTCASES +=3D precequ_qh_obl.tst -#TESTCASES +=3D precequ_qh_obra.tst -#TESTCASES +=3D precequ_qh_obr.tst -TESTCASES +=3D preceq_w_phl.tst -TESTCASES +=3D preceq_w_phr.tst -TESTCASES +=3D preceu_ph_qbla.tst -TESTCASES +=3D preceu_ph_qbl.tst -TESTCASES +=3D preceu_ph_qbra.tst -TESTCASES +=3D preceu_ph_qbr.tst -TESTCASES +=3D preceu_qh_obla.tst -TESTCASES +=3D preceu_qh_obl.tst -TESTCASES +=3D preceu_qh_obra.tst -TESTCASES +=3D preceu_qh_obr.tst -#TESTCASES +=3D precr_ob_qh.tst -TESTCASES +=3D precrq_ob_qh.tst -TESTCASES +=3D precrq_ph_w.tst -TESTCASES +=3D precrq_pw_l.tst -TESTCASES +=3D precrq_qb_ph.tst -TESTCASES +=3D precrq_qh_pw.tst -TESTCASES +=3D precrq_rs_ph_w.tst -TESTCASES +=3D precrq_rs_qh_pw.tst -TESTCASES +=3D precrqu_s_ob_qh.tst -TESTCASES +=3D precrqu_s_qb_ph.tst -#TESTCASES +=3D precr_sra_qh_pw.tst -#TESTCASES +=3D precr_sra_r_qh_pw.tst -#TESTCASES +=3D prependd.tst -#TESTCASES +=3D prependw.tst -#TESTCASES +=3D raddu_l_ob.tst -TESTCASES +=3D raddu_w_qb.tst -TESTCASES +=3D rddsp.tst -TESTCASES +=3D repl_ob.tst -TESTCASES +=3D repl_ph.tst -TESTCASES +=3D repl_pw.tst -TESTCASES +=3D repl_qb.tst -TESTCASES +=3D repl_qh.tst -TESTCASES +=3D replv_ob.tst -TESTCASES +=3D replv_ph.tst -TESTCASES +=3D replv_pw.tst -TESTCASES +=3D replv_qb.tst -TESTCASES +=3D shilo.tst -TESTCASES +=3D shilov.tst -TESTCASES +=3D shll_ob.tst -TESTCASES +=3D shll_ph.tst -TESTCASES +=3D shll_pw.tst -TESTCASES +=3D shll_qb.tst -TESTCASES +=3D shll_qh.tst -TESTCASES +=3D shll_s_ph.tst -TESTCASES +=3D shll_s_pw.tst -TESTCASES +=3D shll_s_qh.tst -TESTCASES +=3D shll_s_w.tst -TESTCASES +=3D shllv_ob.tst -TESTCASES +=3D shllv_ph.tst -TESTCASES +=3D shllv_pw.tst -TESTCASES +=3D shllv_qb.tst -TESTCASES +=3D shllv_qh.tst -TESTCASES +=3D shllv_s_ph.tst -TESTCASES +=3D shllv_s_pw.tst -TESTCASES +=3D shllv_s_qh.tst -TESTCASES +=3D shllv_s_w.tst -#TESTCASES +=3D shra_ob.tst -TESTCASES +=3D shra_ph.tst -TESTCASES +=3D shra_pw.tst -TESTCASES +=3D shra_qh.tst -#TESTCASES +=3D shra_r_ob.tst -TESTCASES +=3D shra_r_ph.tst -TESTCASES +=3D shra_r_pw.tst -TESTCASES +=3D shra_r_qh.tst -TESTCASES +=3D shra_r_w.tst -TESTCASES +=3D shrav_ph.tst -TESTCASES +=3D shrav_pw.tst -TESTCASES +=3D shrav_qh.tst -TESTCASES +=3D shrav_r_ph.tst -TESTCASES +=3D shrav_r_pw.tst -TESTCASES +=3D shrav_r_qh.tst -TESTCASES +=3D shrav_r_w.tst -TESTCASES +=3D shrl_ob.tst -TESTCASES +=3D shrl_qb.tst -#TESTCASES +=3D shrl_qh.tst -TESTCASES +=3D shrlv_ob.tst -TESTCASES +=3D shrlv_qb.tst -#TESTCASES +=3D shrlv_qh.tst -TESTCASES +=3D subq_ph.tst -TESTCASES +=3D subq_pw.tst -TESTCASES +=3D subq_qh.tst -TESTCASES +=3D subq_s_ph.tst -TESTCASES +=3D subq_s_pw.tst -TESTCASES +=3D subq_s_qh.tst -TESTCASES +=3D subq_s_w.tst -TESTCASES +=3D subu_ob.tst -TESTCASES +=3D subu_qb.tst -TESTCASES +=3D subu_s_ob.tst -TESTCASES +=3D subu_s_qb.tst -TESTCASES +=3D wrdsp.tst - -all: build - -head.o : head.S - $(Q)$(CC) $(HEAD_FLAGS) -D"STACK_TOP=3D0xffffffff80200000" -c $< -o $@ - -%.o : %.S - $(CC) $(CFLAGS) -c $< -o $@ - -%.o : %.c - $(CC) $(CFLAGS) -c $< -o $@ - -%.tst: %.o $(VECTORS_OBJ) - $(CC) $(VECTORS_OBJ) $(FLAGS) $(LDFLAGS) $< -o $@ - -build: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES) - -check: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES) - @for case in $(TESTCASES); do \ - echo $(SIM) $(SIMFLAGS) ./$$case; \ - $(SIM) $(SIMFLAGS) ./$$case & (sleep 1; killall $(SIM)); \ - done - -clean: - $(Q)rm -f *.o *.tst *.a diff --git a/tests/tcg/mips/mips64-dsp/absq_s_ob.c b/tests/tcg/mips/mips64-= dsp/absq_s_ob.c deleted file mode 100644 index 6214031..0000000 --- a/tests/tcg/mips/mips64-dsp/absq_s_ob.c +++ /dev/null @@ -1,63 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result, dspcontrol; - rt =3D 0x7F7F7F7F7F7F7F7F; - result =3D 0x7F7F7F7F7F7F7F7F; - - - __asm - (".set mips64\n\t" - "absq_s.ob %0 %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("absq_s.ob test 1 error\n"); - - return -1; - } - - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd >> 20; - rd =3D rd & 0x1; - if (rd !=3D 0) { - printf("absq_s.ob test 1 dspcontrol overflow flag error\n"); - - return -1; - } - - rt =3D 0x80FFFFFFFFFFFFFF; - result =3D 0x7F01010101010101; - - __asm - ("absq_s.ob %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("absq_s.ob test 2 error\n"); - - return -1; - } - - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd =3D rd >> 20; - rd =3D rd & 0x1; - if (rd !=3D 1) { - printf("absq_s.ob test 2 dspcontrol overflow flag error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/absq_s_ph.c b/tests/tcg/mips/mips64-= dsp/absq_s_ph.c deleted file mode 100644 index 238416d..0000000 --- a/tests/tcg/mips/mips64-dsp/absq_s_ph.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x10017EFD; - result =3D 0x10017EFD; - - __asm - ("absq_s.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("absq_s.ph wrong\n"); - - return -1; - } - - rt =3D 0x8000A536; - result =3D 0x7FFF5ACA; - - __asm - ("absq_s.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("absq_s.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/absq_s_pw.c b/tests/tcg/mips/mips64-= dsp/absq_s_pw.c deleted file mode 100644 index 48fc763..0000000 --- a/tests/tcg/mips/mips64-dsp/absq_s_pw.c +++ /dev/null @@ -1,66 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result, dspcontrol; - rd =3D 0; - rt =3D 0x7F7F7F7F7F7F7F7F; - result =3D 0x7F7F7F7F7F7F7F7F; - - - __asm - ("absq_s.pw %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("absq_s.pw test 1 error\n"); - - return -1; - } - - rd =3D 0; - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd >> 20; - rd =3D rd & 0x1; - if (rd !=3D 0) { - printf("absq_s.pw test 1 dspcontrol overflow flag error\n"); - - return -1; - } - - rd =3D 0; - rt =3D 0x80000000FFFFFFFF; - result =3D 0x7FFFFFFF00000001; - - __asm - ("absq_s.pw %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("absq_s.pw test 2 error\n"); - - return -1; - } - - rd =3D 0; - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd =3D rd >> 20; - rd =3D rd & 0x1; - if (rd !=3D 1) { - printf("absq_s.pw test 2 dspcontrol overflow flag error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/absq_s_qh.c b/tests/tcg/mips/mips64-= dsp/absq_s_qh.c deleted file mode 100644 index 9001a9e..0000000 --- a/tests/tcg/mips/mips64-dsp/absq_s_qh.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result, dspcontrol; - rd =3D 0; - rt =3D 0x7F7F7F7F7F7F7F7F; - result =3D 0x7F7F7F7F7F7F7F7F; - - - __asm - ("absq_s.qh %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("absq_s.qh test 1 error\n"); - - return -1; - } - - rd =3D 0; - rt =3D 0x8000FFFFFFFFFFFF; - result =3D 0x7FFF000100000001; - - __asm - ("absq_s.pw %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("absq_s.rw test 2 error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/absq_s_w.c b/tests/tcg/mips/mips64-d= sp/absq_s_w.c deleted file mode 100644 index 414c8bd..0000000 --- a/tests/tcg/mips/mips64-dsp/absq_s_w.c +++ /dev/null @@ -1,48 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("absq_s_w.ph wrong\n"); - - return -1; - } - - rt =3D 0x80030000; - result =3D 0x7FFD0000; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("absq_s_w.ph wrong\n"); - - return -1; - } - - rt =3D 0x31036080; - result =3D 0x31036080; - __asm - ("absq_s.w %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("absq_s_w.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_ph.c b/tests/tcg/mips/mips64-ds= p/addq_ph.c deleted file mode 100644 index 22a36d9..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_ph.c +++ /dev/null @@ -1,57 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x10101010; - result =3D 0x100F100F; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("1 addq.ph wrong\n"); - - return -1; - } - - rs =3D 0x3712847D; - rt =3D 0x0031AF2D; - result =3D 0x374333AA; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("2 addq.ph wrong\n"); - - return -1; - } - - rs =3D 0x7fff847D; - rt =3D 0x0031AF2D; - result =3D 0xffffffff803033AA; - __asm - ("addq.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - __asm("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - - if (rd !=3D result || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("3 addq.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_pw.c b/tests/tcg/mips/mips64-ds= p/addq_pw.c deleted file mode 100644 index 99a7668..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_pw.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456787FFFFFFF; - rt =3D 0x1111111100000101; - result =3D 0x2345678980000100; - dspresult =3D 0x1; - - __asm - ("addq.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq.pw error\n"); - - return -1; - } - - rs =3D 0x1234567880FFFFFF; - rt =3D 0x1111111180000001; - result =3D 0x2345678901000000; - dspresult =3D 0x1; - - __asm - ("addq.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_qh.c b/tests/tcg/mips/mips64-ds= p/addq_qh.c deleted file mode 100644 index 4b874af..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_qh.c +++ /dev/null @@ -1,28 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456787FFF8010; - rt =3D 0x1111111100018000; - result =3D 0x2345678980000010; - dspresult =3D 0x1; - - __asm - ("addq.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_s_ph.c b/tests/tcg/mips/mips64-= dsp/addq_s_ph.c deleted file mode 100644 index ad84cdc..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_s_ph.c +++ /dev/null @@ -1,84 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x10101010; - result =3D 0x100F100F; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("1 addq_s.ph wrong\n"); - - return -1; - } - - rs =3D 0x3712847D; - rt =3D 0x0031AF2D; - result =3D 0x37438000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("2 addq_s.ph wrong\n"); - - return -1; - } - - rs =3D 0x7fff847D; - rt =3D 0x0031AF2D; - result =3D 0x7fff8000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("3 addq_s.ph wrong\n"); - - return -1; - } - - rs =3D 0x8030847D; - rt =3D 0x8a00AF2D; - result =3D 0xffffffff80008000; - __asm - ("addq_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - __asm - ("rddsp %0\n\t" - : "=3Dr"(dsp) - ); - - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("4 addq_s.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_s_pw.c b/tests/tcg/mips/mips64-= dsp/addq_s_pw.c deleted file mode 100644 index 2e380bb..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_s_pw.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rs =3D 0x123456787FFFFFFF; - rt =3D 0x1111111100000001; - result =3D 0x234567897FFFFFFF; - dspresult =3D 0x1; - - __asm - ("addq_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq_s.pw error\n"); - - return -1; - } - - rs =3D 0x80FFFFFFE00000FF; - rt =3D 0x80000001200000DD; - result =3D 0x80000000000001DC; - dspresult =3D 0x01; - - __asm - ("addq_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq_s.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_s_qh.c b/tests/tcg/mips/mips64-= dsp/addq_s_qh.c deleted file mode 100644 index b638a2b..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_s_qh.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rs =3D 0x123456787FFF8000; - rt =3D 0x1111111100028000; - result =3D 0x234567897FFF8000; - dspresult =3D 0x1; - - __asm - ("addq_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addq_s.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addq_s_w.c b/tests/tcg/mips/mips64-d= sp/addq_s_w.c deleted file mode 100644 index 3e08f5d..0000000 --- a/tests/tcg/mips/mips64-dsp/addq_s_w.c +++ /dev/null @@ -1,48 +0,0 @@ -#include "io.h" - -int main() -{ - long long rd, rs, rt; - long long result; - - rt =3D 0x10017EFD; - rs =3D 0x11111111; - result =3D 0x2112900e; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addq_s.w error\n"); - } - - rt =3D 0x80017EFD; - rs =3D 0x81111111; - result =3D 0xffffffff80000000; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addq_s.w error\n"); - } - - rt =3D 0x7fffffff; - rs =3D 0x01111111; - result =3D 0x7fffffff; - - __asm - ("addq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addq_s.w error\n"); - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addsc.c b/tests/tcg/mips/mips64-dsp/= addsc.c deleted file mode 100644 index 4b684b9..0000000 --- a/tests/tcg/mips/mips64-dsp/addsc.c +++ /dev/null @@ -1,39 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x0000000F; - rt =3D 0x00000001; - result =3D 0x00000010; - __asm - ("addsc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("1 addsc wrong\n"); - - return -1; - } - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x00001110; - __asm - ("addsc %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 13) & 0x01) !=3D 1)) { - printf("2 addsc wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addu_ob.c b/tests/tcg/mips/mips64-ds= p/addu_ob.c deleted file mode 100644 index 17f9c66..0000000 --- a/tests/tcg/mips/mips64-dsp/addu_ob.c +++ /dev/null @@ -1,28 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x3456123498DEF390; - result =3D 0x468A68AC329AD180; - dspresult =3D 0x01; - - __asm - ("addu.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addu.ob error\n\t"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addu_qb.c b/tests/tcg/mips/mips64-ds= p/addu_qb.c deleted file mode 100644 index 3b9b5fc..0000000 --- a/tests/tcg/mips/mips64-dsp/addu_qb.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x00FF00FF; - rt =3D 0x00010001; - result =3D 0x00000000; - __asm - ("addu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("1 addu.qb wrong\n"); - - return -1; - } - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0xFFFFFFFFFF011112; - __asm - ("addu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("2 addu.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addu_s_ob.c b/tests/tcg/mips/mips64-= dsp/addu_s_ob.c deleted file mode 100644 index e89a463..0000000 --- a/tests/tcg/mips/mips64-dsp/addu_s_ob.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rs =3D 0x123456789ABCDEF0; - rt =3D 0x3456123498DEF390; - result =3D 0x468A68ACFFFFFFFF; - dspresult =3D 0x01; - - __asm - ("addu_s.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addu_s.ob error\n\t"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addu_s_qb.c b/tests/tcg/mips/mips64-= dsp/addu_s_qb.c deleted file mode 100644 index cb84293..0000000 --- a/tests/tcg/mips/mips64-dsp/addu_s_qb.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x10FF01FF; - rt =3D 0x10010001; - result =3D 0x20FF01FF; - __asm - ("addu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x1) !=3D 1)) { - printf("1 addu_s.qb error 1\n"); - - return -1; - } - - rs =3D 0xFFFFFFFFFFFF1111; - rt =3D 0x00020001; - result =3D 0xFFFFFFFFFFFF1112; - __asm - ("addu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x1) !=3D 1)) { - printf("2 addu_s.qb error 2\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/addwc.c b/tests/tcg/mips/mips64-dsp/= addwc.c deleted file mode 100644 index 5929cd2..0000000 --- a/tests/tcg/mips/mips64-dsp/addwc.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dspi, dspo; - long long result; - - rs =3D 0x10FF01FF; - rt =3D 0x10010001; - dspi =3D 0x00002000; - result =3D 0x21000201; - __asm - ("wrdsp %3\n" - "addwc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dspi) - ); - if (rd !=3D result) { - printf("1 addwc wrong\n"); - - return -1; - } - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - dspi =3D 0x00; - result =3D 0x00011112; - __asm - ("wrdsp %3\n" - "addwc %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dspi) - ); - if (rd !=3D result) { - printf("2 addwc wrong\n"); - - return -1; - } - - rs =3D 0x8FFF1111; - rt =3D 0x80020001; - dspi =3D 0x00; - result =3D 0x10011112; - __asm - ("wrdsp %4\n" - "addwc %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspo) - : "r"(rs), "r"(rt), "r"(dspi) - ); - if ((rd !=3D result) || (((dspo >> 20) & 0x01) !=3D 1)) { - printf("3 addwc wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/bitrev.c b/tests/tcg/mips/mips64-dsp= /bitrev.c deleted file mode 100644 index ac24ef3..0000000 --- a/tests/tcg/mips/mips64-dsp/bitrev.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x00001E6A; - - __asm - ("bitrev %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("bitrev wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/bposge32.c b/tests/tcg/mips/mips64-d= sp/bposge32.c deleted file mode 100644 index 97bce44..0000000 --- a/tests/tcg/mips/mips64-dsp/bposge32.c +++ /dev/null @@ -1,50 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long dsp, sum; - long long result; - - dsp =3D 0x20; - sum =3D 0x01; - result =3D 0x02; - - __asm - ("wrdsp %1\n\t" - "bposge32 test1\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test1:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - if (sum !=3D result) { - printf("bposge32 wrong\n"); - - return -1; - } - - dsp =3D 0x10; - sum =3D 0x01; - result =3D 0xA4; - - __asm - ("wrdsp %1\n\t" - "bposge32 test2\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test2:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - if (sum !=3D result) { - printf("bposge32 wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/bposge64.c b/tests/tcg/mips/mips64-d= sp/bposge64.c deleted file mode 100644 index 36161ad..0000000 --- a/tests/tcg/mips/mips64-dsp/bposge64.c +++ /dev/null @@ -1,50 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long dsp, sum; - long long result; - - dsp =3D 0x40; - sum =3D 0x01; - result =3D 0x02; - - __asm - ("wrdsp %1\n\t" - "bposge64 test1\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test1:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - if (sum !=3D result) { - printf("bposge64 wrong\n"); - - return -1; - } - - dsp =3D 0x10; - sum =3D 0x01; - result =3D 0xA4; - - __asm - ("wrdsp %1\n\t" - "bposge64 test2\n\t" - "nop\n\t" - "addi %0, 0xA2\n\t" - "nop\n\t" - "test2:\n\t" - "addi %0, 0x01\n\t" - : "+r"(sum) - : "r"(dsp) - ); - if (sum !=3D result) { - printf("bposge64 wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_ph.c b/tests/tcg/mips/mips64-= dsp/cmp_eq_ph.c deleted file mode 100644 index 63069d0..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_eq_ph.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x00; - __asm - ("cmp.eq.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.eq.ph wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x03; - __asm - ("cmp.eq.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.eq.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_pw.c b/tests/tcg/mips/mips64-= dsp/cmp_eq_pw.c deleted file mode 100644 index bae4c06..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_eq_pw.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEFF; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x03; - - __asm - ("cmp.eq.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("1 cmp.eq.pw error\n"); - - return -1; - } - - rs =3D 0x123456799ABCDEFe; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x00; - - __asm - ("cmp.eq.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("2 cmp.eq.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_qh.c b/tests/tcg/mips/mips64-= dsp/cmp_eq_qh.c deleted file mode 100644 index 49ea271..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_eq_qh.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x0E; - - __asm - ("cmp.eq.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.eq.qh error\n"); - - return -1; - } - - rs =3D 0x12355a789A4CD3F0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x00; - - __asm - ("cmp.eq.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.eq.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_ph.c b/tests/tcg/mips/mips64-= dsp/cmp_le_ph.c deleted file mode 100644 index 12d24f1..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_le_ph.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x02; - __asm - ("cmp.le.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.le.ph wrong\n"); - - return -1; - } - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x03; - __asm - ("cmp.le.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.le.ph wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_pw.c b/tests/tcg/mips/mips64-= dsp/cmp_le_pw.c deleted file mode 100644 index 6acc43c..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_le_pw.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x03; - - __asm - ("cmp.le.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("1 cmp.le.pw error\n"); - - return -1; - } - - rs =3D 0x123456799ABCEEFF; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x00; - - __asm - ("cmp.le.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("2 cmp.le.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_qh.c b/tests/tcg/mips/mips64-= dsp/cmp_le_qh.c deleted file mode 100644 index c9ce216..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_le_qh.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x0F; - - __asm - ("cmp.le.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.le.qh error\n"); - - return -1; - } - - rs =3D 0x823456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x0f; - - __asm - ("cmp.le.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.le.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_ph.c b/tests/tcg/mips/mips64-= dsp/cmp_lt_ph.c deleted file mode 100644 index 1d91228..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_lt_ph.c +++ /dev/null @@ -1,41 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA33FF; - result =3D 0x02; - __asm - ("cmp.lt.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.lt.ph wrong\n"); - - return -1; - } - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmp.lt.ph %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - rd =3D (rd >> 24) & 0x03; - if (rd !=3D result) { - printf("cmp.lt.ph2 wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_pw.c b/tests/tcg/mips/mips64-= dsp/cmp_lt_pw.c deleted file mode 100644 index 87e74ca..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_lt_pw.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x01; - - __asm - ("cmp.lt.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("cmp.lt.pw error\n"); - - return -1; - } - - rs =3D 0x123456779ABCDEFf; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x02; - - __asm - ("cmp.lt.pw %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x03); - - if (dspreg !=3D dspresult) { - printf("cmp.lt.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_qh.c b/tests/tcg/mips/mips64-= dsp/cmp_lt_qh.c deleted file mode 100644 index 0a13a5e..0000000 --- a/tests/tcg/mips/mips64-dsp/cmp_lt_qh.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123558789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x01; - - __asm - ("cmp.lt.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.lt.qh error\n"); - - return -1; - } - - rs =3D 0x123356779ABbDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x0f; - - __asm - ("cmp.lt.qh %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0x0F); - - if (dspreg !=3D dspresult) { - printf("cmp.lt.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_eq_ob.c deleted file mode 100644 index 697d73d..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0xFE; - - __asm - ("cmpgu.eq.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.eq.ob error\n"); - - return -1; - } - - rs =3D 0x133456789ABCDEF0; - rt =3D 0x123556789ABCDEFF; - result =3D 0x3E; - - __asm - ("cmpgu.eq.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.eq.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_eq_qb.c deleted file mode 100644 index b41c443..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c +++ /dev/null @@ -1,38 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpgu.eq.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.eq.ph wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpgu.eq.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("cmpgu.eq.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_le_ob.c deleted file mode 100644 index 8b65f18..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0xFF; - - __asm - ("cmpgu.le.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.le.ob error\n"); - - return -1; - } - - rs =3D 0x823556789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0x3F; - - __asm - ("cmpgu.le.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.le.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_le_qb.c deleted file mode 100644 index dd2b091..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpgu.le.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("cmpgu.le.qb wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11766066; - result =3D 0x09; - __asm - ("cmpgu.le.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("cmpgu.le.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_lt_ob.c deleted file mode 100644 index 3e5c9dd..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0x01; - - __asm - ("cmpgu.lt.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.lt.ob error\n"); - - return -1; - } - - rs =3D 0x823455789ABCDEF0; - rt =3D 0x123356789ABCDEFF; - result =3D 0x21; - - __asm - ("cmpgu.lt.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.lt.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c b/tests/tcg/mips/mips6= 4-dsp/cmpgu_lt_qb.c deleted file mode 100644 index a467cb7..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c +++ /dev/null @@ -1,38 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpgu.lt.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("cmpgu.lt.qb wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11766066; - result =3D 0x00; - __asm - ("cmpgu.lt.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("cmpgu.lt.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c b/tests/tcg/mips/mips64= -dsp/cmpu_eq_ob.c deleted file mode 100644 index 4d1983e..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0xFE; - - __asm - ("cmpu.eq.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if (dspreg !=3D dspresult) { - printf("cmpu.eq.ob error\n"); - - return -1; - } - - rs =3D 0x133516713A0CD1F0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x00; - - __asm - ("cmpu.eq.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if (dspreg !=3D dspresult) { - printf("cmpu.eq.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c b/tests/tcg/mips/mips64= -dsp/cmpu_eq_qb.c deleted file mode 100644 index 28f3bec..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpu.eq.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.eq.qb wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpu.eq.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.eq.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_le_ob.c b/tests/tcg/mips/mips64= -dsp/cmpu_le_ob.c deleted file mode 100644 index 8acbd1c..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_le_ob.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0xFF; - - __asm - ("cmpu.le.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D dspreg >> 24; - if (dspreg !=3D dspresult) { - printf("cmpu.le.ob error\n"); - - return -1; - } - - rs =3D 0x823656789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x3F; - - __asm - ("cmpu.le.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D dspreg >> 24; - if (dspreg !=3D dspresult) { - printf("cmpu.le.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_le_qb.c b/tests/tcg/mips/mips64= -dsp/cmpu_le_qb.c deleted file mode 100644 index 8a17a08..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_le_qb.c +++ /dev/null @@ -1,41 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpu.le.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.le.qb wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpu.le.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.le.qb wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c b/tests/tcg/mips/mips64= -dsp/cmpu_lt_ob.c deleted file mode 100644 index 34e312d..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x01; - - __asm - ("cmpu.lt.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D dspreg >> 24; - if (dspreg !=3D dspresult) { - printf("cmpu.lt.ob error\n"); - - return -1; - } - - rs =3D 0x823156789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x41; - - __asm - ("cmpu.lt.ob %1, %2\n\t" - "rddsp %0" - : "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D dspreg >> 24; - if (dspreg !=3D dspresult) { - printf("cmpu.lt.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c b/tests/tcg/mips/mips64= -dsp/cmpu_lt_qb.c deleted file mode 100644 index adb75ee..0000000 --- a/tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpu.lt.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.lt.qb wrong\n"); - - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmpu.lt.qb %1, %2\n\t" - "rddsp %0\n\t" - : "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (dsp !=3D result) { - printf("cmpu.lt.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dappend.c b/tests/tcg/mips/mips64-ds= p/dappend.c deleted file mode 100644 index ba8e121..0000000 --- a/tests/tcg/mips/mips64-dsp/dappend.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long res; - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0x1234567887654321; - __asm - ("dappend %0, %1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("dappend error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0x2345678876543215; - __asm - ("dappend %0, %1, 0x4\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("dappend error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextp.c b/tests/tcg/mips/mips64-dsp/= dextp.c deleted file mode 100644 index a469cc0..0000000 --- a/tests/tcg/mips/mips64-dsp/dextp.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - int rs; - - rs =3D 0xabcd1234; - - achi =3D 0x12345678; - acli =3D 0x87654321; - res =3D 0xff; - resdsp =3D 0x0; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4\n\t" - "dextp %0, $ac1, 0x7\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 14) & 0x1; - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextp error\n"); - return -1; - } - - rs =3D 0xabcd1200; - - achi =3D 0x12345678; - acli =3D 0x87654321; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4\n\t" - "dextp %0, $ac1, 0x7\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 14) & 0x1; - if (dsp !=3D resdsp) { - printf("dextp error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextpdp.c b/tests/tcg/mips/mips64-ds= p/dextpdp.c deleted file mode 100644 index a2361e2..0000000 --- a/tests/tcg/mips/mips64-dsp/dextpdp.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp, resdsppos; - int rs; - int tmp1, tmp2; - - rs =3D 0xabcd1234; - - achi =3D 0x12345678; - acli =3D 0x87654321; - res =3D 0xff; - resdsp =3D 0x0; - resdsppos =3D 0x2c; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4\n\t" - "dextpdp %0, $ac1, 0x7\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - tmp1 =3D (dsp >> 14) & 0x1; - tmp2 =3D dsp & 0x3f; - - if ((tmp1 !=3D resdsp) || (rt !=3D res) || (tmp2 !=3D resdsppos)) { - printf("dextpdp error\n"); - return -1; - } - - rs =3D 0xabcd1200; - - achi =3D 0x12345678; - acli =3D 0x87654321; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4\n\t" - "dextpdp %0, $ac1, 0x7\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - tmp1 =3D (dsp >> 14) & 0x1; - - if (tmp1 !=3D resdsp) { - printf("dextpdp error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextpdpv.c b/tests/tcg/mips/mips64-d= sp/dextpdpv.c deleted file mode 100644 index 09c0b5b..0000000 --- a/tests/tcg/mips/mips64-dsp/dextpdpv.c +++ /dev/null @@ -1,63 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp, resdsppos; - int rsdsp; - int tmp1, tmp2; - - rsdsp =3D 0xabcd1234; - rs =3D 0x7; - achi =3D 0x12345678; - acli =3D 0x87654321; - res =3D 0xff; - resdsp =3D 0x0; - resdsppos =3D 0x2c; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4, 0x1\n\t" - "wrdsp %4\n\t" - "dextpdpv %0, $ac1, %5\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs) - ); - - tmp1 =3D (dsp >> 14) & 0x1; - tmp2 =3D dsp & 0x3f; - - if ((tmp1 !=3D resdsp) || (rt !=3D res) || (tmp2 !=3D resdsppos)) { - printf("dextpdpv error\n"); - return -1; - } - - rsdsp =3D 0xabcd1200; - rs =3D 0x7; - achi =3D 0x12345678; - acli =3D 0x87654321; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4, 0x1\n\t" - "wrdsp %4\n\t" - "dextpdpv %0, $ac1, %5\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs) - ); - - tmp1 =3D (dsp >> 14) & 0x1; - - if (tmp1 !=3D resdsp) { - printf("dextpdpv error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextpv.c b/tests/tcg/mips/mips64-dsp= /dextpv.c deleted file mode 100644 index 2626f3d..0000000 --- a/tests/tcg/mips/mips64-dsp/dextpv.c +++ /dev/null @@ -1,58 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp; - int rsdsp; - - rsdsp =3D 0xabcd1234; - rs =3D 0x7; - - achi =3D 0x12345678; - acli =3D 0x87654321; - res =3D 0xff; - resdsp =3D 0x0; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4, 0x1\n\t" - "wrdsp %4\n\t" - "dextpv %0, $ac1, %5\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs) - ); - dsp =3D (dsp >> 14) & 0x1; - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextpv error\n"); - return -1; - } - - rsdsp =3D 0xabcd1200; - rs =3D 0x7; - - achi =3D 0x12345678; - acli =3D 0x87654321; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "wrdsp %4, 0x1\n\t" - "wrdsp %4\n\t" - "dextpv %0, $ac1, %5\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs) - ); - dsp =3D (dsp >> 14) & 0x1; - if (dsp !=3D resdsp) { - printf("dextpv error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_l.c b/tests/tcg/mips/mips64-ds= p/dextr_l.c deleted file mode 100644 index 538846d..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_l.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt; - long long achi, acli; - long long res; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x2100000000123456; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextr.l %0, $ac1, 0x8\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli) - ); - if (rt !=3D res) { - printf("dextr.l error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x12345678; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextr.l %0, $ac1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli) - ); - if (rt !=3D res) { - printf("dextr.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_r_l.c b/tests/tcg/mips/mips64-= dsp/dextr_r_l.c deleted file mode 100644 index a10a9ab..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_r_l.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x2100000000123456; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_r.l %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_r.l error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x12345678; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_r.l %0, $ac1, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_r.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_r_w.c b/tests/tcg/mips/mips64-= dsp/dextr_r_w.c deleted file mode 100644 index 2774e9b..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_r_w.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x123456; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_r.w %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_r.w error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x12345678; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_r.w %0, $ac1, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_r.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_rs_l.c b/tests/tcg/mips/mips64= -dsp/dextr_rs_l.c deleted file mode 100644 index 1a202fe..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_rs_l.c +++ /dev/null @@ -1,52 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x8000000000000000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_rs.l %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_rs.l error\n"); - return -1; - } - - achi =3D 0x00; - acli =3D 0x12345678; - - res =3D 0x12345678; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_rs.l %0, $ac1, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_rs.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_rs_w.c b/tests/tcg/mips/mips64= -dsp/dextr_rs_w.c deleted file mode 100644 index ebe5f99..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_rs_w.c +++ /dev/null @@ -1,52 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0xffffffff80000000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_rs.w %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_rs.w error\n"); - return -1; - } - - achi =3D 0x00; - acli =3D 0x12345678; - - res =3D 0x123456; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_rs.w %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextr_rs.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_s_h.c b/tests/tcg/mips/mips64-= dsp/dextr_s_h.c deleted file mode 100644 index 1adb554..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_s_h.c +++ /dev/null @@ -1,73 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0xffffffffffff8000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_s.h %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("1 dextr_s.h error\n"); - return -1; - } - - achi =3D 0x77654321; - acli =3D 0x12345678; - - res =3D 0x7fff; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_s.h %0, $ac1, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("2 dextr_s.h error\n"); - return -1; - } - - achi =3D 0x00; - acli =3D 0x78; - - res =3D 0x7; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextr_s.h %0, $ac1, 0x4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("3 dextr_s.h error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextr_w.c b/tests/tcg/mips/mips64-ds= p/dextr_w.c deleted file mode 100644 index 79bed5d..0000000 --- a/tests/tcg/mips/mips64-dsp/dextr_w.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt; - long long achi, acli; - long long res; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x123456; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextr.w %0, $ac1, 0x8\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli) - ); - if (rt !=3D res) { - printf("dextr.w error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - - res =3D 0x12345678; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextr.w %0, $ac1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli) - ); - if (rt !=3D res) { - printf("dextr.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_l.c b/tests/tcg/mips/mips64-d= sp/dextrv_l.c deleted file mode 100644 index 2e6187f..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_l.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long res; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x2100000000123456; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextrv.l %0, $ac1, %3\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli), "r"(rs) - ); - if (rt !=3D res) { - printf("dextrv.l error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x0; - - res =3D 0x12345678; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextrv.l %0, $ac1, %3\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli), "r"(rs) - ); - if (rt !=3D res) { - printf("dextrv.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_r_l.c b/tests/tcg/mips/mips64= -dsp/dextrv_r_l.c deleted file mode 100644 index b47a017..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_r_l.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, dsp, rs; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x2100000000123456; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_r.l %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_r.l error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x0; - - res =3D 0x12345678; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_r.l %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_r.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_r_w.c b/tests/tcg/mips/mips64= -dsp/dextrv_r_w.c deleted file mode 100644 index cd201de..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_r_w.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x123456; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_r.w %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_r.w error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x0; - - res =3D 0x12345678; - resdsp =3D 0x01; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_r.w %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_r.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_rs_l.c b/tests/tcg/mips/mips6= 4-dsp/dextrv_rs_l.c deleted file mode 100644 index 6ce4185..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_rs_l.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x8000000000000000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_rs.l %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_rs.l error\n"); - return -1; - } - - achi =3D 0x00; - acli =3D 0x12345678; - rs =3D 0x0; - - res =3D 0x12345678; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_rs.l %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_rs.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_rs_w.c b/tests/tcg/mips/mips6= 4-dsp/dextrv_rs_w.c deleted file mode 100644 index a65183c..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_rs_w.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0xffffffff80000000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_rs.w %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_rs.w error\n"); - return -1; - } - - achi =3D 0x00; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x123456; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_rs.w %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_rs.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_s_h.c b/tests/tcg/mips/mips64= -dsp/dextrv_s_h.c deleted file mode 100644 index 87d3aee..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_s_h.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long res, resdsp; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0xffffffffffff8000; - resdsp =3D 0x1; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dextrv_s.h %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs) - ); - dsp =3D (dsp >> 23) & 0x1; - - if ((dsp !=3D resdsp) || (rt !=3D res)) { - printf("dextrv_s.h error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dextrv_w.c b/tests/tcg/mips/mips64-d= sp/dextrv_w.c deleted file mode 100644 index 973765c..0000000 --- a/tests/tcg/mips/mips64-dsp/dextrv_w.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long res; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x8; - - res =3D 0x123456; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextrv.w %0, $ac1, %3\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli), "r"(rs) - ); - if (rt !=3D res) { - printf("dextrv.w error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x0; - - res =3D 0x12345678; - - __asm - ("mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "dextrv.w %0, $ac1, %3\n\t" - : "=3Dr"(rt) - : "r"(achi), "r"(acli), "r"(rs) - ); - if (rt !=3D res) { - printf("dextrv.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dinsv.c b/tests/tcg/mips/mips64-dsp/= dinsv.c deleted file mode 100644 index f619218..0000000 --- a/tests/tcg/mips/mips64-dsp/dinsv.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long res; - - rs =3D 0x1234567887654321; - rt =3D 0x1234567812345678; - dsp =3D 0x2222; - res =3D 0x1234567812345678; - __asm - ("wrdsp %1, 0x3\n\t" - "wrdsp %1\n\t" - "dinsv %0, %2\n\t" - : "+r"(rt) - : "r"(dsp), "r"(rs) - ); - - if (rt !=3D res) { - printf("dinsv error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dmadd.c b/tests/tcg/mips/mips64-dsp/= dmadd.c deleted file mode 100644 index fb22614..0000000 --- a/tests/tcg/mips/mips64-dsp/dmadd.c +++ /dev/null @@ -1,57 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - achi =3D 0x1; - acli =3D 0x1; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - - resh =3D 0x1; - resl =3D 0x5; - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmadd $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dmadd error\n"); - - return -1; - } - - achi =3D 0x1; - acli =3D 0x1; - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0xaaaabbbbccccdddd; - - resh =3D 0x0000000000000000; - resl =3D 0xffffffffca860b63; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmadd $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dmadd error\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dmaddu.c b/tests/tcg/mips/mips64-dsp= /dmaddu.c deleted file mode 100644 index 39ab0c1..0000000 --- a/tests/tcg/mips/mips64-dsp/dmaddu.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - achi =3D 0x1; - acli =3D 0x2; - - rs =3D 0x0000000200000002; - rt =3D 0x0000000200000002; - resh =3D 0x1; - resl =3D 0xa; - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmaddu $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dmaddu error\n"); - - return -1; - } - - achi =3D 0x1; - acli =3D 0x1; - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0xaaaabbbbccccdddd; - - resh =3D 0x0000000000000002; - resl =3D 0xffffffffca860b63; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmaddu $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dmaddu error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dmsub.c b/tests/tcg/mips/mips64-dsp/= dmsub.c deleted file mode 100644 index 16be617..0000000 --- a/tests/tcg/mips/mips64-dsp/dmsub.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - achi =3D 0x1; - acli =3D 0x8; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - - resh =3D 0x1; - resl =3D 0x4; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmsub $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dmsub error\n"); - - return -1; - } - - achi =3D 0xfffffffF; - acli =3D 0xfffffffF; - - rs =3D 0x8888999977776666; - rt =3D 0x9999888877776666; - - resh =3D 0xffffffffffffffff; - resl =3D 0x789aae13; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmsub $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dmsub error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dmsubu.c b/tests/tcg/mips/mips64-dsp= /dmsubu.c deleted file mode 100644 index cc4838a..0000000 --- a/tests/tcg/mips/mips64-dsp/dmsubu.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - achi =3D 0x1; - acli =3D 0x8; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - - resh =3D 0x1; - resl =3D 0x4; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmsubu $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dmsubu error\n"); - - return -1; - } - - achi =3D 0xfffffffF; - acli =3D 0xfffffffF; - - rs =3D 0x8888999977776666; - rt =3D 0x9999888877776666; - - resh =3D 0xffffffffffffffff; - resl =3D 0x789aae13; - - __asm - ("mthi %2, $ac1 \t\n" - "mtlo %3, $ac1 \t\n" - "dmsubu $ac1, %4, %5\t\n" - "mfhi %0, $ac1 \t\n" - "mflo %1, $ac1 \t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dmsubu error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dmthlip.c b/tests/tcg/mips/mips64-ds= p/dmthlip.c deleted file mode 100644 index 027555f..0000000 --- a/tests/tcg/mips/mips64-dsp/dmthlip.c +++ /dev/null @@ -1,41 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, dsp; - long long achi, acli; - - long long rsdsp; - long long acho, aclo; - - long long res; - long long reshi, reslo; - - - rs =3D 0xaaaabbbbccccdddd; - achi =3D 0x87654321; - acli =3D 0x12345678; - dsp =3D 0x22; - - res =3D 0x62; - reshi =3D 0x12345678; - reslo =3D 0xffffffffccccdddd; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "wrdsp %5\n\t" - "dmthlip %6, $ac1\n\t" - "rddsp %0\n\t" - "mfhi %1, $ac1\n\t" - "mflo %2, $ac1\n\t" - : "=3Dr"(rsdsp), "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(dsp), "r"(rs) - ); - if ((rsdsp !=3D res) || (acho !=3D reshi) || (aclo !=3D reslo)) { - printf("dmthlip error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c b/tests/tcg/mips/mips6= 4-dsp/dpaq_s_w_ph.c deleted file mode 100644 index 1bca935..0000000 --- a/tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long ach =3D 0, acl =3D 0; - long long resulth, resultl, resultdsp; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x00; - resultl =3D 0xFFFFFFFF800003FB; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaq_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D dsp >> 17 & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpaq_w.w.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c b/tests/tcg/mips/mips6= 4-dsp/dpaq_s_w_qh.c deleted file mode 100644 index 844a347..0000000 --- a/tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c +++ /dev/null @@ -1,57 +0,0 @@ -#include"io.h" -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - achi =3D 0x1; - acli =3D 0x1; - rs =3D 0x0001000100010001; - rt =3D 0x0002000200020002; - resh =3D 0x1; - resl =3D 0x11; - - __asm - ("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dpaq_s.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpaq_s.w.qh error\n"); - - return -1; - } - - achi =3D 0xffffffff; - acli =3D 0xaaaaaaaa; - - rs =3D 0x1111222233334444; - rt =3D 0xffffeeeeddddcccc; - - resh =3D 0x00; - resl =3D 0xffffffffd27ad82e; - - __asm - ("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dpaq_s.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dpaq_s.w.qh error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c b/tests/tcg/mips/mips= 64-dsp/dpaq_sa_l_pw.c deleted file mode 100644 index 1bb2ec2..0000000 --- a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c +++ /dev/null @@ -1,88 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long achi, acli; - long long acho, aclo; - long long dsp; - long long resh, resl; - long long resdsp; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - achi =3D 0x1; - acli =3D 0x1; - resh =3D 0xffffffffffffffff; - resl =3D 0x0; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "dpaq_sa.l.pw $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl) || ((dsp >> (16 + 1)) !=3D re= sdsp)) { - printf("1 dpaq_sa_l_pw error\n"); - - return -1; - } - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0x3333444455556666; - achi =3D 0x88888888; - acli =3D 0x66666666; - - resh =3D 0xffffffff88888887; - resl =3D 0xffffffff9e2661da; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpaq_sa.l.pw $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dpaq_sa_l_pw error\n"); - - return -1; - } - - rs =3D 0x8000000080000000; - rt =3D 0x8000000080000000; - achi =3D 0x88888888; - acli =3D 0x66666666; - - resh =3D 0xffffffffffffffff; - resl =3D 0x00; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "dpaq_sa.l.pw $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl) || ((dsp >> (16 + 1)) !=3D re= sdsp)) { - printf("2 dpaq_sa_l_pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c b/tests/tcg/mips/mips6= 4-dsp/dpaq_sa_l_w.c deleted file mode 100644 index f840cdd..0000000 --- a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c +++ /dev/null @@ -1,82 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long ach =3D 0, acl =3D 0; - long long resulth, resultl, resultdsp; - - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x7FFFFFFF; - resultl =3D 0xffffffffFFFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %0, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpaq_sa.l.w error\n"); - - return -1; - } - - ach =3D 0x12; - acl =3D 0x48; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0x7FFFFFFF; - resultl =3D 0xffffffffFFFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %0, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpaq_sa.l.w error\n"); - - return -1; - } - - ach =3D 0x741532A0; - acl =3D 0xfceabb08; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0x7fffffff; - resultl =3D 0xffffffffffffffff; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %0, $ac1\n\t" - "dpaq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpaq_sa.l.w error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_obl.c b/tests/tcg/mips/mips64= -dsp/dpau_h_obl.c deleted file mode 100644 index 54905e8..0000000 --- a/tests/tcg/mips/mips64-dsp/dpau_h_obl.c +++ /dev/null @@ -1,59 +0,0 @@ - -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - achi =3D 0x1; - acli =3D 0x1; - resh =3D 0x1; - resl =3D 0x3; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpau.h.obl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpau.h.obl error\n"); - - return -1; - } - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0x3333444455556666; - achi =3D 0x88888888; - acli =3D 0x66666666; - - resh =3D 0xffffffff88888888; - resl =3D 0x66670d7a; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpau.h.obl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpau.h.obl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_obr.c b/tests/tcg/mips/mips64= -dsp/dpau_h_obr.c deleted file mode 100644 index d7aa60b..0000000 --- a/tests/tcg/mips/mips64-dsp/dpau_h_obr.c +++ /dev/null @@ -1,59 +0,0 @@ - -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - achi =3D 0x1; - acli =3D 0x1; - resh =3D 0x1; - resl =3D 0x3; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpau.h.obr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpau.h.obr error\n"); - - return -1; - } - - rs =3D 0xccccddddaaaabbbb; - rt =3D 0x5555666633334444; - achi =3D 0x88888888; - acli =3D 0x66666666; - - resh =3D 0xffffffff88888888; - resl =3D 0x66670d7a; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpau.h.obr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpau.h.obr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_qbl.c b/tests/tcg/mips/mips64= -dsp/dpau_h_qbl.c deleted file mode 100644 index fcfd764..0000000 --- a/tests/tcg/mips/mips64-dsp/dpau_h_qbl.c +++ /dev/null @@ -1,29 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 3; - long long resulth, resultl; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x05; - resultl =3D 0x4003; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpau.h.qbl $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpau.h.qbl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_qbr.c b/tests/tcg/mips/mips64= -dsp/dpau_h_qbr.c deleted file mode 100644 index 3282461..0000000 --- a/tests/tcg/mips/mips64-dsp/dpau_h_qbr.c +++ /dev/null @@ -1,29 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 3; - long long resulth, resultl; - - rs =3D 0x800000FF; - rt =3D 0x80000002; - resulth =3D 0x05; - resultl =3D 0x0201; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpau.h.qbr $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpau.h.qbr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c b/tests/tcg/mips/mips6= 4-dsp/dpsq_s_w_ph.c deleted file mode 100644 index 7660f03..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c +++ /dev/null @@ -1,51 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFEE9794A3; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("1 dpsq_s.w.ph wrong\n"); - - return -1; - } - - ach =3D 0x1424Ef1f; - acl =3D 0x1035219A; - rs =3D 0x800083AD; - rt =3D 0x80003721; - resulth =3D 0x1424ef1e; - resultl =3D 0x577ed901; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("2 dpsq_s.w.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c b/tests/tcg/mips/mips6= 4-dsp/dpsq_s_w_qh.c deleted file mode 100644 index 2cc50c5..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - rs =3D 0xffffeeeeddddcccc; - rt =3D 0x9999888877776666; - achi =3D 0x67576; - acli =3D 0x98878; - - resh =3D 0x67576; - resl =3D 0x5b1682c4; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpsq_s.w.qh $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpsq_s.w.qh wrong\n"); - - return -1; - } - - rs =3D 0x8000800080008000; - rt =3D 0x8000800080008000; - achi =3D 0x67576; - acli =3D 0x98878; - - resh =3D 0x67575; - resl =3D 0x0009887c; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dpsq_s.w.qh $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dpsq_s.w.qh wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c b/tests/tcg/mips/mips= 64-dsp/dpsq_sa_l_pw.c deleted file mode 100644 index 7fc2503..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c +++ /dev/null @@ -1,76 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long achi, acli; - long long resh, resl, resdsp; - - rs =3D 0x89789BC0123AD; - rt =3D 0x5467591643721; - - achi =3D 0x98765437; - acli =3D 0x65489709; - - resh =3D 0xffffffffffffffff; - resl =3D 0x00; - - resdsp =3D 0x01; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.pw $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(achi), "+r"(acli), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resdsp) || (achi !=3D resh) || (acli !=3D resl)) { - printf("1 dpsq_sa.l.pw wrong\n"); - - return -1; - } - - /* clear dspcontrol reg for next test use. */ - dsp =3D 0; - __asm - ("wrdsp %0" - : - : "r"(dsp) - ); - - rs =3D 0x8B78980000000; - rt =3D 0x5867580000000; - - achi =3D 0x98765437; - acli =3D 0x65489709; - - resh =3D 0xffffffff98765436; - resl =3D 0x11d367d0; - - resdsp =3D 0x01; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.pw $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(achi), "+r"(acli), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resdsp) || (achi !=3D resh) || (acli !=3D resl)) { - printf("2 dpsq_sa.l.pw wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c b/tests/tcg/mips/mips6= 4-dsp/dpsq_sa_l_w.c deleted file mode 100644 index f55afc9..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - - resulth =3D 0xfffffffffdf4cbe0; - resultl =3D 0xFFFFFFFFd138776b; - resultdsp =3D 0x00; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("1 dpsq_sa.l.w wrong\n"); - - return -1; - } - - ach =3D 0x54321123; - acl =3D 5; - rs =3D 0x80000000; - rt =3D 0x80000000; - - resulth =3D 0xffffffffd4321123; - resultl =3D 0x06; - resultdsp =3D 0x01; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsq_sa.l.w $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("2 dpsq_sa.l.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_obl.c b/tests/tcg/mips/mips64= -dsp/dpsu_h_obl.c deleted file mode 100644 index c0a8f4d..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsu_h_obl.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0x88886666BC0123AD; - rt =3D 0x9999888801643721; - - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFFFFEF115; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.obl $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpsu.h.obl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_obr.c b/tests/tcg/mips/mips64= -dsp/dpsu_h_obr.c deleted file mode 100644 index aa0d47a..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsu_h_obr.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0x7878878888886666; - rt =3D 0x9865454399998888; - - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFFFFeF115; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.obr $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpsu.h.qbr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c b/tests/tcg/mips/mips64= -dsp/dpsu_h_qbl.c deleted file mode 100644 index da6dbb6..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c +++ /dev/null @@ -1,29 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFFFFFFEE5; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.qbl $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpsu.h.qbl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c b/tests/tcg/mips/mips64= -dsp/dpsu_h_qbr.c deleted file mode 100644 index bf00b70..0000000 --- a/tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c +++ /dev/null @@ -1,29 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFFFFFE233; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsu.h.qbr $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpsu.h.qbr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dshilo.c b/tests/tcg/mips/mips64-dsp= /dshilo.c deleted file mode 100644 index f50584b..0000000 --- a/tests/tcg/mips/mips64-dsp/dshilo.c +++ /dev/null @@ -1,52 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acli; - long long acho, aclo; - long long reshi, reslo; - - achi =3D 0x87654321; - acli =3D 0x12345678; - - reshi =3D 0xfffffffff8765432; - reslo =3D 0x1234567; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dshilo $ac1, 0x4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli) - ); - - if ((acho !=3D reshi) || (aclo !=3D reslo)) { - printf("1 dshilo error\n"); - return -1; - } - - achi =3D 0x87654321; - acli =3D 0x12345678; - - reshi =3D 0x1234567; - reslo =3D 0x00; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dshilo $ac1, -60\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli) - ); - - if ((acho !=3D reshi) || (aclo !=3D reslo)) { - printf("2 dshilo error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/dshilov.c b/tests/tcg/mips/mips64-ds= p/dshilov.c deleted file mode 100644 index 792bd23..0000000 --- a/tests/tcg/mips/mips64-dsp/dshilov.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acli, rs; - long long acho, aclo; - long long reshi, reslo; - - achi =3D 0x87654321; - acli =3D 0x12345678; - rs =3D 0x4; - - reshi =3D 0xfffffffff8765432; - reslo =3D 0x1234567; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dshilov $ac1, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs) - ); - - if ((acho !=3D reshi) || (aclo !=3D reslo)) { - printf("dshilov error\n"); - return -1; - } - - rs =3D 0x44; - achi =3D 0x87654321; - acli =3D 0x12345678; - - reshi =3D 0x1234567; - reslo =3D 0x00; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "dshilov $ac1, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs) - ); - - if ((acho !=3D reshi) || (aclo !=3D reslo)) { - printf("dshilov error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extp.c b/tests/tcg/mips/mips64-dsp/e= xtp.c deleted file mode 100644 index c72f54b..0000000 --- a/tests/tcg/mips/mips64-dsp/extp.c +++ /dev/null @@ -1,50 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 14) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extp wrong\n"); - - return -1; - } - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 14) & 0x01; - if (dsp !=3D 1) { - printf("extp wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extpdp.c b/tests/tcg/mips/mips64-dsp= /extpdp.c deleted file mode 100644 index f430193..0000000 --- a/tests/tcg/mips/mips64-dsp/extpdp.c +++ /dev/null @@ -1,51 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp, pos, efi; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - pos =3D dsp & 0x3F; - efi =3D (dsp >> 14) & 0x01; - if ((pos !=3D 3) || (efi !=3D 0) || (result !=3D rt)) { - printf("extpdp wrong\n"); - - return -1; - } - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdp %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl) - ); - efi =3D (dsp >> 14) & 0x01; - if (efi !=3D 1) { - printf("extpdp wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extpdpv.c b/tests/tcg/mips/mips64-ds= p/extpdpv.c deleted file mode 100644 index ba57426..0000000 --- a/tests/tcg/mips/mips64-dsp/extpdpv.c +++ /dev/null @@ -1,52 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, ach, acl, dsp, pos, efi; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(rs) - ); - pos =3D dsp & 0x3F; - efi =3D (dsp >> 14) & 0x01; - if ((pos !=3D 3) || (efi !=3D 0) || (result !=3D rt)) { - printf("extpdpv wrong\n"); - - return -1; - } - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpdpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(rs) - ); - efi =3D (dsp >> 14) & 0x01; - if (efi !=3D 1) { - printf("extpdpv wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extpv.c b/tests/tcg/mips/mips64-dsp/= extpv.c deleted file mode 100644 index 158472b..0000000 --- a/tests/tcg/mips/mips64-dsp/extpv.c +++ /dev/null @@ -1,51 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ac, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - ac =3D 0x03; - result =3D 0x000C; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(ac) - ); - dsp =3D (dsp >> 14) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extpv wrong\n"); - - return -1; - } - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x01; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extpv %0, $ac1, %4\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(ach), "r"(acl), "r"(ac) - ); - dsp =3D (dsp >> 14) & 0x01; - if (dsp !=3D 1) { - printf("extpv wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extr_r_w.c b/tests/tcg/mips/mips64-d= sp/extr_r_w.c deleted file mode 100644 index 94572ad..0000000 --- a/tests/tcg/mips/mips64-dsp/extr_r_w.c +++ /dev/null @@ -1,53 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0xFFFFFFFFA0001699; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("1 extr_r.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_r.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("2 extr_r.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extr_rs_w.c b/tests/tcg/mips/mips64-= dsp/extr_rs_w.c deleted file mode 100644 index 73551f9..0000000 --- a/tests/tcg/mips/mips64-dsp/extr_rs_w.c +++ /dev/null @@ -1,53 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0x7FFFFFFF; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("1 extr_rs.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_rs.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("2 extr_rs.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extr_s_h.c b/tests/tcg/mips/mips64-d= sp/extr_s_h.c deleted file mode 100644 index de10cb5..0000000 --- a/tests/tcg/mips/mips64-dsp/extr_s_h.c +++ /dev/null @@ -1,71 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0x00007FFF; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extr_s.h wrong\n"); - - return -1; - } - - ach =3D 0xffffffff; - acl =3D 0x12344321; - result =3D 0xffffffffFFFF8000; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x08\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extr_s.h wrong\n"); - - return -1; - } - - /* Clear dsp */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x00; - acl =3D 0x4321; - result =3D 0x432; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr_s.h %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extr_s.h wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extr_w.c b/tests/tcg/mips/mips64-dsp= /extr_w.c deleted file mode 100644 index bd69576..0000000 --- a/tests/tcg/mips/mips64-dsp/extr_w.c +++ /dev/null @@ -1,53 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - result =3D 0xFFFFFFFFA0001699; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extr.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4C; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "extr.w %0, $ac1, 0x04\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "=3Dr"(dsp) - : "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extr.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extrv_r_w.c b/tests/tcg/mips/mips64-= dsp/extrv_r_w.c deleted file mode 100644 index 8379729..0000000 --- a/tests/tcg/mips/mips64-dsp/extrv_r_w.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0xFFFFFFFFA0001699; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_r.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extrv_r.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 4; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_r.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extrv_r.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extrv_rs_w.c b/tests/tcg/mips/mips64= -dsp/extrv_rs_w.c deleted file mode 100644 index 8707cd11..0000000 --- a/tests/tcg/mips/mips64-dsp/extrv_rs_w.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0x7FFFFFFF; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_rs.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("1 extrv_rs.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 4; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4D; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_rs.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("2 extrv_rs.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extrv_s_h.c b/tests/tcg/mips/mips64-= dsp/extrv_s_h.c deleted file mode 100644 index b6dcaeb..0000000 --- a/tests/tcg/mips/mips64-dsp/extrv_s_h.c +++ /dev/null @@ -1,79 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0x00007FFF; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extrv_s.h wrong\n"); - - return -1; - } - - rs =3D 0x08; - ach =3D 0xffffffff; - acl =3D 0x12344321; - result =3D 0xffffffffFFFF8000; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extrv_s.h wrong\n"); - - return -1; - } - - /* Clear dsp */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x04; - ach =3D 0x00; - acl =3D 0x4321; - result =3D 0x432; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv_s.h %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extrv_s.h wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/extrv_w.c b/tests/tcg/mips/mips64-ds= p/extrv_w.c deleted file mode 100644 index 8adffb3..0000000 --- a/tests/tcg/mips/mips64-dsp/extrv_w.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, ach, acl, dsp; - long long result; - - ach =3D 0x05; - acl =3D 0xB4CB; - dsp =3D 0x07; - rs =3D 0x03; - result =3D 0xFFFFFFFFA0001699; - - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 1) || (result !=3D rt)) { - printf("extrv.w wrong\n"); - - return -1; - } - - /* Clear dspcontrol */ - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 4; - ach =3D 0x01; - acl =3D 0xB4CB; - result =3D 0x10000B4C; - __asm - ("wrdsp %1, 0x01\n\t" - "mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "extrv.w %0, $ac1, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(rt), "+r"(dsp) - : "r"(rs), "r"(ach), "r"(acl) - ); - dsp =3D (dsp >> 23) & 0x01; - if ((dsp !=3D 0) || (result !=3D rt)) { - printf("extrv.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/head.S b/tests/tcg/mips/mips64-dsp/h= ead.S deleted file mode 100644 index 9a099ae..0000000 --- a/tests/tcg/mips/mips64-dsp/head.S +++ /dev/null @@ -1,16 +0,0 @@ -/* - * Startup Code for MIPS64 CPU-core - * - */ -.text -.globl _start -.align 4 -_start: - ori $2, $2, 0xffff - sll $2, $2, 16 - ori $2, $2, 0xffff - mtc0 $2, $12, 0 - jal main - -end: - b end diff --git a/tests/tcg/mips/mips64-dsp/insv.c b/tests/tcg/mips/mips64-dsp/i= nsv.c deleted file mode 100644 index fc5696f..0000000 --- a/tests/tcg/mips/mips64-dsp/insv.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long result; - - /* msb =3D 10, lsb =3D 5 */ - dsp =3D 0x305; - rt =3D 0x12345678; - rs =3D 0xffffffff87654321; - result =3D 0x12345338; - __asm - ("wrdsp %2, 0x03\n\t" - "insv %0, %1\n\t" - : "+r"(rt) - : "r"(rs), "r"(dsp) - ); - if (rt !=3D result) { - printf("insv wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/io.h b/tests/tcg/mips/mips64-dsp/io.h deleted file mode 100644 index b7db61d..0000000 --- a/tests/tcg/mips/mips64-dsp/io.h +++ /dev/null @@ -1,22 +0,0 @@ -#ifndef _ASM_IO_H -#define _ASM_IO_H -extern int printf(const char *fmt, ...); -extern unsigned long get_ticks(void); - -#define _read(source) \ -({ unsigned long __res; \ - __asm__ __volatile__( \ - "mfc0\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -#define __read(source) \ -({ unsigned long __res; \ - __asm__ __volatile__( \ - "move\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -#endif diff --git a/tests/tcg/mips/mips64-dsp/lbux.c b/tests/tcg/mips/mips64-dsp/l= bux.c deleted file mode 100644 index dbdc87b..0000000 --- a/tests/tcg/mips/mips64-dsp/lbux.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long value, rd; - long long *p; - unsigned long long addr, index; - long long result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long long)p; - index =3D 0; - result =3D value & 0xFF; - __asm - ("lbux %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - if (rd !=3D result) { - printf("lbux wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/ldx.c b/tests/tcg/mips/mips64-dsp/ld= x.c deleted file mode 100644 index 787d9f0..0000000 --- a/tests/tcg/mips/mips64-dsp/ldx.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long value, rd; - long long *p; - unsigned long long addr, index; - long long result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long long)p; - index =3D 0; - result =3D 0xBCDEF389; - __asm - ("ldx %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - if (rd !=3D result) { - printf("lwx wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/lhx.c b/tests/tcg/mips/mips64-dsp/lh= x.c deleted file mode 100644 index 2020e56..0000000 --- a/tests/tcg/mips/mips64-dsp/lhx.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long value, rd; - long long *p; - unsigned long long addr, index; - long long result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long long)p; - index =3D 0; - result =3D 0xFFFFFFFFFFFFF389; - __asm - ("lhx %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - if (rd !=3D result) { - printf("lhx wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/lwx.c b/tests/tcg/mips/mips64-dsp/lw= x.c deleted file mode 100644 index 6a81414..0000000 --- a/tests/tcg/mips/mips64-dsp/lwx.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long value, rd; - long long *p; - unsigned long long addr, index; - long long result; - - value =3D 0xBCDEF389; - p =3D &value; - addr =3D (unsigned long long)p; - index =3D 0; - result =3D 0xFFFFFFFFBCDEF389; - __asm - ("lwx %0, %1(%2)\n\t" - : "=3Dr"(rd) - : "r"(index), "r"(addr) - ); - if (rd !=3D result) { - printf("lwx wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/madd.c b/tests/tcg/mips/mips64-dsp/m= add.c deleted file mode 100644 index de6e44f..0000000 --- a/tests/tcg/mips/mips64-dsp/madd.c +++ /dev/null @@ -1,33 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x01; - rt =3D 0x01; - resulth =3D 0x05; - resultl =3D 0xB4CC; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "madd $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("madd wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maddu.c b/tests/tcg/mips/mips64-dsp/= maddu.c deleted file mode 100644 index e9f426a..0000000 --- a/tests/tcg/mips/mips64-dsp/maddu.c +++ /dev/null @@ -1,33 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x01; - rt =3D 0x01; - resulth =3D 0x05; - resultl =3D 0xB4CC; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "madd $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maddu wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c b/tests/tcg/mips/mips6= 4-dsp/maq_s_l_pwl.c deleted file mode 100644 index c196b43..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x98765432FF060000; - rt =3D 0xfdeca987CB000000; - resulth =3D 0x05; - resultl =3D 0x18278587; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.l.pwl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s_l.w.pwl wrong 1\n"); - - return -1; - } - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x80000000FF060000; - rt =3D 0x80000000CB000000; - resulth =3D 0x05; - resultl =3D 0xb4ca; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.l.pwl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s_l.w.pwl wrong 2\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c b/tests/tcg/mips/mips6= 4-dsp/maq_s_l_pwr.c deleted file mode 100644 index e2af69f..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x87898765432; - rt =3D 0x7878fdeca987; - resulth =3D 0x05; - resultl =3D 0x18278587; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.l.pwr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s.w.pwr wrong\n"); - - return -1; - } - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0x89899980000000; - rt =3D 0x88780000000; - resulth =3D 0x05; - resultl =3D 0xb4ca; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.l.pwr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s.w.pwr wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_phl.c b/tests/tcg/mips/mips6= 4-dsp/maq_s_w_phl.c deleted file mode 100644 index 7dba874..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_phl.c +++ /dev/null @@ -1,60 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long dsp; - long long acho, aclo; - long long resulth, resultl; - long long resdsp; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0xFF060000; - rt =3D 0xCB000000; - resulth =3D 0x04; - resultl =3D 0xffffffff947438CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.phl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_s.w.phl error\n"); - - return -1; - } - - achi =3D 0x06; - acli =3D 0xB4CB; - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x6; - resultl =3D 0xffffffff8000b4ca; - resdsp =3D 1; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.phl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo) || - (((dsp >> 17) & 0x01) !=3D resdsp)) { - printf("2 maq_s.w.phl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_phr.c b/tests/tcg/mips/mips6= 4-dsp/maq_s_w_phr.c deleted file mode 100644 index 138ee2a..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_phr.c +++ /dev/null @@ -1,60 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long dsp; - long long acho, aclo; - long long resulth, resultl; - long long resdsp; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0xFF06; - rt =3D 0xCB00; - resulth =3D 0x04; - resultl =3D 0xffffffff947438CB; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.phr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_s.w.phr error\n"); - - return -1; - } - - achi =3D 0x06; - acli =3D 0xB4CB; - rs =3D 0x8000; - rt =3D 0x8000; - resulth =3D 0x6; - resultl =3D 0xffffffff8000b4ca; - resdsp =3D 1; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.phr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo) || - (((dsp >> 17) & 0x01) !=3D resdsp)) { - printf("2 maq_s.w.phr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c b/tests/tcg/mips/mips= 64-dsp/maq_s_w_qhll.c deleted file mode 100644 index 234a0af..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c +++ /dev/null @@ -1,62 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234888899990000; - rt =3D 0x9876888899990000; - - resulth =3D 0x05; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.qhll $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s.w.qhll wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000888899990000; - rt =3D 0x8000888899990000; - - resulth =3D 0x04; - resultl =3D 0xffffffff80000005; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.qhll $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_s.w.qhll wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c b/tests/tcg/mips/mips= 64-dsp/maq_s_w_qhlr.c deleted file mode 100644 index 8768cba..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c +++ /dev/null @@ -1,62 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234123412340000; - rt =3D 0x9876987698760000; - - resulth =3D 0x05; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.qhlr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_s.w.qhlr wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000800080000000; - rt =3D 0x8000800080000000; - - resulth =3D 0x04; - resultl =3D 0xffffffff80000005; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.qhlr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_s.w.qhlr wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c b/tests/tcg/mips/mips= 64-dsp/maq_s_w_qhrl.c deleted file mode 100644 index 5006e2b..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c +++ /dev/null @@ -1,63 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234888812340000; - rt =3D 0x9876888898760000; - - resulth =3D 0x05; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.qhrl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_s.w.qhrl wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8888999980000000; - rt =3D 0x8888999980000000; - - resulth =3D 0x04; - resultl =3D 0xffffffff80000005; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.qhrl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_s.w.qhrl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c b/tests/tcg/mips/mips= 64-dsp/maq_s_w_qhrr.c deleted file mode 100644 index 1d213a5..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c +++ /dev/null @@ -1,63 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234888812341234; - rt =3D 0x9876888898769876; - - resulth =3D 0x05; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_s.w.qhrr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_s.w.qhrr wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000888899998000; - rt =3D 0x8000888899998000; - - resulth =3D 0x04; - resultl =3D 0xffffffff80000005; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_s.w.qhrr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_s.w.qhrr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c b/tests/tcg/mips/mips= 64-dsp/maq_sa_w_phl.c deleted file mode 100644 index 5530ffb..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c +++ /dev/null @@ -1,60 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long dsp; - long long acho, aclo; - long long resulth, resultl; - long long resdsp; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0xFF060000; - rt =3D 0xCB000000; - resulth =3D 0xffffffffffffffff; - resultl =3D 0xffffffff947438cb; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_sa.w.phl $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_sa.w.phl error\n"); - - return -1; - } - - achi =3D 0x06; - acli =3D 0xB4CB; - rs =3D 0x80000000; - rt =3D 0x80000000; - resulth =3D 0x00; - resultl =3D 0x7fffffff; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.phl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo) || - (((dsp >> 17) & 0x01) !=3D 0x01)) { - printf("2 maq_sa.w.phl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c b/tests/tcg/mips/mips= 64-dsp/maq_sa_w_phr.c deleted file mode 100644 index b611cfa..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c +++ /dev/null @@ -1,60 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long dsp; - long long acho, aclo; - long long resulth, resultl; - long long resdsp; - - achi =3D 0x05; - acli =3D 0xB4CB; - rs =3D 0xFF06; - rt =3D 0xCB00; - resulth =3D 0xffffffffffffffff; - resultl =3D 0xffffffff947438cb; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_sa.w.phr $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_sa.w.phr error\n"); - - return -1; - } - - achi =3D 0x06; - acli =3D 0xB4CB; - rs =3D 0x8000; - rt =3D 0x8000; - resulth =3D 0x00; - resultl =3D 0x7fffffff; - resdsp =3D 0x01; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.phr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((resulth !=3D acho) || (resultl !=3D aclo) || - (((dsp >> 17) & 0x01) !=3D 0x01)) { - printf("2 maq_sa.w.phr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c b/tests/tcg/mips/mip= s64-dsp/maq_sa_w_qhll.c deleted file mode 100644 index 136ff2d..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c +++ /dev/null @@ -1,62 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234888899990000; - rt =3D 0x9876888899990000; - - resulth =3D 0x00; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "maq_sa.w.qhll $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_sa.w.qhll wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000888899990000; - rt =3D 0x8000888899990000; - - resulth =3D 0x00; - resultl =3D 0x7fffffff; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhll $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_sa.w.qhll wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c b/tests/tcg/mips/mip= s64-dsp/maq_sa_w_qhlr.c deleted file mode 100644 index dd0ae1c..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c +++ /dev/null @@ -1,64 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234123412340000; - rt =3D 0x9876987699990000; - - resulth =3D 0x0; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhlr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x0) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_sa.w.qhlr wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000800099990000; - rt =3D 0x8000800099990000; - - resulth =3D 0x00; - resultl =3D 0x7fffffff; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhlr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("maq_sa.w.qhlr wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c b/tests/tcg/mips/mip= s64-dsp/maq_sa_w_qhrl.c deleted file mode 100644 index a3de6f8..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c +++ /dev/null @@ -1,64 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234123412340000; - rt =3D 0x9876987698760000; - - resulth =3D 0x0; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhrl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x0) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_sa.w.qhrl wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000800080000000; - rt =3D 0x8000800080000000; - - resulth =3D 0x00; - resultl =3D 0x7fffffff; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhrl $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_sa.w.qhrl wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c b/tests/tcg/mips/mip= s64-dsp/maq_sa_w_qhrr.c deleted file mode 100644 index f021737..0000000 --- a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c +++ /dev/null @@ -1,64 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs, dsp; - long long achi, acli; - long long acho, aclo; - long long resulth, resultl; - - achi =3D 0x05; - acli =3D 0x05; - - rs =3D 0x1234123412341234; - rt =3D 0x9876987698769876; - - resulth =3D 0x0; - resultl =3D 0x15ae87f5; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhrr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x0) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("1 maq_sa.w.qhrr wrong\n"); - - return -1; - } - - - achi =3D 0x04; - acli =3D 0x06; - rs =3D 0x8000800080008000; - rt =3D 0x8000800080008000; - - resulth =3D 0x00; - resultl =3D 0x7fffffff; - - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "maq_sa.w.qhrr $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (resulth !=3D acho) || (resultl !=3D aclo)) { - printf("2 maq_sa.w.qhrr wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mfhi.c b/tests/tcg/mips/mips64-dsp/m= fhi.c deleted file mode 100644 index ee915f7..0000000 --- a/tests/tcg/mips/mips64-dsp/mfhi.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acho; - long long result; - - achi =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(acho) - : "r"(achi) - ); - if (result !=3D acho) { - printf("mfhi wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mflo.c b/tests/tcg/mips/mips64-dsp/m= flo.c deleted file mode 100644 index cdc646b..0000000 --- a/tests/tcg/mips/mips64-dsp/mflo.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long acli, aclo; - long long result; - - acli =3D 0x004433; - result =3D 0x004433; - - __asm - ("mtlo %1, $ac1\n\t" - "mflo %0, $ac1\n\t" - : "=3Dr"(aclo) - : "r"(acli) - ); - if (result !=3D aclo) { - printf("mflo wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mips_boot.lds b/tests/tcg/mips/mips6= 4-dsp/mips_boot.lds deleted file mode 100644 index bd7c0c0..0000000 --- a/tests/tcg/mips/mips64-dsp/mips_boot.lds +++ /dev/null @@ -1,31 +0,0 @@ -OUTPUT_ARCH(mips) -SECTIONS -{ - . =3D 0xffffffff80100000; - . =3D ALIGN((1 << 13)); - .text : - { - *(.text) - *(.rodata) - *(.rodata.*) - } - - __init_begin =3D .; - . =3D ALIGN((1 << 12)); - .init.text : AT(ADDR(.init.text) - 0) - { - *(.init.text) - } - .init.data : AT(ADDR(.init.data) - 0) - { - *(.init.data) - } - . =3D ALIGN((1 << 12)); - __init_end =3D .; - - . =3D ALIGN((1 << 13)); - .data : - { - *(.data) - } -} diff --git a/tests/tcg/mips/mips64-dsp/modsub.c b/tests/tcg/mips/mips64-dsp= /modsub.c deleted file mode 100644 index 2c91cb4..0000000 --- a/tests/tcg/mips/mips64-dsp/modsub.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0xFFFFFFFF; - rt =3D 0x000000FF; - result =3D 0xFFFFFF00; - __asm - ("modsub %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("modsub wrong\n"); - - return -1; - } - - rs =3D 0x00000000; - rt =3D 0x00CD1FFF; - result =3D 0x0000CD1F; - __asm - ("modsub %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("modsub wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/msub.c b/tests/tcg/mips/mips64-dsp/m= sub.c deleted file mode 100644 index 75066b5..0000000 --- a/tests/tcg/mips/mips64-dsp/msub.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acli, rs, rt; - long long acho, aclo; - long long resulth, resultl; - - rs =3D 0x00BBAACC; - rt =3D 0x0B1C3D2F; - achi =3D 0x00004433; - acli =3D 0xFFCC0011; - resulth =3D 0xFFFFFFFFFFF81F29; - resultl =3D 0xFFFFFFFFB355089D; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "msub $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resulth) || (aclo !=3D resultl)) { - printf("msub wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/msubu.c b/tests/tcg/mips/mips64-dsp/= msubu.c deleted file mode 100644 index 55f8ae0..0000000 --- a/tests/tcg/mips/mips64-dsp/msubu.c +++ /dev/null @@ -1,32 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acli, rs, rt; - long long acho, aclo; - long long resulth, resultl; - - rs =3D 0x00BBAACC; - rt =3D 0x0B1C3D2F; - achi =3D 0x00004433; - acli =3D 0xFFCC0011; - resulth =3D 0xFFFFFFFFFFF81F29; - resultl =3D 0xFFFFFFFFB355089D; - - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "msubu $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resulth) || (aclo !=3D resultl)) { - printf("msubu wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mthi.c b/tests/tcg/mips/mips64-dsp/m= thi.c deleted file mode 100644 index 8570051..0000000 --- a/tests/tcg/mips/mips64-dsp/mthi.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long achi, acho; - long long result; - - achi =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(acho) - : "r"(achi) - ); - if (result !=3D acho) { - printf("mthi wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mthlip.c b/tests/tcg/mips/mips64-dsp= /mthlip.c deleted file mode 100644 index 957cd42..0000000 --- a/tests/tcg/mips/mips64-dsp/mthlip.c +++ /dev/null @@ -1,61 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, ach, acl, dsp; - long long result, resulth, resultl; - - dsp =3D 0x07; - ach =3D 0x05; - acl =3D 0xB4CB; - rs =3D 0x00FFBBAA; - resulth =3D 0xB4CB; - resultl =3D 0x00FFBBAA; - result =3D 0x27; - - __asm - ("wrdsp %0, 0x01\n\t" - "mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "mthlip %3, $ac1\n\t" - "mfhi %1, $ac1\n\t" - "mflo %2, $ac1\n\t" - "rddsp %0\n\t" - : "+r"(dsp), "+r"(ach), "+r"(acl) - : "r"(rs) - ); - dsp =3D dsp & 0x3F; - if ((dsp !=3D result) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("mthlip wrong\n"); - - return -1; - } - - dsp =3D 0x3f; - ach =3D 0x05; - acl =3D 0xB4CB; - rs =3D 0x00FFBBAA; - resulth =3D 0xB4CB; - resultl =3D 0x00FFBBAA; - result =3D 0x3f; - - __asm - ("wrdsp %0, 0x01\n\t" - "mthi %1, $ac1\n\t" - "mtlo %2, $ac1\n\t" - "mthlip %3, $ac1\n\t" - "mfhi %1, $ac1\n\t" - "mflo %2, $ac1\n\t" - "rddsp %0\n\t" - : "+r"(dsp), "+r"(ach), "+r"(acl) - : "r"(rs) - ); - dsp =3D dsp & 0x3F; - if ((dsp !=3D result) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("mthlip wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mtlo.c b/tests/tcg/mips/mips64-dsp/m= tlo.c deleted file mode 100644 index 304fffb..0000000 --- a/tests/tcg/mips/mips64-dsp/mtlo.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long acli, aclo; - long long result; - - acli =3D 0x004433; - result =3D 0x004433; - - __asm - ("mthi %1, $ac1\n\t" - "mfhi %0, $ac1\n\t" - : "=3Dr"(aclo) - : "r"(acli) - ); - if (result !=3D aclo) { - printf("mtlo wrong\n"); - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c b/tests/tcg/mips/mi= ps64-dsp/muleq_s_pw_qhl.c deleted file mode 100644 index 6c68d45..0000000 --- a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c +++ /dev/null @@ -1,56 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rd =3D 0; - rs =3D 0x45BCFFFF12345678; - rt =3D 0x98529AD287654321; - result =3D 0x52fbec7035a2ca5c; - - __asm - ("muleq_s.pw.qhl %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (result !=3D rd) { - printf("1 muleq_s.pw.qhl error\n"); - - return -1; - } - - rd =3D 0; - rs =3D 0x45BC800012345678; - rt =3D 0x9852800087654321; - result =3D 0x52fbec707FFFFFFF; - - __asm - ("muleq_s.pw.qhl %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (result !=3D rd) { - printf("2 muleq_s.pw.qhl error\n"); - - return -1; - } - - rd =3D 0; - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd =3D rd >> 21; - rd =3D rd & 0x1; - - if (rd !=3D 1) { - printf("3 muleq_s.pw.qhl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c b/tests/tcg/mips/mi= ps64-dsp/muleq_s_pw_qhr.c deleted file mode 100644 index fa8b41f..0000000 --- a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c +++ /dev/null @@ -1,57 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rd =3D 0; - rs =3D 0x1234567845BCFFFF; - rt =3D 0x8765432198529AD2; - result =3D 0x52fbec7035a2ca5c; - - __asm - ("muleq_s.pw.qhr %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (result !=3D rd) { - printf("1 muleq_s.pw.qhr error\n"); - - return -1; - } - - rd =3D 0; - rs =3D 0x1234567845BC8000; - rt =3D 0x8765432198528000; - result =3D 0x52fbec707FFFFFFF; - - __asm - ("muleq_s.pw.qhr %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (result !=3D rd) { - printf("2 muleq_s.pw.qhr error\n"); - - return -1; - } - - rd =3D 0; - __asm - ("rddsp %0\n\t" - : "=3Dr"(rd) - ); - rd =3D rd >> 21; - rd =3D rd & 0x1; - - if (rd !=3D 1) { - printf("3 muleq_s.pw.qhr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c b/tests/tcg/mips/mip= s64-dsp/muleq_s_w_phl.c deleted file mode 100644 index 997a9f6..0000000 --- a/tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c +++ /dev/null @@ -1,46 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80009988; - rt =3D 0x80009988; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleq_s.w.phl wrong\n"); - - return -1; - } - - rs =3D 0x12343322; - rt =3D 0x43213322; - result =3D 0x98be968; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleq_s.w.phl wrong\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c b/tests/tcg/mips/mip= s64-dsp/muleq_s_w_phr.c deleted file mode 100644 index 0e59479..0000000 --- a/tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x8000; - rt =3D 0x8000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleq_s.w.phr wrong\n"); - - return -1; - } - - rs =3D 0x1234; - rt =3D 0x4321; - result =3D 0x98be968; - resultdsp =3D 1; - - __asm - ("muleq_s.w.phr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleq_s.w.phr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c b/tests/tcg/mips/mi= ps64-dsp/muleu_s_ph_qbl.c deleted file mode 100644 index 2f444c9..0000000 --- a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0xFFFFFFFFFFFF0000; - resultdsp =3D 1; - - __asm - ("muleu_s.ph.qbl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleu_s.ph.qbl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c b/tests/tcg/mips/mi= ps64-dsp/muleu_s_ph_qbr.c deleted file mode 100644 index 8bd0e99..0000000 --- a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x8000; - rt =3D 0x80004321; - result =3D 0xFFFFFFFFFFFF0000; - resultdsp =3D 1; - - __asm - ("muleu_s.ph.qbr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("muleu_s.ph.qbr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c b/tests/tcg/mips/mi= ps64-dsp/muleu_s_qh_obl.c deleted file mode 100644 index db0d386..0000000 --- a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c +++ /dev/null @@ -1,30 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long resdsp, result; - - rd =3D 0; - rs =3D 0x1234567802020202; - rt =3D 0x0034432112344321; - result =3D 0x03A8FFFFFFFFFFFF; - resdsp =3D 0x01; - - __asm - ("muleu_s.qh.obl %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (resdsp !=3D dsp)) { - printf("muleu_s.qh.obl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c b/tests/tcg/mips/mi= ps64-dsp/muleu_s_qh_obr.c deleted file mode 100644 index 52ed9c0..0000000 --- a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c +++ /dev/null @@ -1,31 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long resdsp, result; - - rd =3D 0; - rs =3D 0x0202020212345678; - - rt =3D 0x0034432112344321; - result =3D 0x03A8FFFFFFFFFFFF; - resdsp =3D 0x01; - - __asm - ("muleu_s.qh.obr %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (resdsp !=3D dsp)) { - printf("muleu_s.qh.obr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mulq_rs_ph.c b/tests/tcg/mips/mips64= -dsp/mulq_rs_ph.c deleted file mode 100644 index fd6233d..0000000 --- a/tests/tcg/mips/mips64-dsp/mulq_rs_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFF098C; - resultdsp =3D 1; - - __asm - ("mulq_rs.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if ((rd !=3D result) || (dsp !=3D resultdsp)) { - printf("mulq_rs.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mulq_rs_qh.c b/tests/tcg/mips/mips64= -dsp/mulq_rs_qh.c deleted file mode 100644 index 7863c05..0000000 --- a/tests/tcg/mips/mips64-dsp/mulq_rs_qh.c +++ /dev/null @@ -1,33 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dsp, dspresult; - rt =3D 0x80003698CE8F9201; - rs =3D 0x800034634BCDE321; - result =3D 0x7fff16587a530313; - - dspresult =3D 0x01; - - __asm - ("mulq_rs.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D result) { - printf("mulq_rs.qh error\n"); - - return -1; - } - - dsp =3D (dsp >> 21) & 0x01; - if (dsp !=3D dspresult) { - printf("mulq_rs.qh DSPControl Reg ouflag error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c b/tests/tcg/mips/mip= s64-dsp/mulsaq_s_l_pw.c deleted file mode 100644 index 02548f8..0000000 --- a/tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c +++ /dev/null @@ -1,59 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long achi, acli; - long long acho, aclo; - long long resl, resh; - - achi =3D 0x4; - acli =3D 0x4; - - rs =3D 0x1234567887654321; - rt =3D 0x8765432112345678; - - resh =3D 0x4; - resl =3D 0x4; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "mulsaq_s.l.pw $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 mulsaq_s.l.pw wrong\n"); - - return -1; - } - - achi =3D 0x4; - acli =3D 0x4; - - rs =3D 0x8000000087654321; - rt =3D 0x8000000012345678; - - resh =3D 0x4; - resl =3D 0x1e8ee513; - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "mulsaq_s.l.pw $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (acho !=3D resh) || (aclo !=3D resl)) { - printf("2 mulsaq_s.l.pw wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c b/tests/tcg/mips/mip= s64-dsp/mulsaq_s_w_qh.c deleted file mode 100644 index 92d7a0b..0000000 --- a/tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c +++ /dev/null @@ -1,57 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long achi, acli; - long long acho, aclo; - long long resl, resh; - - achi =3D 0x4; - acli =3D 0x4; - - rs =3D 0x5678123443218765; - rt =3D 0x4321876556781234; - - resh =3D 0x4; - resl =3D 0x342fcbd4; - __asm - ("mthi %2, $ac1\n\t" - "mtlo %3, $ac1\n\t" - "mulsaq_s.w.qh $ac1, %4, %5\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 mulsaq_s.w.qh wrong\n"); - return -1; - } - - achi =3D 0x4; - acli =3D 0x4; - - rs =3D 0x8000800087654321; - rt =3D 0x8000800012345678; - - resh =3D 0x3; - resl =3D 0xffffffffe5e81a1c; - __asm - ("mthi %3, $ac1\n\t" - "mtlo %4, $ac1\n\t" - "mulsaq_s.w.qh $ac1, %5, %6\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "=3Dr"(acho), "=3Dr"(aclo), "=3Dr"(dsp) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x1; - if ((dsp !=3D 0x1) || (acho !=3D resh) || (aclo !=3D resl)) { - printf("2 mulsaq_s.w.qh wrong\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/mult.c b/tests/tcg/mips/mips64-dsp/m= ult.c deleted file mode 100644 index 4a294d1..0000000 --- a/tests/tcg/mips/mips64-dsp/mult.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, ach, acl; - long long result, resulth, resultl; - - rs =3D 0x00FFBBAA; - rt =3D 0x4B231000; - resulth =3D 0x4b0f01; - resultl =3D 0x71f8a000; - __asm - ("mult $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(ach), "=3Dr"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("mult wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/multu.c b/tests/tcg/mips/mips64-dsp/= multu.c deleted file mode 100644 index 21a8a7c..0000000 --- a/tests/tcg/mips/mips64-dsp/multu.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt, ach, acl; - long long result, resulth, resultl; - - rs =3D 0x00FFBBAA; - rt =3D 0x4B231000; - resulth =3D 0x4b0f01; - resultl =3D 0x71f8a000; - __asm - ("multu $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "=3Dr"(ach), "=3Dr"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("multu wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/packrl_ph.c b/tests/tcg/mips/mips64-= dsp/packrl_ph.c deleted file mode 100644 index 3722b0a..0000000 --- a/tests/tcg/mips/mips64-dsp/packrl_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x56788765; - - __asm - ("packrl.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("packrl.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/packrl_pw.c b/tests/tcg/mips/mips64-= dsp/packrl_pw.c deleted file mode 100644 index 7807418..0000000 --- a/tests/tcg/mips/mips64-dsp/packrl_pw.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long res; - - rs =3D 0x1234567887654321; - rt =3D 0xabcdef9812345678; - - res =3D 0x87654321abcdef98; - - __asm - ("packrl.pw %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D res) { - printf("packrl.pw error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/pick_ob.c b/tests/tcg/mips/mips64-ds= p/pick_ob.c deleted file mode 100644 index 160049f..0000000 --- a/tests/tcg/mips/mips64-dsp/pick_ob.c +++ /dev/null @@ -1,66 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long res; - - dsp =3D 0xff000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234567812345678; - - __asm - ("wrdsp %1, 0x10\n\t" - "pick.ob %0, %2, %3\n\t" - : "=3Dr"(rd) - : "r"(dsp), "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("1 pick.ob error\n"); - return -1; - } - - dsp =3D 0x00000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x8765432187654321; - - __asm - ("wrdsp %1, 0x10\n\t" - "pick.ob %0, %2, %3\n\t" - : "=3Dr"(rd) - : "r"(dsp), "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("2 pick.ob error\n"); - return -1; - } - - dsp =3D 0x34000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x8765567887344321; - - __asm - ("wrdsp %1, 0x10\n\t" - "pick.ob %0, %2, %3\n\t" - : "=3Dr"(rd) - : "r"(dsp), "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("3 pick.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/pick_ph.c b/tests/tcg/mips/mips64-ds= p/pick_ph.c deleted file mode 100644 index 8800c14..0000000 --- a/tests/tcg/mips/mips64-dsp/pick_ph.c +++ /dev/null @@ -1,60 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x0A000000; - result =3D 0x12344321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - if (rd !=3D result) { - printf("1 pick.ph wrong\n"); - - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x03000000; - result =3D 0x12345678; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - if (rd !=3D result) { - printf("2 pick.ph wrong\n"); - - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x00000000; - result =3D 0xffffffff87654321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - if (rd !=3D result) { - printf("3 pick.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/pick_pw.c b/tests/tcg/mips/mips64-ds= p/pick_pw.c deleted file mode 100644 index 24d80f5..0000000 --- a/tests/tcg/mips/mips64-dsp/pick_pw.c +++ /dev/null @@ -1,48 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long res; - dsp =3D 0xff000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234567812345678; - - __asm - ("wrdsp %1, 0x10\n\t" - "wrdsp %1\n\t" - "pick.pw %0, %2, %3\n\t" - : "=3Dr"(rd), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("pick.pw error\n"); - return -1; - } - - dsp =3D 0x00000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x8765432187654321; - - __asm - ("wrdsp %1, 0x10\n\t" - "wrdsp %1\n\t" - "pick.pw %0, %2, %3\n\t" - : "=3Dr"(rd), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("pick.pw error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/pick_qb.c b/tests/tcg/mips/mips64-ds= p/pick_qb.c deleted file mode 100644 index 0d5de9d..0000000 --- a/tests/tcg/mips/mips64-dsp/pick_qb.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x0f000000; - result =3D 0x12345678; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - if (rd !=3D result) { - printf("pick.qb wrong\n"); - - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - dsp =3D 0x00000000; - result =3D 0xffffffff87654321; - - __asm - ("wrdsp %3, 0x10\n\t" - "pick.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt), "r"(dsp) - ); - if (rd !=3D result) { - printf("pick.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/pick_qh.c b/tests/tcg/mips/mips64-ds= p/pick_qh.c deleted file mode 100644 index aa2e293..0000000 --- a/tests/tcg/mips/mips64-dsp/pick_qh.c +++ /dev/null @@ -1,48 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long res; - dsp =3D 0xff000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234567812345678; - - __asm - ("wrdsp %1, 0x10\n\t" - "wrdsp %1\n\t" - "pick.qh %0, %2, %3\n\t" - : "=3Dr"(rd), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("pick.qh error\n"); - return -1; - } - - dsp =3D 0x00000000; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x8765432187654321; - - __asm - ("wrdsp %1, 0x10\n\t" - "wrdsp %1\n\t" - "pick.qh %0, %2, %3\n\t" - : "=3Dr"(rd), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("pick.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_l_pwl.c b/tests/tcg/mips/mips= 64-dsp/preceq_l_pwl.c deleted file mode 100644 index 6455100..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_l_pwl.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - rt =3D 0xFFFFFFFF11111111; - result =3D 0xFFFFFFFF00000000; - - __asm - ("preceq.l.pwl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceq.l.pwl wrong\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/preceq_l_pwr.c b/tests/tcg/mips/mips= 64-dsp/preceq_l_pwr.c deleted file mode 100644 index 1e05339..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_l_pwr.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - rt =3D 0xFFFFFFFF11111111; - result =3D 0x1111111100000000; - - __asm - ("preceq.l.pwl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceq.l.pwr wrong\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c b/tests/tcg/mips/mip= s64-dsp/preceq_pw_qhl.c deleted file mode 100644 index f44b940..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c +++ /dev/null @@ -1,21 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x0123456789ABCDEF; - result =3D 0x0123000045670000; - - __asm - ("preceq.pw.qhl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceq.pw.qhl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c b/tests/tcg/mips/mi= ps64-dsp/preceq_pw_qhla.c deleted file mode 100644 index f0f78f4..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x123400009ABC0000; - - __asm - ("preceq.pw.qhla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceq.pw.qhla error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c b/tests/tcg/mips/mip= s64-dsp/preceq_pw_qhr.c deleted file mode 100644 index 709d4f9..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c +++ /dev/null @@ -1,21 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x0123456789ABCDEF; - result =3D 0x89AB0000CDEF0000; - - __asm - ("preceq.pw.qhr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceq.pw.qhr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c b/tests/tcg/mips/mi= ps64-dsp/preceq_pw_qhra.c deleted file mode 100644 index 4d071ec..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x56780000DEF00000; - - __asm - ("preceq.pw.qhra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceq.pw.qhra error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_w_phl.c b/tests/tcg/mips/mips= 64-dsp/preceq_w_phl.c deleted file mode 100644 index 4ed3fc0..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_w_phl.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0xFFFFFFFF87650000; - - __asm - ("preceq.w.phl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceq.w.phl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceq_w_phr.c b/tests/tcg/mips/mips= 64-dsp/preceq_w_phr.c deleted file mode 100644 index e2ea093..0000000 --- a/tests/tcg/mips/mips64-dsp/preceq_w_phr.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x43210000; - - __asm - ("preceq.w.phr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceq.w.phr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c b/tests/tcg/mips/mi= ps64-dsp/precequ_ph_qbl.c deleted file mode 100644 index 17b7331..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x43803280; - - __asm - ("precequ.ph.qbl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("precequ.ph.qbl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c b/tests/tcg/mips/m= ips64-dsp/precequ_ph_qbla.c deleted file mode 100644 index 15e9494..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x43802180; - - __asm - ("precequ.ph.qbla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("precequ.ph.qbla wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c b/tests/tcg/mips/mi= ps64-dsp/precequ_ph_qbr.c deleted file mode 100644 index 495368c..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x21801080; - - __asm - ("precequ.ph.qbr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("precequ.ph.qbr wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c b/tests/tcg/mips/m= ips64-dsp/precequ_ph_qbra.c deleted file mode 100644 index 7c66369..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x32801080; - - __asm - ("precequ.ph.qbra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("precequ.ph.qbra wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obl.c b/tests/tcg/mips/mi= ps64-dsp/precequ_qh_obl.c deleted file mode 100644 index 176d236..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_qh_obl.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x123456789ABCDEF0; - result =3D 0x09001A002B003C00; - - __asm - ("precequ.qh.obla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("precequ.qh.obla error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obla.c b/tests/tcg/mips/m= ips64-dsp/precequ_qh_obla.c deleted file mode 100644 index 93a36a4..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_qh_obla.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x123456789ABCDEF0; - result =3D 0x09002B004D006F00; - - __asm - ("precequ.qh.obla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("precequ.qh.obla error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obr.c b/tests/tcg/mips/mi= ps64-dsp/precequ_qh_obr.c deleted file mode 100644 index 1214730..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_qh_obr.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x4D005E006F007000; - - __asm - ("precequ.qh.obr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("precequ.qh.obr error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obra.c b/tests/tcg/mips/m= ips64-dsp/precequ_qh_obra.c deleted file mode 100644 index 3aa0e09..0000000 --- a/tests/tcg/mips/mips64-dsp/precequ_qh_obra.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x1A003C005D007000; - - __asm - ("precequ.qh.obra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("precequ.qh.obra error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c b/tests/tcg/mips/mip= s64-dsp/preceu_ph_qbl.c deleted file mode 100644 index 81f7917..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x00870065; - - __asm - ("preceu.ph.qbl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceu.ph.qbl wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c b/tests/tcg/mips/mi= ps64-dsp/preceu_ph_qbla.c deleted file mode 100644 index 38cf6a6..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x00870043; - - __asm - ("preceu.ph.qbla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceu.ph.qbla wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c b/tests/tcg/mips/mip= s64-dsp/preceu_ph_qbr.c deleted file mode 100644 index 70c32b6..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x00430021; - - __asm - ("preceu.ph.qbr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceu.ph.qbr wrong"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c b/tests/tcg/mips/mi= ps64-dsp/preceu_ph_qbra.c deleted file mode 100644 index c6638aa..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0x00650021; - - __asm - ("preceu.ph.qbra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (result !=3D rd) { - printf("preceu.ph.qbra wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obl.c b/tests/tcg/mips/mip= s64-dsp/preceu_qh_obl.c deleted file mode 100644 index 63f9373..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_qh_obl.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x123456789ABCDEF0; - result =3D 0x0012003400560078; - - __asm - ("preceu.qh.obl %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceu.qh.obl error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obla.c b/tests/tcg/mips/mi= ps64-dsp/preceu_qh_obla.c deleted file mode 100644 index 5fb65e4..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_qh_obla.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rt =3D 0x123456789ABCDEF0; - result =3D 0x00120056009A00DE; - - __asm - ("preceu.qh.obla %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceu.qh.obla error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obr.c b/tests/tcg/mips/mip= s64-dsp/preceu_qh_obr.c deleted file mode 100644 index 9af3b63..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_qh_obr.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x009A00BC00DE00F0; - - __asm - ("preceu.qh.obr %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceu.qh.obr error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obra.c b/tests/tcg/mips/mi= ps64-dsp/preceu_qh_obra.c deleted file mode 100644 index fd04083..0000000 --- a/tests/tcg/mips/mips64-dsp/preceu_qh_obra.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0x123456789ABCDEF0; - result =3D 0x0034007800BC00F0; - - __asm - ("preceu.qh.obra %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("preceu.qh.obra error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precr_ob_qh.c b/tests/tcg/mips/mips6= 4-dsp/precr_ob_qh.c deleted file mode 100644 index ce2da79..0000000 --- a/tests/tcg/mips/mips64-dsp/precr_ob_qh.c +++ /dev/null @@ -1,25 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long res; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x3478347865216521; - - __asm - ("precr.ob.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precr.ob.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c b/tests/tcg/mips/m= ips64-dsp/precr_sra_qh_pw.c deleted file mode 100644 index 8bb16de..0000000 --- a/tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long res; - - rt =3D 0x8765432187654321; - rs =3D 0x1234567812345678; - - res =3D 0x4321432156785678; - - __asm - ("precr_sra.qh.pw %0, %1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("precr_sra.qh.pw error\n"); - return -1; - } - - rt =3D 0x8765432187654321; - rs =3D 0x1234567812345678; - - res =3D 0x5432543245674567; - - __asm - ("precr_sra.qh.pw %0, %1, 0x4\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("precr_sra.qh.pw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c b/tests/tcg/mips= /mips64-dsp/precr_sra_r_qh_pw.c deleted file mode 100644 index 734ac32..0000000 --- a/tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c +++ /dev/null @@ -1,40 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long res; - - rt =3D 0x8765432187654321; - rs =3D 0x1234567812345678; - - res =3D 0x4321432156785678; - - __asm - ("precr_sra_r.qh.pw %0, %1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("precr_sra_r.qh.pw error\n"); - return -1; - } - - rt =3D 0x8765432187654321; - rs =3D 0x1234567812345678; - - res =3D 0x5432543245684568; - - __asm - ("precr_sra_r.qh.pw %0, %1, 0x4\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("precr_sra_r.qh.pw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_ob_qh.c b/tests/tcg/mips/mips= 64-dsp/precrq_ob_qh.c deleted file mode 100644 index 4f61b17..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_ob_qh.c +++ /dev/null @@ -1,25 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long res; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1256125687438743; - - __asm - ("precrq.ob.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precrq.ob.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_ph_w.c b/tests/tcg/mips/mips6= 4-dsp/precrq_ph_w.c deleted file mode 100644 index f0946ab..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_ph_w.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12348765; - - __asm - ("precrq.ph.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("precrq.ph.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_pw_l.c b/tests/tcg/mips/mips6= 4-dsp/precrq_pw_l.c deleted file mode 100644 index da957c0..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_pw_l.c +++ /dev/null @@ -1,25 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long res; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234567887654321; - - __asm - ("precrq.pw.l %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precrq.pw.l error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_qb_ph.c b/tests/tcg/mips/mips= 64-dsp/precrq_qb_ph.c deleted file mode 100644 index f417c9f..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_qb_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12568743; - - __asm - ("precrq.qb.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("precrq.qb.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_qh_pw.c b/tests/tcg/mips/mips= 64-dsp/precrq_qh_pw.c deleted file mode 100644 index 4a4ffef..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_qh_pw.c +++ /dev/null @@ -1,25 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long res; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234123487658765; - - __asm - ("precrq.qh.pw %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precrq.qh.pw error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c b/tests/tcg/mips/mi= ps64-dsp/precrq_rs_ph_w.c deleted file mode 100644 index 61da333..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c +++ /dev/null @@ -1,41 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x12348765; - - __asm - ("precrq_rs.ph.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("1 precrq_rs.ph.w wrong\n"); - - return -1; - } - - rs =3D 0x7fffC678; - rt =3D 0x865432A0; - result =3D 0x7fff8654; - - __asm - ("precrq_rs.ph.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((result !=3D rd) || (((dsp >> 22) & 0x01) !=3D 1)) { - printf("2 precrq_rs.ph.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c b/tests/tcg/mips/m= ips64-dsp/precrq_rs_qh_pw.c deleted file mode 100644 index ac78728..0000000 --- a/tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long res; - - rs =3D 0x1234567812345678; - rt =3D 0x8765432187654321; - - res =3D 0x1234123487658765; - - __asm - ("precrq_rs.qh.pw %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precrq_rs.qh.pw error\n"); - return -1; - } - - rs =3D 0x7fffC67812345678; - rt =3D 0x8765432187654321; - - res =3D 0x7fff123487658765; - - __asm - ("precrq_rs.qh.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D res) { - printf("precrq_rs.qh.pw error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c b/tests/tcg/mips/m= ips64-dsp/precrqu_s_ob_qh.c deleted file mode 100644 index e27c36b..0000000 --- a/tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long res, resdsp; - - rs =3D 0x7fff567812345678; - rt =3D 0x8765432187654321; - - res =3D 0xffac24ac00860086; - resdsp =3D 0x1; - - __asm - ("precrqu_s.ob.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x1; - if ((rd !=3D res) || (dsp !=3D resdsp)) { - printf("precrq_s.ob.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c b/tests/tcg/mips/m= ips64-dsp/precrqu_s_qb_ph.c deleted file mode 100644 index cb1fee4..0000000 --- a/tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87657fff; - result =3D 0x24AC00FF; - - __asm - ("precrqu_s.qb.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((result !=3D rd) || (((dsp >> 22) & 0x01) !=3D 0x01)) { - printf("precrqu_s.qb.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/prependd.c b/tests/tcg/mips/mips64-d= sp/prependd.c deleted file mode 100644 index b4208c2..0000000 --- a/tests/tcg/mips/mips64-dsp/prependd.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long res; - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0x1234567887654321; - __asm - ("prependd %0, %1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("prependd error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0xd876512345678876; - __asm - ("prependd %0, %1, 0x4\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("prependd error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/prependw.c b/tests/tcg/mips/mips64-d= sp/prependw.c deleted file mode 100644 index d91bd20..0000000 --- a/tests/tcg/mips/mips64-dsp/prependw.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long res; - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0x1234567887654321; - __asm - ("prependw %0, %1, 0x0\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("prependw error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd8765; - - res =3D 0x5123456788765432; - __asm - ("prependw %0, %1, 0x4\n\t" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("prependw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/printf.c b/tests/tcg/mips/mips64-dsp= /printf.c deleted file mode 100644 index cf8676d..0000000 --- a/tests/tcg/mips/mips64-dsp/printf.c +++ /dev/null @@ -1,266 +0,0 @@ - -typedef unsigned long va_list; - -#define ACC 4 -#define __read(source) \ -({ va_list __res; \ - __asm__ __volatile__( \ - "move\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -enum format_type { - FORMAT_TYPE_NONE, - FORMAT_TYPE_HEX, - FORMAT_TYPE_ULONG, - FORMAT_TYPE_FLOAT -}; - -struct printf_spec { - char type; -}; - -static int format_decode(char *fmt, struct printf_spec *spec) -{ - char *start =3D fmt; - - for (; *fmt ; ++fmt) { - if (*fmt =3D=3D '%') { - break; - } - } - - switch (*++fmt) { - case 'x': - spec->type =3D FORMAT_TYPE_HEX; - break; - - case 'd': - spec->type =3D FORMAT_TYPE_ULONG; - break; - - case 'f': - spec->type =3D FORMAT_TYPE_FLOAT; - break; - - default: - spec->type =3D FORMAT_TYPE_NONE; - } - - return ++fmt - start; -} - -void *memcpy(void *dest, void *src, int n) -{ - int i; - char *s =3D src; - char *d =3D dest; - - for (i =3D 0; i < n; i++) { - d[i] =3D s[i]; - } - return dest; -} - -char *number(char *buf, va_list num) -{ - int i; - char *str =3D buf; - static char digits[16] =3D "0123456789abcdef"; - str =3D str + sizeof(num) * 2; - - for (i =3D 0; i < sizeof(num) * 2; i++) { - *--str =3D digits[num & 15]; - num >>=3D 4; - } - - return buf + sizeof(num) * 2; -} - -char *__number(char *buf, va_list num) -{ - int i; - va_list mm =3D num; - char *str =3D buf; - - if (!num) { - *str++ =3D '0'; - return str; - } - - for (i =3D 0; mm; mm =3D mm/10, i++) { - /* Do nothing. */ - } - - str =3D str + i; - - while (num) { - *--str =3D num % 10 + 48; - num =3D num / 10; - } - - return str + i; -} - -va_list modf(va_list args, va_list *integer, va_list *num) -{ - int i; - double dot_v =3D 0; - va_list E, DOT, DOT_V; - - if (!args) { - return 0; - } - - for (i =3D 0, args =3D args << 1 >> 1; i < 52; i++) { - if ((args >> i) & 0x1) { - break; - } - } - - *integer =3D 0; - - if ((args >> 56 !=3D 0x3f) || (args >> 52 =3D=3D 0x3ff)) { - E =3D (args >> 52) - 1023; - DOT =3D 52 - E - i; - DOT_V =3D args << (12 + E) >> (12 + E) >> i; - *integer =3D ((args << 12 >> 12) >> (i + DOT)) | (1 << E); - } else { - E =3D ~((args >> 52) - 1023) + 1; - DOT_V =3D args << 12 >> 12; - - dot_v +=3D 1.0 / (1 << E); - - for (i =3D 1; i <=3D 16; i++) { - if ((DOT_V >> (52 - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << E + i); - } - } - - for (i =3D 1, E =3D 0; i <=3D ACC; i++) { - dot_v *=3D 10; - if (!(va_list)dot_v) { - E++; - } - } - - *num =3D E; - - return dot_v; - } - - if (args & 0xf) { - for (i =3D 1; i <=3D 16; i++) { - if ((DOT_V >> (DOT - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << i); - } - } - - for (i =3D 1, E =3D 0; i <=3D ACC; i++) { - dot_v *=3D 10; - if (!(va_list)dot_v) { - E++; - } - } - - *num =3D E; - - return dot_v; - } else if (DOT) { - for (i =3D 1; i <=3D DOT; i++) { - if ((DOT_V >> (DOT - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << i); - } - } - - for (i =3D 1; i <=3D ACC; i++) { - dot_v =3D dot_v * 10; - } - - return dot_v; - } - - return 0; -} - -int vsnprintf(char *buf, int size, char *fmt, va_list args) -{ - char *str, *mm; - struct printf_spec spec =3D {0}; - - str =3D mm =3D buf; - - while (*fmt) { - char *old_fmt =3D fmt; - int read =3D format_decode(fmt, &spec); - - fmt +=3D read; - - switch (spec.type) { - case FORMAT_TYPE_NONE: { - memcpy(str, old_fmt, read); - str +=3D read; - break; - } - case FORMAT_TYPE_HEX: { - memcpy(str, old_fmt, read); - str =3D number(str + read, args); - for (; *mm ; ++mm) { - if (*mm =3D=3D '%') { - *mm =3D '0'; - break; - } - } - break; - } - case FORMAT_TYPE_ULONG: { - memcpy(str, old_fmt, read - 2); - str =3D __number(str + read - 2, args); - break; - } - case FORMAT_TYPE_FLOAT: { - va_list integer, dot_v, num; - dot_v =3D modf(args, &integer, &num); - memcpy(str, old_fmt, read - 2); - str +=3D read - 2; - if ((args >> 63 & 0x1)) { - *str++ =3D '-'; - } - str =3D __number(str, integer); - if (dot_v) { - *str++ =3D '.'; - while (num--) { - *str++ =3D '0'; - } - str =3D __number(str, dot_v); - } - break; - } - } - } - *str =3D '\0'; - - return str - buf; -} - -static void serial_out(char *str) -{ - while (*str) { - *(char *)0xffffffffb80003f8 =3D *str++; - } -} - -int vprintf(char *fmt, va_list args) -{ - int printed_len =3D 0; - static char printf_buf[512]; - printed_len =3D vsnprintf(printf_buf, sizeof(printf_buf), fmt, args); - serial_out(printf_buf); - return printed_len; -} - -int printf(char *fmt, ...) -{ - return vprintf(fmt, __read($5)); -} diff --git a/tests/tcg/mips/mips64-dsp/raddu_l_ob.c b/tests/tcg/mips/mips64= -dsp/raddu_l_ob.c deleted file mode 100644 index 76ddf25..0000000 --- a/tests/tcg/mips/mips64-dsp/raddu_l_ob.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, result; - rs =3D 0x12345678ABCDEF0; - result =3D 0x000000000001E258; - - __asm - ("raddu.l.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs) - ); - - if (rd !=3D result) { - printf("raddu.l.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/raddu_w_qb.c b/tests/tcg/mips/mips64= -dsp/raddu_w_qb.c deleted file mode 100644 index c9d6535..0000000 --- a/tests/tcg/mips/mips64-dsp/raddu_w_qb.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs; - long long result; - - rs =3D 0x12345678; - result =3D 0x114; - - __asm - ("raddu.w.qb %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rs) - ); - if (rd !=3D result) { - printf("raddu.w.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/rddsp.c b/tests/tcg/mips/mips64-dsp/= rddsp.c deleted file mode 100644 index 7165572..0000000 --- a/tests/tcg/mips/mips64-dsp/rddsp.c +++ /dev/null @@ -1,53 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long dsp_i, dsp_o; - long long ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; - long long ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; - long long ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r; - - ccond_i =3D 0x000000BC;/* 4 */ - outflag_i =3D 0x0000001B;/* 3 */ - efi_i =3D 0x00000001;/* 5 */ - c_i =3D 0x00000001;/* 2 */ - scount_i =3D 0x0000000F;/* 1 */ - pos_i =3D 0x0000000C;/* 0 */ - - dsp_i =3D (ccond_i << 24) | \ - (outflag_i << 16) | \ - (efi_i << 14) | \ - (c_i << 13) | \ - (scount_i << 7) | \ - pos_i; - - ccond_r =3D ccond_i; - outflag_r =3D outflag_i; - efi_r =3D efi_i; - c_r =3D c_i; - scount_r =3D scount_i; - pos_r =3D pos_i; - - __asm - ("wrdsp %1, 0x3F\n\t" - "rddsp %0, 0x3F\n\t" - : "=3Dr"(dsp_o) - : "r"(dsp_i) - ); - - ccond_o =3D (dsp_o >> 24) & 0xFF; - outflag_o =3D (dsp_o >> 16) & 0xFF; - efi_o =3D (dsp_o >> 14) & 0x01; - c_o =3D (dsp_o >> 14) & 0x01; - scount_o =3D (dsp_o >> 7) & 0x3F; - pos_o =3D dsp_o & 0x1F; - - if ((ccond_o !=3D ccond_r) || (outflag_o !=3D outflag_r) || (efi_o != =3D efi_r) \ - || (c_o !=3D c_r) || (scount_o !=3D scount_r) || (pos_o !=3D p= os_r)) { - printf("rddsp wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/repl_ob.c b/tests/tcg/mips/mips64-ds= p/repl_ob.c deleted file mode 100644 index 20cb780..0000000 --- a/tests/tcg/mips/mips64-dsp/repl_ob.c +++ /dev/null @@ -1,21 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, result; - rd =3D 0; - result =3D 0xFFFFFFFFFFFFFFFF; - - __asm - ("repl.ob %0, 0xFF\n\t" - : "=3Dr"(rd) - ); - - if (result !=3D rd) { - printf("repl.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/repl_ph.c b/tests/tcg/mips/mips64-ds= p/repl_ph.c deleted file mode 100644 index 11d29bd..0000000 --- a/tests/tcg/mips/mips64-dsp/repl_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, result; - - result =3D 0x01BF01BF; - __asm - ("repl.ph %0, 0x1BF\n\t" - : "=3Dr"(rd) - ); - if (rd !=3D result) { - printf("repl.ph wrong\n"); - - return -1; - } - - result =3D 0x01FF01FF; - __asm - ("repl.ph %0, 0x01FF\n\t" - : "=3Dr"(rd) - ); - if (rd !=3D result) { - printf("repl.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/repl_pw.c b/tests/tcg/mips/mips64-ds= p/repl_pw.c deleted file mode 100644 index d35376a..0000000 --- a/tests/tcg/mips/mips64-dsp/repl_pw.c +++ /dev/null @@ -1,34 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, result; - rd =3D 0; - result =3D 0x000001FF000001FF; - - __asm - ("repl.pw %0, 0x1FF\n\t" - : "=3Dr"(rd) - ); - - if (result !=3D rd) { - printf("repl.pw error1\n"); - - return -1; - } - - rd =3D 0; - result =3D 0xFFFFFE00FFFFFE00; - __asm - ("repl.pw %0, 0xFFFFFFFFFFFFFE00\n\t" - : "=3Dr"(rd) - ); - - if (result !=3D rd) { - printf("repl.pw error2\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/repl_qb.c b/tests/tcg/mips/mips64-ds= p/repl_qb.c deleted file mode 100644 index 592feae..0000000 --- a/tests/tcg/mips/mips64-dsp/repl_qb.c +++ /dev/null @@ -1,19 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, result; - - result =3D 0xFFFFFFFFBFBFBFBF; - __asm - ("repl.qb %0, 0xBF\n\t" - : "=3Dr"(rd) - ); - if (rd !=3D result) { - printf("repl.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/repl_qh.c b/tests/tcg/mips/mips64-ds= p/repl_qh.c deleted file mode 100644 index 82afc37..0000000 --- a/tests/tcg/mips/mips64-dsp/repl_qh.c +++ /dev/null @@ -1,34 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, result; - rd =3D 0; - result =3D 0x01FF01FF01FF01FF; - - __asm - ("repl.qh %0, 0x1FF\n\t" - : "=3Dr"(rd) - ); - - if (result !=3D rd) { - printf("repl.qh error 1\n"); - - return -1; - } - - rd =3D 0; - result =3D 0xFE00FE00FE00FE00; - __asm - ("repl.qh %0, 0xFFFFFFFFFFFFFE00\n\t" - : "=3Dr"(rd) - ); - - if (result !=3D rd) { - printf("repl.qh error 2\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/replv_ob.c b/tests/tcg/mips/mips64-d= sp/replv_ob.c deleted file mode 100644 index 31ff318..0000000 --- a/tests/tcg/mips/mips64-dsp/replv_ob.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - - rt =3D 0xFF; - result =3D 0xFFFFFFFFFFFFFFFF; - - __asm - ("replv.ob %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("replv.ob error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/replv_ph.c b/tests/tcg/mips/mips64-d= sp/replv_ph.c deleted file mode 100644 index 0af7a36..0000000 --- a/tests/tcg/mips/mips64-dsp/replv_ph.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x56785678; - __asm - ("replv.ph %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("replv.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/replv_pw.c b/tests/tcg/mips/mips64-d= sp/replv_pw.c deleted file mode 100644 index e1789af..0000000 --- a/tests/tcg/mips/mips64-dsp/replv_pw.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, result; - rd =3D 0; - rt =3D 0xFFFFFFFF; - result =3D 0xFFFFFFFFFFFFFFFF; - - __asm - ("replv.pw %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (result !=3D rd) { - printf("replv.pw error\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/replv_qb.c b/tests/tcg/mips/mips64-d= sp/replv_qb.c deleted file mode 100644 index d99298c..0000000 --- a/tests/tcg/mips/mips64-dsp/replv_qb.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x78787878; - __asm - ("replv.qb %0, %1\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("replv.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shilo.c b/tests/tcg/mips/mips64-dsp/= shilo.c deleted file mode 100644 index 5f454f6..0000000 --- a/tests/tcg/mips/mips64-dsp/shilo.c +++ /dev/null @@ -1,29 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long ach, acl; - long long resulth, resultl; - - ach =3D 0xBBAACCFF; - acl =3D 0x1C3B001D; - - resulth =3D 0x17755; - resultl =3D 0xFFFFFFFF99fe3876; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilo $ac1, 0x0F\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("shilo wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shilov.c b/tests/tcg/mips/mips64-dsp= /shilov.c deleted file mode 100644 index e82615a..0000000 --- a/tests/tcg/mips/mips64-dsp/shilov.c +++ /dev/null @@ -1,31 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, ach, acl; - long long resulth, resultl; - - rs =3D 0x0F; - ach =3D 0xBBAACCFF; - acl =3D 0x1C3B001D; - - resulth =3D 0x17755; - resultl =3D 0xFFFFFFFF99fe3876; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "shilov $ac1, %2\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("shilov wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_ob.c b/tests/tcg/mips/mips64-ds= p/shll_ob.c deleted file mode 100644 index 7dcb58f..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_ob.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long res, resdsp; - - rt =3D 0x9ba8765433456789; - res =3D 0x9ba8765433456789; - resdsp =3D 0x0; - __asm - ("shll.ob %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll.ob error\n"); - return -1; - } - - rt =3D 0x9ba8765433456789; - res =3D 0xd840b0a098283848; - resdsp =3D 0x1; - __asm - ("shll.ob %0, %2, 0x3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_ph.c b/tests/tcg/mips/mips64-ds= p/shll_ph.c deleted file mode 100644 index 42b462d..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_ph.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x12345678; - result =3D 0x12345678; - resultdsp =3D 0; - - __asm - ("shll.ph %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll.ph wrong\n"); - - return -1; - } - - rt =3D 0x12345678; - result =3D 0xFFFFFFFFA000C000; - resultdsp =3D 1; - - __asm - ("shll.ph %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll.ph wrong1\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_pw.c b/tests/tcg/mips/mips64-ds= p/shll_pw.c deleted file mode 100644 index d7878b2..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_pw.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shll.pw %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll.pw wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - result =3D 0x6543210034567800; - resultdsp =3D 1; - - __asm - ("shll.pw %0, %2, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll.pw wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_qb.c b/tests/tcg/mips/mips64-ds= p/shll_qb.c deleted file mode 100644 index c21ab66..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_qb.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x87654321; - result =3D 0x38281808; - resultdsp =3D 0x01; - - __asm - ("shll.qb %0, %2, 0x03\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if (rd !=3D result) { - printf("shll.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_qh.c b/tests/tcg/mips/mips64-ds= p/shll_qh.c deleted file mode 100644 index 1380825..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_qh.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long res, resdsp; - - rt =3D 0x9ba8765433456789; - res =3D 0x9ba8765433456789; - resdsp =3D 0x0; - __asm - ("shll.qh %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll.qh error\n"); - return -1; - } - - rt =3D 0x9ba8765433456789; - res =3D 0xdd40b2a09a283c48; - resdsp =3D 0x1; - __asm - ("shll.qh %0, %2, 0x3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll.qh error1\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_s_ph.c b/tests/tcg/mips/mips64-= dsp/shll_s_ph.c deleted file mode 100644 index 1cf5d6d..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_s_ph.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x12345678; - result =3D 0x12345678; - resultdsp =3D 0x0; - - __asm - ("shll_s.ph %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll_s.ph wrong\n"); - - return -1; - } - - rt =3D 0x12345678; - result =3D 0x7FFF7FFF; - resultdsp =3D 0x01; - - __asm - ("shll_s.ph %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll_s.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_s_pw.c b/tests/tcg/mips/mips64-= dsp/shll_s_pw.c deleted file mode 100644 index e38f686..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_s_pw.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shll_s.pw %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll_s.pw wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - result =3D 0x800000007fffffff; - resultdsp =3D 1; - - __asm - ("shll_s.pw %0, %2, 0x8\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll_s.pw wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_s_qh.c b/tests/tcg/mips/mips64-= dsp/shll_s_qh.c deleted file mode 100644 index f2f57fa..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_s_qh.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long res, resdsp; - - rt =3D 0x9ba8765433456789; - res =3D 0x9ba8765433456789; - resdsp =3D 0x0; - __asm - ("shll_s.qh %0, %2, 0x0\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll_s.qh error\n"); - return -1; - } - - rt =3D 0x9ba8765433456789; - res =3D 0x80007fff7fff7fff; - resdsp =3D 0x1; - __asm - ("shll_s.qh %0, %2, 0x3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - - dsp =3D (dsp >> 22) & 0x1; - - if ((dsp !=3D resdsp) || (rd !=3D res)) { - printf("shll_s.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shll_s_w.c b/tests/tcg/mips/mips64-d= sp/shll_s_w.c deleted file mode 100644 index 5780061..0000000 --- a/tests/tcg/mips/mips64-dsp/shll_s_w.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, dsp; - long long result, resultdsp; - - rt =3D 0x12345678; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("shll_s.w %0, %2, 0x0B\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shll_s.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_ob.c b/tests/tcg/mips/mips64-d= sp/shllv_ob.c deleted file mode 100644 index 96a2e6f..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_ob.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - rs =3D 0x0; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shllv.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.ob wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - rs =3D 0x4; - result =3D 0x7050301020406080; - resultdsp =3D 1; - - __asm - ("shllv.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.ob wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_ph.c b/tests/tcg/mips/mips64-d= sp/shllv_ph.c deleted file mode 100644 index 532291f..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0xFFFFFFFFA000C000; - resultdsp =3D 1; - - __asm - ("shllv.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_pw.c b/tests/tcg/mips/mips64-d= sp/shllv_pw.c deleted file mode 100644 index 8d4ec29..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_pw.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs, dsp; - long long result, resultdsp; - rt =3D 0x8765432112345678; - rs =3D 0x0; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shllv.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.pw wrong\n"); - return -1; - } - - - rt =3D 0x8765432112345678; - rs =3D 0x8; - result =3D 0x6543210034567800; - resultdsp =3D 1; - - __asm - ("shllv.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.pw wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_qb.c b/tests/tcg/mips/mips64-d= sp/shllv_qb.c deleted file mode 100644 index e49356b..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_qb.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0x38281808; - resultdsp =3D 0x01; - - __asm - ("shllv.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - if (rd !=3D result) { - printf("shllv.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_qh.c b/tests/tcg/mips/mips64-d= sp/shllv_qh.c deleted file mode 100644 index 0de4077..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_qh.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - rs =3D 0x0; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shllv.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.qh wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - rs =3D 0x4; - result =3D 0x7650321023406780; - resultdsp =3D 1; - - __asm - ("shllv.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv.qh wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_ph.c b/tests/tcg/mips/mips64= -dsp/shllv_s_ph.c deleted file mode 100644 index 7e69f94..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_s_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0x7FFF7FFF; - resultdsp =3D 0x01; - - __asm - ("shllv_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_pw.c b/tests/tcg/mips/mips64= -dsp/shllv_s_pw.c deleted file mode 100644 index f8dc8d2..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_s_pw.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - rs =3D 0x0; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shllv_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.pw wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - rs =3D 0x8; - result =3D 0x800000007fffffff; - resultdsp =3D 1; - - __asm - ("shllv_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.pw wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_qh.c b/tests/tcg/mips/mips64= -dsp/shllv_s_qh.c deleted file mode 100644 index db3832d..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_s_qh.c +++ /dev/null @@ -1,45 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs, dsp; - long long result, resultdsp; - - rt =3D 0x8765432112345678; - rs =3D 0x0; - result =3D 0x8765432112345678; - resultdsp =3D 0; - - __asm - ("shllv_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.qh wrong\n"); - return -1; - } - - rt =3D 0x8765432112345678; - rs =3D 0x4; - result =3D 0x80007fff7fff7fff; - resultdsp =3D 1; - - __asm - ("shllv_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.qh wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_w.c b/tests/tcg/mips/mips64-= dsp/shllv_s_w.c deleted file mode 100644 index 5f6af8b..0000000 --- a/tests/tcg/mips/mips64-dsp/shllv_s_w.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x0B; - rt =3D 0x12345678; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("shllv_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rt), "r"(rs) - ); - dsp =3D (dsp >> 22) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("shllv_s.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_ob.c b/tests/tcg/mips/mips64-ds= p/shra_ob.c deleted file mode 100644 index d7fcfa8..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_ob.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main() -{ - long long rd, rt; - long long res; - - rt =3D 0xbc98756abc654389; - res =3D 0xfbf9f7f6fb0604f8; - - __asm - ("shra.ob %0, %1, 0x4\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_ph.c b/tests/tcg/mips/mips64-ds= p/shra_ph.c deleted file mode 100644 index a2dc014..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0EC0864; - - __asm - ("shra.ph %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_pw.c b/tests/tcg/mips/mips64-ds= p/shra_pw.c deleted file mode 100644 index 33b1b8f..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_pw.c +++ /dev/null @@ -1,36 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0x1234567887654321; - res =3D 0x01234567f8765432; - - __asm - ("shra.pw %0, %1, 0x4" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra.pw error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - res =3D 0x1234567887654321; - - __asm - ("shra.pw %0, %1, 0x0" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra.pw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_qh.c b/tests/tcg/mips/mips64-ds= p/shra_qh.c deleted file mode 100644 index 85dbfef..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_qh.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0x8512345654323454; - res =3D 0xf851034505430345; - - __asm - ("shra.qh %0, %1, 0x4\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra.qh error\n"); - return -1; - } - - rt =3D 0x8512345654323454; - res =3D 0x8512345654323454; - - __asm - ("shra.qh %0, %1, 0x0\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra.qh error1\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_r_ob.c b/tests/tcg/mips/mips64-= dsp/shra_r_ob.c deleted file mode 100644 index 1847094..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_r_ob.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main() -{ - long long rd, rt; - long long res; - - rt =3D 0xbc98756abc654389; - res =3D 0xfcfaf8f7fc0705f9; - - __asm - ("shra_r.ob %0, %1, 0x4\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra_r.ob error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_r_ph.c b/tests/tcg/mips/mips64-= dsp/shra_r_ph.c deleted file mode 100644 index e0943ad..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_r_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0ED0864; - - __asm - ("shra_r.ph %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra_r.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_r_pw.c b/tests/tcg/mips/mips64-= dsp/shra_r_pw.c deleted file mode 100644 index 6a86e68..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_r_pw.c +++ /dev/null @@ -1,36 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0x1234567887654321; - res =3D 0x01234568f8765432; - - __asm - ("shra_r.pw %0, %1, 0x4" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra_r.pw error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - res =3D 0x1234567887654321; - - __asm - ("shra_r.pw %0, %1, 0x0" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra_r.pw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_r_qh.c b/tests/tcg/mips/mips64-= dsp/shra_r_qh.c deleted file mode 100644 index d5c2110..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_r_qh.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0x8512345654323454; - res =3D 0xf0a2068b0a86068b; - - __asm - ("shra_r.qh %0, %1, 0x3\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra_r.qh error\n"); - return -1; - } - - rt =3D 0x8512345654323454; - res =3D 0x8512345654323454; - - __asm - ("shra_r.qh %0, %1, 0x0\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shra_r.qh error1\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shra_r_w.c b/tests/tcg/mips/mips64-d= sp/shra_r_w.c deleted file mode 100644 index 36d2c9c..0000000 --- a/tests/tcg/mips/mips64-dsp/shra_r_w.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0ECA864; - - __asm - ("shra_r.w %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra_r.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_ph.c b/tests/tcg/mips/mips64-d= sp/shrav_ph.c deleted file mode 100644 index 1b4e983..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0EC0864; - - __asm - ("shrav.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_pw.c b/tests/tcg/mips/mips64-d= sp/shrav_pw.c deleted file mode 100644 index e19d515..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_pw.c +++ /dev/null @@ -1,38 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x1234567887654321; - rs =3D 0x4; - res =3D 0x01234567f8765432; - - __asm - ("shrav.pw %0, %1, %2" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav.pw error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0x0; - res =3D 0x1234567887654321; - - __asm - ("shrav.pw %0, %1, %2" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav.pw error1\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_qh.c b/tests/tcg/mips/mips64-d= sp/shrav_qh.c deleted file mode 100644 index dc92e09..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_qh.c +++ /dev/null @@ -1,39 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x8512345654323454; - rs =3D 0x4; - res =3D 0xf851034505430345; - - __asm - ("shrav.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav.qh error\n"); - return -1; - } - - rt =3D 0x8512345654323454; - rs =3D 0x0; - res =3D 0x8512345654323454; - - __asm - ("shrav.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_ph.c b/tests/tcg/mips/mips64= -dsp/shrav_r_ph.c deleted file mode 100644 index 350d529..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_r_ph.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0ED0864; - - __asm - ("shrav_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav_r.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_pw.c b/tests/tcg/mips/mips64= -dsp/shrav_r_pw.c deleted file mode 100644 index 25b0545..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_r_pw.c +++ /dev/null @@ -1,37 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x1234567887654321; - rs =3D 0x4; - res =3D 0x01234568f8765432; - - __asm - ("shrav_r.pw %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav_r.pw error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0x0; - res =3D 0x1234567887654321; - - __asm - ("shrav_r.pw %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D res) { - printf("shrav_r.pw error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_qh.c b/tests/tcg/mips/mips64= -dsp/shrav_r_qh.c deleted file mode 100644 index fd187a1..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_r_qh.c +++ /dev/null @@ -1,39 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x8512345654323454; - rs =3D 0x3; - res =3D 0xf0a2068b0a86068b; - - __asm - ("shrav_r.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav_r.qh error\n"); - return -1; - } - - rt =3D 0x400000000000000; - rs =3D 0x0; - res =3D 0x400000000000000; - - __asm - ("shrav_r.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrav_r.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_w.c b/tests/tcg/mips/mips64-= dsp/shrav_r_w.c deleted file mode 100644 index 3766c72..0000000 --- a/tests/tcg/mips/mips64-dsp/shrav_r_w.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF0ECA864; - - __asm - ("shrav_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav_r.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrl_ob.c b/tests/tcg/mips/mips64-ds= p/shrl_ob.c deleted file mode 100644 index a114571..0000000 --- a/tests/tcg/mips/mips64-dsp/shrl_ob.c +++ /dev/null @@ -1,38 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0xab76543212345678; - res =3D 0x150e0a0602060a0f; - - __asm - ("shrl.ob %0, %1, 0x3\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shrl.ob error\n"); - return -1; - } - - rt =3D 0xab76543212345678; - res =3D 0xab76543212345678; - - __asm - ("shrl.ob %0, %1, 0x0\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shrl.ob error\n"); - return -1; - } - - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrl_qb.c b/tests/tcg/mips/mips64-ds= p/shrl_qb.c deleted file mode 100644 index c0e36db..0000000 --- a/tests/tcg/mips/mips64-dsp/shrl_qb.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x00010203; - - __asm - ("shrl.qb %0, %1, 0x05\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shrl.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrl_qh.c b/tests/tcg/mips/mips64-ds= p/shrl_qh.c deleted file mode 100644 index c156246..0000000 --- a/tests/tcg/mips/mips64-dsp/shrl_qh.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt; - long long res; - - rt =3D 0x8765679abc543786; - res =3D 0x087606790bc50378; - - __asm - ("shrl.qh %0, %1, 0x4\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - - if (rd !=3D res) { - printf("shrl.qh error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrlv_ob.c b/tests/tcg/mips/mips64-d= sp/shrlv_ob.c deleted file mode 100644 index cb39c46..0000000 --- a/tests/tcg/mips/mips64-dsp/shrlv_ob.c +++ /dev/null @@ -1,39 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0xab76543212345678; - rs =3D 0x3; - res =3D 0x150e0a0602060a0f; - - __asm - ("shrlv.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrlv.ob error\n"); - return -1; - } - - rt =3D 0xab76543212345678; - rs =3D 0x0; - res =3D 0xab76543212345678; - - __asm - ("shrlv.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrlv.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrlv_qb.c b/tests/tcg/mips/mips64-d= sp/shrlv_qb.c deleted file mode 100644 index 5616aa9..0000000 --- a/tests/tcg/mips/mips64-dsp/shrlv_qb.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x05; - rt =3D 0x12345678; - result =3D 0x00010203; - - __asm - ("shrlv.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrlv.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/shrlv_qh.c b/tests/tcg/mips/mips64-d= sp/shrlv_qh.c deleted file mode 100644 index 05de2fd..0000000 --- a/tests/tcg/mips/mips64-dsp/shrlv_qh.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x8765679abc543786; - rs =3D 0x4; - res =3D 0x087606790bc50378; - - __asm - ("shrlv.qh %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shrlv.qh error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subq_ph.c b/tests/tcg/mips/mips64-ds= p/subq_ph.c deleted file mode 100644 index 6a1b186..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFF8ACF1357; - resultdsp =3D 0x01; - - __asm - ("subq.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("subq.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subq_pw.c b/tests/tcg/mips/mips64-ds= p/subq_pw.c deleted file mode 100644 index 32f96ba..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_pw.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rt =3D 0x123456789ABCDEF0; - rs =3D 0x123456789ABCDEF0; - result =3D 0x0; - dspresult =3D 0x0; - - __asm - ("subq.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq.pw error1\n\t"); - - return -1; - } - - rt =3D 0x123456789ABCDEF1; - rs =3D 0x123456789ABCDEF2; - result =3D 0x0000000000000001; - dspresult =3D 0x0; - - __asm - ("subq.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq.pw error2\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/subq_qh.c b/tests/tcg/mips/mips64-ds= p/subq_qh.c deleted file mode 100644 index 76d5f0a..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_qh.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rt =3D 0x123456789ABCDEF0; - rs =3D 0x123456789ABCDEF0; - result =3D 0x0; - dspresult =3D 0x0; - - __asm - ("subq.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq.qh error\n\t"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/subq_s_ph.c b/tests/tcg/mips/mips64-= dsp/subq_s_ph.c deleted file mode 100644 index 0b162f0..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_s_ph.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x7FFF1357; - resultdsp =3D 0x01; - - __asm - ("subq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("subq_s.ph wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subq_s_pw.c b/tests/tcg/mips/mips64-= dsp/subq_s_pw.c deleted file mode 100644 index 4c080b7..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_s_pw.c +++ /dev/null @@ -1,63 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rt =3D 0x9FFFFFFD9FFFFFFD; - rs =3D 0x4000000080000000; - result =3D 0x7fffffffe0000003; - dspresult =3D 0x1; - - __asm - ("subq_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq_s.pw error1\n"); - - return -1; - } - - rt =3D 0x123456789ABCDEF1; - rs =3D 0x123456789ABCDEF2; - result =3D 0x0000000000000001; - /* This time we do not set dspctrl, but set it in pre-action. */ - dspresult =3D 0x1; - - __asm - ("subq_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq_s.pw error2\n"); - - return -1; - } - - rt =3D 0x8000000080000000; - rs =3D 0x7000000070000000; - dspresult =3D 0x1; - - __asm - ("subq_s.pw %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D (dspreg >> 20) & 0x1; - if ((dspreg !=3D dspresult)) { - printf("subq_s.pw error3\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/subq_s_qh.c b/tests/tcg/mips/mips64-= dsp/subq_s_qh.c deleted file mode 100644 index 4053b6b..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_s_qh.c +++ /dev/null @@ -1,61 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEF0; - result =3D 0x0; - dspresult =3D 0x0; - - __asm - ("subq_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq_s.qh error1\n"); - - return -1; - } - - rs =3D 0x4000000080000000; - rt =3D 0x9FFD00009FFC0000; - result =3D 0x7FFF0000E0040000; - dspresult =3D 0x1; - - __asm - ("subq_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq_s.qh error2\n"); - - return -1; - } - - rs =3D 0x8000000000000000; - rt =3D 0x7000000000000000; - result =3D 0x8000000000000000; - dspresult =3D 0x1; - __asm - ("subq_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D (dspreg >> 20) & 0x1; - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subq_s.qh error3\n"); - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/subq_s_w.c b/tests/tcg/mips/mips64-d= sp/subq_s_w.c deleted file mode 100644 index 91d32da..0000000 --- a/tests/tcg/mips/mips64-dsp/subq_s_w.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - - __asm - ("subq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("subq_s.w wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subu_ob.c b/tests/tcg/mips/mips64-ds= p/subu_ob.c deleted file mode 100644 index f670967..0000000 --- a/tests/tcg/mips/mips64-dsp/subu_ob.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - rs =3D 0x6F6F6F6F6F6F6F6F; - rt =3D 0x5E5E5E5E5E5E5E5E; - result =3D 0x1111111111111111; - dspresult =3D 0x0; - - __asm - ("subu.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subu.ob error\n"); - - return -1; - } - - return 0; -} - diff --git a/tests/tcg/mips/mips64-dsp/subu_qb.c b/tests/tcg/mips/mips64-ds= p/subu_qb.c deleted file mode 100644 index 9eb80df..0000000 --- a/tests/tcg/mips/mips64-dsp/subu_qb.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFF8BCF1357; - resultdsp =3D 0x01; - - __asm - ("subu.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("subu.qb wrong\n"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subu_s_ob.c b/tests/tcg/mips/mips64-= dsp/subu_s_ob.c deleted file mode 100644 index 5df64e5..0000000 --- a/tests/tcg/mips/mips64-dsp/subu_s_ob.c +++ /dev/null @@ -1,26 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg, result, dspresult; - rs =3D 0x12345678ABCDEF0; - rt =3D 0x12345678ABCDEF1; - result =3D 0x00000000000; - dspresult =3D 0x01; - - __asm - ("subu_s.ob %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subu_s.ob error\n\t"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/subu_s_qb.c b/tests/tcg/mips/mips64-= dsp/subu_s_qb.c deleted file mode 100644 index 9de76f4..0000000 --- a/tests/tcg/mips/mips64-dsp/subu_s_qb.c +++ /dev/null @@ -1,27 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x00001357; - resultdsp =3D 0x01; - - __asm - ("subu_s.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if ((dsp !=3D resultdsp) || (rd !=3D result)) { - printf("subu_s_qb wrong"); - - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dsp/wrdsp.c b/tests/tcg/mips/mips64-dsp/= wrdsp.c deleted file mode 100644 index 3033fd8..0000000 --- a/tests/tcg/mips/mips64-dsp/wrdsp.c +++ /dev/null @@ -1,48 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long dsp_i, dsp_o; - long long ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i; - long long ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o; - long long ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r; - - ccond_i =3D 0x000000BC;/* 4 */ - outflag_i =3D 0x0000001B;/* 3 */ - efi_i =3D 0x00000001;/* 5 */ - c_i =3D 0x00000001;/* 2 */ - scount_i =3D 0x0000000F;/* 1 */ - pos_i =3D 0x0000000C;/* 0 */ - - dsp_i =3D (ccond_i << 24) | (outflag_i << 16) | (efi_i << 14) | (c_i <= < 13) - | (scount_i << 7) | pos_i; - - ccond_r =3D ccond_i; - outflag_r =3D outflag_i; - efi_r =3D efi_i; - c_r =3D c_i; - scount_r =3D scount_i; - pos_r =3D pos_i; - - __asm - ("wrdsp %1, 0x3F\n\t" - "rddsp %0, 0x3F\n\t" - : "=3Dr"(dsp_o) - : "r"(dsp_i) - ); - - ccond_o =3D (dsp_o >> 24) & 0xFF; - outflag_o =3D (dsp_o >> 16) & 0xFF; - efi_o =3D (dsp_o >> 14) & 0x01; - c_o =3D (dsp_o >> 14) & 0x01; - scount_o =3D (dsp_o >> 7) & 0x3F; - pos_o =3D dsp_o & 0x1F; - - if ((ccond_o !=3D ccond_r) || (outflag_o !=3D outflag_r) || (efi_o != =3D efi_r) \ - || (c_o !=3D c_r) || (scount_o !=3D scount_r) || (pos_o !=3D p= os_r)) { - printf("wrddsp wrong\n"); - - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/Makefile b/tests/tcg/mips/mips64-d= spr2/Makefile deleted file mode 100644 index ba44bb9..0000000 --- a/tests/tcg/mips/mips64-dspr2/Makefile +++ /dev/null @@ -1,116 +0,0 @@ -CROSS_COMPILE ?=3D mips64el-unknown-linux-gnu- - -SIM =3D qemu-system-mips64el -SIMFLAGS =3D -nographic -cpu mips64dspr2 -kernel - -AS =3D $(CROSS_COMPILE)as -LD =3D $(CROSS_COMPILE)ld -CC =3D $(CROSS_COMPILE)gcc -AR =3D $(CROSS_COMPILE)ar -NM =3D $(CROSS_COMPILE)nm -STRIP =3D $(CROSS_COMPILE)strip -RANLIB =3D $(CROSS_COMPILE)ranlib -OBJCOPY =3D $(CROSS_COMPILE)objcopy -OBJDUMP =3D $(CROSS_COMPILE)objdump - -VECTORS_OBJ ?=3D ./head.o ./printf.o - -HEAD_FLAGS ?=3D -nostdinc -mabi=3D64 -G 0 -mno-abicalls -fno-pic -pipe \ - -msoft-float -march=3Dmips64 -Wa,-mips64 -Wa,--trap \ - -msym32 -DKBUILD_64BIT_SYM32 -I./ - -CFLAGS ?=3D -nostdinc -mabi=3D64 -G 0 -mno-abicalls -fno-pic -fno-builtin = \ - -pipe -march=3Dmips64r2 -mgp64 -mdspr2 -static -Wa,--trap -msym3= 2 \ - -DKBUILD_64BIT_SYM32 -I./ - -LDFLAGS =3D -T./mips_boot.lds -L./ -FLAGS =3D -nostdlib -mabi=3D64 -march=3Dmips64r2 -mgp64 -mdspr2 - -TESTCASES =3D absq_s_qb.tst -TESTCASES +=3D addqh_ph.tst -TESTCASES +=3D addqh_r_ph.tst -TESTCASES +=3D addqh_r_w.tst -TESTCASES +=3D addqh_w.tst -#TESTCASES +=3D adduh_ob.tst -TESTCASES +=3D adduh_qb.tst -#TESTCASES +=3D adduh_r_ob.tst -TESTCASES +=3D adduh_r_qb.tst -TESTCASES +=3D addu_ph.tst -#TESTCASES +=3D addu_qh.tst -TESTCASES +=3D addu_s_ph.tst -#TESTCASES +=3D addu_s_qh.tst -TESTCASES +=3D append.tst -TESTCASES +=3D balign.tst -#TESTCASES +=3D cmpgdu_eq_ob.tst -TESTCASES +=3D cmpgdu_eq_qb.tst -#TESTCASES +=3D cmpgdu_le_ob.tst -TESTCASES +=3D cmpgdu_le_qb.tst -#TESTCASES +=3D cmpgdu_lt_ob.tst -TESTCASES +=3D cmpgdu_lt_qb.tst -#TESTCASES +=3D dbalign.tst -TESTCASES +=3D dpaqx_sa_w_ph.tst -TESTCASES +=3D dpaqx_s_w_ph.tst -TESTCASES +=3D dpa_w_ph.tst -#TESTCASES +=3D dpa_w_qh.tst -TESTCASES +=3D dpax_w_ph.tst -TESTCASES +=3D dpsqx_sa_w_ph.tst -TESTCASES +=3D dpsqx_s_w_ph.tst -TESTCASES +=3D dps_w_ph.tst -#TESTCASES +=3D dps_w_qh.tst -TESTCASES +=3D dpsx_w_ph.tst -TESTCASES +=3D mul_ph.tst -TESTCASES +=3D mulq_rs_w.tst -TESTCASES +=3D mulq_s_ph.tst -TESTCASES +=3D mulq_s_w.tst -TESTCASES +=3D mulsaq_s_w_ph.tst -TESTCASES +=3D mulsa_w_ph.tst -TESTCASES +=3D mul_s_ph.tst -TESTCASES +=3D precr_qb_ph.tst -TESTCASES +=3D precr_sra_ph_w.tst -TESTCASES +=3D precr_sra_r_ph_w.tst -TESTCASES +=3D prepend.tst -TESTCASES +=3D shra_qb.tst -TESTCASES +=3D shra_r_qb.tst -#TESTCASES +=3D shrav_ob.tst -TESTCASES +=3D shrav_qb.tst -#TESTCASES +=3D shrav_r_ob.tst -TESTCASES +=3D shrav_r_qb.tst -TESTCASES +=3D shrl_ph.tst -TESTCASES +=3D shrlv_ph.tst -TESTCASES +=3D subqh_ph.tst -TESTCASES +=3D subqh_r_ph.tst -TESTCASES +=3D subqh_r_w.tst -TESTCASES +=3D subqh_w.tst -#TESTCASES +=3D subuh_ob.tst -TESTCASES +=3D subuh_qb.tst -#TESTCASES +=3D subuh_r_ob.tst -TESTCASES +=3D subuh_r_qb.tst -TESTCASES +=3D subu_ph.tst -#TESTCASES +=3D subu_qh.tst -TESTCASES +=3D subu_s_ph.tst -#TESTCASES +=3D subu_s_qh.tst - -all: build - -head.o : head.S - $(Q)$(CC) $(HEAD_FLAGS) -D"STACK_TOP=3D0xffffffff80200000" -c $< -o $@ - -%.o : %.S - $(CC) $(CFLAGS) -c $< -o $@ - -%.o : %.c - $(CC) $(CFLAGS) -c $< -o $@ - -%.tst: %.o $(VECTORS_OBJ) - $(CC) $(VECTORS_OBJ) $(FLAGS) $(LDFLAGS) $< -o $@ - -build: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES) - -check: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES) - @for case in $(TESTCASES); do \ - echo $(SIM) $(SIMFLAGS) ./$$case; \ - $(SIM) $(SIMFLAGS) ./$$case & (sleep 1; killall $(SIM)); \ - done - -clean: - $(Q)rm -f *.o *.tst *.a diff --git a/tests/tcg/mips/mips64-dspr2/absq_s_qb.c b/tests/tcg/mips/mips6= 4-dspr2/absq_s_qb.c deleted file mode 100644 index f7aec3e..0000000 --- a/tests/tcg/mips/mips64-dspr2/absq_s_qb.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" -int main() -{ - long long input, result, dsp; - long long hope; - - input =3D 0x701BA35E; - hope =3D 0x701B5D5E; - - __asm - ("absq_s.qb %0, %1\n\t" - : "=3Dr"(result) - : "r"(input) - ); - if (result !=3D hope) { - printf("absq_s.qb error\n"); - return -1; - } - - input =3D 0x801BA35E; - hope =3D 0x7F1B5D5E; - - __asm - ("absq_s.qb %0, %2\n\t" - "rddsp %1\n\t" - : "=3Dr"(result), "=3Dr"(dsp) - : "r"(input) - ); - dsp =3D dsp >> 20; - dsp &=3D 0x01; - if (result !=3D hope) { - printf("absq_s.qb error\n"); - return -1; - } - - if (dsp !=3D 1) { - printf("absq_s.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addqh_ph.c b/tests/tcg/mips/mips64= -dspr2/addqh_ph.c deleted file mode 100644 index 6b43cb8..0000000 --- a/tests/tcg/mips/mips64-dspr2/addqh_ph.c +++ /dev/null @@ -1,35 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x706A13FE; - rt =3D 0x13065174; - result =3D 0x41B832B9; - __asm - ("addqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("addqh.ph error!\n"); - return -1; - } - - rs =3D 0x81000100; - rt =3D 0xc2000100; - result =3D 0xffffffffa1800100; - __asm - ("addqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("addqh.ph error!\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addqh_r_ph.c b/tests/tcg/mips/mips= 64-dspr2/addqh_r_ph.c deleted file mode 100644 index 890ec98..0000000 --- a/tests/tcg/mips/mips64-dspr2/addqh_r_ph.c +++ /dev/null @@ -1,35 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x706A13FE; - rt =3D 0x13065174; - result =3D 0x41B832B9; - __asm - ("addqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addqh_r.ph error\n"); - return -1; - } - - rs =3D 0x81010100; - rt =3D 0xc2000100; - result =3D 0xffffffffa1810100; - __asm - ("addqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addqh_r.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addqh_r_w.c b/tests/tcg/mips/mips6= 4-dspr2/addqh_r_w.c deleted file mode 100644 index d324dec..0000000 --- a/tests/tcg/mips/mips64-dspr2/addqh_r_w.c +++ /dev/null @@ -1,38 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x00000010; - rt =3D 0x00000001; - result =3D 0x00000009; - - __asm - ("addqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("addqh_r.w error!\n"); - return -1; - } - rs =3D 0xFFFFFFFE; - rt =3D 0x00000001; - result =3D 0x00000000; - - __asm - ("addqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("addqh_r.w error!\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addqh_w.c b/tests/tcg/mips/mips64-= dspr2/addqh_w.c deleted file mode 100644 index 78559e6..0000000 --- a/tests/tcg/mips/mips64-dspr2/addqh_w.c +++ /dev/null @@ -1,39 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x00000010; - rt =3D 0x00000001; - result =3D 0x00000008; - - __asm - ("addqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("addqh.w wrong\n"); - return -1; - } - - rs =3D 0xFFFFFFFE; - rt =3D 0x00000001; - result =3D 0xFFFFFFFFFFFFFFFF; - - __asm - ("addqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("addqh.w wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addu_ph.c b/tests/tcg/mips/mips64-= dspr2/addu_ph.c deleted file mode 100644 index d64c8cd..0000000 --- a/tests/tcg/mips/mips64-dspr2/addu_ph.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x00FF00FF; - rt =3D 0x00010001; - result =3D 0x01000100; - __asm - ("addu.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("1 addu.ph error\n"); - return -1; - } - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0x00011112; - __asm - ("addu.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("2 addu.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addu_qh.c b/tests/tcg/mips/mips64-= dspr2/addu_qh.c deleted file mode 100644 index edcbf34..0000000 --- a/tests/tcg/mips/mips64-dspr2/addu_qh.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg; - long long result, dspresult; - - rs =3D 0x123456787FFF0000; - rt =3D 0x1111111180000000; - result =3D 0x23456789FFFF0000; - dspresult =3D 0x0; - - __asm("addu.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addu.qh error\n"); - return -1; - } - - rs =3D 0x123456787FFF0000; - rt =3D 0x1111111180020000; - result =3D 0x23456789FFFF0000; - dspresult =3D 0x01; - - __asm("addu.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("addu.qh overflow error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addu_s_ph.c b/tests/tcg/mips/mips6= 4-dspr2/addu_s_ph.c deleted file mode 100644 index 9250edb..0000000 --- a/tests/tcg/mips/mips64-dspr2/addu_s_ph.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x00FE00FE; - rt =3D 0x00020001; - result =3D 0x010000FF; - __asm - ("addu_s.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("addu_s.ph error\n"); - return -1; - } - - rs =3D 0xFFFF1111; - rt =3D 0x00020001; - result =3D 0xFFFFFFFFFFFF1112; - __asm - ("addu_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - if ((rd !=3D result) || (((dsp >> 20) & 0x01) !=3D 1)) { - printf("addu_s.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/addu_s_qh.c b/tests/tcg/mips/mips6= 4-dspr2/addu_s_qh.c deleted file mode 100644 index b0c1626..0000000 --- a/tests/tcg/mips/mips64-dspr2/addu_s_qh.c +++ /dev/null @@ -1,43 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg; - long long result, dspresult; - - rs =3D 0x123456787FFF0000; - rt =3D 0x1111111180000000; - result =3D 0x23456789FFFF0000; - dspresult =3D 0x0; - - __asm("addu_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("1 addu_s.qh error\n"); - return -1; - } - - rs =3D 0x12345678FFFF0000; - rt =3D 0x11111111000F0000; - result =3D 0x23456789FFFF0000; - dspresult =3D 0x01; - - __asm("addu_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("2 addu_s.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/adduh_ob.c b/tests/tcg/mips/mips64= -dspr2/adduh_ob.c deleted file mode 100644 index 9b309f6..0000000 --- a/tests/tcg/mips/mips64-dspr2/adduh_ob.c +++ /dev/null @@ -1,35 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - rs =3D 0xFF987CDEBCEF2356; - rt =3D 0xFF987CDEBCEF2354; - result =3D 0xFF987CDEBCEF2355; - - __asm("adduh.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("adduh.ob error\n\t"); - return -1; - } - - rs =3D 0xac50691729945316; - rt =3D 0xb9234ca3f5573162; - result =3D 0xb2395a5d8f75423c; - - __asm("adduh.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("adduh.ob error\n\t"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/adduh_qb.c b/tests/tcg/mips/mips64= -dspr2/adduh_qb.c deleted file mode 100644 index 796b409..0000000 --- a/tests/tcg/mips/mips64-dspr2/adduh_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0xffffffff80094B62; - __asm - ("adduh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("adduh.qb error\n"); - return -1; - } - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x7F800888; - - __asm - ("adduh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("adduh.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/adduh_r_ob.c b/tests/tcg/mips/mips= 64-dspr2/adduh_r_ob.c deleted file mode 100644 index 832de83..0000000 --- a/tests/tcg/mips/mips64-dspr2/adduh_r_ob.c +++ /dev/null @@ -1,35 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - rs =3D 0xFF987CDEBCEF2356; - rt =3D 0xFF987CDEBCEF2355; - result =3D 0xFF987CDEBCEF2356; - - __asm("adduh_r.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("1 adduh_r.ob error\n\t"); - return -1; - } - - rs =3D 0xac50691729945316; - rt =3D 0xb9234ca3f5573162; - result =3D 0xb33a5b5d8f76423c; - - __asm("adduh_r.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("2 adduh_r.ob error\n\t"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/adduh_r_qb.c b/tests/tcg/mips/mips= 64-dspr2/adduh_r_qb.c deleted file mode 100644 index ae65fa5..0000000 --- a/tests/tcg/mips/mips64-dspr2/adduh_r_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0xFF0055AA; - rt =3D 0x01112211; - result =3D 0xffffffff80093C5E; - __asm - ("adduh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("adduh_r.qb error\n"); - return -1; - } - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0xffffffff80800888; - __asm - ("adduh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("adduh_r.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/append.c b/tests/tcg/mips/mips64-d= spr2/append.c deleted file mode 100644 index 68a7cec..0000000 --- a/tests/tcg/mips/mips64-dspr2/append.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0x02268436; - __asm - ("append %0, %1, 0x01\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("append error\n"); - return -1; - } - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x0010111F; - __asm - ("append %0, %1, 0x04\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("append error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/balign.c b/tests/tcg/mips/mips64-d= spr2/balign.c deleted file mode 100644 index 7fbe815..0000000 --- a/tests/tcg/mips/mips64-dspr2/balign.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long result; - - rs =3D 0xFF0055AA; - rt =3D 0x0113421B; - result =3D 0x13421BFF; - __asm - ("balign %0, %1, 0x01\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("balign error\n"); - return -1; - } - - rs =3D 0xFFFF0FFF; - rt =3D 0x00010111; - result =3D 0x11FFFF0F; - __asm - ("balign %0, %1, 0x03\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("balign error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_eq_ob.c deleted file mode 100644 index 61217f3..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0xFE; - dspresult =3D 0xFE; - - __asm("cmpgdu.eq.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("1 cmpgdu.eq.ob error\n"); - return -1; - } - - rs =3D 0x133256789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0x3E; - dspresult =3D 0x3E; - - __asm("cmpgdu.eq.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("2 cmpgdu.eq.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_eq_qb.c deleted file mode 100644 index c63f648..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c +++ /dev/null @@ -1,41 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x02; - __asm - ("cmpgdu.eq.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if ((rd !=3D result) || (dsp !=3D result)) { - printf("cmpgdu.eq.qb error\n"); - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x0F; - __asm - ("cmpgdu.eq.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - - if ((rd !=3D result) || (dsp !=3D result)) { - printf("cmpgdu.eq.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_le_ob.c deleted file mode 100644 index b3da098..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456789abcdef0; - rt =3D 0x123456789abcdeff; - dspresult =3D 0xff; - result =3D 0xff; - - __asm("cmpgdu.le.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xff); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("cmpgdu.le.ob error\n"); - return -1; - } - - rs =3D 0x113556789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - result =3D 0xBE; - dspresult =3D 0xFE; - - __asm("cmpgdu.eq.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("cmpgdu.eq.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_le_qb.c deleted file mode 100644 index f0a60ea..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c +++ /dev/null @@ -1,48 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0F; - __asm - ("cmpgdu.le.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (rd !=3D result) { - printf("cmpgdu.le.qb error\n"); - return -1; - } - if (dsp !=3D result) { - printf("cmpgdu.le.qb error\n"); - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11707066; - result =3D 0x0B; - __asm - ("cmpgdu.le.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (rd !=3D result) { - printf("cmpgdu.le.qb error\n"); - return -1; - } - if (dsp !=3D result) { - printf("cmpgdu.le.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_lt_ob.c deleted file mode 100644 index d80b4e6..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c +++ /dev/null @@ -1,44 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result, dspreg, dspresult; - - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x01; - result =3D 0x01; - - __asm("cmpgdu.lt.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("cmpgdu.lt.ob error\n"); - return -1; - } - - rs =3D 0x143356789ABCDEF0; - rt =3D 0x123456789ABCDEFF; - dspresult =3D 0x41; - result =3D 0x41; - - __asm("cmpgdu.lt.ob %0, %2, %3\n\t" - "rddsp %1" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 24) & 0xFF); - - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("cmpgdu.lt.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c b/tests/tcg/mips/mi= ps64-dspr2/cmpgdu_lt_qb.c deleted file mode 100644 index a71e4e3..0000000 --- a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c +++ /dev/null @@ -1,48 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long dsp; - long long result; - - rs =3D 0x11777066; - rt =3D 0x55AA70FF; - result =3D 0x0D; - __asm - ("cmpgdu.lt.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (rd !=3D result) { - printf("cmpgdu.lt.qb error\n"); - return -1; - } - if (dsp !=3D result) { - printf("cmpgdu.lt.qb error\n"); - return -1; - } - - rs =3D 0x11777066; - rt =3D 0x11777066; - result =3D 0x00; - __asm - ("cmpgdu.lt.qb %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 24) & 0x0F; - if (rd !=3D result) { - printf("cmpgdu.lt.qb error\n"); - return -1; - } - if (dsp !=3D result) { - printf("cmpgdu.lt.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dbalign.c b/tests/tcg/mips/mips64-= dspr2/dbalign.c deleted file mode 100644 index c7431b1..0000000 --- a/tests/tcg/mips/mips64-dspr2/dbalign.c +++ /dev/null @@ -1,39 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rt, rs; - long long res; - - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd1234; - - res =3D 0x34567887654321ab; - - asm ("dbalign %0, %1, 0x1\n" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("dbalign error\n"); - return -1; - } - - rt =3D 0x1234567887654321; - rs =3D 0xabcd1234abcd1234; - - res =3D 0x7887654321abcd12; - - asm ("dbalign %0, %1, 0x3\n" - : "=3Dr"(rt) - : "r"(rs) - ); - - if (rt !=3D res) { - printf("dbalign error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpa_w_ph.c b/tests/tcg/mips/mips64= -dspr2/dpa_w_ph.c deleted file mode 100644 index 39dc99a..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpa_w_ph.c +++ /dev/null @@ -1,47 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x0302; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("1 dpa.w.ph error\n"); - return -1; - } - - ach =3D 6, acl =3D 7; - rs =3D 0xFFFF00FF; - rt =3D 0xFFFF0002; - resulth =3D 0x05; - resultl =3D 0xfffffffffffe0206; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if ((ach !=3D resulth) || (acl !=3D resultl)) { - printf("2 dpa.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpa_w_qh.c b/tests/tcg/mips/mips64= -dspr2/dpa_w_qh.c deleted file mode 100644 index 1411e44..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpa_w_qh.c +++ /dev/null @@ -1,56 +0,0 @@ -#include"io.h" -int main(void) -{ - long long rt, rs; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - achi =3D 0x1; - acli =3D 0x1; - - rs =3D 0x0001000100010001; - rt =3D 0x0002000200020002; - - resh =3D 0x1; - resl =3D 0x9; - - asm("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dpa.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dpa.w.qh error\n"); - return -1; - } - - - achi =3D 0xffffffff; - acli =3D 0xaaaaaaaa; - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0x7777888899996666; - - resh =3D 0xffffffffffffffff; - resl =3D 0x320cdf02; - - asm("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dpa.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("2 dpa.w.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c b/tests/tcg/mips/mi= ps64-dspr2/dpaqx_s_w_ph.c deleted file mode 100644 index 51252fb..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c +++ /dev/null @@ -1,97 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl, resultdsp; - - rs =3D 0x800000FF; - rt =3D 0x00018000; - resulth =3D 0x05; - resultl =3D 0xFFFFFFFF80000202; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - if (ach !=3D resulth) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - if (acl !=3D resultl) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - - ach =3D 5; - acl =3D 5; - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x05FF; - /*********************************************************** - * Because of we set outflag at last time, although this - * time we set nothing, but it is stay the last time value. - **********************************************************/ - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - if (ach !=3D resulth) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - if (acl !=3D resultl) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - - ach =3D 5; - acl =3D 5; - rs =3D 0x800000FF; - rt =3D 0x00028000; - resulth =3D 0x05; - resultl =3D 0xffffffff80000400; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if ((dsp !=3D resultdsp) || (ach !=3D resulth) || (acl !=3D resultl)) { - printf("dpaqx_s.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c b/tests/tcg/mips/m= ips64-dspr2/dpaqx_sa_w_ph.c deleted file mode 100644 index 18d6b3a..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c +++ /dev/null @@ -1,54 +0,0 @@ -#include "io.h" - -int main() -{ - long long rs, rt, dsp; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl, resultdsp; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x00; - resultl =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - __asm - ("wrdsp %2\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - if ((dsp >> (16 + 1) !=3D resultdsp) || (ach !=3D resulth) || - (acl !=3D resultl)) { - printf("dpaqx_sa.w.ph errror\n"); - } - - ach =3D 9; - acl =3D 0xb; - rs =3D 0x800000FF; - rt =3D 0x00018000; - resulth =3D 0x00; - resultl =3D 0x7fffffff; - resultdsp =3D 0x01; - __asm - ("wrdsp %2\n\t" - "mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpaqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "+r"(dsp) - : "r"(rs), "r"(rt) - ); - if ((dsp >> (16 + 1) !=3D resultdsp) || (ach !=3D resulth) || - (acl !=3D resultl)) { - printf("dpaqx_sa.w.ph errror\n"); - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpax_w_ph.c b/tests/tcg/mips/mips6= 4-dspr2/dpax_w_ph.c deleted file mode 100644 index 9d595fc..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpax_w_ph.c +++ /dev/null @@ -1,32 +0,0 @@ -#include"io.h" - -int main(void) -{ - long rs, rt; - long ach =3D 5, acl =3D 5; - long resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x05; - resultl =3D 0x0302; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpax.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if (ach !=3D resulth) { - printf("dpax.w.ph error\n"); - return -1; - } - if (acl !=3D resultl) { - printf("dpax.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dps_w_ph.c b/tests/tcg/mips/mips64= -dspr2/dps_w_ph.c deleted file mode 100644 index 99f292e..0000000 --- a/tests/tcg/mips/mips64-dspr2/dps_w_ph.c +++ /dev/null @@ -1,28 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0x00FF00FF; - rt =3D 0x00010002; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFFFFFFFD08; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dps.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if (ach !=3D resulth || acl !=3D resultl) { - printf("dps.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dps_w_qh.c b/tests/tcg/mips/mips64= -dspr2/dps_w_qh.c deleted file mode 100644 index 61277eb..0000000 --- a/tests/tcg/mips/mips64-dspr2/dps_w_qh.c +++ /dev/null @@ -1,55 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rs, rt; - long long achi, acli; - long long acho, aclo; - long long resh, resl; - - rs =3D 0x0000000100000001; - rt =3D 0x0000000200000002; - achi =3D 0x1; - acli =3D 0x8; - - resh =3D 0x1; - resl =3D 0x4; - - asm ("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dps.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dps.w.qh error\n"); - return -1; - } - - rs =3D 0xaaaabbbbccccdddd; - rt =3D 0xaaaabbbbccccdddd; - - achi =3D 0x88888888; - achi =3D 0x55555555; - - resh =3D 0xfffffffff7777777; - resl =3D 0x0a38b181; - - asm ("mthi %2, $ac1\t\n" - "mtlo %3, $ac1\t\n" - "dps.w.qh $ac1, %4, %5\t\n" - "mfhi %0, $ac1\t\n" - "mflo %1, $ac1\t\n" - : "=3Dr"(acho), "=3Dr"(aclo) - : "r"(achi), "r"(acli), "r"(rs), "r"(rt) - ); - - if ((acho !=3D resh) || (aclo !=3D resl)) { - printf("1 dps.w.qh error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c b/tests/tcg/mips/mi= ps64-dspr2/dpsqx_s_w_ph.c deleted file mode 100644 index ba46a92..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c +++ /dev/null @@ -1,55 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt, dsp; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFAEA3E09B; - resultdsp =3D 0x00; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp || ach !=3D resulth || acl !=3D resultl) { - printf("dpsqx_s.w.ph error\n"); - return -1; - } - - ach =3D 0x99f13005; - acl =3D 0x51730062; - rs =3D 0x80008000; - rt =3D 0x80008000; - - resulth =3D 0xffffffff99f13004; - resultl =3D 0x51730064; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_s.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp || ach !=3D resulth || acl !=3D resultl) { - printf("dpsqx_s.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c b/tests/tcg/mips/m= ips64-dspr2/dpsqx_sa_w_ph.c deleted file mode 100644 index 24c8881..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c +++ /dev/null @@ -1,53 +0,0 @@ -#include"io.h" -int main() -{ - long long rs, rt, dsp; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl, resultdsp; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x00; - resultl =3D 0x7FFFFFFF; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp || ach !=3D resulth || acl !=3D resultl) { - printf("dpsqx_sa.w.ph error\n"); - return -1; - } - - ach =3D 0x8c0b354A; - acl =3D 0xbbc02249; - rs =3D 0x800023AD; - rt =3D 0x01648000; - resulth =3D 0xffffffffffffffff; - resultl =3D 0xffffffff80000000; - resultdsp =3D 0x01; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsqx_sa.w.ph $ac1, %3, %4\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - "rddsp %2\n\t" - : "+r"(ach), "+r"(acl), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 17) & 0x01; - if (dsp !=3D resultdsp || ach !=3D resulth || acl !=3D resultl) { - printf("dpsqx_sa.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c b/tests/tcg/mips/mips6= 4-dspr2/dpsx_w_ph.c deleted file mode 100644 index b6291b5..0000000 --- a/tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c +++ /dev/null @@ -1,28 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long ach =3D 5, acl =3D 5; - long long resulth, resultl; - - rs =3D 0xBC0123AD; - rt =3D 0x01643721; - resulth =3D 0x04; - resultl =3D 0xFFFFFFFFD751F050; - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "dpsx.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if (ach !=3D resulth || acl !=3D resultl) { - printf("dpsx.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/head.S b/tests/tcg/mips/mips64-dsp= r2/head.S deleted file mode 100644 index 9a099ae..0000000 --- a/tests/tcg/mips/mips64-dspr2/head.S +++ /dev/null @@ -1,16 +0,0 @@ -/* - * Startup Code for MIPS64 CPU-core - * - */ -.text -.globl _start -.align 4 -_start: - ori $2, $2, 0xffff - sll $2, $2, 16 - ori $2, $2, 0xffff - mtc0 $2, $12, 0 - jal main - -end: - b end diff --git a/tests/tcg/mips/mips64-dspr2/io.h b/tests/tcg/mips/mips64-dspr2= /io.h deleted file mode 100644 index b7db61d..0000000 --- a/tests/tcg/mips/mips64-dspr2/io.h +++ /dev/null @@ -1,22 +0,0 @@ -#ifndef _ASM_IO_H -#define _ASM_IO_H -extern int printf(const char *fmt, ...); -extern unsigned long get_ticks(void); - -#define _read(source) \ -({ unsigned long __res; \ - __asm__ __volatile__( \ - "mfc0\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -#define __read(source) \ -({ unsigned long __res; \ - __asm__ __volatile__( \ - "move\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -#endif diff --git a/tests/tcg/mips/mips64-dspr2/mips_boot.lds b/tests/tcg/mips/mip= s64-dspr2/mips_boot.lds deleted file mode 100644 index bd7c0c0..0000000 --- a/tests/tcg/mips/mips64-dspr2/mips_boot.lds +++ /dev/null @@ -1,31 +0,0 @@ -OUTPUT_ARCH(mips) -SECTIONS -{ - . =3D 0xffffffff80100000; - . =3D ALIGN((1 << 13)); - .text : - { - *(.text) - *(.rodata) - *(.rodata.*) - } - - __init_begin =3D .; - . =3D ALIGN((1 << 12)); - .init.text : AT(ADDR(.init.text) - 0) - { - *(.init.text) - } - .init.data : AT(ADDR(.init.data) - 0) - { - *(.init.data) - } - . =3D ALIGN((1 << 12)); - __init_end =3D .; - - . =3D ALIGN((1 << 13)); - .data : - { - *(.data) - } -} diff --git a/tests/tcg/mips/mips64-dspr2/mul_ph.c b/tests/tcg/mips/mips64-d= spr2/mul_ph.c deleted file mode 100644 index 5a3d05c..0000000 --- a/tests/tcg/mips/mips64-dspr2/mul_ph.c +++ /dev/null @@ -1,50 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x03FB1234; - rt =3D 0x0BCC4321; - result =3D 0xFFFFFFFFF504F4B4; - resultdsp =3D 1; - - __asm - ("mul.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("mul.ph wrong\n"); - return -1; - } - - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x00210010; - rt =3D 0x00110005; - result =3D 0x2310050; - resultdsp =3D 0; - - __asm - ("mul.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("mul.ph wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mul_s_ph.c b/tests/tcg/mips/mips64= -dspr2/mul_s_ph.c deleted file mode 100644 index 7c8b2c7..0000000 --- a/tests/tcg/mips/mips64-dspr2/mul_s_ph.c +++ /dev/null @@ -1,67 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x03FB1234; - rt =3D 0x0BCC4321; - result =3D 0x7fff7FFF; - resultdsp =3D 1; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("1 mul_s.ph error\n"); - return -1; - } - - rs =3D 0x7fffff00; - rt =3D 0xff007fff; - result =3D 0xffffffff80008000; - resultdsp =3D 1; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("2 mul_s.ph error\n"); - return -1; - } - - dsp =3D 0; - __asm - ("wrdsp %0\n\t" - : - : "r"(dsp) - ); - - rs =3D 0x00320001; - rt =3D 0x00210002; - result =3D 0x06720002; - resultdsp =3D 0; - - __asm - ("mul_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("3 mul_s.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mulq_rs_w.c b/tests/tcg/mips/mips6= 4-dspr2/mulq_rs_w.c deleted file mode 100644 index ffdc66d..0000000 --- a/tests/tcg/mips/mips64-dspr2/mulq_rs_w.c +++ /dev/null @@ -1,40 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0xFFFFFFFF80005555; - - __asm - ("mulq_rs.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("mulq_rs.w error!\n"); - return -1; - } - - rs =3D 0x80000000; - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("mulq_rs.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("mulq_rs.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mulq_s_ph.c b/tests/tcg/mips/mips6= 4-dspr2/mulq_s_ph.c deleted file mode 100644 index b8c20c6..0000000 --- a/tests/tcg/mips/mips64-dspr2/mulq_s_ph.c +++ /dev/null @@ -1,26 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0x7FFF098B; - resultdsp =3D 1; - - __asm - ("mulq_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("mulq_s.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mulq_s_w.c b/tests/tcg/mips/mips64= -dspr2/mulq_s_w.c deleted file mode 100644 index db74b71..0000000 --- a/tests/tcg/mips/mips64-dspr2/mulq_s_w.c +++ /dev/null @@ -1,40 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x80001234; - rt =3D 0x80004321; - result =3D 0xFFFFFFFF80005555; - - __asm - ("mulq_s.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("mulq_s.w error\n"); - return -1; - } - - rs =3D 0x80000000; - rt =3D 0x80000000; - result =3D 0x7FFFFFFF; - resultdsp =3D 1; - - __asm - ("mulq_s.w %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 21) & 0x01; - if (rd !=3D result || dsp !=3D resultdsp) { - printf("mulq_s.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c b/tests/tcg/mips/mips= 64-dspr2/mulsa_w_ph.c deleted file mode 100644 index 5b22a60..0000000 --- a/tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt, ach, acl; - long long resulth, resultl; - - ach =3D 0x05; - acl =3D 0x00BBDDCC; - rs =3D 0x80001234; - rt =3D 0x80004321; - resulth =3D 0x05; - resultl =3D 0x3BF5E918; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "mulsa.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if (ach !=3D resulth || acl !=3D resultl) { - printf("mulsa.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c b/tests/tcg/mips/m= ips64-dspr2/mulsaq_s_w_ph.c deleted file mode 100644 index 835a73d..0000000 --- a/tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c +++ /dev/null @@ -1,30 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt, ach, acl; - long long resulth, resultl; - - ach =3D 0x05; - acl =3D 0x00BBDDCC; - rs =3D 0x80001234; - rt =3D 0x80004321; - resulth =3D 0x05; - resultl =3D 0x772ff463; - - __asm - ("mthi %0, $ac1\n\t" - "mtlo %1, $ac1\n\t" - "mulsaq_s.w.ph $ac1, %2, %3\n\t" - "mfhi %0, $ac1\n\t" - "mflo %1, $ac1\n\t" - : "+r"(ach), "+r"(acl) - : "r"(rs), "r"(rt) - ); - if (ach !=3D resulth || acl !=3D resultl) { - printf("mulsaq_s.w.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/precr_qb_ph.c b/tests/tcg/mips/mip= s64-dspr2/precr_qb_ph.c deleted file mode 100644 index 80d5e8d..0000000 --- a/tests/tcg/mips/mips64-dspr2/precr_qb_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main() -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x34786521; - - __asm - ("precr.qb.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (result !=3D rd) { - printf("precr.qb.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c b/tests/tcg/mips/= mips64-dspr2/precr_sra_ph_w.c deleted file mode 100644 index b1d7bcd..0000000 --- a/tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x43215678; - - __asm - ("precr_sra.ph.w %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (result !=3D rt) { - printf("precr_sra.ph.w error\n"); - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFFFFF0000; - - __asm - ("precr_sra.ph.w %0, %1, 0x1F\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (result !=3D rt) { - printf("precr_sra.ph.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c b/tests/tcg/mip= s/mips64-dspr2/precr_sra_r_ph_w.c deleted file mode 100644 index 62d220d..0000000 --- a/tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x43215678; - - __asm - ("precr_sra_r.ph.w %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (result !=3D rt) { - printf("precr_sra_r.ph.w error\n"); - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFFFFF0000; - - __asm - ("precr_sra_r.ph.w %0, %1, 0x1F\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (result !=3D rt) { - printf("precr_sra_r.ph.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/prepend.c b/tests/tcg/mips/mips64-= dspr2/prepend.c deleted file mode 100644 index 4ab083e..0000000 --- a/tests/tcg/mips/mips64-dspr2/prepend.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFF87654321; - __asm - ("prepend %0, %1, 0x00\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("prepend error\n"); - return -1; - } - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFACF10ECA; - __asm - ("prepend %0, %1, 0x0F\n\t" - : "+r"(rt) - : "r"(rs) - ); - if (rt !=3D result) { - printf("prepend error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/printf.c b/tests/tcg/mips/mips64-d= spr2/printf.c deleted file mode 100644 index cf8676d..0000000 --- a/tests/tcg/mips/mips64-dspr2/printf.c +++ /dev/null @@ -1,266 +0,0 @@ - -typedef unsigned long va_list; - -#define ACC 4 -#define __read(source) \ -({ va_list __res; \ - __asm__ __volatile__( \ - "move\t%0, " #source "\n\t" \ - : "=3Dr" (__res)); \ - __res; \ -}) - -enum format_type { - FORMAT_TYPE_NONE, - FORMAT_TYPE_HEX, - FORMAT_TYPE_ULONG, - FORMAT_TYPE_FLOAT -}; - -struct printf_spec { - char type; -}; - -static int format_decode(char *fmt, struct printf_spec *spec) -{ - char *start =3D fmt; - - for (; *fmt ; ++fmt) { - if (*fmt =3D=3D '%') { - break; - } - } - - switch (*++fmt) { - case 'x': - spec->type =3D FORMAT_TYPE_HEX; - break; - - case 'd': - spec->type =3D FORMAT_TYPE_ULONG; - break; - - case 'f': - spec->type =3D FORMAT_TYPE_FLOAT; - break; - - default: - spec->type =3D FORMAT_TYPE_NONE; - } - - return ++fmt - start; -} - -void *memcpy(void *dest, void *src, int n) -{ - int i; - char *s =3D src; - char *d =3D dest; - - for (i =3D 0; i < n; i++) { - d[i] =3D s[i]; - } - return dest; -} - -char *number(char *buf, va_list num) -{ - int i; - char *str =3D buf; - static char digits[16] =3D "0123456789abcdef"; - str =3D str + sizeof(num) * 2; - - for (i =3D 0; i < sizeof(num) * 2; i++) { - *--str =3D digits[num & 15]; - num >>=3D 4; - } - - return buf + sizeof(num) * 2; -} - -char *__number(char *buf, va_list num) -{ - int i; - va_list mm =3D num; - char *str =3D buf; - - if (!num) { - *str++ =3D '0'; - return str; - } - - for (i =3D 0; mm; mm =3D mm/10, i++) { - /* Do nothing. */ - } - - str =3D str + i; - - while (num) { - *--str =3D num % 10 + 48; - num =3D num / 10; - } - - return str + i; -} - -va_list modf(va_list args, va_list *integer, va_list *num) -{ - int i; - double dot_v =3D 0; - va_list E, DOT, DOT_V; - - if (!args) { - return 0; - } - - for (i =3D 0, args =3D args << 1 >> 1; i < 52; i++) { - if ((args >> i) & 0x1) { - break; - } - } - - *integer =3D 0; - - if ((args >> 56 !=3D 0x3f) || (args >> 52 =3D=3D 0x3ff)) { - E =3D (args >> 52) - 1023; - DOT =3D 52 - E - i; - DOT_V =3D args << (12 + E) >> (12 + E) >> i; - *integer =3D ((args << 12 >> 12) >> (i + DOT)) | (1 << E); - } else { - E =3D ~((args >> 52) - 1023) + 1; - DOT_V =3D args << 12 >> 12; - - dot_v +=3D 1.0 / (1 << E); - - for (i =3D 1; i <=3D 16; i++) { - if ((DOT_V >> (52 - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << E + i); - } - } - - for (i =3D 1, E =3D 0; i <=3D ACC; i++) { - dot_v *=3D 10; - if (!(va_list)dot_v) { - E++; - } - } - - *num =3D E; - - return dot_v; - } - - if (args & 0xf) { - for (i =3D 1; i <=3D 16; i++) { - if ((DOT_V >> (DOT - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << i); - } - } - - for (i =3D 1, E =3D 0; i <=3D ACC; i++) { - dot_v *=3D 10; - if (!(va_list)dot_v) { - E++; - } - } - - *num =3D E; - - return dot_v; - } else if (DOT) { - for (i =3D 1; i <=3D DOT; i++) { - if ((DOT_V >> (DOT - i)) & 0x1) { - dot_v +=3D 1.0 / (1 << i); - } - } - - for (i =3D 1; i <=3D ACC; i++) { - dot_v =3D dot_v * 10; - } - - return dot_v; - } - - return 0; -} - -int vsnprintf(char *buf, int size, char *fmt, va_list args) -{ - char *str, *mm; - struct printf_spec spec =3D {0}; - - str =3D mm =3D buf; - - while (*fmt) { - char *old_fmt =3D fmt; - int read =3D format_decode(fmt, &spec); - - fmt +=3D read; - - switch (spec.type) { - case FORMAT_TYPE_NONE: { - memcpy(str, old_fmt, read); - str +=3D read; - break; - } - case FORMAT_TYPE_HEX: { - memcpy(str, old_fmt, read); - str =3D number(str + read, args); - for (; *mm ; ++mm) { - if (*mm =3D=3D '%') { - *mm =3D '0'; - break; - } - } - break; - } - case FORMAT_TYPE_ULONG: { - memcpy(str, old_fmt, read - 2); - str =3D __number(str + read - 2, args); - break; - } - case FORMAT_TYPE_FLOAT: { - va_list integer, dot_v, num; - dot_v =3D modf(args, &integer, &num); - memcpy(str, old_fmt, read - 2); - str +=3D read - 2; - if ((args >> 63 & 0x1)) { - *str++ =3D '-'; - } - str =3D __number(str, integer); - if (dot_v) { - *str++ =3D '.'; - while (num--) { - *str++ =3D '0'; - } - str =3D __number(str, dot_v); - } - break; - } - } - } - *str =3D '\0'; - - return str - buf; -} - -static void serial_out(char *str) -{ - while (*str) { - *(char *)0xffffffffb80003f8 =3D *str++; - } -} - -int vprintf(char *fmt, va_list args) -{ - int printed_len =3D 0; - static char printf_buf[512]; - printed_len =3D vsnprintf(printf_buf, sizeof(printf_buf), fmt, args); - serial_out(printf_buf); - return printed_len; -} - -int printf(char *fmt, ...) -{ - return vprintf(fmt, __read($5)); -} diff --git a/tests/tcg/mips/mips64-dspr2/shra_qb.c b/tests/tcg/mips/mips64-= dspr2/shra_qb.c deleted file mode 100644 index cac3102..0000000 --- a/tests/tcg/mips/mips64-dspr2/shra_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x02060A0F; - - __asm - ("shra.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra.qb error\n"); - return -1; - } - - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF00C0804; - - __asm - ("shra.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shra_r_qb.c b/tests/tcg/mips/mips6= 4-dspr2/shra_r_qb.c deleted file mode 100644 index 9c64f75..0000000 --- a/tests/tcg/mips/mips64-dspr2/shra_r_qb.c +++ /dev/null @@ -1,35 +0,0 @@ -#include "io.h" - -int main() -{ - int rd, rt; - int result; - - rt =3D 0x12345678; - result =3D 0x02070B0F; - - __asm - ("shra_r.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra_r.qb wrong\n"); - return -1; - } - - rt =3D 0x87654321; - result =3D 0xF10D0804; - - __asm - ("shra_r.qb %0, %1, 0x03\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shra_r.qb wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrav_ob.c b/tests/tcg/mips/mips64= -dspr2/shrav_ob.c deleted file mode 100644 index fbdfbab..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrav_ob.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x1234567887654321; - rs =3D 0x4; - res =3D 0xf1f3f5f7f8060402; - - asm ("shrav.ob %0, %1, %2" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shra.ob error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrav_qb.c b/tests/tcg/mips/mips64= -dspr2/shrav_qb.c deleted file mode 100644 index a716203..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrav_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x03; - rt =3D 0x12345678; - result =3D 0x02060A0F; - - __asm - ("shrav.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav.qb error\n"); - return -1; - } - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF00C0804; - - __asm - ("shrav.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrav_r_ob.c b/tests/tcg/mips/mips= 64-dspr2/shrav_r_ob.c deleted file mode 100644 index b80100a..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrav_r_ob.c +++ /dev/null @@ -1,22 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rt, rs; - long long res; - - rt =3D 0x1234567887654321; - rs =3D 0x4; - res =3D 0xe3e7ebf0f1ede9e5; - - asm ("shrav_r.ob %0, %1, %2" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - - if (rd !=3D res) { - printf("shra_r.ob error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrav_r_qb.c b/tests/tcg/mips/mips= 64-dspr2/shrav_r_qb.c deleted file mode 100644 index 009080b..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrav_r_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x03; - rt =3D 0x12345678; - result =3D 0x02070B0F; - - __asm - ("shrav_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav_r.qb error\n"); - return -1; - } - - rs =3D 0x03; - rt =3D 0x87654321; - result =3D 0xFFFFFFFFF10D0804; - - __asm - ("shrav_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrav_r.qb error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrl_ph.c b/tests/tcg/mips/mips64-= dspr2/shrl_ph.c deleted file mode 100644 index e32d976..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrl_ph.c +++ /dev/null @@ -1,22 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rt; - long long result; - - rt =3D 0x12345678; - result =3D 0x009102B3; - - __asm - ("shrl.ph %0, %1, 0x05\n\t" - : "=3Dr"(rd) - : "r"(rt) - ); - if (rd !=3D result) { - printf("shrl.ph error!\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/shrlv_ph.c b/tests/tcg/mips/mips64= -dspr2/shrlv_ph.c deleted file mode 100644 index 58c5488..0000000 --- a/tests/tcg/mips/mips64-dspr2/shrlv_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x05; - rt =3D 0x12345678; - result =3D 0x009102B3; - - __asm - ("shrlv.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rt), "r"(rs) - ); - if (rd !=3D result) { - printf("shrlv.ph error!\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subqh_ph.c b/tests/tcg/mips/mips64= -dspr2/subqh_ph.c deleted file mode 100644 index 9037401..0000000 --- a/tests/tcg/mips/mips64-dspr2/subqh_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456709AB; - - __asm - ("subqh.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("subqh.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subqh_r_ph.c b/tests/tcg/mips/mips= 64-dspr2/subqh_r_ph.c deleted file mode 100644 index b8f9d2f..0000000 --- a/tests/tcg/mips/mips64-dspr2/subqh_r_ph.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456809AC; - - __asm - ("subqh_r.ph %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("subqh_r.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subqh_r_w.c b/tests/tcg/mips/mips6= 4-dspr2/subqh_r_w.c deleted file mode 100644 index b025e40..0000000 --- a/tests/tcg/mips/mips64-dspr2/subqh_r_w.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main() -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456789AC; - - __asm - ("subqh_r.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("subqh_r.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subqh_w.c b/tests/tcg/mips/mips64-= dspr2/subqh_w.c deleted file mode 100644 index 65f1760..0000000 --- a/tests/tcg/mips/mips64-dspr2/subqh_w.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0x456789AB; - - __asm - ("subqh.w %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("subqh.w error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subu_ph.c b/tests/tcg/mips/mips64-= dspr2/subu_ph.c deleted file mode 100644 index 60a6b1b..0000000 --- a/tests/tcg/mips/mips64-dspr2/subu_ph.c +++ /dev/null @@ -1,26 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x87654321; - rt =3D 0x12345678; - result =3D 0x7531ECA9; - resultdsp =3D 0x01; - - __asm - ("subu.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if (dsp !=3D resultdsp || rd !=3D result) { - printf("subu.ph error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subu_qh.c b/tests/tcg/mips/mips64-= dspr2/subu_qh.c deleted file mode 100644 index 911cb34..0000000 --- a/tests/tcg/mips/mips64-dspr2/subu_qh.c +++ /dev/null @@ -1,24 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg, result, dspresult; - rs =3D 0x123456789ABCDEF0; - rt =3D 0x123456789ABCDEF1; - result =3D 0x000000000000000F; - dspresult =3D 0x01; - - __asm("subu.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subu.qh error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subu_s_ph.c b/tests/tcg/mips/mips6= 4-dspr2/subu_s_ph.c deleted file mode 100644 index ae32cc0..0000000 --- a/tests/tcg/mips/mips64-dspr2/subu_s_ph.c +++ /dev/null @@ -1,25 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt, dsp; - long long result, resultdsp; - - rs =3D 0x87654321; - rt =3D 0x12345678; - result =3D 0x75310000; - resultdsp =3D 0x01; - - __asm - ("subu_s.ph %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dsp) - : "r"(rs), "r"(rt) - ); - dsp =3D (dsp >> 20) & 0x01; - if (dsp !=3D resultdsp || rd !=3D result) { - printf("subu_s.ph error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subu_s_qh.c b/tests/tcg/mips/mips6= 4-dspr2/subu_s_qh.c deleted file mode 100644 index de7a29e..0000000 --- a/tests/tcg/mips/mips64-dspr2/subu_s_qh.c +++ /dev/null @@ -1,42 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, dspreg, result, dspresult; - rs =3D 0x1111111111111111; - rt =3D 0x2222222222222222; - result =3D 0x1111111111111111; - dspresult =3D 0x00; - - __asm("subu_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subu_s.qh error\n\t"); - return -1; - } - - - rs =3D 0x8888888888888888; - rt =3D 0xa888a888a888a888; - result =3D 0x0000000000000000; - dspresult =3D 0x01; - - __asm("subu_s.qh %0, %2, %3\n\t" - "rddsp %1\n\t" - : "=3Dr"(rd), "=3Dr"(dspreg) - : "r"(rs), "r"(rt) - ); - - dspreg =3D ((dspreg >> 20) & 0x01); - if ((rd !=3D result) || (dspreg !=3D dspresult)) { - printf("subu_s.qh error\n\t"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subuh_ob.c b/tests/tcg/mips/mips64= -dspr2/subuh_ob.c deleted file mode 100644 index 3fc452b..0000000 --- a/tests/tcg/mips/mips64-dspr2/subuh_ob.c +++ /dev/null @@ -1,36 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rd =3D 0x0; - rs =3D 0x246856789ABCDEF0; - rt =3D 0x123456789ABCDEF0; - result =3D 0x091A000000000000; - - __asm("subuh.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("subuh.ob error\n"); - return -1; - } - - rs =3D 0x246856789ABCDEF0; - rt =3D 0x1131517191B1D1F1; - result =3D 0x1b4f2d2d51637577; - - __asm("subuh.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("subuh.ob error\n"); - return -1; - } - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subuh_qb.c b/tests/tcg/mips/mips64= -dspr2/subuh_qb.c deleted file mode 100644 index aac7a83..0000000 --- a/tests/tcg/mips/mips64-dspr2/subuh_qb.c +++ /dev/null @@ -1,23 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xC5E7092B; - - __asm - ("subuh.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("subuh.qb wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subuh_r_ob.c b/tests/tcg/mips/mips= 64-dspr2/subuh_r_ob.c deleted file mode 100644 index fc20ffd..0000000 --- a/tests/tcg/mips/mips64-dspr2/subuh_r_ob.c +++ /dev/null @@ -1,23 +0,0 @@ -#include "io.h" - -int main(void) -{ - long long rd, rs, rt, result; - - rd =3D 0x0; - rs =3D 0x246956789ABCDEF0; - rt =3D 0x123456789ABCDEF0; - result =3D 0x091B000000000000; - - __asm("subuh.ob %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - - if (rd !=3D result) { - printf("subuh.ob error\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mips64-dspr2/subuh_r_qb.c b/tests/tcg/mips/mips= 64-dspr2/subuh_r_qb.c deleted file mode 100644 index 66d4680..0000000 --- a/tests/tcg/mips/mips64-dspr2/subuh_r_qb.c +++ /dev/null @@ -1,37 +0,0 @@ -#include"io.h" - -int main(void) -{ - long long rd, rs, rt; - long long result; - - rs =3D 0x12345678; - rt =3D 0x87654321; - result =3D 0xC6E80A2C; - - __asm - ("subuh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("1 subuh_r.qb wrong\n"); - return -1; - } - - rs =3D 0xBEFC292A; - rt =3D 0x9205C1B4; - result =3D 0x167cb4bb; - - __asm - ("subuh_r.qb %0, %1, %2\n\t" - : "=3Dr"(rd) - : "r"(rs), "r"(rt) - ); - if (rd !=3D result) { - printf("2 subuh_r.qb wrong\n"); - return -1; - } - - return 0; -} diff --git a/tests/tcg/mips/mipsr5900/Makefile b/tests/tcg/mips/mipsr5900/M= akefile deleted file mode 100644 index 27ee5d5..0000000 --- a/tests/tcg/mips/mipsr5900/Makefile +++ /dev/null @@ -1,32 +0,0 @@ --include ../../config-host.mak - -CROSS=3Dmipsr5900el-unknown-linux-gnu- - -SIM=3Dqemu-mipsel -SIM_FLAGS=3D-cpu R5900 - -CC =3D $(CROSS)gcc -CFLAGS =3D -Wall -mabi=3D32 -march=3Dr5900 -static - -TESTCASES =3D div1.tst -TESTCASES +=3D divu1.tst -TESTCASES +=3D madd.tst -TESTCASES +=3D maddu.tst -TESTCASES +=3D mflohi1.tst -TESTCASES +=3D mtlohi1.tst -TESTCASES +=3D mult.tst -TESTCASES +=3D multu.tst - -all: $(TESTCASES) - -%.tst: %.c - $(CC) $(CFLAGS) $< -o $@ - -check: $(TESTCASES) - @for case in $(TESTCASES); do \ - echo $(SIM) $(SIM_FLAGS) ./$$case;\ - $(SIM) $(SIM_FLAGS) ./$$case; \ - done - -clean: - $(RM) -rf $(TESTCASES) --=20 2.7.4 From nobody Fri Nov 7 14:35:25 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423578090711.7752959305876; Fri, 25 Jan 2019 05:39:38 -0800 (PST) Received: from localhost ([127.0.0.1]:44752 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1hi-0000RH-MM for importer@patchew.org; Fri, 25 Jan 2019 08:39:30 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46469) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aK-0002lc-7T for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:53 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aI-0002Y2-Rb for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:52 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36397 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aI-0002WJ-Gk for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:31:50 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id D66321A2427; Fri, 25 Jan 2019 14:31:48 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id B7A2E1A23E2; Fri, 25 Jan 2019 14:31:48 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:37 +0100 Message-Id: <1548423098-31864-14-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 13/14] qemu-doc: Add nanoMIPS ISA information 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Stefan Markovic Add nanoMIPS information in qemu-doc.texi. An example of usage is included. Reviewed-by: Aleksandar Markovic Signed-off-by: Stefan Markovic Signed-off-by: Aleksandar Markovic --- qemu-doc.texi | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/qemu-doc.texi b/qemu-doc.texi index 16b955c..83be010 100644 --- a/qemu-doc.texi +++ b/qemu-doc.texi @@ -1995,6 +1995,10 @@ Set the emulated machine type. The default is sun4u. @section MIPS System emulator @cindex system emulation (MIPS) =20 +@menu +* nanoMIPS System emulator :: +@end menu + Four executables cover simulation of 32 and 64-bit MIPS systems in both endian options, @file{qemu-system-mips}, @file{qemu-system-mipsel} @file{qemu-system-mips64} and @file{qemu-system-mips64el}. @@ -2086,6 +2090,31 @@ SCSI controller G364 framebuffer @end itemize =20 +@node nanoMIPS System emulator +@subsection nanoMIPS System emulator +@cindex system emulation (nanoMIPS) + +Executable @file{qemu-system-mipsel} also covers simulation of +32-bit nanoMIPS system in little endian mode: + +@itemize @minus +@item +nanoMIPS I7200 CPU +@end itemize + +Example of @file{qemu-system-mipsel} usage for nanoMIPS is shown below: + +Download @code{} from @url{https://mipsdistros.mips.com/L= inuxDistro/nanomips/buildroot/index.html}. + +Download @code{} from @url{https://mipsdistros.mips.com= /LinuxDistro/nanomips/kernels/v4.15.18-432-gb2eb9a8b07a1-20180627102142/ind= ex.html}. + +Start system emulation of Malta board with nanoMIPS I7200 CPU: +@example +qemu-system-mipsel -cpu I7200 -kernel @code{} \ + -M malta -serial stdio -m @code{} -hda @code{} \ + -append "mem=3D256m@@0x0 rw console=3DttyS0 vga=3Dcirrus vesa=3D0x111 = root=3D/dev/sda" +@end example + =20 @node ARM System emulator @section ARM System emulator --=20 2.7.4 From nobody Fri Nov 7 14:35:25 2025 Delivered-To: importer@patchew.org Received-SPF: temperror (zoho.com: Error in retrieving data from DNS) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=temperror (zoho.com: Error in retrieving data from DNS) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (209.51.188.17 [209.51.188.17]) by mx.zohomail.com with SMTPS id 1548423738123552.8266141151194; Fri, 25 Jan 2019 05:42:18 -0800 (PST) Received: from localhost ([127.0.0.1]:44808 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1kF-0002cS-01 for importer@patchew.org; Fri, 25 Jan 2019 08:42:07 -0500 Received: from eggs.gnu.org ([209.51.188.92]:46538) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gn1aU-0002th-Dm for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:03 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gn1aT-0002f1-6U for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:02 -0500 Received: from mx2.rt-rk.com ([89.216.37.149]:36555 helo=mail.rt-rk.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1gn1aS-0002Wq-Rs for qemu-devel@nongnu.org; Fri, 25 Jan 2019 08:32:01 -0500 Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 288511A21F3; Fri, 25 Jan 2019 14:31:49 +0100 (CET) Received: from rtrkw774-lin.domain.local (rtrkw774-lin.domain.local [10.10.13.43]) by mail.rt-rk.com (Postfix) with ESMTPSA id C1C601A23E6; Fri, 25 Jan 2019 14:31:48 +0100 (CET) X-Virus-Scanned: amavisd-new at rt-rk.com From: Aleksandar Markovic To: qemu-devel@nongnu.org Date: Fri, 25 Jan 2019 14:31:38 +0100 Message-Id: <1548423098-31864-15-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1548423098-31864-1-git-send-email-aleksandar.markovic@rt-rk.com> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 89.216.37.149 Subject: [Qemu-devel] [PULL 14/14] docs/qemu-cpu-models: Add MIPS/nanoMIPS QEMU supported CPU models 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: peter.maydell@linaro.org, amarkovic@wavecomp.com Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" From: Stefan Markovic Add list of supported and preferred CPU models for MIPS32, MIPS64 and nanoMIPS hosts. Signed-off-by: Aleksandar Markovic Signed-off-by: Stefan Markovic Signed-off-by: Aleksandar Markovic --- docs/qemu-cpu-models.texi | 163 ++++++++++++++++++++++++++++++++++++++++++= +++- 1 file changed, 161 insertions(+), 2 deletions(-) diff --git a/docs/qemu-cpu-models.texi b/docs/qemu-cpu-models.texi index 1935f98..475d434 100644 --- a/docs/qemu-cpu-models.texi +++ b/docs/qemu-cpu-models.texi @@ -5,8 +5,9 @@ QEMU / KVM CPU model configuration @c man begin DESCRIPTION =20 @menu -* recommendations_cpu_models_x86:: Recommendations for KVM CPU model confi= guration on x86 hosts -* cpu_model_syntax_apps:: Syntax for configuring CPU models +* recommendations_cpu_models_x86:: Recommendations for KVM CPU model conf= iguration on x86 hosts +* recommendations_cpu_models_MIPS:: Supported CPU model configurations on = MIPS hosts +* cpu_model_syntax_apps:: Syntax for configuring CPU models @end menu =20 QEMU / KVM virtualization supports two ways to configure CPU models @@ -368,6 +369,164 @@ hardware assisted virtualization, that should thus no= t be required for running virtual machines. @end table =20 +@node recommendations_cpu_models_MIPS +@subsection Supported CPU model configurations on MIPS hosts + +QEMU supports variety of MIPS CPU models: + +@menu +* cpu_models_MIPS32:: Supported CPU models for MIPS32 hosts +* cpu_models_MIPS64:: Supported CPU models for MIPS64 hosts +* cpu_models_nanoMIPS:: Supported CPU models for nanoMIPS hosts +* preferred_cpu_models_MIPS:: Preferred CPU models for MIPS hosts +@end menu + +@node cpu_models_MIPS32 +@subsubsection Supported CPU models for MIPS32 hosts + +The following CPU models are supported for use on MIPS32 hosts. Administra= tors / +applications are recommended to use the CPU model that matches the generat= ion +of the host CPUs in use. In a deployment with a mixture of host CPU models +between machines, if live migration compatibility is required, use the new= est +CPU model that is compatible across all desired hosts. + +@table @option +@item @code{mips32r6-generic} + +MIPS32 Processor (Release 6, 2015) + + +@item @code{P5600} + +MIPS32 Processor (P5600, 2014) + + +@item @code{M14K} +@item @code{M14Kc} + +MIPS32 Processor (M14K, 2009) + + +@item @code{74Kf} + +MIPS32 Processor (74K, 2007) + + +@item @code{34Kf} + +MIPS32 Processor (34K, 2006) + + +@item @code{24Kc} +@item @code{24KEc} +@item @code{24Kf} + +MIPS32 Processor (24K, 2003) + + +@item @code{4Kc} +@item @code{4Km} +@item @code{4KEcR1} +@item @code{4KEmR1} +@item @code{4KEc} +@item @code{4KEm} + +MIPS32 Processor (4K, 1999) +@end table + +@node cpu_models_MIPS64 +@subsubsection Supported CPU models for MIPS64 hosts + +The following CPU models are supported for use on MIPS64 hosts. Administra= tors / +applications are recommended to use the CPU model that matches the generat= ion +of the host CPUs in use. In a deployment with a mixture of host CPU models +between machines, if live migration compatibility is required, use the new= est +CPU model that is compatible across all desired hosts. + +@table @option +@item @code{I6400} + +MIPS64 Processor (Release 6, 2014) + + +@item @code{Loongson-2F} + +MIPS64 Processor (Longsoon 2, 2008) + + +@item @code{Loongson-2E} + +MIPS64 Processor (Loongson 2, 2006) + + +@item @code{mips64dspr2} + +MIPS64 Processor (Release 2, 2006) + + +@item @code{MIPS64R2-generic} +@item @code{5KEc} +@item @code{5KEf} + +MIPS64 Processor (Release 2, 2002) + + +@item @code{20Kc} + +MIPS64 Processor (20K, 2000) + + +@item @code{5Kc} +@item @code{5Kf} + +MIPS64 Processor (5K, 1999) + + +@item @code{VR5432} + +MIPS64 Processor (VR, 1998) + + +@item @code{R4000} + +MIPS64 Processor (MIPS III, 1991) +@end table + +@node cpu_models_nanoMIPS +@subsubsection Supported CPU models for nanoMIPS hosts + +The following CPU models are supported for use on nanoMIPS hosts. Administ= rators / +applications are recommended to use the CPU model that matches the generat= ion +of the host CPUs in use. In a deployment with a mixture of host CPU models +between machines, if live migration compatibility is required, use the new= est +CPU model that is compatible across all desired hosts. + +@table @option +@item @code{I7200} + +MIPS I7200 (nanoMIPS, 2018) + +@end table + +@node preferred_cpu_models_MIPS +@subsubsection Preferred CPU models for MIPS hosts + +The following CPU models are preferred for use on different MIPS hosts: + +@table @option +@item @code{MIPS III} +R4000 + +@item @code{MIPS32R2} +34Kf + +@item @code{MIPS64R6} +I6400 + +@item @code{nanoMIPS} +I7200 +@end table + @node cpu_model_syntax_apps @subsection Syntax for configuring CPU models =20 --=20 2.7.4