Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1051713pxk; Fri, 18 Sep 2020 02:33:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyVD5CgzH+Aw8NM0TC/mwdZpmCN+mUR+D7rrS/zjrzZDE+J1KbeKkm5RP+qUougWwhEkiO+ X-Received: by 2002:a05:6402:45a:: with SMTP id p26mr39594865edw.8.1600421598992; Fri, 18 Sep 2020 02:33:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600421598; cv=none; d=google.com; s=arc-20160816; b=q4/lmNhtEtcIdU1wYOy4sxX9+fRZ0i+WL2Sj1LDgVk+mtvRb8/c79aWg41rhCWJ/u9 1Kj2qOXaQWH7A9vY6OxUBsjnzHCYTWfgF9tvjBaNO4jprbqG6OZ6G44/YZQOJBKF4YlI rYJ5+Yj5A7VQ/9sfOn2kUoNwD9ymNXJmh/7Ec0D0kYazSZtzgGRpAaYRi8/t3/g4Krpa VwlclxdLV0eaAgebQMgKJhEZ7oMxWsnFI2PlUdcYowM5zpgHXHlQ7b9PPuLVqWVm/Bi7 joAirXpRksqLO6y/Ow3PsrpTJ91D+1gI8+H+vtKFipMgrh9ON3dgQMStsJnk6UkJD6Dj AKRA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=KRaaiore/8iZooCZi7oSR8VppOie/rnVo/rk7wo5udY=; b=vBbWm8IDlugRecid6sn3V5M8nS6rg87e++QbMmkXUCJb4mPstJ5+F4N6XGYGaIxpUk WrXRHshJrAJvtKhWugTWBYwpKS1dFj2iEpNgEPmZxe+RjokHQqhBszWbDzpTSkJX3qrI 8EMbRu+UJIyHR4vkQELXfRohCZJkZQQdvjLzPclESHVyJQ59xHvVdmet1EcfpO8nmQLV ZkR+tpHDhx5cZyCfE0++s0DDpDaLMp8ckPy8o5TNTWO2tilzlp/FmQkEK248rDwmJIVN mfyPwkhX+ryhn2zkabLIPwFx4s2An2mKTDlMA0bBG4TsLdUUWhk6jACozwh5R0bQAnS4 Hf+Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f2si1701847edr.143.2020.09.18.02.32.54; Fri, 18 Sep 2020 02:33:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726192AbgIRJbX (ORCPT + 99 others); Fri, 18 Sep 2020 05:31:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38052 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726154AbgIRJbW (ORCPT ); Fri, 18 Sep 2020 05:31:22 -0400 Received: from theia.8bytes.org (8bytes.org [IPv6:2a01:238:4383:600:38bc:a715:4b6d:a889]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 655DDC06174A for ; Fri, 18 Sep 2020 02:31:22 -0700 (PDT) Received: by theia.8bytes.org (Postfix, from userid 1000) id 764C2293; Fri, 18 Sep 2020 11:31:19 +0200 (CEST) Date: Fri, 18 Sep 2020 11:31:18 +0200 From: Joerg Roedel To: Suravee Suthikulpanit Cc: linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org, Jon.Grimm@amd.com, brijesh.singh@amd.com Subject: Re: [PATCH 2/3] iommu: amd: Add support for RMP_PAGE_FAULT and RMP_HW_ERR Message-ID: <20200918093117.GO31590@8bytes.org> References: <20200916135549.146468-1-suravee.suthikulpanit@amd.com> <20200916135549.146468-3-suravee.suthikulpanit@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200916135549.146468-3-suravee.suthikulpanit@amd.com> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Suravee, On Wed, Sep 16, 2020 at 01:55:48PM +0000, Suravee Suthikulpanit wrote: > +static void amd_iommu_report_rmp_hw_error(volatile u32 *event) > +{ > + struct pci_dev *pdev; > + struct iommu_dev_data *dev_data = NULL; > + int devid = (event[0] >> EVENT_DEVID_SHIFT) & EVENT_DEVID_MASK; > + int vmg_tag = (event[1]) & 0xFFFF; > + int flags = (event[1] >> EVENT_FLAGS_SHIFT) & EVENT_FLAGS_MASK; > + u64 spa = ((u64)event[3] << 32) | (event[2] & 0xFFFFFFF8); Please write this as: struct iommu_dev_data *dev_data = NULL; int devid, vmg_tag, flags; struct pci_dev *pdev; u64 spa; devid = (event[0] >> EVENT_DEVID_SHIFT) & EVENT_DEVID_MASK; vmg_tag = (event[1]) & 0xFFFF; flags = (event[1] >> EVENT_FLAGS_SHIFT) & EVENT_FLAGS_MASK; spa = ((u64)event[3] << 32) | (event[2] & 0xFFFFFFF8); Same applied the the next function. > + > + pdev = pci_get_domain_bus_and_slot(0, PCI_BUS_NUM(devid), > + devid & 0xff); > + if (pdev) > + dev_data = dev_iommu_priv_get(&pdev->dev); > + > + if (dev_data && __ratelimit(&dev_data->rs)) { > + pci_err(pdev, "Event logged [RMP_HW_ERROR devid=0x%04x, vmg_tag=0x%04x, spa=0x%llx, flags=0x%04x]\n", > + devid, vmg_tag, spa, flags); Printing the devid is not really needed here, no? Same issue in the next function. Regards, Joerg