Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp6430405rwb; Wed, 18 Jan 2023 05:13:15 -0800 (PST) X-Google-Smtp-Source: AMrXdXu2PDOwCdr0nR3xzBFcSrduyznP08y9illzQEizlc00AdfYksWIPAlOFJK3pcv3SM/sEQ64 X-Received: by 2002:a17:907:62a8:b0:86a:d385:81df with SMTP id nd40-20020a17090762a800b0086ad38581dfmr10802167ejc.3.1674047594920; Wed, 18 Jan 2023 05:13:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1674047594; cv=none; d=google.com; s=arc-20160816; b=Ibw9L46EVuWhdWxHbVc5VkaVCWWlUT1oobTg/46CWXezlvoJ2HJHt8VcwN2Ui6j0Oo 7GeS/QIi2337aTnNbYAEaA8H1L0ksDh0aeKJmRQN4ufL3BaSt3syoyNmJLoNI4aQWE7b Yx9Ci/FAPzFh9qTUbWoNHPD/UaR9P8ssULIsVNJXKhBGTbjypvAQlS79QFeanGsaQWav wWh6gNx9VQhxPPYo5IiiFAzoqhMGx3OvbsJ8OTmdwin2FuCB49y4eyzH2W/s188WAqSe DTvyPcoEGtE1YNBP0jzdsVPDn5Czal4+GY9rIZkzPOgBZ48qOQoNzoz4FJF/CQ3s2CXq K/xA== 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 :message-id:date:in-reply-to:subject:cc:to:from:dkim-signature; bh=n60fz9YcAqu7Rq2mevdDz66/rWE+P9eecmuLG5Gwg8M=; b=WCyIppdzCYCdD083gJTBjzmDDy8B22UYbv6eQoHsl5KYsXDDYVay86XTde7GoztL/z ekUYnYLLSdFgdbSvsTWurbx/of2gA0nL3egCGc4wA5Vpo+n6hOI/c0IVT6fszM2kvx9C BaSLuzigMWMiXLGAp/OcDh3Fy8g22cQesigJQAQSxyWOPepIaIqSbxpj8dFBhkj9YtvA h17T2mMbsAM6uNlPByAMrT3pow20TfPFfGny/LHQUsOSaDwKxCq4+OCBJ9ibmZMd79IR +fe5bh1wjFl6jknX+juifgtHa85KhRWw5e23B9r0/pnAzdJUX0pinFg1+/6tVFUyMrnv L3/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=isWW50P9; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id xh7-20020a170906da8700b0084d14322868si38885584ejb.179.2023.01.18.05.13.03; Wed, 18 Jan 2023 05:13:14 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=isWW50P9; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229806AbjARLtO (ORCPT + 45 others); Wed, 18 Jan 2023 06:49:14 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57930 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230280AbjARLqc (ORCPT ); Wed, 18 Jan 2023 06:46:32 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9A15036697 for ; Wed, 18 Jan 2023 03:09:01 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 5CC1AB81C52 for ; Wed, 18 Jan 2023 11:09:00 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id AA1B5C433D2; Wed, 18 Jan 2023 11:08:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1674040139; bh=GvpUj3xLuNjjGGKiolsN/80QxOzBKhmKRzegY8kskMI=; h=From:To:Cc:Subject:In-Reply-To:Date:From; b=isWW50P9c2NFbryW876/62nH0oCkqVQLrurvR60LsZMO8Zwbz93UNRmzM/k4UgZ0b 8v44oYLfomS+fDexpJqmNRPd7P2DkqP6u1/4TOJr6myOLVVP0WPG8ARtIrX0BobzyC 2l9+gDdTsf2OD+rXNE4Zzx/cMqC2GIJc1CzABzhLhwAZqScD44zAU33osq/2mwV3PS QnoyZuQlzRJ8ac3kOoFM/Jvv+CnD+osBHEF21XcfflTxKFTnO9Q09HKBTi0Dan9be7 LHlK5JOgw3V+E60nkQNPoFl7rFdCT+zegQW2s4Z5sSGN59BeDZkRqfNS+ZrrVsDr7j 8hHkOc+JliylQ== From: =?utf-8?B?QmrDtnJuIFTDtnBlbA==?= To: Geert Uytterhoeven Cc: Paul Walmsley , Palmer Dabbelt , Albert Ou , linux-riscv@lists.infradead.org, =?utf-8?B?QmrDtnJuIFTDtnBlbA==?= , Andreas Schwab , linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 1/2] riscv: Add instruction dump to RISC-V splats In-Reply-To: Date: Wed, 18 Jan 2023 12:08:56 +0100 Message-ID: <87pmbcnlpz.fsf@all.your.base.are.belong.to.us> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS 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 Geert Uytterhoeven writes: >> +static void dump_kernel_instr(const char *loglvl, struct pt_regs *regs) >> +{ >> + char str[sizeof("0000 ") * 12 + 2 + 1], *p =3D str; >> + unsigned long addr =3D regs->epc; > > Given you never use this as an unsigned long, what about > > const u16 *insns =3D (u16 *)instruction_pointer(regs); > > so you no longer need casts below? Indeed! Good suggestion, thank you! I'll do this change in v3. >> + long bad; >> + u16 val; >> + int i; >> + >> + for (i =3D -10; i < 2; i++) { >> + bad =3D get_kernel_nofault(val, &((u16 *)addr)[i]); >> + if (!bad) { >> + p +=3D sprintf(p, i =3D=3D 0 ? "(%04hx) " : "%04= hx ", val); >> + } else { >> + printk("%sCode: Unable to access instruction at = 0x%lx.\n", > > %px, so you can drop the cast to long below. Much cleaner. Thanks! Bj=C3=B6rn