Blame view
include/drm/drm_file.h
10.7 KB
a8f8b1d9b
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
/* * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas. * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California. * Copyright (c) 2009-2010, Code Aurora Forum. * All rights reserved. * * Author: Rickard E. (Rik) Faith <faith@valinux.com> * Author: Gareth Hughes <gareth@valinux.com> * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice (including the next * paragraph) shall be included in all copies or substantial portions of the * Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. */ #ifndef _DRM_FILE_H_ #define _DRM_FILE_H_ #include <linux/types.h> #include <linux/completion.h> |
39e236748
|
35 |
#include <linux/idr.h> |
a8f8b1d9b
|
36 37 38 39 40 41 42 43 |
#include <uapi/drm/drm.h> #include <drm/drm_prime.h> struct dma_fence; struct drm_file; struct drm_device; |
3ed4351a8
|
44 |
struct device; |
a8f8b1d9b
|
45 46 47 48 49 |
/* * FIXME: Not sure we want to have drm_minor here in the end, but to avoid * header include loops we need it here for now. */ |
b93658f83
|
50 |
|
c9ac371d4
|
51 52 53 |
/* Note that the order of this enum is ABI (it determines * /dev/dri/renderD* numbers). */ |
a8f8b1d9b
|
54 55 |
enum drm_minor_type { DRM_MINOR_PRIMARY, |
c9ac371d4
|
56 |
DRM_MINOR_CONTROL, |
a8f8b1d9b
|
57 58 59 60 |
DRM_MINOR_RENDER, }; /** |
b93658f83
|
61 62 63 64 65 66 67 |
* struct drm_minor - DRM device minor structure * * This structure represents a DRM minor number for device nodes in /dev. * Entirely opaque to drivers and should never be inspected directly by drivers. * Drivers instead should only interact with &struct drm_file and of course * &struct drm_device, which is also where driver-private data and resources can * be attached to. |
a8f8b1d9b
|
68 69 |
*/ struct drm_minor { |
b93658f83
|
70 71 72 73 |
/* private: */ int index; /* Minor device number */ int type; /* Control or render */ struct device *kdev; /* Linux device */ |
a8f8b1d9b
|
74 75 76 77 78 79 80 |
struct drm_device *dev; struct dentry *debugfs_root; struct list_head debugfs_list; struct mutex debugfs_lock; /* Protects debugfs_list. */ }; |
b93658f83
|
81 82 83 84 85 86 87 |
/** * struct drm_pending_event - Event queued up for userspace to read * * This represents a DRM event. Drivers can use this as a generic completion * mechanism, which supports kernel-internal &struct completion, &struct dma_fence * and also the DRM-specific &struct drm_event delivery mechanism. */ |
a8f8b1d9b
|
88 |
struct drm_pending_event { |
b93658f83
|
89 90 91 92 93 94 95 |
/** * @completion: * * Optional pointer to a kernel internal completion signalled when * drm_send_event() is called, useful to internally synchronize with * nonblocking operations. */ |
a8f8b1d9b
|
96 |
struct completion *completion; |
b93658f83
|
97 98 99 100 101 102 103 104 |
/** * @completion_release: * * Optional callback currently only used by the atomic modeset helpers * to clean up the reference count for the structure @completion is * stored in. */ |
a8f8b1d9b
|
105 |
void (*completion_release)(struct completion *completion); |
b93658f83
|
106 107 108 109 110 111 112 113 114 |
/** * @event: * * Pointer to the actual event that should be sent to userspace to be * read using drm_read(). Can be optional, since nowadays events are * also used to signal kernel internal threads with @completion or DMA * transactions using @fence. */ |
a8f8b1d9b
|
115 |
struct drm_event *event; |
b93658f83
|
116 117 118 119 120 121 122 |
/** * @fence: * * Optional DMA fence to unblock other hardware transactions which * depend upon the nonblocking DRM operation this event represents. */ |
a8f8b1d9b
|
123 |
struct dma_fence *fence; |
b93658f83
|
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 |
/** * @file_priv: * * &struct drm_file where @event should be delivered to. Only set when * @event is set. */ struct drm_file *file_priv; /** * @link: * * Double-linked list to keep track of this event. Can be used by the * driver up to the point when it calls drm_send_event(), after that * this list entry is owned by the core for its own book-keeping. */ |
a8f8b1d9b
|
140 |
struct list_head link; |
b93658f83
|
141 142 143 144 145 146 147 148 |
/** * @pending_link: * * Entry on &drm_file.pending_event_list, to keep track of all pending * events for @file_priv, to allow correct unwinding of them when * userspace closes the file before the event is delivered. */ |
a8f8b1d9b
|
149 |
struct list_head pending_link; |
a8f8b1d9b
|
150 |
}; |
b93658f83
|
151 152 153 154 155 |
/** * struct drm_file - DRM file private data * * This structure tracks DRM state per open file descriptor. */ |
a8f8b1d9b
|
156 |
struct drm_file { |
b93658f83
|
157 158 159 160 161 162 163 164 165 |
/** * @authenticated: * * Whether the client is allowed to submit rendering, which for legacy * nodes means it must be authenticated. * * See also the :ref:`section on primary nodes and authentication * <drm_primary_node>`. */ |
078b7de41
|
166 |
bool authenticated; |
b93658f83
|
167 168 169 170 171 172 |
/** * @stereo_allowed: * * True when the client has asked us to expose stereo 3D mode flags. */ |
078b7de41
|
173 |
bool stereo_allowed; |
b93658f83
|
174 175 176 177 178 179 |
/** * @universal_planes: * * True if client understands CRTC primary planes and cursor planes * in the plane list. Automatically set when @atomic is set. |
a8f8b1d9b
|
180 |
*/ |
078b7de41
|
181 |
bool universal_planes; |
b93658f83
|
182 183 |
/** @atomic: True if client understands atomic properties. */ |
078b7de41
|
184 |
bool atomic; |
b93658f83
|
185 186 |
/** |
7595bda2f
|
187 188 189 190 191 |
* @aspect_ratio_allowed: * * True, if client can handle picture aspect ratios, and has requested * to pass this information along with the mode. */ |
078b7de41
|
192 |
bool aspect_ratio_allowed; |
7595bda2f
|
193 194 |
/** |
d67b6a206
|
195 196 197 198 |
* @writeback_connectors: * * True if client understands writeback connectors */ |
078b7de41
|
199 |
bool writeback_connectors; |
d67b6a206
|
200 201 |
/** |
b93658f83
|
202 203 204 205 206 207 208 |
* @is_master: * * This client is the creator of @master. Protected by struct * &drm_device.master_mutex. * * See also the :ref:`section on primary nodes and authentication * <drm_primary_node>`. |
a8f8b1d9b
|
209 |
*/ |
078b7de41
|
210 |
bool is_master; |
a8f8b1d9b
|
211 |
|
b93658f83
|
212 213 214 215 216 217 218 219 220 221 222 223 224 |
/** * @master: * * Master this node is currently associated with. Only relevant if * drm_is_primary_client() returns true. Note that this only * matches &drm_device.master if the master is the currently active one. * * See also @authentication and @is_master and the :ref:`section on * primary nodes and authentication <drm_primary_node>`. */ struct drm_master *master; /** @pid: Process that opened this file. */ |
a8f8b1d9b
|
225 |
struct pid *pid; |
b93658f83
|
226 227 |
/** @magic: Authentication magic, see @authenticated. */ |
a8f8b1d9b
|
228 |
drm_magic_t magic; |
b93658f83
|
229 230 231 232 233 234 235 |
/** * @lhead: * * List of all open files of a DRM device, linked into * &drm_device.filelist. Protected by &drm_device.filelist_mutex. */ |
a8f8b1d9b
|
236 |
struct list_head lhead; |
b93658f83
|
237 238 |
/** @minor: &struct drm_minor for this file. */ |
a8f8b1d9b
|
239 |
struct drm_minor *minor; |
a8f8b1d9b
|
240 |
|
b93658f83
|
241 242 243 244 245 246 |
/** * @object_idr: * * Mapping of mm object handles to object pointers. Used by the GEM * subsystem. Protected by @table_lock. */ |
a8f8b1d9b
|
247 |
struct idr object_idr; |
b93658f83
|
248 249 |
/** @table_lock: Protects @object_idr. */ |
a8f8b1d9b
|
250 |
spinlock_t table_lock; |
e9083420b
|
251 252 253 254 |
/** @syncobj_idr: Mapping of sync object handles to object pointers. */ struct idr syncobj_idr; /** @syncobj_table_lock: Protects @syncobj_idr. */ spinlock_t syncobj_table_lock; |
b93658f83
|
255 |
/** @filp: Pointer to the core file structure. */ |
a8f8b1d9b
|
256 |
struct file *filp; |
b93658f83
|
257 258 259 260 261 262 263 |
/** * @driver_priv: * * Optional pointer for driver private data. Can be allocated in * &drm_driver.open and should be freed in &drm_driver.postclose. */ |
a8f8b1d9b
|
264 |
void *driver_priv; |
a8f8b1d9b
|
265 |
/** |
b93658f83
|
266 267 268 269 |
* @fbs: * * List of &struct drm_framebuffer associated with this file, using the * &drm_framebuffer.filp_head entry. |
a8f8b1d9b
|
270 |
* |
b93658f83
|
271 272 |
* Protected by @fbs_lock. Note that the @fbs list holds a reference on * the framebuffer object to prevent it from untimely disappearing. |
a8f8b1d9b
|
273 274 |
*/ struct list_head fbs; |
b93658f83
|
275 276 |
/** @fbs_lock: Protects @fbs. */ |
a8f8b1d9b
|
277 |
struct mutex fbs_lock; |
b93658f83
|
278 279 280 281 282 283 284 285 |
/** * @blobs: * * User-created blob properties; this retains a reference on the * property. * * Protected by @drm_mode_config.blob_lock; */ |
a8f8b1d9b
|
286 |
struct list_head blobs; |
b93658f83
|
287 |
/** @event_wait: Waitqueue for new events added to @event_list. */ |
a8f8b1d9b
|
288 |
wait_queue_head_t event_wait; |
b93658f83
|
289 290 291 292 293 294 295 296 297 298 |
/** * @pending_event_list: * * List of pending &struct drm_pending_event, used to clean up pending * events in case this file gets closed before the event is signalled. * Uses the &drm_pending_event.pending_link entry. * * Protect by &drm_device.event_lock. */ |
a8f8b1d9b
|
299 |
struct list_head pending_event_list; |
b93658f83
|
300 301 302 303 304 305 306 307 308 |
/** * @event_list: * * List of &struct drm_pending_event, ready for delivery to userspace * through drm_read(). Uses the &drm_pending_event.link entry. * * Protect by &drm_device.event_lock. */ |
a8f8b1d9b
|
309 |
struct list_head event_list; |
b93658f83
|
310 311 312 313 314 315 316 317 |
/** * @event_space: * * Available event space to prevent userspace from * exhausting kernel memory. Currently limited to the fairly arbitrary * value of 4KB. */ |
a8f8b1d9b
|
318 |
int event_space; |
b93658f83
|
319 |
/** @event_read_lock: Serializes drm_read(). */ |
a8f8b1d9b
|
320 |
struct mutex event_read_lock; |
b93658f83
|
321 322 323 324 325 |
/** * @prime: * * Per-file buffer caches used by the PRIME buffer sharing code. */ |
a8f8b1d9b
|
326 |
struct drm_prime_file_private prime; |
b93658f83
|
327 328 |
/* private: */ |
ee22f7630
|
329 |
#if IS_ENABLED(CONFIG_DRM_LEGACY) |
b93658f83
|
330 |
unsigned long lock_count; /* DRI1 legacy lock count */ |
ee22f7630
|
331 |
#endif |
a8f8b1d9b
|
332 |
}; |
b93658f83
|
333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 |
/** * drm_is_primary_client - is this an open file of the primary node * @file_priv: DRM file * * Returns true if this is an open file of the primary node, i.e. * &drm_file.minor of @file_priv is a primary minor. * * See also the :ref:`section on primary nodes and authentication * <drm_primary_node>`. */ static inline bool drm_is_primary_client(const struct drm_file *file_priv) { return file_priv->minor->type == DRM_MINOR_PRIMARY; } /** * drm_is_render_client - is this an open file of the render node * @file_priv: DRM file * * Returns true if this is an open file of the render node, i.e. * &drm_file.minor of @file_priv is a render minor. * * See also the :ref:`section on render nodes <drm_render_node>`. */ |
a8f8b1d9b
|
357 358 359 360 |
static inline bool drm_is_render_client(const struct drm_file *file_priv) { return file_priv->minor->type == DRM_MINOR_RENDER; } |
a8f8b1d9b
|
361 362 363 364 |
int drm_open(struct inode *inode, struct file *filp); ssize_t drm_read(struct file *filp, char __user *buffer, size_t count, loff_t *offset); int drm_release(struct inode *inode, struct file *filp); |
afc9a42b7
|
365 |
__poll_t drm_poll(struct file *filp, struct poll_table_struct *wait); |
a8f8b1d9b
|
366 367 368 369 370 371 372 373 374 375 376 377 378 379 |
int drm_event_reserve_init_locked(struct drm_device *dev, struct drm_file *file_priv, struct drm_pending_event *p, struct drm_event *e); int drm_event_reserve_init(struct drm_device *dev, struct drm_file *file_priv, struct drm_pending_event *p, struct drm_event *e); void drm_event_cancel_free(struct drm_device *dev, struct drm_pending_event *p); void drm_send_event_locked(struct drm_device *dev, struct drm_pending_event *e); void drm_send_event(struct drm_device *dev, struct drm_pending_event *e); #endif /* _DRM_FILE_H_ */ |