Author: br
Date: Thu Aug  6 08:48:23 2020
New Revision: 363946
URL: https://svnweb.freebsd.org/changeset/base/363946

Log:
  Add iommu_domain constructor and destructor.
  
  Reviewed by:  kib
  Sponsored by: DARPA/AFRL
  Differential Revision:        https://reviews.freebsd.org/D25956

Modified:
  head/sys/dev/iommu/busdma_iommu.c
  head/sys/dev/iommu/iommu.h
  head/sys/x86/iommu/intel_ctx.c
  head/sys/x86/iommu/intel_dmar.h
  head/sys/x86/iommu/intel_idpgtbl.c

Modified: head/sys/dev/iommu/busdma_iommu.c
==============================================================================
--- head/sys/dev/iommu/busdma_iommu.c   Thu Aug  6 08:21:33 2020        
(r363945)
+++ head/sys/dev/iommu/busdma_iommu.c   Thu Aug  6 08:48:23 2020        
(r363946)
@@ -1063,3 +1063,23 @@ bus_dma_iommu_load_ident(bus_dma_tag_t dmat, bus_dmama
        free(ma, M_TEMP);
        return (error);
 }
+
+void
+iommu_domain_init(struct iommu_unit *unit, struct iommu_domain *domain,
+    const struct iommu_domain_map_ops *ops)
+{
+
+       domain->ops = ops;
+       domain->iommu = unit;
+
+       RB_INIT(&domain->rb_root);
+       TAILQ_INIT(&domain->unload_entries);
+       mtx_init(&domain->lock, "iodom", NULL, MTX_DEF);
+}
+
+void
+iommu_domain_fini(struct iommu_domain *domain)
+{
+
+       mtx_destroy(&domain->lock);
+}

