/* * SPDX-License-Identifier: MIT * * Copyright © 2017 Intel Corporation */ #include #include #include "i915_drv.h" #include "i915_gemfs.h" #include "i915_utils.h" int i915_gemfs_init(struct drm_i915_private *i915) { char huge_opt[] = "huge=within_size"; /* r/w */ struct file_system_type *type; struct vfsmount *gemfs; char *opts; type = get_fs_type("tmpfs"); if (!type) return -ENODEV; /* * By creating our own shmemfs mountpoint, we can pass in * mount flags that better match our usecase. * * One example, although it is probably better with a per-file * control, is selecting huge page allocations ("huge=within_size"). * However, we only do so to offset the overhead of iommu lookups * due to bandwidth issues (slow reads) on Broadwell+. */ opts = NULL; if (i915_vtd_active(i915)) { if (IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE)) { opts = huge_opt; drm_info(&i915->drm, "Transparent Hugepage mode '%s'\n", opts); } else { drm_notice(&i915->drm, "Transparent Hugepage support is recommended for optimal performance when IOMMU is enabled!\n"); } } gemfs = vfs_kern_mount(type, SB_KERNMOUNT, type->name, opts); if (IS_ERR(gemfs)) return PTR_ERR(gemfs); i915->mm.gemfs = gemfs; return 0; } void i915_gemfs_fini(struct drm_i915_private *i915) { kern_unmount(i915->mm.gemfs); }