Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp785964rwb; Sat, 5 Aug 2023 00:38:59 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFHoe3ggVRHMvbLWZc1ZvzNEGLUzxf86dC37QOJdntTkMiyeEt2vuzhl5JsnGHLIiEC61Rz X-Received: by 2002:a9d:750c:0:b0:6b9:f26a:3c51 with SMTP id r12-20020a9d750c000000b006b9f26a3c51mr3953826otk.7.1691221139512; Sat, 05 Aug 2023 00:38:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691221139; cv=none; d=google.com; s=arc-20160816; b=eFYtEaJ/uz7g3cOShUExrby5JSCv4LPN8rB1dWEAG3x56x5fMTk2hJ5p0Ku0sZHg9u G0XKupeSXstOB3YHmIHawXG5pIhO8ZzQ4j7kpNiy+bFfAcoV/i4Ns98dMsruacSwmu5p VN2O+Uoar44+yL4afCbXE1CP83iPPw3ttvZ/orMld3uAd0Ag66AnsopKdWBM79KwoHSk pc39MljK+VbQmCMEj5SXf9huMpC2y6wlIUQXvszBp4rDo97cKG1loqiPSdU4Jg2Rlc9i B6EW83/04yM+rA0uBqH3RiMeOmjajPXV/NH5nxrS3+6MFBjXiN97Pw2oiM4ws73mnRkr fbtw== 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=AFiRED77pPDoozH4wtE5kGkfVQK9BCEaT/hCb6W4S6g=; fh=4XMCVqELsHQeLXPR8wfY+nEap6vsUBU0MIzBtyzMdg4=; b=m1oSKY2+Tl9errKRi3frS6wWN4Rt8QVDJ6CfZnbQrUaPg2qP279VF5f5ImweETBThW NalNbcV4mEiSqFbATUpiKVTcByukF3sxi3d8tl998DjNTCKOGn7+CJ6oNKugPpNSNFk5 k+jPxzbOOP16OV7ZiTEx/Kf8QMYd0qL+zfvGt7XPGnWGEvE7h7ztEvNyO27ancfLgn1V 4t8qre78nbAjSsWnA6l83emUm0coK2j144YiE88Aw211KE5F2KY5UMYdj0yHz0WkWEMs jU+e6ur6m8+E/QgDQSOexh4ObZdV2FFe/j23nNN8K4STpWR9kSJvHBx/YrbG3+AHVBeP XW3w== 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 j65-20020a638b44000000b005537a94f14dsi255424pge.844.2023.08.05.00.38.47; Sat, 05 Aug 2023 00:38:59 -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 S229914AbjHEHWQ (ORCPT + 99 others); Sat, 5 Aug 2023 03:22:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43788 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229832AbjHEHVn (ORCPT ); Sat, 5 Aug 2023 03:21:43 -0400 Received: from dggsgout11.his.huawei.com (unknown [45.249.212.51]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 98B834EC7 for ; Sat, 5 Aug 2023 00:21:41 -0700 (PDT) Received: from mail02.huawei.com (unknown [172.30.67.143]) by dggsgout11.his.huawei.com (SkyGuard) with ESMTP id 4RHvCN5xgbz4f3mJ4 for ; Sat, 5 Aug 2023 15:21:36 +0800 (CST) Received: from huaweicloud.com (unknown [10.174.178.55]) by APP4 (Coremail) with SMTP id gCh0CgAHoZR_+M1kFAdsPg--.4573S5; Sat, 05 Aug 2023 15:21:37 +0800 (CST) From: thunder.leizhen@huaweicloud.com To: Petr Mladek , Sergey Senozhatsky , Steven Rostedt , John Ogness , linux-kernel@vger.kernel.org Cc: Zhen Lei Subject: [PATCH 1/2] hexdump: minimize the output width of the offset Date: Sat, 5 Aug 2023 15:21:15 +0800 Message-Id: <20230805072116.1260-2-thunder.leizhen@huaweicloud.com> X-Mailer: git-send-email 2.37.3.windows.1 In-Reply-To: <20230805072116.1260-1-thunder.leizhen@huaweicloud.com> References: <20230805072116.1260-1-thunder.leizhen@huaweicloud.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CM-TRANSID: gCh0CgAHoZR_+M1kFAdsPg--.4573S5 X-Coremail-Antispam: 1UD129KBjvJXoW7Kw13tF4UKF13XF17Cw4UJwb_yoW8tw45pF 98t3yYgFZ7Jr1xCr17Ar10gr1Yka47C3W0kFWqk34qvF4UWF1fXrykKFW3try5Jr1qqrsI qr9rtw1Fyr17Gw7anT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUU9vb4IE77IF4wAFF20E14v26r4j6ryUM7CY07I20VC2zVCF04k2 6cxKx2IYs7xG6r1S6rWUM7CIcVAFz4kK6r1j6r18M28IrcIa0xkI8VA2jI8067AKxVWUGw A2048vs2IY020Ec7CjxVAFwI0_JFI_Gr1l8cAvFVAK0II2c7xJM28CjxkF64kEwVA0rcxS w2x7M28EF7xvwVC0I7IYx2IY67AKxVWDJVCq3wA2z4x0Y4vE2Ix0cI8IcVCY1x0267AKxV WxJr0_GcWl84ACjcxK6I8E87Iv67AKxVW0oVCq3wA2z4x0Y4vEx4A2jsIEc7CjxVAFwI0_ GcCE3s1le2I262IYc4CY6c8Ij28IcVAaY2xG8wAqx4xG64xvF2IEw4CE5I8CrVC2j2WlYx 0E2Ix0cI8IcVAFwI0_Jr0_Jr4lYx0Ex4A2jsIE14v26r1j6r4UMcvjeVCFs4IE7xkEbVWU JVW8JwACjcxG0xvY0x0EwIxGrwAKzVCY07xG64k0F24l42xK82IYc2Ij64vIr41l4I8I3I 0E4IkC6x0Yz7v_Jr0_Gr1lx2IqxVAqx4xG67AKxVWUJVWUGwC20s026x8GjcxK67AKxVWU GVWUWwC2zVAF1VAY17CE14v26r126r1DMIIYrxkI7VAKI48JMIIF0xvE2Ix0cI8IcVAFwI 0_Jr0_JF4lIxAIcVC0I7IYx2IY6xkF7I0E14v26r4j6F4UMIIF0xvE42xK8VAvwI8IcIk0 rVWUJVWUCwCI42IY6I8E87Iv67AKxVWUJVW8JwCI42IY6I8E87Iv6xkF7I0E14v26r4UJV WxJrUvcSsGvfC2KfnxnUUI43ZEXa7IU8U73DUUUUU== X-CM-SenderInfo: hwkx0vthuozvpl2kv046kxt4xhlfz01xgou0bp/ X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,KHOP_HELO_FCRDNS, 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 --- lib/hexdump.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/lib/hexdump.c b/lib/hexdump.c index 06833d404398d74..86cb4cc3eec485a 100644 --- a/lib/hexdump.c +++ b/lib/hexdump.c @@ -263,12 +263,21 @@ 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) rowsize = 16; + if (prefix_type == DUMP_PREFIX_OFFSET) { + unsigned long tmp = len - 1; /* offset start from 0, so minus 1 */ + + do { + width++; + tmp >>= 4; + } while (tmp); + } + for (i = 0; i < len; i += rowsize) { linelen = min(remaining, rowsize); remaining -= rowsize; @@ -282,7 +291,7 @@ 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); + 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