Author: sephe
Date: Mon May 23 06:35:11 2016
New Revision: 300478
URL: https://svnweb.freebsd.org/changeset/base/300478

Log:
  hyperv: Add helpers for busdma(9) operation
  
  MFC after:    1 week
  Sponsored by: Microsoft OSTC
  Differential Revision:        https://reviews.freebsd.org/D6443

Added:
  head/sys/dev/hyperv/include/hyperv_busdma.h   (contents, props changed)
  head/sys/dev/hyperv/vmbus/hyperv_busdma.c   (contents, props changed)
Modified:
  head/sys/conf/files.amd64
  head/sys/conf/files.i386
  head/sys/modules/hyperv/vmbus/Makefile

Modified: head/sys/conf/files.amd64
==============================================================================
--- head/sys/conf/files.amd64   Mon May 23 06:13:35 2016        (r300477)
+++ head/sys/conf/files.amd64   Mon May 23 06:35:11 2016        (r300478)
@@ -277,6 +277,7 @@ dev/hyperv/vmbus/hv_hv.c                            
optional        hyp
 dev/hyperv/vmbus/hv_et.c                               optional        hyperv
 dev/hyperv/vmbus/hv_ring_buffer.c                      optional        hyperv
 dev/hyperv/vmbus/hv_vmbus_drv_freebsd.c                        optional        
hyperv
+dev/hyperv/vmbus/hyperv_busdma.c                       optional        hyperv
 dev/hyperv/vmbus/amd64/hv_vector.S                     optional        hyperv
 dev/nfe/if_nfe.c               optional        nfe pci
 dev/ntb/if_ntb/if_ntb.c                optional        if_ntb

Modified: head/sys/conf/files.i386
==============================================================================
--- head/sys/conf/files.i386    Mon May 23 06:13:35 2016        (r300477)
+++ head/sys/conf/files.i386    Mon May 23 06:35:11 2016        (r300478)
@@ -252,6 +252,7 @@ dev/hyperv/vmbus/hv_hv.c                            
optional        hyp
 dev/hyperv/vmbus/hv_et.c                               optional        hyperv
 dev/hyperv/vmbus/hv_ring_buffer.c                      optional        hyperv
 dev/hyperv/vmbus/hv_vmbus_drv_freebsd.c                        optional        
hyperv
+dev/hyperv/vmbus/hyperv_busdma.c                       optional        hyperv
 dev/hyperv/vmbus/i386/hv_vector.S                      optional        hyperv
 dev/ichwd/ichwd.c              optional ichwd
 dev/if_ndis/if_ndis.c          optional ndis

Added: head/sys/dev/hyperv/include/hyperv_busdma.h
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/sys/dev/hyperv/include/hyperv_busdma.h Mon May 23 06:35:11 2016        
(r300478)
@@ -0,0 +1,45 @@
+/*-
+ * Copyright (c) 2016 Microsoft Corp.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice unmodified, this list of conditions, and the following
+ *    disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * $FreeBSD$
+ */
+
+#ifndef _HYPERV_BUSDMA_H_
+#define _HYPERV_BUSDMA_H_
+
+struct hyperv_dma {
+       bus_addr_t      hv_paddr;
+       bus_dma_tag_t   hv_dtag;
+       bus_dmamap_t    hv_dmap;
+};
+
+void   hyperv_dma_map_paddr(void *arg, bus_dma_segment_t *segs, int nseg,
+           int error);
+void   *hyperv_dmamem_alloc(bus_dma_tag_t parent_dtag, bus_size_t alignment,
+           bus_addr_t boundary, bus_size_t size, struct hyperv_dma *dma,
+           int flags);
+void   hyperv_dmamem_free(struct hyperv_dma *dma, void *ptr);
+
+#endif /* !_HYPERV_BUSDMA_H_ */

Added: head/sys/dev/hyperv/vmbus/hyperv_busdma.c
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/sys/dev/hyperv/vmbus/hyperv_busdma.c   Mon May 23 06:35:11 2016        
(r300478)
@@ -0,0 +1,98 @@
+/*-
+ * Copyright (c) 2016 Microsoft Corp.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice unmodified, this list of conditions, and the following
+ *    disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#include <sys/param.h>
+#include <sys/systm.h>
+#include <sys/bus.h>
+
+#include <machine/bus.h>
+
+#include <dev/hyperv/include/hyperv_busdma.h>
+
+#define HYPERV_DMA_WAITMASK    (BUS_DMA_WAITOK | BUS_DMA_NOWAIT)
+
+void
+hyperv_dma_map_paddr(void *arg, bus_dma_segment_t *segs, int nseg, int error)
+{
+       bus_addr_t *paddr = arg;
+
+       if (error)
+               return;
+
+       KASSERT(nseg == 1, ("too many segments %d!", nseg));
+       *paddr = segs->ds_addr;
+}
+
+void *
+hyperv_dmamem_alloc(bus_dma_tag_t parent_dtag, bus_size_t alignment,
+    bus_addr_t boundary, bus_size_t size, struct hyperv_dma *dma, int flags)
+{
+       void *ret;
+       int error;
+
+       error = bus_dma_tag_create(parent_dtag, /* parent */
+           alignment,          /* alignment */
+           boundary,           /* boundary */
+           BUS_SPACE_MAXADDR,  /* lowaddr */
+           BUS_SPACE_MAXADDR,  /* highaddr */
+           NULL, NULL,         /* filter, filterarg */
+           size,               /* maxsize */
+           1,                  /* nsegments */
+           size,               /* maxsegsize */
+           0,                  /* flags */
+           NULL,               /* lockfunc */
+           NULL,               /* lockfuncarg */
+           &dma->hv_dtag);
+       if (error)
+               return NULL;
+
+       error = bus_dmamem_alloc(dma->hv_dtag, &ret,
+           (flags & HYPERV_DMA_WAITMASK) | BUS_DMA_COHERENT, &dma->hv_dmap);
+       if (error) {
+               bus_dma_tag_destroy(dma->hv_dtag);
+               return NULL;
+       }
+
+       error = bus_dmamap_load(dma->hv_dtag, dma->hv_dmap, ret, size,
+           hyperv_dma_map_paddr, &dma->hv_paddr, BUS_DMA_NOWAIT);
+       if (error) {
+               bus_dmamem_free(dma->hv_dtag, ret, dma->hv_dmap);
+               bus_dma_tag_destroy(dma->hv_dtag);
+               return NULL;
+       }
+       return ret;
+}
+
+void
+hyperv_dmamem_free(struct hyperv_dma *dma, void *ptr)
+{
+       bus_dmamap_unload(dma->hv_dtag, dma->hv_dmap);
+       bus_dmamem_free(dma->hv_dtag, ptr, dma->hv_dmap);
+       bus_dma_tag_destroy(dma->hv_dtag);
+}

Modified: head/sys/modules/hyperv/vmbus/Makefile
==============================================================================
--- head/sys/modules/hyperv/vmbus/Makefile      Mon May 23 06:13:35 2016        
(r300477)
+++ head/sys/modules/hyperv/vmbus/Makefile      Mon May 23 06:35:11 2016        
(r300478)
@@ -11,7 +11,8 @@ SRCS= hv_channel.c \
        hv_hv.c \
        hv_ring_buffer.c \
        hv_vmbus_drv_freebsd.c \
-       hv_vmbus_priv.h
+       hv_vmbus_priv.h \
+       hyperv_busdma.c
 SRCS+= acpi_if.h bus_if.h device_if.h opt_acpi.h
 
 # XXX: for assym.s
_______________________________________________
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