From nobody Fri Oct 24 22:15:00 2025 Delivered-To: importer@patchew.org Received-SPF: pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Authentication-Results: mx.zohomail.com; spf=pass (zoho.com: domain of gnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) by mx.zohomail.com with SMTPS id 1518751231382117.0464016684756; Thu, 15 Feb 2018 19:20:31 -0800 (PST) Received: from localhost ([::1]:60974 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emWZa-0004Jn-FX for importer@patchew.org; Thu, 15 Feb 2018 22:20:30 -0500 Received: from eggs.gnu.org ([2001:4830:134:3::10]:39772) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1emWXm-0002wJ-Ei for qemu-devel@nongnu.org; Thu, 15 Feb 2018 22:18:39 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1emWXi-0002U6-FI for qemu-devel@nongnu.org; Thu, 15 Feb 2018 22:18:38 -0500 Received: from out5-smtp.messagingengine.com ([66.111.4.29]:54255) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1emWXi-0002Tt-8E for qemu-devel@nongnu.org; Thu, 15 Feb 2018 22:18:34 -0500 Received: from compute4.internal (compute4.nyi.internal [10.202.2.44]) by mailout.nyi.internal (Postfix) with ESMTP id DCC8E20C9D; Thu, 15 Feb 2018 22:18:32 -0500 (EST) Received: from frontend1 ([10.202.2.160]) by compute4.internal (MEProxy); Thu, 15 Feb 2018 22:18:32 -0500 Received: from localhost (flamenco.cs.columbia.edu [128.59.20.216]) by mail.messagingengine.com (Postfix) with ESMTPA id 98B9B7E3D9; Thu, 15 Feb 2018 22:18:32 -0500 (EST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=braap.org; h=cc :date:from:in-reply-to:message-id:references:subject:to :x-me-sender:x-me-sender:x-sasl-enc; s=mesmtp; bh=TcrC/4mE+WvdU3 7q4kMW1n2Yzj41wEwILZtJH7OXr7Q=; b=RH87N3jGvXcdQPwXDlQhvom1Uos2bX yZmSNF6SaetKDBx/erKfsyDhfyHUYe6h8q+0AHZdiiKoVA9yJYe7Qx0MShh2aR2o l2d9RSVd3qJ065Gp8ACTPYH8J1MJBtKdCnn1pi3Fzw+ZzRANSIR3RbjRxFGjBx0d RTuxxQEAysEh4= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:date:from:in-reply-to:message-id :references:subject:to:x-me-sender:x-me-sender:x-sasl-enc; s= fm2; bh=TcrC/4mE+WvdU37q4kMW1n2Yzj41wEwILZtJH7OXr7Q=; b=TFdjcDvX M9wQ1W9NloXDxJiQkVrCePQEloSFbDFh625oLwQBn4u7KLxOgNWdtMV61PTjvPtE wKUEOKjQnNk265qPVqAvvUMZHom2EhM2bimRd1Iogof+kRhEbR8Lnl7ktXnDCBzG 70csF6bAxauL4Tc/iu2jp7uejh/nj6Vfo2xwPuIYjq2t/qkq/1NwYhEvV3afrX3r nYScHTCBMGNgQp/rK+Z4ZeOkulFCUxvhnb8WvcEncYKfWuQ0mdtRT+cB1tRfUmBF jA9lFNS5aRH/Me/pvQlosysE319/l8ERD5zGHN+gTodMVnD/WPcmnYjbX/nC3g7Z YOq5gY9YC7/tew== X-ME-Sender: From: "Emilio G. Cota" To: qemu-devel@nongnu.org Date: Thu, 15 Feb 2018 22:18:24 -0500 Message-Id: <1518751105-17211-2-git-send-email-cota@braap.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1518751105-17211-1-git-send-email-cota@braap.org> References: <1518751105-17211-1-git-send-email-cota@braap.org> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] [fuzzy] X-Received-From: 66.111.4.29 Subject: [Qemu-devel] [PATCH 1/2] translator: pass max_insns to tb_start 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: Aurelien Jarno , Richard Henderson Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail: RSF_0 Z_629925259 SPT_0 Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" sh4 will need it. Signed-off-by: Emilio G. Cota Reviewed-by: Richard Henderson --- accel/tcg/translator.c | 2 +- include/exec/translator.h | 3 ++- target/alpha/translate.c | 3 ++- target/arm/translate-a64.c | 4 +++- target/arm/translate.c | 4 +++- target/hppa/translate.c | 4 +++- target/i386/translate.c | 3 ++- 7 files changed, 16 insertions(+), 7 deletions(-) diff --git a/accel/tcg/translator.c b/accel/tcg/translator.c index 23c6602..4ab6f8d 100644 --- a/accel/tcg/translator.c +++ b/accel/tcg/translator.c @@ -64,7 +64,7 @@ void translator_loop(const TranslatorOps *ops, DisasConte= xtBase *db, =20 /* Start translating. */ gen_tb_start(db->tb); - ops->tb_start(db, cpu); + max_insns =3D ops->tb_start(db, cpu, max_insns); tcg_debug_assert(db->is_jmp =3D=3D DISAS_NEXT); /* no early exit */ =20 while (true) { diff --git a/include/exec/translator.h b/include/exec/translator.h index e2dc2a0..0182ada 100644 --- a/include/exec/translator.h +++ b/include/exec/translator.h @@ -81,6 +81,7 @@ typedef struct DisasContextBase { * @tb_start: * Emit any code required before the start of the main loop, * after the generic gen_tb_start(). + * Return max_insns, modified if necessary. * * @insn_start: * Emit the tcg_gen_insn_start opcode. @@ -108,7 +109,7 @@ typedef struct DisasContextBase { typedef struct TranslatorOps { int (*init_disas_context)(DisasContextBase *db, CPUState *cpu, int max_insns); - void (*tb_start)(DisasContextBase *db, CPUState *cpu); + int (*tb_start)(DisasContextBase *db, CPUState *cpu, int max_insns); void (*insn_start)(DisasContextBase *db, CPUState *cpu); bool (*breakpoint_check)(DisasContextBase *db, CPUState *cpu, const CPUBreakpoint *bp); diff --git a/target/alpha/translate.c b/target/alpha/translate.c index 73a1b5e..b603dbd 100644 --- a/target/alpha/translate.c +++ b/target/alpha/translate.c @@ -2963,8 +2963,9 @@ static int alpha_tr_init_disas_context(DisasContextBa= se *dcbase, return MIN(max_insns, bound); } =20 -static void alpha_tr_tb_start(DisasContextBase *db, CPUState *cpu) +static int alpha_tr_tb_start(DisasContextBase *db, CPUState *cpu, int max_= insns) { + return max_insns; } =20 static void alpha_tr_insn_start(DisasContextBase *dcbase, CPUState *cpu) diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c index 1c88539..7aa47ee 100644 --- a/target/arm/translate-a64.c +++ b/target/arm/translate-a64.c @@ -12080,9 +12080,11 @@ static int aarch64_tr_init_disas_context(DisasCont= extBase *dcbase, return max_insns; } =20 -static void aarch64_tr_tb_start(DisasContextBase *db, CPUState *cpu) +static int aarch64_tr_tb_start(DisasContextBase *db, CPUState *cpu, + int max_insns) { tcg_clear_temp_count(); + return max_insns; } =20 static void aarch64_tr_insn_start(DisasContextBase *dcbase, CPUState *cpu) diff --git a/target/arm/translate.c b/target/arm/translate.c index 1270022..bdee04e 100644 --- a/target/arm/translate.c +++ b/target/arm/translate.c @@ -12060,7 +12060,8 @@ static int arm_tr_init_disas_context(DisasContextBa= se *dcbase, return max_insns; } =20 -static void arm_tr_tb_start(DisasContextBase *dcbase, CPUState *cpu) +static int arm_tr_tb_start(DisasContextBase *dcbase, CPUState *cpu, + int max_insns) { DisasContext *dc =3D container_of(dcbase, DisasContext, base); =20 @@ -12102,6 +12103,7 @@ static void arm_tr_tb_start(DisasContextBase *dcbas= e, CPUState *cpu) store_cpu_field(tmp, condexec_bits); } tcg_clear_temp_count(); + return max_insns; } =20 static void arm_tr_insn_start(DisasContextBase *dcbase, CPUState *cpu) diff --git a/target/hppa/translate.c b/target/hppa/translate.c index b4b74a8..c816ad1 100644 --- a/target/hppa/translate.c +++ b/target/hppa/translate.c @@ -4726,7 +4726,8 @@ static int hppa_tr_init_disas_context(DisasContextBas= e *dcbase, return bound; } =20 -static void hppa_tr_tb_start(DisasContextBase *dcbase, CPUState *cs) +static int hppa_tr_tb_start(DisasContextBase *dcbase, CPUState *cs, + int max_insns) { DisasContext *ctx =3D container_of(dcbase, DisasContext, base); =20 @@ -4738,6 +4739,7 @@ static void hppa_tr_tb_start(DisasContextBase *dcbase= , CPUState *cs) ctx->psw_n_nonzero =3D true; } ctx->null_lab =3D NULL; + return max_insns; } =20 static void hppa_tr_insn_start(DisasContextBase *dcbase, CPUState *cs) diff --git a/target/i386/translate.c b/target/i386/translate.c index 0135415..7527e8d 100644 --- a/target/i386/translate.c +++ b/target/i386/translate.c @@ -8472,8 +8472,9 @@ static int i386_tr_init_disas_context(DisasContextBas= e *dcbase, CPUState *cpu, return max_insns; } =20 -static void i386_tr_tb_start(DisasContextBase *db, CPUState *cpu) +static int i386_tr_tb_start(DisasContextBase *db, CPUState *cpu, int max_i= nsns) { + return max_insns; } =20 static void i386_tr_insn_start(DisasContextBase *dcbase, CPUState *cpu) --=20 2.7.4