On Mon, Jul 08, 2019 at 05:13:05PM +0200, Auger Eric wrote: > > #define STRTAB_STE_0_S1FMT GENMASK_ULL(5, 4) > > #define STRTAB_STE_0_S1FMT_LINEAR 0 > > +#define STRTAB_STE_0_S1FMT_4K_L2 1 > As you only use 64kB L2, I guess you can remove the 4K define? I prefer defining all values, but I suppose I can get rid of it. > > + cfg->tables = devm_kzalloc(smmu->dev, sizeof(struct arm_smmu_cd_table) * > > + cfg->num_tables, GFP_KERNEL); > > + if (!cfg->tables) > > + return -ENOMEM; > goto err_free_l1 > > + > > + ret = arm_smmu_alloc_cd_leaf_table(smmu, &cfg->tables[0], num_leaf_entries); > don't you want to do that only in linear case. In 2-level mode, I > understand arm_smmu_get_cd_ptr() will do the job. OK, that might be better > > > + if (ret) > > + goto err_free_l1; > > + > > + if (cfg->l1ptr) > > + arm_smmu_write_cd_l1_desc(cfg->l1ptr, &cfg->tables[0]); > that stuff could be removed as well? Yes > By the way I can see that > arm_smmu_get_cd_ptr() does a arm_smmu_sync_cd after. wouldn't it be > needed here as well? No context table is reachable from a STE at this point, so we don't have to invalidate anything. > > @@ -1815,7 +1935,7 @@ static void arm_smmu_domain_free(struct iommu_domain *domain) > > if (smmu_domain->stage == ARM_SMMU_DOMAIN_S1) { > > struct arm_smmu_s1_cfg *cfg = &smmu_domain->s1_cfg; > > > > - if (cfg->table.ptr) { > > + if (cfg->tables) { > > arm_smmu_free_cd_tables(smmu_domain); > > arm_smmu_bitmap_free(smmu->asid_map, cfg->cd.asid); > I don't get why the arm_smmu_bitmap_free is dependent on cfg->tables. Simply because arm_smmu_bitmap_alloc() and arm_smmu_alloc_cd_tables() are both performed in arm_smmu_domain_finalise_s1(). A domain returned by arm_smmu_domain_alloc() is not fully initialized, it still needs to be finalized by arm_smmu_attach_dev(). So here we check whether the domain has been finalized or not. Zero being a valid ASID in this driver, we can't check whether cfg->cd.asid is valid, so we check cfg->tables instead. And I forgot to clear cfg->tables after failure of domain_finalise in this series, I'll need to fix it. Thanks, Jean