|
@@ -1,5 +1,5 @@
|
|
/*
|
|
/*
|
|
- * Copyright (c) 2018-2019, The Linux Foundation. All rights reserved.
|
|
|
|
|
|
+ * Copyright (c) 2018-2020, The Linux Foundation. All rights reserved.
|
|
* Copyright (C) 2013 Red Hat
|
|
* Copyright (C) 2013 Red Hat
|
|
* Author: Rob Clark <[email protected]>
|
|
* Author: Rob Clark <[email protected]>
|
|
*
|
|
*
|
|
@@ -416,9 +416,36 @@ static int msm_gem_get_iova_locked(struct drm_gem_object *obj,
|
|
|
|
|
|
if (!vma) {
|
|
if (!vma) {
|
|
struct page **pages;
|
|
struct page **pages;
|
|
|
|
+ struct device *dev;
|
|
|
|
+ struct dma_buf *dmabuf;
|
|
|
|
+ bool reattach = false;
|
|
|
|
+
|
|
|
|
+ dev = msm_gem_get_aspace_device(aspace);
|
|
|
|
+ if (dev && obj->import_attach &&
|
|
|
|
+ (dev != obj->import_attach->dev)) {
|
|
|
|
+ dmabuf = obj->import_attach->dmabuf;
|
|
|
|
+
|
|
|
|
+ DRM_DEBUG("detach nsec-dev:%pK attach sec-dev:%pK\n",
|
|
|
|
+ obj->import_attach->dev, dev);
|
|
|
|
+ SDE_EVT32(obj->import_attach->dev, dev, msm_obj->sgt);
|
|
|
|
+
|
|
|
|
+ if (msm_obj->sgt)
|
|
|
|
+ dma_buf_unmap_attachment(obj->import_attach,
|
|
|
|
+ msm_obj->sgt, DMA_BIDIRECTIONAL);
|
|
|
|
+ dma_buf_detach(dmabuf, obj->import_attach);
|
|
|
|
+
|
|
|
|
+ obj->import_attach = dma_buf_attach(dmabuf, dev);
|
|
|
|
+ if (IS_ERR(obj->import_attach)) {
|
|
|
|
+ DRM_ERROR("dma_buf_attach failure, err=%ld\n",
|
|
|
|
+ PTR_ERR(obj->import_attach));
|
|
|
|
+ goto unlock;
|
|
|
|
+ }
|
|
|
|
+ reattach = true;
|
|
|
|
+ }
|
|
|
|
|
|
/* perform delayed import for buffers without existing sgt */
|
|
/* perform delayed import for buffers without existing sgt */
|
|
- if (((msm_obj->flags & MSM_BO_EXTBUF) && !(msm_obj->sgt))) {
|
|
|
|
|
|
+ if (((msm_obj->flags & MSM_BO_EXTBUF) && !(msm_obj->sgt))
|
|
|
|
+ || reattach) {
|
|
ret = msm_gem_delayed_import(obj);
|
|
ret = msm_gem_delayed_import(obj);
|
|
if (ret) {
|
|
if (ret) {
|
|
DRM_ERROR("delayed dma-buf import failed %d\n",
|
|
DRM_ERROR("delayed dma-buf import failed %d\n",
|