Re: [PATCH v9 06/13] iommu/amd: copy old trans table from old kernel

From: Joerg Roedel
Date: Fri Aug 04 2017 - 08:21:25 EST


On Tue, Aug 01, 2017 at 07:37:22PM +0800, Baoquan He wrote:
> static void init_device_table_dma(void)
> {
> @@ -2137,9 +2140,49 @@ static void early_enable_iommu(struct amd_iommu *iommu)
> static void early_enable_iommus(void)
> {
> struct amd_iommu *iommu;
> + bool is_pre_disabled = false;
>
> - for_each_iommu(iommu)
> - early_enable_iommu(iommu);
> + for_each_iommu(iommu) {
> + if (!translation_pre_enabled(iommu)) {
> + is_pre_disabled = true;
> + break;
> + }
> + }

I think this could be easier if you make 'is_pre_disabled' a global state
bool variable with reversed meaning and initialize it with 'true'.
Basically

static bool __init amd_iommu_pre_enabled = true;

And set this variable to 'false' when you find a already disabled IOMMU
during initialization. Then you can remove the code above.

> +
> + if (is_pre_disabled) {
> + for_each_iommu(iommu)
> + early_enable_iommu(iommu);

return
}

> + } else {

And remove this to get rid of one indendation level for the code below.

> + pr_warn("Translation is already enabled - trying to copy translation structures\n");
> + if (copy_device_table()) {

Seeing how the return value of copy_device_table() is used, it makes
sense to change its return-type to bool. This way it is also easier to
see which one is the sucess and which one the failure case.