struct nvkm_device *device = nvxx_device(&drm->client.device);
        struct nvkm_pci *pci = device->pci;
        struct drm_device *dev = drm->dev;
-       u8 bits;
        int ret;
 
        if (pci && pci->agp.bridge) {
                drm->agp.cma = pci->agp.cma;
        }
 
-       bits = nvxx_mmu(&drm->client.device)->dma_bits;
-       if (nvxx_device(&drm->client.device)->func->pci) {
-               if (drm->agp.bridge)
-                       bits = 32;
-       } else if (device->func->tegra) {
-               struct nvkm_device_tegra *tegra = device->func->tegra(device);
-
-               /*
-                * If the platform can use a IOMMU, then the addressable DMA
-                * space is constrained by the IOMMU bit
-                */
-               if (tegra->func->iommu_bit)
-                       bits = min(bits, tegra->func->iommu_bit);
-
-       }
-
-       ret = dma_set_mask(dev->dev, DMA_BIT_MASK(bits));
-       if (ret && bits != 32) {
-               bits = 32;
-               ret = dma_set_mask(dev->dev, DMA_BIT_MASK(bits));
-       }
-       if (ret)
-               return ret;
-
-       ret = dma_set_coherent_mask(dev->dev, DMA_BIT_MASK(bits));
-       if (ret)
-               dma_set_coherent_mask(dev->dev, DMA_BIT_MASK(32));
-
        ret = nouveau_ttm_global_init(drm);
        if (ret)
                return ret;
                                  &nouveau_bo_driver,
                                  dev->anon_inode->i_mapping,
                                  DRM_FILE_PAGE_OFFSET,
-                                 bits <= 32 ? true : false);
+                                 drm->client.mmu.dmabits <= 32 ? true : false);
        if (ret) {
                NV_ERROR(drm, "error initialising bo driver, %d\n", ret);
                return ret;
 
        const struct nvkm_device_pci_vendor *pciv;
        const char *name = NULL;
        struct nvkm_device_pci *pdev;
-       int ret;
+       int ret, bits;
 
        ret = pci_enable_device(pci_dev);
        if (ret)
        if (ret)
                return ret;
 
-       /*
-        * Set a preliminary DMA mask based on the .dma_bits member of the
-        * MMU subdevice. This allows other subdevices to create DMA mappings
-        * in their init() or oneinit() methods, which may be called before the
-        * TTM layer sets the DMA mask definitively.
-        * This is necessary for platforms where the default DMA mask of 32
-        * does not cover any system memory, i.e., when all RAM is > 4 GB.
-        */
-       if (pdev->device.mmu)
-               dma_set_mask_and_coherent(&pci_dev->dev,
-                               DMA_BIT_MASK(pdev->device.mmu->dma_bits));
+       /* Set DMA mask based on capabilities reported by the MMU subdev. */
+       if (pdev->device.mmu && !pdev->device.pci->agp.bridge)
+               bits = pdev->device.mmu->dma_bits;
+       else
+               bits = 32;
+
+       ret = dma_set_mask_and_coherent(&pci_dev->dev, DMA_BIT_MASK(bits));
+       if (ret && bits != 32) {
+               dma_set_mask_and_coherent(&pci_dev->dev, DMA_BIT_MASK(32));
+               pdev->device.mmu->dma_bits = 32;
+       }
 
        return 0;
 }