Modified: head/sys/dev/iommu/iommu.h
==============================================================================
--- head/sys/dev/iommu/iommu.h  Thu Aug  6 08:21:33 2020        (r363945)
+++ head/sys/dev/iommu/iommu.h  Thu Aug  6 08:48:23 2020        (r363946)
@@ -223,6 +223,9 @@ int iommu_gas_reserve_region(struct iommu_domain *doma
 
 void iommu_set_buswide_ctx(struct iommu_unit *unit, u_int busno);
 bool iommu_is_buswide_ctx(struct iommu_unit *unit, u_int busno);
+void iommu_domain_init(struct iommu_unit *unit, struct iommu_domain *domain,
+    const struct iommu_domain_map_ops *ops);
+void iommu_domain_fini(struct iommu_domain *domain);
 
 bool bus_dma_iommu_set_buswide(device_t dev);
 int bus_dma_iommu_load_ident(bus_dma_tag_t dmat, bus_dmamap_t map,

Modified: head/sys/x86/iommu/intel_ctx.c
==============================================================================
--- head/sys/x86/iommu/intel_ctx.c      Thu Aug  6 08:21:33 2020        
(r363945)
+++ head/sys/x86/iommu/intel_ctx.c      Thu Aug  6 08:48:23 2020        
(r363946)
@@ -322,6 +322,7 @@ static struct dmar_domain *
 dmar_domain_alloc(struct dmar_unit *dmar, bool id_mapped)
 {
        struct iommu_domain *iodom;
+       struct iommu_unit *unit;
        struct dmar_domain *domain;
        int error, id, mgaw;
 
@@ -330,16 +331,14 @@ dmar_domain_alloc(struct dmar_unit *dmar, bool id_mapp
                return (NULL);
        domain = malloc(sizeof(*domain), M_DMAR_DOMAIN, M_WAITOK | M_ZERO);
        iodom = DOM2IODOM(domain);
+       unit = DMAR2IOMMU(dmar);
        domain->domain = id;
        LIST_INIT(&domain->contexts);
-       RB_INIT(&domain->iodom.rb_root);
-       TAILQ_INIT(&domain->iodom.unload_entries);
        TASK_INIT(&domain->iodom.unload_task, 0, dmar_domain_unload_task,
            domain);
-       mtx_init(&domain->iodom.lock, "dmardom", NULL, MTX_DEF);
+       iommu_domain_init(unit, iodom, &dmar_domain_map_ops);
+
        domain->dmar = dmar;
-       domain->iodom.iommu = &dmar->iommu;
-       domain_pgtbl_init(domain);
 
        /*
         * For now, use the maximal usable physical address of the
@@ -430,8 +429,11 @@ dmar_ctx_unlink(struct dmar_ctx *ctx)
 static void
 dmar_domain_destroy(struct dmar_domain *domain)
 {
+       struct iommu_domain *iodom;
        struct dmar_unit *dmar;
 
+       iodom = DOM2IODOM(domain);
+
        KASSERT(TAILQ_EMPTY(&domain->iodom.unload_entries),
            ("unfinished unloads %p", domain));
        KASSERT(LIST_EMPTY(&domain->contexts),
@@ -442,7 +444,7 @@ dmar_domain_destroy(struct dmar_domain *domain)
            ("destroying dom %p with refs %d", domain, domain->refs));
        if ((domain->iodom.flags & IOMMU_DOMAIN_GAS_INITED) != 0) {
                DMAR_DOMAIN_LOCK(domain);
-               iommu_gas_fini_domain(DOM2IODOM(domain));
+               iommu_gas_fini_domain(iodom);
                DMAR_DOMAIN_UNLOCK(domain);
        }
        if ((domain->iodom.flags & IOMMU_DOMAIN_PGTBL_INITED) != 0) {
@@ -450,7 +452,7 @@ dmar_domain_destroy(struct dmar_domain *domain)
                        DMAR_DOMAIN_PGLOCK(domain);
                domain_free_pgtbl(domain);
        }
-       mtx_destroy(&domain->iodom.lock);
+       iommu_domain_fini(iodom);
        dmar = DOM2DMAR(domain);
        free_unr(dmar->domids, domain->domain);
        free(domain, M_DMAR_DOMAIN);

Modified: head/sys/x86/iommu/intel_dmar.h
==============================================================================
--- head/sys/x86/iommu/intel_dmar.h     Thu Aug  6 08:21:33 2020        
(r363945)
+++ head/sys/x86/iommu/intel_dmar.h     Thu Aug  6 08:48:23 2020        
(r363946)
@@ -264,7 +264,7 @@ void domain_flush_iotlb_sync(struct dmar_domain *domai
     iommu_gaddr_t size);
 int domain_alloc_pgtbl(struct dmar_domain *domain);
 void domain_free_pgtbl(struct dmar_domain *domain);
-void domain_pgtbl_init(struct dmar_domain *domain);
+extern const struct iommu_domain_map_ops dmar_domain_map_ops;
 
 int dmar_dev_depth(device_t child);
 void dmar_dev_path(device_t child, int *busno, void *path1, int depth);

Modified: head/sys/x86/iommu/intel_idpgtbl.c
==============================================================================
--- head/sys/x86/iommu/intel_idpgtbl.c  Thu Aug  6 08:21:33 2020        
(r363945)
+++ head/sys/x86/iommu/intel_idpgtbl.c  Thu Aug  6 08:48:23 2020        
(r363946)
@@ -813,16 +813,7 @@ domain_flush_iotlb_sync(struct dmar_domain *domain, io
        DMAR_UNLOCK(unit);
 }
 
-static const struct iommu_domain_map_ops dmar_domain_map_ops = {
+const struct iommu_domain_map_ops dmar_domain_map_ops = {
        .map = domain_map_buf,
        .unmap = domain_unmap_buf,
 };
-
-void
-domain_pgtbl_init(struct dmar_domain *domain)
-{
-       struct iommu_domain *iodom;
-
-       iodom = DOM2IODOM(domain);
-       iodom->ops = &dmar_domain_map_ops;
-}
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to