From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932311AbcI1NBv (ORCPT ); Wed, 28 Sep 2016 09:01:51 -0400 Received: from mx1.redhat.com ([209.132.183.28]:44648 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750988AbcI1NBl (ORCPT ); Wed, 28 Sep 2016 09:01:41 -0400 Date: Wed, 28 Sep 2016 21:01:36 +0800 From: Baoquan He To: Joerg Roedel Cc: iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, kexec@lists.infradead.org, dyoung@redhat.com, xlpang@redhat.com, Vincent.Wan@amd.com Subject: Re: [PATCH v5 5/8] iommu/amd: copy old trans table from old kernel Message-ID: <20160928130136.GA9185@x1.redhat.com> References: <1473951806-25511-1-git-send-email-bhe@redhat.com> <1473951806-25511-6-git-send-email-bhe@redhat.com> <20160920124031.GD3541@8bytes.org> <20160928013702.GH14155@x1.redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160928013702.GH14155@x1.redhat.com> User-Agent: Mutt/1.5.21 (2010-09-15) X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.30]); Wed, 28 Sep 2016 13:01:40 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 09/28/16 at 09:37am, Baoquan He wrote: > Hi Joerg, > > On 09/20/16 at 02:40pm, Joerg Roedel wrote: > > > + if ( !is_pre_enabled) { > > > + for_each_iommu(iommu) > > > + early_enable_iommu(iommu); > > > + } else { > > > + if (copy_dev_tables()) { > > > + pr_err("Failed to copy DEV table from previous kernel.\n"); > > > + /* > > > + * If failed to copy dev tables from old kernel, continue to proceed > > > + * as it does in normal kernel. > > > + */ > > > + for_each_iommu(iommu) { > > > + clear_translation_pre_enabled(iommu); > > > + early_enable_iommu(iommu); > > > + } > > > + } else { > > > + pr_info("Copied DEV table from previous kernel.\n"); > > > + for_each_iommu(iommu) { > > > + iommu_feature_disable(iommu, CONTROL_CMDBUF_EN); > > > + iommu_feature_disable(iommu, CONTROL_EVT_LOG_EN); > > > > Could you move that into new helpers (iommu_disable_command_buffer...)? > > Did you mean wraping iommu_feature_disable(iommu, CONTROL_CMDBUF_EN) into a > helper function like iommu_disable_command_buffer(), and wraping > iommu_feature_disable(iommu, CONTROL_EVT_LOG_EN) into > iommu_disable_event_buffer()? > > I retest with not disabling command buffer and event log here, it works > on amd iommu v1 and v2 systems. So if I understand your comment > correctly, there's no need to add "iommu_feature_disable(iommu, > CONTROL_CMDBUF_EN)" and "iommu_feature_disable(iommu, > CONTROL_EVT_LOG_EN)" here. I remember I added them here because more > IO_PAGE_FAULT messages are printed without them. But now it seems not to > related to them. So I will remove above two lines of code. Oh, sorry, please ignore this. It will print many lines of below message if do not disable cmd buffer and event log here. [ 0.455642] AMD-Vi: Completion-Wait loop timed out