mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
iommu/ipmmu-vmsa: Move num_utlbs to SoC-specific features
The maximum number of micro-TLBs per IPMMU instance is not fixed, but depends on the SoC type. Hence move it from struct ipmmu_vmsa_device to struct ipmmu_features, and set up the correct value for both R-Car Gen2 and Gen3 SoCs. Note that currently no code uses this value. Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Simon Horman <horms+renesas@verge.net.au> Reviewed-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Tested-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Signed-off-by: Joerg Roedel <jroedel@suse.de>
This commit is contained in:
parent
b43e0d8a45
commit
b7f3f047ae
@ -42,6 +42,7 @@ struct ipmmu_features {
|
|||||||
bool use_ns_alias_offset;
|
bool use_ns_alias_offset;
|
||||||
bool has_cache_leaf_nodes;
|
bool has_cache_leaf_nodes;
|
||||||
unsigned int number_of_contexts;
|
unsigned int number_of_contexts;
|
||||||
|
unsigned int num_utlbs;
|
||||||
bool setup_imbuscr;
|
bool setup_imbuscr;
|
||||||
bool twobit_imttbcr_sl0;
|
bool twobit_imttbcr_sl0;
|
||||||
bool reserved_context;
|
bool reserved_context;
|
||||||
@ -53,7 +54,6 @@ struct ipmmu_vmsa_device {
|
|||||||
struct iommu_device iommu;
|
struct iommu_device iommu;
|
||||||
struct ipmmu_vmsa_device *root;
|
struct ipmmu_vmsa_device *root;
|
||||||
const struct ipmmu_features *features;
|
const struct ipmmu_features *features;
|
||||||
unsigned int num_utlbs;
|
|
||||||
unsigned int num_ctx;
|
unsigned int num_ctx;
|
||||||
spinlock_t lock; /* Protects ctx and domains[] */
|
spinlock_t lock; /* Protects ctx and domains[] */
|
||||||
DECLARE_BITMAP(ctx, IPMMU_CTX_MAX);
|
DECLARE_BITMAP(ctx, IPMMU_CTX_MAX);
|
||||||
@ -972,6 +972,7 @@ static const struct ipmmu_features ipmmu_features_default = {
|
|||||||
.use_ns_alias_offset = true,
|
.use_ns_alias_offset = true,
|
||||||
.has_cache_leaf_nodes = false,
|
.has_cache_leaf_nodes = false,
|
||||||
.number_of_contexts = 1, /* software only tested with one context */
|
.number_of_contexts = 1, /* software only tested with one context */
|
||||||
|
.num_utlbs = 32,
|
||||||
.setup_imbuscr = true,
|
.setup_imbuscr = true,
|
||||||
.twobit_imttbcr_sl0 = false,
|
.twobit_imttbcr_sl0 = false,
|
||||||
.reserved_context = false,
|
.reserved_context = false,
|
||||||
@ -981,6 +982,7 @@ static const struct ipmmu_features ipmmu_features_rcar_gen3 = {
|
|||||||
.use_ns_alias_offset = false,
|
.use_ns_alias_offset = false,
|
||||||
.has_cache_leaf_nodes = true,
|
.has_cache_leaf_nodes = true,
|
||||||
.number_of_contexts = 8,
|
.number_of_contexts = 8,
|
||||||
|
.num_utlbs = 48,
|
||||||
.setup_imbuscr = false,
|
.setup_imbuscr = false,
|
||||||
.twobit_imttbcr_sl0 = true,
|
.twobit_imttbcr_sl0 = true,
|
||||||
.reserved_context = true,
|
.reserved_context = true,
|
||||||
@ -1033,7 +1035,6 @@ static int ipmmu_probe(struct platform_device *pdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
mmu->dev = &pdev->dev;
|
mmu->dev = &pdev->dev;
|
||||||
mmu->num_utlbs = 48;
|
|
||||||
spin_lock_init(&mmu->lock);
|
spin_lock_init(&mmu->lock);
|
||||||
bitmap_zero(mmu->ctx, IPMMU_CTX_MAX);
|
bitmap_zero(mmu->ctx, IPMMU_CTX_MAX);
|
||||||
mmu->features = of_device_get_match_data(&pdev->dev);
|
mmu->features = of_device_get_match_data(&pdev->dev);
|
||||||
|
Loading…
Reference in New Issue
Block a user