struct most_channel *c = mbo->context;
        u16 const coherent_buf_size = c->cfg.buffer_size + c->cfg.extra_len;
 
-       dma_free_coherent(NULL, coherent_buf_size, mbo->virt_address,
-                         mbo->bus_address);
+       if (c->iface->dma_free)
+               c->iface->dma_free(mbo, coherent_buf_size);
+       else
+               kfree(mbo->virt_address);
        kfree(mbo);
        if (atomic_sub_and_test(1, &c->mbo_ref))
                complete(&c->cleanup);
                mbo->context = c;
                mbo->ifp = c->iface;
                mbo->hdm_channel_id = c->channel_id;
-               mbo->virt_address = dma_alloc_coherent(NULL,
-                                                      coherent_buf_size,
-                                                      &mbo->bus_address,
-                                                      GFP_KERNEL);
+               if (c->iface->dma_alloc) {
+                       mbo->virt_address =
+                               c->iface->dma_alloc(mbo, coherent_buf_size);
+               } else {
+                       mbo->virt_address =
+                               kzalloc(coherent_buf_size, GFP_KERNEL);
+               }
                if (!mbo->virt_address)
                        goto release_mbo;
 
 
        const char *description;
        unsigned int num_channels;
        struct most_channel_capability *channel_vector;
+       void *(*dma_alloc)(struct mbo *mbo, u32 size);
+       void (*dma_free)(struct mbo *mbo, u32 size);
        int (*configure)(struct most_interface *iface, int channel_idx,
                         struct most_channel_config *channel_config);
        int (*enqueue)(struct most_interface *iface, int channel_idx,
 
        return ret;
 }
 
+static void *dma_alloc(struct mbo *mbo, u32 size)
+{
+       return dma_alloc_coherent(NULL, size, &mbo->bus_address, GFP_KERNEL);
+}
+
+static void dma_free(struct mbo *mbo, u32 size)
+{
+       dma_free_coherent(NULL, size, mbo->virt_address, mbo->bus_address);
+}
+
 /*
  * dim2_probe - dim2 probe handler
  * @pdev: platform device structure
        dev->most_iface.channel_vector = dev->capabilities;
        dev->most_iface.configure = configure_channel;
        dev->most_iface.enqueue = enqueue;
+       dev->most_iface.dma_alloc = dma_alloc;
+       dev->most_iface.dma_free = dma_free;
        dev->most_iface.poison_channel = poison_channel;
        dev->most_iface.request_netinfo = request_netinfo;
        dev->dev.init_name = "dim2_state";
 
        return retval;
 }
 
+static void *hdm_dma_alloc(struct mbo *mbo, u32 size)
+{
+       struct most_dev *mdev = to_mdev(mbo->ifp);
+
+       return usb_alloc_coherent(mdev->usb_device, size, GFP_KERNEL,
+                                 &mbo->bus_address);
+}
+
+static void hdm_dma_free(struct mbo *mbo, u32 size)
+{
+       struct most_dev *mdev = to_mdev(mbo->ifp);
+
+       usb_free_coherent(mdev->usb_device, size, mbo->virt_address,
+                         mbo->bus_address);
+}
+
 /**
  * hdm_configure_channel - receive channel configuration from core
  * @iface: interface
        mdev->iface.request_netinfo = hdm_request_netinfo;
        mdev->iface.enqueue = hdm_enqueue;
        mdev->iface.poison_channel = hdm_poison_channel;
+       mdev->iface.dma_alloc = hdm_dma_alloc;
+       mdev->iface.dma_free = hdm_dma_free;
        mdev->iface.description = mdev->description;
        mdev->iface.num_channels = num_endpoints;