Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp848927rdg; Fri, 11 Aug 2023 01:31:12 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEg3uXX7uGhNRaHN7QR0yM0ll2Oe7AciNeBF3aCD8OMpq51veZ4sqEueGNh5x+aGyvazoTQ X-Received: by 2002:a17:90a:85:b0:269:12a5:c1df with SMTP id a5-20020a17090a008500b0026912a5c1dfmr5711302pja.3.1691742671525; Fri, 11 Aug 2023 01:31:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691742671; cv=none; d=google.com; s=arc-20160816; b=obWSC2+wc9gHH4p66lK9dOpC/vdsO8+dH+JrcHNimMfmiwPDAki1ePQntU6x/41c6N B8GjAkowC7Kf5R7R6sMDa9f3299MXa0ls5LlZq2mkCXXOBuSNHgjXa/qcvg2n8oBvv0x CPacE8ikLMiJWBBtjEq0P6EhwqZmMxrgxiaVJiCOn3DNheiBuMx29rwGEH+lr2tW7Uk4 RqHsZtCj92IcXqZEDxUa3lJgF36s+hLxM6KyJMPqVXEH9ypkzxQu9CR3dgBkVnp/Nxwn cf2Nh1EiZE0rCRUwSLKm7BjHx0O19N8kaIHEcyyuJTg4ldSMO7/jOmA5kz3nJhWeT65j 1DNA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=bBw9xCSDhBw/5Q/zDDmE8iGwcbKgC+0scYSjYPDPvuo=; fh=BHdAqCtXQk2EWZNv3TzltgEN0mmKIS4hw5j/7slC4No=; b=kK7FckxgSwcXmshTYqrt0OwXALjvXKEXBwsd6sR9mBR3tX004nONdXskF4f9y7R/44 6sSIK2nr1beEOxgN4FdNURH/vJs2cwtwLIGmE+GSMCk9csvV3u5hnFwy642zWV7SRsNU Xxsepuhs0RcW7QmW5iFLUQSm2y6cfNg9ieb46HrkwKkI3J2MzqlYWgddOPzLKxYxiAsv erpWc2xOyyElR+sD6rgyMxqvN1ldwa6R8c1ObD1C7+dG8B0Vxr5FlK4tvQYJL8AUN0OW ofY8IG33lZdJ2eTVnlQ2J/Oycp9OZB3u2sFJ8FYSJj61YD0f7RnA/3O+v06NgH4LRJo0 eMYg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id n62-20020a17090a2cc400b002639ae468d4si3073340pjd.162.2023.08.11.01.30.59; Fri, 11 Aug 2023 01:31:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234215AbjHKHtm (ORCPT + 99 others); Fri, 11 Aug 2023 03:49:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56210 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234125AbjHKHtk (ORCPT ); Fri, 11 Aug 2023 03:49:40 -0400 Received: from dggsgout11.his.huawei.com (dggsgout11.his.huawei.com [45.249.212.51]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 44A19211B for ; Fri, 11 Aug 2023 00:49:39 -0700 (PDT) Received: from mail02.huawei.com (unknown [172.30.67.143]) by dggsgout11.his.huawei.com (SkyGuard) with ESMTP id 4RMbXt3ZYZz4f3pHb for ; Fri, 11 Aug 2023 15:49:34 +0800 (CST) Received: from huaweicloud.com (unknown [10.174.178.55]) by APP4 (Coremail) with SMTP id gCh0CgD3hqkM6NVk9GLHAQ--.43376S5; Fri, 11 Aug 2023 15:49:35 +0800 (CST) From: thunder.leizhen@huaweicloud.com To: Petr Mladek , Sergey Senozhatsky , Steven Rostedt , John Ogness , linux-kernel@vger.kernel.org Cc: Zhen Lei , Randy Dunlap Subject: [PATCH v3 1/2] hexdump: minimize the output width of the offset Date: Fri, 11 Aug 2023 15:49:20 +0800 Message-Id: <20230811074922.1388-2-thunder.leizhen@huaweicloud.com> X-Mailer: git-send-email 2.37.3.windows.1 In-Reply-To: <20230811074922.1388-1-thunder.leizhen@huaweicloud.com> References: <20230811074922.1388-1-thunder.leizhen@huaweicloud.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CM-TRANSID: gCh0CgD3hqkM6NVk9GLHAQ--.43376S5 X-Coremail-Antispam: 1UD129KBjvJXoW7Kw13tF4UKF13XF17Cw4UJwb_yoW8tryrpF n8t3y5KFZ7JF1IyrnFyr10gF1Yka47CF10kFWqk34qvF4DWr13JrykKFW3try5Jr4vvrsI qry7t3WFyr17Gw7anT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUU9vb4IE77IF4wAFF20E14v26ryj6rWUM7CY07I20VC2zVCF04k2 6cxKx2IYs7xG6r1S6rWUM7CIcVAFz4kK6r1j6r18M28IrcIa0xkI8VA2jI8067AKxVWUGw A2048vs2IY020Ec7CjxVAFwI0_JFI_Gr1l8cAvFVAK0II2c7xJM28CjxkF64kEwVA0rcxS w2x7M28EF7xvwVC0I7IYx2IY67AKxVWDJVCq3wA2z4x0Y4vE2Ix0cI8IcVCY1x0267AKxV W8Jr0_Cr1UM28EF7xvwVC2z280aVAFwI0_GcCE3s1l84ACjcxK6I8E87Iv6xkF7I0E14v2 6rxl6s0DM2AIxVAIcxkEcVAq07x20xvEncxIr21l5I8CrVACY4xI64kE6c02F40Ex7xfMc Ij6xIIjxv20xvE14v26r1j6r18McIj6I8E87Iv67AKxVWUJVW8JwAm72CE4IkC6x0Yz7v_ Jr0_Gr1lF7xvr2IYc2Ij64vIr41lw4CEc2x0rVAKj4xxMxAIw28IcxkI7VAKI48JMxC20s 026xCaFVCjc4AY6r1j6r4UMI8I3I0E5I8CrVAFwI0_Jr0_Jr4lx2IqxVCjr7xvwVAFwI0_ JrI_JrWlx4CE17CEb7AF67AKxVWUAVWUtwCIc40Y0x0EwIxGrwCI42IY6xIIjxv20xvE14 v26r1j6r1xMIIF0xvE2Ix0cI8IcVCY1x0267AKxVW8JVWxJwCI42IY6xAIw20EY4v20xva j40_Jr0_JF4lIxAIcVC2z280aVAFwI0_Jr0_Gr1lIxAIcVC2z280aVCY1x0267AKxVW8JV W8JrUvcSsGvfC2KfnxnUUI43ZEXa7IU88-BtUUUUU== X-CM-SenderInfo: hwkx0vthuozvpl2kv046kxt4xhlfz01xgou0bp/ X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zhen Lei The offset of case DUMP_PREFIX_OFFSET always starts from 0. Currently, the output width is fixed to 8. But we usually dump only tens or hundreds of bytes, occasionally thousands of bytes. Therefore, the output offset value always has a number of leading zeros, which increases the number of bytes printed and reduces readability. Let's minimize the output width of the offset based on the number of significant bits of its maximum value. Before: dump_size=36: 00000000: c0 ba 8c 80 00 80 ff ff 6c 93 ee 2f ee bf ff ff 00000010: 00 50 1e 98 ff 27 ff ff 01 00 00 00 00 00 00 00 00000020: 80 ca 2f 98 After: dump_size=8: 0: c0 ba 89 80 00 80 ff ff dump_size=36: 00: c0 3a 91 80 00 80 ff ff 6c 93 ae 76 30 ce ff ff 10: 00 60 cd 60 7d 4e ff ff 01 00 00 00 00 00 00 00 20: 40 9e 29 40 dump_size=300: 000: c0 ba 8d 80 00 80 ff ff 6c 93 ce d4 78 a7 ff ff 010: 00 00 16 18 0c 40 ff ff 01 00 00 00 00 00 00 00 020: 01 00 00 00 00 00 00 00 e8 bc 8d 80 00 80 ff ff ... ... 110: 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 120: 00 08 12 01 0c 40 ff ff 00 00 01 00 Signed-off-by: Zhen Lei Reviewed-by: Randy Dunlap --- lib/hexdump.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/lib/hexdump.c b/lib/hexdump.c index 06833d404398d74..1064706d57c15ed 100644 --- a/lib/hexdump.c +++ b/lib/hexdump.c @@ -263,7 +263,7 @@ void print_hex_dump(const char *level, const char *prefix_str, int prefix_type, const void *buf, size_t len, bool ascii) { const u8 *ptr = buf; - int i, linelen, remaining = len; + int i, linelen, width = 0, remaining = len; unsigned char linebuf[32 * 3 + 2 + 32 + 1]; if (rowsize != 16 && rowsize != 32) @@ -282,7 +282,15 @@ void print_hex_dump(const char *level, const char *prefix_str, int prefix_type, level, prefix_str, ptr + i, linebuf); break; case DUMP_PREFIX_OFFSET: - printk("%s%s%.8x: %s\n", level, prefix_str, i, linebuf); + if (!width) { + unsigned long tmp = len - 1; /* offset start from 0, so minus 1 */ + + do { + width++; + tmp >>= 4; + } while (tmp); + } + printk("%s%s%0*x: %s\n", level, prefix_str, width, i, linebuf); break; default: printk("%s%s%s\n", level, prefix_str, linebuf); -- 2.34.1