Revert "drm/vc4: Verify at boot that CMA doesn't cross a 256MB boundary."
authorEric Anholt <eric@anholt.net>
Thu, 30 Mar 2017 17:23:27 +0000 (10:23 -0700)
committerRaspbian kernel package updater <root@raspbian.org>
Sat, 31 Mar 2018 14:53:28 +0000 (15:53 +0100)
This reverts commit 016c804fa69381bd23a1a13cba08a3c4557fcdff.  The
restriction was lifted by the previous commit.

drivers/base/dma-contiguous.c
drivers/gpu/drm/vc4/vc4_v3d.c
mm/cma.c

index 60f5c2591ccdb0202461458eab4035cfba731b8b..e167a1e1bccb062efef2595fcd5299301a97df80 100644 (file)
@@ -35,7 +35,6 @@
 #endif
 
 struct cma *dma_contiguous_default_area;
-EXPORT_SYMBOL(dma_contiguous_default_area);
 
 /*
  * Default global CMA area size can be defined in kernel's .config.
index b2f6b7edf5d4b6fcdfb1d0cb0613514dee895791..550fcdc5733029e9eec57b722f83ad5958bbc286 100644 (file)
  * this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
-#include "linux/init.h"
-#include "linux/cma.h"
 #include "linux/component.h"
-#include "linux/dma-contiguous.h"
 #include "linux/pm_runtime.h"
 #include "vc4_drv.h"
 #include "vc4_regs.h"
@@ -337,23 +334,8 @@ static int vc4_v3d_bind(struct device *dev, struct device *master, void *data)
        struct drm_device *drm = dev_get_drvdata(master);
        struct vc4_dev *vc4 = to_vc4_dev(drm);
        struct vc4_v3d *v3d = NULL;
-       struct cma *cma;
        int ret;
 
-       cma = dev_get_cma_area(dev);
-       if (!cma)
-               return -EINVAL;
-
-       if ((cma_get_base(cma) & 0xf0000000) !=
-           ((cma_get_base(cma) + cma_get_size(cma) - 1) & 0xf0000000)) {
-               DRM_ERROR("V3D requires that the CMA area (0x%08lx - 0x%08lx) "
-                         "not span a 256MB boundary, or memory corruption "
-                         "would happen.\n",
-                         (long)cma_get_base(cma),
-                         cma_get_base(cma) + cma_get_size(cma));
-               return -EINVAL;
-       }
-
        v3d = devm_kzalloc(&pdev->dev, sizeof(*v3d), GFP_KERNEL);
        if (!v3d)
                return -ENOMEM;
index 6a242bd373f24fc5b79c22a11ade48b9139d6dc6..397687fc51f97467901a807b08a5cc5ecc1addea 100644 (file)
--- a/mm/cma.c
+++ b/mm/cma.c
@@ -47,13 +47,11 @@ phys_addr_t cma_get_base(const struct cma *cma)
 {
        return PFN_PHYS(cma->base_pfn);
 }
-EXPORT_SYMBOL(cma_get_base);
 
 unsigned long cma_get_size(const struct cma *cma)
 {
        return cma->count << PAGE_SHIFT;
 }
-EXPORT_SYMBOL(cma_get_size);
 
 static unsigned long cma_bitmap_aligned_mask(const struct cma *cma,
                                             unsigned int align_order)