[PATCH 15/16] iommu/fsl: Make use of domain_alloc and domain_free

Varun Sethi Varun.Sethi at freescale.com
Sun Apr 12 07:25:58 PDT 2015



> -----Original Message-----
> From: iommu-bounces at lists.linux-foundation.org [mailto:iommu-
> bounces at lists.linux-foundation.org] On Behalf Of Joerg Roedel
> Sent: Thursday, March 26, 2015 6:13 PM
> To: iommu at lists.linux-foundation.org
> Cc: Alexandre Courbot; linux-samsung-soc at vger.kernel.org; Heiko Stuebner;
> Arnd Bergmann; Stephen Warren; Will Deacon; linux-
> kernel at vger.kernel.org; linux-rockchip at lists.infradead.org; Kukjin Kim;
> Thierry Reding; jroedel at suse.de; linux-tegra at vger.kernel.org; Yingjoe
> Chen; David Woodhouse; linux-arm-kernel at lists.infradead.org
> Subject: [PATCH 15/16] iommu/fsl: Make use of domain_alloc and
> domain_free
> 
> From: Joerg Roedel <jroedel at suse.de>
> 
> Implement domain_alloc and domain_free iommu-ops as a replacement for
> domain_init/domain_destroy.
> 
> Signed-off-by: Joerg Roedel <jroedel at suse.de>
> ---
>  drivers/iommu/fsl_pamu_domain.c | 60 ++++++++++++++++++++++--------
> -----------
>  drivers/iommu/fsl_pamu_domain.h |  2 +-
>  2 files changed, 33 insertions(+), 29 deletions(-)
> 
> diff --git a/drivers/iommu/fsl_pamu_domain.c
> b/drivers/iommu/fsl_pamu_domain.c index ceebd28..1d45293 100644
> --- a/drivers/iommu/fsl_pamu_domain.c
> +++ b/drivers/iommu/fsl_pamu_domain.c
> @@ -33,6 +33,11 @@ static struct kmem_cache *fsl_pamu_domain_cache;
> static struct kmem_cache *iommu_devinfo_cache;  static
> DEFINE_SPINLOCK(device_domain_lock);
> 
> +static struct fsl_dma_domain *to_fsl_dma_domain(struct iommu_domain
> +*dom) {
> +	return container_of(dom, struct fsl_dma_domain, iommu_domain);
> }
> +
>  static int __init iommu_init_mempool(void)  {
>  	fsl_pamu_domain_cache =
> kmem_cache_create("fsl_pamu_domain",
> @@ -65,7 +70,7 @@ static phys_addr_t get_phys_addr(struct
> fsl_dma_domain *dma_domain, dma_addr_t i
>  	struct dma_window *win_ptr = &dma_domain->win_arr[0];
>  	struct iommu_domain_geometry *geom;
> 
> -	geom = &dma_domain->iommu_domain->geometry;
> +	geom = &dma_domain->iommu_domain.geometry;
> 
>  	if (!win_cnt || !dma_domain->geom_size) {
>  		pr_debug("Number of windows/geometry not configured
> for the domain\n"); @@ -123,7 +128,7 @@ static int map_win(int liodn,
> struct fsl_dma_domain *dma_domain)  {
>  	int ret;
>  	struct dma_window *wnd = &dma_domain->win_arr[0];
> -	phys_addr_t wnd_addr = dma_domain->iommu_domain-
> >geometry.aperture_start;
> +	phys_addr_t wnd_addr =
> +dma_domain->iommu_domain.geometry.aperture_start;
>  	unsigned long flags;
> 
>  	spin_lock_irqsave(&iommu_lock, flags); @@ -172,7 +177,7 @@ static
> int update_liodn(int liodn, struct fsl_dma_domain *dma_domain, u32
> wnd_nr
>  	} else {
>  		phys_addr_t wnd_addr;
> 
> -		wnd_addr = dma_domain->iommu_domain-
> >geometry.aperture_start;
> +		wnd_addr = dma_domain-
> >iommu_domain.geometry.aperture_start;
> 
>  		ret = pamu_config_ppaace(liodn, wnd_addr,
>  					 wnd->size,
> @@ -384,7 +389,7 @@ static void attach_device(struct fsl_dma_domain
> *dma_domain, int liodn, struct d  static phys_addr_t
> fsl_pamu_iova_to_phys(struct iommu_domain *domain,
>  					 dma_addr_t iova)
>  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
> 
>  	if (iova < domain->geometry.aperture_start ||
>  	    iova > domain->geometry.aperture_end) @@ -398,11 +403,9 @@
> static bool fsl_pamu_capable(enum iommu_cap cap)
>  	return cap == IOMMU_CAP_CACHE_COHERENCY;  }
> 
> -static void fsl_pamu_domain_destroy(struct iommu_domain *domain)
> +static void fsl_pamu_domain_free(struct iommu_domain *domain)
>  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> -
> -	domain->priv = NULL;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
> 
>  	/* remove all the devices from the device list */
>  	detach_device(NULL, dma_domain);
> @@ -413,23 +416,24 @@ static void fsl_pamu_domain_destroy(struct
> iommu_domain *domain)
>  	kmem_cache_free(fsl_pamu_domain_cache, dma_domain);  }
> 
> -static int fsl_pamu_domain_init(struct iommu_domain *domain)
> +static struct iommu_domain *fsl_pamu_domain_alloc(unsigned type)
>  {
>  	struct fsl_dma_domain *dma_domain;
> 
> +	if (type != IOMMU_DOMAIN_UNMANAGED)
> +		return NULL;
> +
>  	dma_domain = iommu_alloc_dma_domain();
>  	if (!dma_domain) {
>  		pr_debug("dma_domain allocation failed\n");
> -		return -ENOMEM;
> +		return NULL;
>  	}
> -	domain->priv = dma_domain;
> -	dma_domain->iommu_domain = domain;
>  	/* defaul geometry 64 GB i.e. maximum system address */
> -	domain->geometry.aperture_start = 0;
> -	domain->geometry.aperture_end = (1ULL << 36) - 1;
> -	domain->geometry.force_aperture = true;
> +	dma_domain->iommu_domain. geometry.aperture_start = 0;
> +	dma_domain->iommu_domain.geometry.aperture_end = (1ULL <<
> 36) - 1;
> +	dma_domain->iommu_domain.geometry.force_aperture = true;
> 
> -	return 0;
> +	return &dma_domain->iommu_domain;
>  }
> 
>  /* Configure geometry settings for all LIODNs associated with domain */
> @@ -499,7 +503,7 @@ static int disable_domain_win(struct fsl_dma_domain
> *dma_domain, u32 wnd_nr)
> 
>  static void fsl_pamu_window_disable(struct iommu_domain *domain, u32
> wnd_nr)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	unsigned long flags;
>  	int ret;
> 
> @@ -530,7 +534,7 @@ static void fsl_pamu_window_disable(struct
> iommu_domain *domain, u32 wnd_nr)  static int
> fsl_pamu_window_enable(struct iommu_domain *domain, u32 wnd_nr,
>  				  phys_addr_t paddr, u64 size, int prot)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	struct dma_window *wnd;
>  	int pamu_prot = 0;
>  	int ret;
> @@ -607,7 +611,7 @@ static int handle_attach_device(struct
> fsl_dma_domain *dma_domain,
>  				int num)
>  {
>  	unsigned long flags;
> -	struct iommu_domain *domain = dma_domain->iommu_domain;
> +	struct iommu_domain *domain = &dma_domain->iommu_domain;
>  	int ret = 0;
>  	int i;
> 
> @@ -653,7 +657,7 @@ static int handle_attach_device(struct
> fsl_dma_domain *dma_domain,  static int fsl_pamu_attach_device(struct
> iommu_domain *domain,
>  				  struct device *dev)
>  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	const u32 *liodn;
>  	u32 liodn_cnt;
>  	int len, ret = 0;
> @@ -691,7 +695,7 @@ static int fsl_pamu_attach_device(struct
> iommu_domain *domain,  static void fsl_pamu_detach_device(struct
> iommu_domain *domain,
>  				   struct device *dev)
>  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	const u32 *prop;
>  	int len;
>  	struct pci_dev *pdev = NULL;
> @@ -723,7 +727,7 @@ static void fsl_pamu_detach_device(struct
> iommu_domain *domain,  static  int configure_domain_geometry(struct
> iommu_domain *domain, void *data)  {
>  	struct iommu_domain_geometry *geom_attr = data;
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	dma_addr_t geom_size;
>  	unsigned long flags;
> 
> @@ -813,7 +817,7 @@ static int configure_domain_dma_state(struct
> fsl_dma_domain *dma_domain, bool en  static int
> fsl_pamu_set_domain_attr(struct iommu_domain *domain,
>  				    enum iommu_attr attr_type, void *data)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	int ret = 0;
> 
>  	switch (attr_type) {
> @@ -838,7 +842,7 @@ static int fsl_pamu_set_domain_attr(struct
> iommu_domain *domain,  static int fsl_pamu_get_domain_attr(struct
> iommu_domain *domain,
>  				    enum iommu_attr attr_type, void *data)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	int ret = 0;
> 
>  	switch (attr_type) {
> @@ -999,7 +1003,7 @@ static void fsl_pamu_remove_device(struct device
> *dev)
> 
>  static int fsl_pamu_set_windows(struct iommu_domain *domain, u32
> w_count)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
>  	unsigned long flags;
>  	int ret;
> 
> @@ -1048,15 +1052,15 @@ static int fsl_pamu_set_windows(struct
> iommu_domain *domain, u32 w_count)
> 
>  static u32 fsl_pamu_get_windows(struct iommu_domain *domain)  {
> -	struct fsl_dma_domain *dma_domain = domain->priv;
> +	struct fsl_dma_domain *dma_domain =
> to_fsl_dma_domain(domain);
> 
>  	return dma_domain->win_cnt;
>  }
> 
>  static const struct iommu_ops fsl_pamu_ops = {
>  	.capable	= fsl_pamu_capable,
> -	.domain_init	= fsl_pamu_domain_init,
> -	.domain_destroy = fsl_pamu_domain_destroy,
> +	.domain_alloc	= fsl_pamu_domain_alloc,
> +	.domain_free    = fsl_pamu_domain_free,
>  	.attach_dev	= fsl_pamu_attach_device,
>  	.detach_dev	= fsl_pamu_detach_device,
>  	.domain_window_enable = fsl_pamu_window_enable, diff --git
> a/drivers/iommu/fsl_pamu_domain.h b/drivers/iommu/fsl_pamu_domain.h
> index c90293f..f2b0f74 100644
> --- a/drivers/iommu/fsl_pamu_domain.h
> +++ b/drivers/iommu/fsl_pamu_domain.h
> @@ -71,7 +71,7 @@ struct fsl_dma_domain {
>  	u32				stash_id;
>  	struct pamu_stash_attribute	dma_stash;
>  	u32				snoop_id;
> -	struct iommu_domain		*iommu_domain;
> +	struct iommu_domain		iommu_domain;
>  	spinlock_t			domain_lock;
>  };
Acked-by: Varun Sethi <varun.sethi at freescale.com>



More information about the Linux-rockchip mailing list