1 // SPDX-License-Identifier: MIT 2 /* 3 * Copyright (C) 2013-2017 Oracle Corporation 4 * This file is based on ast_ttm.c 5 * Copyright 2012 Red Hat Inc. 6 * Authors: Dave Airlie <airlied@redhat.com> 7 * Michael Thayer <michael.thayer@oracle.com> 8 */ 9 #include <linux/pci.h> 10 #include <drm/drm_file.h> 11 #include "vbox_drv.h" 12 13 int vbox_mm_init(struct vbox_private *vbox) 14 { 15 struct drm_vram_mm *vmm; 16 int ret; 17 struct drm_device *dev = &vbox->ddev; 18 19 vmm = drm_vram_helper_alloc_mm(dev, pci_resource_start(dev->pdev, 0), 20 vbox->available_vram_size, 21 &drm_gem_vram_mm_funcs); 22 if (IS_ERR(vmm)) { 23 ret = PTR_ERR(vmm); 24 DRM_ERROR("Error initializing VRAM MM; %d\n", ret); 25 return ret; 26 } 27 28 #ifdef DRM_MTRR_WC 29 vbox->fb_mtrr = drm_mtrr_add(pci_resource_start(dev->pdev, 0), 30 pci_resource_len(dev->pdev, 0), 31 DRM_MTRR_WC); 32 #else 33 vbox->fb_mtrr = arch_phys_wc_add(pci_resource_start(dev->pdev, 0), 34 pci_resource_len(dev->pdev, 0)); 35 #endif 36 return 0; 37 } 38 39 void vbox_mm_fini(struct vbox_private *vbox) 40 { 41 #ifdef DRM_MTRR_WC 42 drm_mtrr_del(vbox->fb_mtrr, 43 pci_resource_start(vbox->ddev.pdev, 0), 44 pci_resource_len(vbox->ddev.pdev, 0), DRM_MTRR_WC); 45 #else 46 arch_phys_wc_del(vbox->fb_mtrr); 47 #endif 48 drm_vram_helper_release_mm(&vbox->ddev); 49 } 50