• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# SPDX-License-Identifier: GPL-2.0-only
2menu "DMABUF options"
3
4config SYNC_FILE
5	bool "Explicit Synchronization Framework"
6	default n
7	select DMA_SHARED_BUFFER
8	help
9	  The Sync File Framework adds explicit synchronization via
10	  userspace. It enables send/receive 'struct dma_fence' objects to/from
11	  userspace via Sync File fds for synchronization between drivers via
12	  userspace components. It has been ported from Android.
13
14	  The first and main user for this is graphics in which a fence is
15	  associated with a buffer. When a job is submitted to the GPU a fence
16	  is attached to the buffer and is transferred via userspace, using Sync
17	  Files fds, to the DRM driver for example. More details at
18	  Documentation/driver-api/sync_file.rst.
19
20config SW_SYNC
21	bool "Sync File Validation Framework"
22	default n
23	depends on SYNC_FILE
24	depends on DEBUG_FS
25	help
26	  A sync object driver that uses a 32bit counter to coordinate
27	  synchronization.  Useful when there is no hardware primitive backing
28	  the synchronization.
29
30	  WARNING: improper use of this can result in deadlocking kernel
31	  drivers from userspace. Intended for test and debug only.
32
33config UDMABUF
34	bool "userspace dmabuf misc driver"
35	default n
36	depends on DMA_SHARED_BUFFER
37	depends on MEMFD_CREATE || COMPILE_TEST
38	help
39	  A driver to let userspace turn memfd regions into dma-bufs.
40	  Qemu can use this to create host dmabufs for guest framebuffers.
41
42config DMABUF_MOVE_NOTIFY
43	bool "Move notify between drivers (EXPERIMENTAL)"
44	default n
45	depends on DMA_SHARED_BUFFER
46	help
47	  Don't pin buffers if the dynamic DMA-buf interface is available on
48	  both the exporter as well as the importer. This fixes a security
49	  problem where userspace is able to pin unrestricted amounts of memory
50	  through DMA-buf.
51	  This is marked experimental because we don't yet have a consistent
52	  execution context and memory management between drivers.
53
54config DMABUF_SELFTESTS
55	tristate "Selftests for the dma-buf interfaces"
56	default n
57	depends on DMA_SHARED_BUFFER
58
59config DMABUF_PROCESS_INFO
60	bool "Show dmabuf usage of all processes"
61	default n
62	depends on DMA_SHARED_BUFFER
63	depends on PROC_FS || DEBUG_FS
64	help
65	  Choose this option to show dmabuf objects usage of all processes.
66	  Firstly, with this option, when a process creates a dmabuf object,
67	  its pid and task_comm will be recorded in the dmabuf.
68	  Secondly, this option creates dma_buf/process_bufinfo file in
69	  debugfs (if DEBUG_FS enabled) and process_dmabuf_info file in procfs
70	  (if PROC_FS enabled) to show dmabuf objects usage of all processes.
71
72menuconfig DMABUF_HEAPS
73	bool "DMA-BUF Userland Memory Heaps"
74	select DMA_SHARED_BUFFER
75	help
76	  Choose this option to enable the DMA-BUF userland memory heaps.
77	  This options creates per heap chardevs in /dev/dma_heap/ which
78	  allows userspace to allocate dma-bufs that can be shared
79	  between drivers.
80
81menuconfig DMABUF_SYSFS_STATS
82	bool "DMA-BUF sysfs statistics"
83	depends on DMA_SHARED_BUFFER
84	help
85	   Choose this option to enable DMA-BUF sysfs statistics
86	   in location /sys/kernel/dmabuf/buffers.
87
88	   /sys/kernel/dmabuf/buffers/<inode_number> will contain
89	   statistics for the DMA-BUF with the unique inode number
90	   <inode_number>.
91
92source "drivers/dma-buf/heaps/Kconfig"
93
94endmenu
95