Commit 734554fd authored by Robin Murphy's avatar Robin Murphy Committed by Will Deacon

iommu/arm-smmu-v3: Retire disable_bypass parameter

The disable_bypass parameter has been mostly meaningless for a long time
since the introduction of default domains. Its original intent is now
fulfilled by the controls users have over the default domain type, and
its remaining effect in the brief window between Stream Table
initialisation and default domain creation hardly seems worth the
complication. Furthermore, thanks to 2-level Stream Tables, disabling
disable_bypass (there's another reason not to like it right there) has
never guaranteed that any particular StreamID *will* bypass anyway - any
device which might actually care about that wants RMRs - so there's not
really much lost by taking away that option (which has already been
non-default for nearing 6 years now).

As part of this, also remove the weird behaviour where we "successfully"
probe and register a non-functional SMMU if the DT "#iommu-cells"
property is wrong. I have no memory of what possessed me to think that
was a good idea at the time, and by now I suspect it's likely to break
things worse than simply failing probe would.
Signed-off-by: default avatarRobin Murphy <robin.murphy@arm.com>
Reviewed-by: default avatarMostafa Saleh <smostafa@google.com>
Link: https://lore.kernel.org/r/ea3ac4cd595a81b5511729601b2f7d4668178438.1712335927.git.robin.murphy@arm.comSigned-off-by: default avatarWill Deacon <will@kernel.org>
parent 39cd87c4
...@@ -30,11 +30,6 @@ ...@@ -30,11 +30,6 @@
#include "arm-smmu-v3.h" #include "arm-smmu-v3.h"
#include "../../dma-iommu.h" #include "../../dma-iommu.h"
static bool disable_bypass = true;
module_param(disable_bypass, bool, 0444);
MODULE_PARM_DESC(disable_bypass,
"Disable bypass streams such that incoming transactions from devices that are not attached to an iommu domain will report an abort back to the device and will not be allowed to pass through the SMMU.");
static bool disable_msipolling; static bool disable_msipolling;
module_param(disable_msipolling, bool, 0444); module_param(disable_msipolling, bool, 0444);
MODULE_PARM_DESC(disable_msipolling, MODULE_PARM_DESC(disable_msipolling,
...@@ -1567,17 +1562,13 @@ static void arm_smmu_make_s2_domain_ste(struct arm_smmu_ste *target, ...@@ -1567,17 +1562,13 @@ static void arm_smmu_make_s2_domain_ste(struct arm_smmu_ste *target,
* This can safely directly manipulate the STE memory without a sync sequence * This can safely directly manipulate the STE memory without a sync sequence
* because the STE table has not been installed in the SMMU yet. * because the STE table has not been installed in the SMMU yet.
*/ */
static void arm_smmu_init_initial_stes(struct arm_smmu_device *smmu, static void arm_smmu_init_initial_stes(struct arm_smmu_ste *strtab,
struct arm_smmu_ste *strtab,
unsigned int nent) unsigned int nent)
{ {
unsigned int i; unsigned int i;
for (i = 0; i < nent; ++i) { for (i = 0; i < nent; ++i) {
if (disable_bypass)
arm_smmu_make_abort_ste(strtab); arm_smmu_make_abort_ste(strtab);
else
arm_smmu_make_bypass_ste(smmu, strtab);
strtab++; strtab++;
} }
} }
...@@ -1605,7 +1596,7 @@ static int arm_smmu_init_l2_strtab(struct arm_smmu_device *smmu, u32 sid) ...@@ -1605,7 +1596,7 @@ static int arm_smmu_init_l2_strtab(struct arm_smmu_device *smmu, u32 sid)
return -ENOMEM; return -ENOMEM;
} }
arm_smmu_init_initial_stes(smmu, desc->l2ptr, 1 << STRTAB_SPLIT); arm_smmu_init_initial_stes(desc->l2ptr, 1 << STRTAB_SPLIT);
arm_smmu_write_strtab_l1_desc(strtab, desc); arm_smmu_write_strtab_l1_desc(strtab, desc);
return 0; return 0;
} }
...@@ -2915,10 +2906,10 @@ static void arm_smmu_release_device(struct device *dev) ...@@ -2915,10 +2906,10 @@ static void arm_smmu_release_device(struct device *dev)
iopf_queue_remove_device(master->smmu->evtq.iopf, dev); iopf_queue_remove_device(master->smmu->evtq.iopf, dev);
/* Put the STE back to what arm_smmu_init_strtab() sets */ /* Put the STE back to what arm_smmu_init_strtab() sets */
if (disable_bypass && !dev->iommu->require_direct) if (dev->iommu->require_direct)
arm_smmu_attach_dev_blocked(&arm_smmu_blocked_domain, dev);
else
arm_smmu_attach_dev_identity(&arm_smmu_identity_domain, dev); arm_smmu_attach_dev_identity(&arm_smmu_identity_domain, dev);
else
arm_smmu_attach_dev_blocked(&arm_smmu_blocked_domain, dev);
arm_smmu_disable_pasid(master); arm_smmu_disable_pasid(master);
arm_smmu_remove_master(master); arm_smmu_remove_master(master);
...@@ -3273,7 +3264,7 @@ static int arm_smmu_init_strtab_linear(struct arm_smmu_device *smmu) ...@@ -3273,7 +3264,7 @@ static int arm_smmu_init_strtab_linear(struct arm_smmu_device *smmu)
reg |= FIELD_PREP(STRTAB_BASE_CFG_LOG2SIZE, smmu->sid_bits); reg |= FIELD_PREP(STRTAB_BASE_CFG_LOG2SIZE, smmu->sid_bits);
cfg->strtab_base_cfg = reg; cfg->strtab_base_cfg = reg;
arm_smmu_init_initial_stes(smmu, strtab, cfg->num_l1_ents); arm_smmu_init_initial_stes(strtab, cfg->num_l1_ents);
return 0; return 0;
} }
...@@ -3503,7 +3494,7 @@ static int arm_smmu_device_disable(struct arm_smmu_device *smmu) ...@@ -3503,7 +3494,7 @@ static int arm_smmu_device_disable(struct arm_smmu_device *smmu)
return ret; return ret;
} }
static int arm_smmu_device_reset(struct arm_smmu_device *smmu, bool bypass) static int arm_smmu_device_reset(struct arm_smmu_device *smmu)
{ {
int ret; int ret;
u32 reg, enables; u32 reg, enables;
...@@ -3513,7 +3504,6 @@ static int arm_smmu_device_reset(struct arm_smmu_device *smmu, bool bypass) ...@@ -3513,7 +3504,6 @@ static int arm_smmu_device_reset(struct arm_smmu_device *smmu, bool bypass)
reg = readl_relaxed(smmu->base + ARM_SMMU_CR0); reg = readl_relaxed(smmu->base + ARM_SMMU_CR0);
if (reg & CR0_SMMUEN) { if (reg & CR0_SMMUEN) {
dev_warn(smmu->dev, "SMMU currently enabled! Resetting...\n"); dev_warn(smmu->dev, "SMMU currently enabled! Resetting...\n");
WARN_ON(is_kdump_kernel() && !disable_bypass);
arm_smmu_update_gbpa(smmu, GBPA_ABORT, 0); arm_smmu_update_gbpa(smmu, GBPA_ABORT, 0);
} }
...@@ -3620,14 +3610,8 @@ static int arm_smmu_device_reset(struct arm_smmu_device *smmu, bool bypass) ...@@ -3620,14 +3610,8 @@ static int arm_smmu_device_reset(struct arm_smmu_device *smmu, bool bypass)
if (is_kdump_kernel()) if (is_kdump_kernel())
enables &= ~(CR0_EVTQEN | CR0_PRIQEN); enables &= ~(CR0_EVTQEN | CR0_PRIQEN);
/* Enable the SMMU interface, or ensure bypass */ /* Enable the SMMU interface */
if (!bypass || disable_bypass) {
enables |= CR0_SMMUEN; enables |= CR0_SMMUEN;
} else {
ret = arm_smmu_update_gbpa(smmu, 0, GBPA_ABORT);
if (ret)
return ret;
}
ret = arm_smmu_write_reg_sync(smmu, enables, ARM_SMMU_CR0, ret = arm_smmu_write_reg_sync(smmu, enables, ARM_SMMU_CR0,
ARM_SMMU_CR0ACK); ARM_SMMU_CR0ACK);
if (ret) { if (ret) {
...@@ -4019,7 +4003,6 @@ static int arm_smmu_device_probe(struct platform_device *pdev) ...@@ -4019,7 +4003,6 @@ static int arm_smmu_device_probe(struct platform_device *pdev)
resource_size_t ioaddr; resource_size_t ioaddr;
struct arm_smmu_device *smmu; struct arm_smmu_device *smmu;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
bool bypass;
smmu = devm_kzalloc(dev, sizeof(*smmu), GFP_KERNEL); smmu = devm_kzalloc(dev, sizeof(*smmu), GFP_KERNEL);
if (!smmu) if (!smmu)
...@@ -4030,12 +4013,9 @@ static int arm_smmu_device_probe(struct platform_device *pdev) ...@@ -4030,12 +4013,9 @@ static int arm_smmu_device_probe(struct platform_device *pdev)
ret = arm_smmu_device_dt_probe(pdev, smmu); ret = arm_smmu_device_dt_probe(pdev, smmu);
} else { } else {
ret = arm_smmu_device_acpi_probe(pdev, smmu); ret = arm_smmu_device_acpi_probe(pdev, smmu);
if (ret == -ENODEV)
return ret;
} }
if (ret)
/* Set bypass mode according to firmware probing result */ return ret;
bypass = !!ret;
/* Base address */ /* Base address */
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
...@@ -4099,7 +4079,7 @@ static int arm_smmu_device_probe(struct platform_device *pdev) ...@@ -4099,7 +4079,7 @@ static int arm_smmu_device_probe(struct platform_device *pdev)
arm_smmu_rmr_install_bypass_ste(smmu); arm_smmu_rmr_install_bypass_ste(smmu);
/* Reset the device */ /* Reset the device */
ret = arm_smmu_device_reset(smmu, bypass); ret = arm_smmu_device_reset(smmu);
if (ret) if (ret)
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment