From patchwork Thu Jul 13 14:24:17 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Paolo Bonzini X-Patchwork-Id: 107695 Delivered-To: patch@linaro.org Received: by 10.140.101.44 with SMTP id t41csp2301755qge; Thu, 13 Jul 2017 07:41:29 -0700 (PDT) X-Received: by 10.55.148.70 with SMTP id w67mr5082267qkd.160.1499956889843; Thu, 13 Jul 2017 07:41:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1499956889; cv=none; d=google.com; s=arc-20160816; b=Ta5cKRdiDAtTBQy5IVYzpgfLP3UriIb8b70N2/F5wAbPGng6uam1mnbvnBmbUfy1gj n9lGWdUC/rJfCU1vrlkREM4CuJe+36BdEizJTrFIHnP4WWOdTAvbJX8EoMfTtDWDdrSG YtIDdQ4YJ0RDNNbLGe0FsI5xwfTCjXDISysr6tHi4FNSTHfjVhtxIVwkx8JiYAQXTfSe rtUF7PQE2A2OofAk61B4HabWtOKODanw9tqU7fTNgmksRmd0WCDX4nQvbaimWnyLFinV N93Niec6O+FFeLUdvnk0j8DHrspLeLnEvJKjDK8Q3rh/rzzbXF4sr49MmwdYdO8dnt5V PZ1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:subject :content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:to:from:dkim-signature:arc-authentication-results; bh=jEI1iyUNgqBDnBVxv41UCPc9Zo2uQoG7t4lksrVr4I0=; b=BLc0Cp9fYqIaFy5R9UULxbziDWQngFXe89qp9vChQi9MulTh1yBLOLJrH7Q7wfzs51 KTNvQXrAqSd5gND91b1eYPpKWwxIXhD/SK3ctSaDNafnDKWVZtW5lbu//AqABGeKKZhs +QoRvqgm/zVQ9hYsUeBoh1+bGttgxizHsbBAz8FM5dywx4UQ3CsxWX3qytdMMD6rIix3 Swb/TTud4liapL615nDLRoY6MUiKB2NVArZDChEvhNUR39t4X2maM1iomQnkMbhvYUty WWslweMLL5+uxtNF8MV2K62vtxN6JbMEyXsHyBRmkA0Ut+RPTgb7a9jLYf8ORr9du2JS re4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.b=bX0fRqQH; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+patch=linaro.org@nongnu.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lists.gnu.org (lists.gnu.org. [208.118.235.17]) by mx.google.com with ESMTPS id d51si5131070qtb.292.2017.07.13.07.41.29 for (version=TLS1 cipher=AES128-SHA bits=128/128); Thu, 13 Jul 2017 07:41:29 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 208.118.235.17 as permitted sender) client-ip=208.118.235.17; Authentication-Results: mx.google.com; dkim=fail header.i=@gmail.com header.b=bX0fRqQH; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 208.118.235.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+patch=linaro.org@nongnu.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from localhost ([::1]:60436 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dVfIg-0007YW-3L for patch@linaro.org; Thu, 13 Jul 2017 10:41:06 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:51805) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dVf4R-0001tF-30 for qemu-devel@nongnu.org; Thu, 13 Jul 2017 10:26:24 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dVf4N-0004KI-2L for qemu-devel@nongnu.org; Thu, 13 Jul 2017 10:26:23 -0400 Received: from mail-wr0-f195.google.com ([209.85.128.195]:35673) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1dVf4M-0004K0-PM for qemu-devel@nongnu.org; Thu, 13 Jul 2017 10:26:18 -0400 Received: by mail-wr0-f195.google.com with SMTP id y28so4891663wrd.2 for ; Thu, 13 Jul 2017 07:26:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=jEI1iyUNgqBDnBVxv41UCPc9Zo2uQoG7t4lksrVr4I0=; b=bX0fRqQHRbf4rkMZ7lNiT5rGYozByqSzVt1X9aNzf6JCIRiHjZqYRMO2qhBWdHYsj2 IF6U7ICHowD7RoWEMcOGtTJszFwYz64++AosAMtwYkL157zxXuSZK7yow0ujIvavPNYM mwy4kJkGAA5r2oITPl7eY0ET357Ldtpq0WkvG7aa+Ql0YAlJWv8oyEXAh4DIJEzpJMsX P77fW/F4PHGWm0y3E/4qq9i7YFyp0IMXfRjpo6aKdjarHEO1ewrAD8ZYdF1CRUAJLQQu 2anfT6OqRXzH4ta+HA3l0Uh5l7jfwRqolUxf/Na/HQGowMStmhpoixJhAbZxFXmFWpy5 SYUA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references:mime-version:content-transfer-encoding; bh=jEI1iyUNgqBDnBVxv41UCPc9Zo2uQoG7t4lksrVr4I0=; b=VzmwVvN4ssrF8tZd59zsranpxmcLCNNSa4YhI9foth7KEZjyHeLLLJtBYqnG0lMZJl yQH0C3N8IRp+egFZ3eK0uAhoByvPkDzyZBN2onIgN2K/XpffBSOC0lqJiwOHOpe9N1Xu xiIWIykTtmJuPqRmeJxpf91WFniQkGIZ+msWqltSo/PQ+EqdwnMkdBM+dIx3p81D5Gtq z3sccQQlWJpVBmFl+gzaN2fHuWjCBl78skN/Lfg0FemQPO6wABljE2SWykoTsPoxTVIY zdcHlasrbRDCNIlBjGLbSlZeSBAuhRgWMg5eR/vGBnRApxXXwRjBUEOAvudi+nfe3/HA P2lw== X-Gm-Message-State: AIVw113wB4TGkaK2V8J4EERLGzmoBpXMKTIkKKPR9f8JeibZyiULgcfJ bTec5+8AzRqbeya+/CI= X-Received: by 10.223.177.129 with SMTP id q1mr1873673wra.82.1499955917508; Thu, 13 Jul 2017 07:25:17 -0700 (PDT) Received: from 640k.lan (94-39-191-51.adsl-ull.clienti.tiscali.it. [94.39.191.51]) by smtp.gmail.com with ESMTPSA id k75sm6042448wmh.10.2017.07.13.07.25.16 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 13 Jul 2017 07:25:16 -0700 (PDT) From: Paolo Bonzini To: qemu-devel@nongnu.org Date: Thu, 13 Jul 2017 16:24:17 +0200 Message-Id: <1499955874-10954-25-git-send-email-pbonzini@redhat.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1499955874-10954-1-git-send-email-pbonzini@redhat.com> References: <1499955874-10954-1-git-send-email-pbonzini@redhat.com> MIME-Version: 1.0 X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] [fuzzy] X-Received-From: 209.85.128.195 Subject: [Qemu-devel] [PULL 24/41] gdbstub: modernise DEBUG_GDB 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: =?utf-8?q?Alex_Benn=C3=A9e?= Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" From: Alex Bennée Convert the a gdb_debug helper which compiles away to nothing when not used but still ensures the format strings are checked. There is some minor code motion for the incorrect checksum message to report it before we attempt to send the reply. Signed-off-by: Alex Bennée Reviewed-by: Philippe Mathieu-Daudé Reviewed-by: Greg Kurz Message-Id: <20170712105216.747-2-alex.bennee@linaro.org> Signed-off-by: Paolo Bonzini --- gdbstub.c | 77 +++++++++++++++++++++++++++------------------------------------ 1 file changed, 33 insertions(+), 44 deletions(-) -- 1.8.3.1 diff --git a/gdbstub.c b/gdbstub.c index e561244..3965980 100644 --- a/gdbstub.c +++ b/gdbstub.c @@ -272,7 +272,20 @@ static int gdb_signal_to_target (int sig) return -1; } -//#define DEBUG_GDB +/* #define DEBUG_GDB */ + +#ifdef DEBUG_GDB +# define DEBUG_GDB_GATE 1 +#else +# define DEBUG_GDB_GATE 0 +#endif + +#define gdb_debug(fmt, ...) do { \ + if (DEBUG_GDB_GATE) { \ + fprintf(stderr, "%s: " fmt, __func__, ## __VA_ARGS__); \ + } \ +} while (0) + typedef struct GDBRegisterState { int base_reg; @@ -548,9 +561,7 @@ static int put_packet_binary(GDBState *s, const char *buf, int len) /* return -1 if error, 0 if OK */ static int put_packet(GDBState *s, const char *buf) { -#ifdef DEBUG_GDB - printf("reply='%s'\n", buf); -#endif + gdb_debug("reply='%s'\n", buf); return put_packet_binary(s, buf, strlen(buf)); } @@ -956,9 +967,9 @@ static int gdb_handle_packet(GDBState *s, const char *line_buf) uint8_t *registers; target_ulong addr, len; -#ifdef DEBUG_GDB - printf("command='%s'\n", line_buf); -#endif + + gdb_debug("command='%s'\n", line_buf); + p = line_buf; ch = *p++; switch(ch) { @@ -1519,17 +1530,14 @@ static void gdb_read_byte(GDBState *s, int ch) /* Waiting for a response to the last packet. If we see the start of a new command then abandon the previous response. */ if (ch == '-') { -#ifdef DEBUG_GDB - printf("Got NACK, retransmitting\n"); -#endif + gdb_debug("Got NACK, retransmitting\n"); put_buffer(s, (uint8_t *)s->last_packet, s->last_packet_len); + } else if (ch == '+') { + gdb_debug("Got ACK\n"); + } else { + gdb_debug("Got '%c' when expecting ACK/NACK\n", ch); } -#ifdef DEBUG_GDB - else if (ch == '+') - printf("Got ACK\n"); - else - printf("Got '%c' when expecting ACK/NACK\n", ch); -#endif + if (ch == '+' || ch == '$') s->last_packet_len = 0; if (ch != '$') @@ -1550,9 +1558,7 @@ static void gdb_read_byte(GDBState *s, int ch) s->line_sum = 0; s->state = RS_GETLINE; } else { -#ifdef DEBUG_GDB - printf("gdbstub received garbage between packets: 0x%x\n", ch); -#endif + gdb_debug("received garbage between packets: 0x%x\n", ch); } break; case RS_GETLINE: @@ -1568,9 +1574,7 @@ static void gdb_read_byte(GDBState *s, int ch) /* end of command, start of checksum*/ s->state = RS_CHKSUM1; } else if (s->line_buf_index >= sizeof(s->line_buf) - 1) { -#ifdef DEBUG_GDB - printf("gdbstub command buffer overrun, dropping command\n"); -#endif + gdb_debug("command buffer overrun, dropping command\n"); s->state = RS_IDLE; } else { /* unescaped command character */ @@ -1584,9 +1588,7 @@ static void gdb_read_byte(GDBState *s, int ch) s->state = RS_CHKSUM1; } else if (s->line_buf_index >= sizeof(s->line_buf) - 1) { /* command buffer overrun */ -#ifdef DEBUG_GDB - printf("gdbstub command buffer overrun, dropping command\n"); -#endif + gdb_debug("command buffer overrun, dropping command\n"); s->state = RS_IDLE; } else { /* parse escaped character and leave escape state */ @@ -1598,25 +1600,18 @@ static void gdb_read_byte(GDBState *s, int ch) case RS_GETLINE_RLE: if (ch < ' ') { /* invalid RLE count encoding */ -#ifdef DEBUG_GDB - printf("gdbstub got invalid RLE count: 0x%x\n", ch); -#endif + gdb_debug("got invalid RLE count: 0x%x\n", ch); s->state = RS_GETLINE; } else { /* decode repeat length */ int repeat = (unsigned char)ch - ' ' + 3; if (s->line_buf_index + repeat >= sizeof(s->line_buf) - 1) { /* that many repeats would overrun the command buffer */ -#ifdef DEBUG_GDB - printf("gdbstub command buffer overrun," - " dropping command\n"); -#endif + gdb_debug("command buffer overrun, dropping command\n"); s->state = RS_IDLE; } else if (s->line_buf_index < 1) { /* got a repeat but we have nothing to repeat */ -#ifdef DEBUG_GDB - printf("gdbstub got invalid RLE sequence\n"); -#endif + gdb_debug("got invalid RLE sequence\n"); s->state = RS_GETLINE; } else { /* repeat the last character */ @@ -1631,9 +1626,7 @@ static void gdb_read_byte(GDBState *s, int ch) case RS_CHKSUM1: /* get high hex digit of checksum */ if (!isxdigit(ch)) { -#ifdef DEBUG_GDB - printf("gdbstub got invalid command checksum digit\n"); -#endif + gdb_debug("got invalid command checksum digit\n"); s->state = RS_GETLINE; break; } @@ -1644,21 +1637,17 @@ static void gdb_read_byte(GDBState *s, int ch) case RS_CHKSUM2: /* get low hex digit of checksum */ if (!isxdigit(ch)) { -#ifdef DEBUG_GDB - printf("gdbstub got invalid command checksum digit\n"); -#endif + gdb_debug("got invalid command checksum digit\n"); s->state = RS_GETLINE; break; } s->line_csum |= fromhex(ch); if (s->line_csum != (s->line_sum & 0xff)) { + gdb_debug("got command packet with incorrect checksum\n"); /* send NAK reply */ reply = '-'; put_buffer(s, &reply, 1); -#ifdef DEBUG_GDB - printf("gdbstub got command packet with incorrect checksum\n"); -#endif s->state = RS_IDLE; } else { /* send ACK reply */