aboutsummaryrefslogtreecommitdiffstats
path: root/include/drm/drmP.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/drm/drmP.h')
-rw-r--r--include/drm/drmP.h780
1 files changed, 83 insertions, 697 deletions
diff --git a/include/drm/drmP.h b/include/drm/drmP.h
index e41f17ea1f13..53ed87698a74 100644
--- a/include/drm/drmP.h
+++ b/include/drm/drmP.h
@@ -1,17 +1,14 @@
1/**
2 * \file drmP.h
3 * Private header for Direct Rendering Manager
4 *
5 * \author Rickard E. (Rik) Faith <faith@valinux.com>
6 * \author Gareth Hughes <gareth@valinux.com>
7 */
8
9/* 1/*
2 * Internal Header for the Direct Rendering Manager
3 *
10 * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas. 4 * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
11 * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California. 5 * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
12 * Copyright (c) 2009-2010, Code Aurora Forum. 6 * Copyright (c) 2009-2010, Code Aurora Forum.
13 * All rights reserved. 7 * All rights reserved.
14 * 8 *
9 * Author: Rickard E. (Rik) Faith <faith@valinux.com>
10 * Author: Gareth Hughes <gareth@valinux.com>
11 *
15 * Permission is hereby granted, free of charge, to any person obtaining a 12 * Permission is hereby granted, free of charge, to any person obtaining a
16 * copy of this software and associated documentation files (the "Software"), 13 * copy of this software and associated documentation files (the "Software"),
17 * to deal in the Software without restriction, including without limitation 14 * to deal in the Software without restriction, including without limitation
@@ -35,59 +32,62 @@
35#ifndef _DRM_P_H_ 32#ifndef _DRM_P_H_
36#define _DRM_P_H_ 33#define _DRM_P_H_
37 34
38#ifdef __KERNEL__ 35#include <linux/agp_backend.h>
39#ifdef __alpha__ 36#include <linux/cdev.h>
40/* add include of current.h so that "current" is defined 37#include <linux/dma-mapping.h>
41 * before static inline funcs in wait.h. Doing this so we 38#include <linux/file.h>
42 * can build the DRM (part of PI DRI). 4/21/2000 S + B */
43#include <asm/current.h>
44#endif /* __alpha__ */
45#include <linux/kernel.h>
46#include <linux/kref.h>
47#include <linux/miscdevice.h>
48#include <linux/fs.h> 39#include <linux/fs.h>
40#include <linux/highmem.h>
41#include <linux/idr.h>
49#include <linux/init.h> 42#include <linux/init.h>
50#include <linux/file.h> 43#include <linux/io.h>
51#include <linux/platform_device.h>
52#include <linux/pci.h>
53#include <linux/jiffies.h> 44#include <linux/jiffies.h>
54#include <linux/dma-mapping.h> 45#include <linux/kernel.h>
46#include <linux/kref.h>
47#include <linux/miscdevice.h>
55#include <linux/mm.h> 48#include <linux/mm.h>
56#include <linux/cdev.h>
57#include <linux/mutex.h> 49#include <linux/mutex.h>
58#include <linux/io.h> 50#include <linux/pci.h>
59#include <linux/slab.h> 51#include <linux/platform_device.h>
52#include <linux/poll.h>
60#include <linux/ratelimit.h> 53#include <linux/ratelimit.h>
61#if defined(__alpha__) || defined(__powerpc__) 54#include <linux/sched.h>
62#include <asm/pgtable.h> /* For pte_wrprotect */ 55#include <linux/slab.h>
63#endif
64#include <asm/mman.h>
65#include <asm/uaccess.h>
66#include <linux/types.h> 56#include <linux/types.h>
67#include <linux/agp_backend.h> 57#include <linux/vmalloc.h>
68#include <linux/workqueue.h> 58#include <linux/workqueue.h>
69#include <linux/poll.h> 59
60#include <asm/mman.h>
70#include <asm/pgalloc.h> 61#include <asm/pgalloc.h>
71#include <drm/drm.h> 62#include <asm/uaccess.h>
72#include <drm/drm_sarea.h>
73#include <drm/drm_vma_manager.h>
74 63
75#include <linux/idr.h> 64#include <uapi/drm/drm.h>
65#include <uapi/drm/drm_mode.h>
76 66
77#define __OS_HAS_AGP (defined(CONFIG_AGP) || (defined(CONFIG_AGP_MODULE) && defined(MODULE))) 67#include <drm/drm_agpsupport.h>
68#include <drm/drm_crtc.h>
69#include <drm/drm_global.h>
70#include <drm/drm_hashtab.h>
71#include <drm/drm_mem_util.h>
72#include <drm/drm_mm.h>
73#include <drm/drm_os_linux.h>
74#include <drm/drm_sarea.h>
75#include <drm/drm_vma_manager.h>
78 76
79struct module; 77struct module;
80 78
81struct drm_file; 79struct drm_file;
82struct drm_device; 80struct drm_device;
81struct drm_agp_head;
82struct drm_local_map;
83struct drm_device_dma;
84struct drm_dma_handle;
85struct drm_gem_object;
83 86
84struct device_node; 87struct device_node;
85struct videomode; 88struct videomode;
86struct reservation_object; 89struct reservation_object;
87 90struct dma_buf_attachment;
88#include <drm/drm_os_linux.h>
89#include <drm/drm_hashtab.h>
90#include <drm/drm_mm.h>
91 91
92/* 92/*
93 * 4 debug categories are defined: 93 * 4 debug categories are defined:
@@ -126,7 +126,7 @@ extern __printf(2, 3)
126void drm_ut_debug_printk(const char *function_name, 126void drm_ut_debug_printk(const char *function_name,
127 const char *format, ...); 127 const char *format, ...);
128extern __printf(2, 3) 128extern __printf(2, 3)
129int drm_err(const char *func, const char *format, ...); 129void drm_err(const char *func, const char *format, ...);
130 130
131/***********************************************************************/ 131/***********************************************************************/
132/** \name DRM template customization defaults */ 132/** \name DRM template customization defaults */
@@ -145,21 +145,6 @@ int drm_err(const char *func, const char *format, ...);
145#define DRIVER_RENDER 0x8000 145#define DRIVER_RENDER 0x8000
146 146
147/***********************************************************************/ 147/***********************************************************************/
148/** \name Begin the DRM... */
149/*@{*/
150
151#define DRM_DEBUG_CODE 2 /**< Include debugging code if > 1, then
152 also include looping detection. */
153
154#define DRM_MAGIC_HASH_ORDER 4 /**< Size of key hash table. Must be power of 2. */
155#define DRM_KERNEL_CONTEXT 0 /**< Change drm_resctx if changed */
156#define DRM_RESERVED_CONTEXTS 1 /**< Change drm_resctx if changed */
157
158#define DRM_MAP_HASH_OFFSET 0x10000000
159
160/*@}*/
161
162/***********************************************************************/
163/** \name Macros to make printk easier */ 148/** \name Macros to make printk easier */
164/*@{*/ 149/*@{*/
165 150
@@ -200,7 +185,6 @@ int drm_err(const char *func, const char *format, ...);
200 * \param fmt printf() like format string. 185 * \param fmt printf() like format string.
201 * \param arg arguments 186 * \param arg arguments
202 */ 187 */
203#if DRM_DEBUG_CODE
204#define DRM_DEBUG(fmt, args...) \ 188#define DRM_DEBUG(fmt, args...) \
205 do { \ 189 do { \
206 if (unlikely(drm_debug & DRM_UT_CORE)) \ 190 if (unlikely(drm_debug & DRM_UT_CORE)) \
@@ -222,12 +206,6 @@ int drm_err(const char *func, const char *format, ...);
222 if (unlikely(drm_debug & DRM_UT_PRIME)) \ 206 if (unlikely(drm_debug & DRM_UT_PRIME)) \
223 drm_ut_debug_printk(__func__, fmt, ##args); \ 207 drm_ut_debug_printk(__func__, fmt, ##args); \
224 } while (0) 208 } while (0)
225#else
226#define DRM_DEBUG_DRIVER(fmt, args...) do { } while (0)
227#define DRM_DEBUG_KMS(fmt, args...) do { } while (0)
228#define DRM_DEBUG_PRIME(fmt, args...) do { } while (0)
229#define DRM_DEBUG(fmt, arg...) do { } while (0)
230#endif
231 209
232/*@}*/ 210/*@}*/
233 211
@@ -238,23 +216,6 @@ int drm_err(const char *func, const char *format, ...);
238#define DRM_IF_VERSION(maj, min) (maj << 16 | min) 216#define DRM_IF_VERSION(maj, min) (maj << 16 | min)
239 217
240/** 218/**
241 * Test that the hardware lock is held by the caller, returning otherwise.
242 *
243 * \param dev DRM device.
244 * \param filp file pointer of the caller.
245 */
246#define LOCK_TEST_WITH_RETURN( dev, _file_priv ) \
247do { \
248 if (!_DRM_LOCK_IS_HELD(_file_priv->master->lock.hw_lock->lock) || \
249 _file_priv->master->lock.file_priv != _file_priv) { \
250 DRM_ERROR( "%s called without lock held, held %d owner %p %p\n",\
251 __func__, _DRM_LOCK_IS_HELD(_file_priv->master->lock.hw_lock->lock),\
252 _file_priv->master->lock.file_priv, _file_priv); \
253 return -EINVAL; \
254 } \
255} while (0)
256
257/**
258 * Ioctl function type. 219 * Ioctl function type.
259 * 220 *
260 * \param inode device inode. 221 * \param inode device inode.
@@ -294,91 +255,6 @@ struct drm_ioctl_desc {
294#define DRM_IOCTL_DEF_DRV(ioctl, _func, _flags) \ 255#define DRM_IOCTL_DEF_DRV(ioctl, _func, _flags) \
295 [DRM_IOCTL_NR(DRM_##ioctl)] = {.cmd = DRM_##ioctl, .func = _func, .flags = _flags, .cmd_drv = DRM_IOCTL_##ioctl, .name = #ioctl} 256 [DRM_IOCTL_NR(DRM_##ioctl)] = {.cmd = DRM_##ioctl, .func = _func, .flags = _flags, .cmd_drv = DRM_IOCTL_##ioctl, .name = #ioctl}
296 257
297struct drm_magic_entry {
298 struct list_head head;
299 struct drm_hash_item hash_item;
300 struct drm_file *priv;
301};
302
303struct drm_vma_entry {
304 struct list_head head;
305 struct vm_area_struct *vma;
306 pid_t pid;
307};
308
309/**
310 * DMA buffer.
311 */
312struct drm_buf {
313 int idx; /**< Index into master buflist */
314 int total; /**< Buffer size */
315 int order; /**< log-base-2(total) */
316 int used; /**< Amount of buffer in use (for DMA) */
317 unsigned long offset; /**< Byte offset (used internally) */
318 void *address; /**< Address of buffer */
319 unsigned long bus_address; /**< Bus address of buffer */
320 struct drm_buf *next; /**< Kernel-only: used for free list */
321 __volatile__ int waiting; /**< On kernel DMA queue */
322 __volatile__ int pending; /**< On hardware DMA queue */
323 struct drm_file *file_priv; /**< Private of holding file descr */
324 int context; /**< Kernel queue for this buffer */
325 int while_locked; /**< Dispatch this buffer while locked */
326 enum {
327 DRM_LIST_NONE = 0,
328 DRM_LIST_FREE = 1,
329 DRM_LIST_WAIT = 2,
330 DRM_LIST_PEND = 3,
331 DRM_LIST_PRIO = 4,
332 DRM_LIST_RECLAIM = 5
333 } list; /**< Which list we're on */
334
335 int dev_priv_size; /**< Size of buffer private storage */
336 void *dev_private; /**< Per-buffer private storage */
337};
338
339/** bufs is one longer than it has to be */
340struct drm_waitlist {
341 int count; /**< Number of possible buffers */
342 struct drm_buf **bufs; /**< List of pointers to buffers */
343 struct drm_buf **rp; /**< Read pointer */
344 struct drm_buf **wp; /**< Write pointer */
345 struct drm_buf **end; /**< End pointer */
346 spinlock_t read_lock;
347 spinlock_t write_lock;
348};
349
350struct drm_freelist {
351 int initialized; /**< Freelist in use */
352 atomic_t count; /**< Number of free buffers */
353 struct drm_buf *next; /**< End pointer */
354
355 wait_queue_head_t waiting; /**< Processes waiting on free bufs */
356 int low_mark; /**< Low water mark */
357 int high_mark; /**< High water mark */
358 atomic_t wfh; /**< If waiting for high mark */
359 spinlock_t lock;
360};
361
362typedef struct drm_dma_handle {
363 dma_addr_t busaddr;
364 void *vaddr;
365 size_t size;
366} drm_dma_handle_t;
367
368/**
369 * Buffer entry. There is one of this for each buffer size order.
370 */
371struct drm_buf_entry {
372 int buf_size; /**< size */
373 int buf_count; /**< number of buffers */
374 struct drm_buf *buflist; /**< buffer list */
375 int seg_count;
376 int page_order;
377 struct drm_dma_handle **seglist;
378
379 struct drm_freelist freelist;
380};
381
382/* Event queued up for userspace to read */ 258/* Event queued up for userspace to read */
383struct drm_pending_event { 259struct drm_pending_event {
384 struct drm_event *event; 260 struct drm_event *event;
@@ -397,7 +273,6 @@ struct drm_prime_file_private {
397 273
398/** File private data */ 274/** File private data */
399struct drm_file { 275struct drm_file {
400 unsigned always_authenticated :1;
401 unsigned authenticated :1; 276 unsigned authenticated :1;
402 /* Whether we're master for a minor. Protected by master_mutex */ 277 /* Whether we're master for a minor. Protected by master_mutex */
403 unsigned is_master :1; 278 unsigned is_master :1;
@@ -442,23 +317,6 @@ struct drm_file {
442 struct drm_prime_file_private prime; 317 struct drm_prime_file_private prime;
443}; 318};
444 319
445/** Wait queue */
446struct drm_queue {
447 atomic_t use_count; /**< Outstanding uses (+1) */
448 atomic_t finalization; /**< Finalization in progress */
449 atomic_t block_count; /**< Count of processes waiting */
450 atomic_t block_read; /**< Queue blocked for reads */
451 wait_queue_head_t read_queue; /**< Processes waiting on block_read */
452 atomic_t block_write; /**< Queue blocked for writes */
453 wait_queue_head_t write_queue; /**< Processes waiting on block_write */
454 atomic_t total_queued; /**< Total queued statistic */
455 atomic_t total_flushed; /**< Total flushes statistic */
456 atomic_t total_locks; /**< Total locks statistics */
457 enum drm_ctx_flags flags; /**< Context preserving and 2D-only */
458 struct drm_waitlist waitlist; /**< Pending buffers */
459 wait_queue_head_t flush_queue; /**< Processes waiting until flush */
460};
461
462/** 320/**
463 * Lock data. 321 * Lock data.
464 */ 322 */
@@ -475,223 +333,12 @@ struct drm_lock_data {
475}; 333};
476 334
477/** 335/**
478 * DMA data.
479 */
480struct drm_device_dma {
481
482 struct drm_buf_entry bufs[DRM_MAX_ORDER + 1]; /**< buffers, grouped by their size order */
483 int buf_count; /**< total number of buffers */
484 struct drm_buf **buflist; /**< Vector of pointers into drm_device_dma::bufs */
485 int seg_count;
486 int page_count; /**< number of pages */
487 unsigned long *pagelist; /**< page list */
488 unsigned long byte_count;
489 enum {
490 _DRM_DMA_USE_AGP = 0x01,
491 _DRM_DMA_USE_SG = 0x02,
492 _DRM_DMA_USE_FB = 0x04,
493 _DRM_DMA_USE_PCI_RO = 0x08
494 } flags;
495
496};
497
498/**
499 * AGP memory entry. Stored as a doubly linked list.
500 */
501struct drm_agp_mem {
502 unsigned long handle; /**< handle */
503 struct agp_memory *memory;
504 unsigned long bound; /**< address */
505 int pages;
506 struct list_head head;
507};
508
509/**
510 * AGP data.
511 *
512 * \sa drm_agp_init() and drm_device::agp.
513 */
514struct drm_agp_head {
515 struct agp_kern_info agp_info; /**< AGP device information */
516 struct list_head memory;
517 unsigned long mode; /**< AGP mode */
518 struct agp_bridge_data *bridge;
519 int enabled; /**< whether the AGP bus as been enabled */
520 int acquired; /**< whether the AGP device has been acquired */
521 unsigned long base;
522 int agp_mtrr;
523 int cant_use_aperture;
524 unsigned long page_mask;
525};
526
527/**
528 * Scatter-gather memory.
529 */
530struct drm_sg_mem {
531 unsigned long handle;
532 void *virtual;
533 int pages;
534 struct page **pagelist;
535 dma_addr_t *busaddr;
536};
537
538struct drm_sigdata {
539 int context;
540 struct drm_hw_lock *lock;
541};
542
543
544/**
545 * Kernel side of a mapping
546 */
547struct drm_local_map {
548 resource_size_t offset; /**< Requested physical address (0 for SAREA)*/
549 unsigned long size; /**< Requested physical size (bytes) */
550 enum drm_map_type type; /**< Type of memory to map */
551 enum drm_map_flags flags; /**< Flags */
552 void *handle; /**< User-space: "Handle" to pass to mmap() */
553 /**< Kernel-space: kernel-virtual address */
554 int mtrr; /**< MTRR slot used */
555};
556
557typedef struct drm_local_map drm_local_map_t;
558
559/**
560 * Mappings list
561 */
562struct drm_map_list {
563 struct list_head head; /**< list head */
564 struct drm_hash_item hash;
565 struct drm_local_map *map; /**< mapping */
566 uint64_t user_token;
567 struct drm_master *master;
568};
569
570/**
571 * Context handle list
572 */
573struct drm_ctx_list {
574 struct list_head head; /**< list head */
575 drm_context_t handle; /**< context handle */
576 struct drm_file *tag; /**< associated fd private data */
577};
578
579/* location of GART table */
580#define DRM_ATI_GART_MAIN 1
581#define DRM_ATI_GART_FB 2
582
583#define DRM_ATI_GART_PCI 1
584#define DRM_ATI_GART_PCIE 2
585#define DRM_ATI_GART_IGP 3
586
587struct drm_ati_pcigart_info {
588 int gart_table_location;
589 int gart_reg_if;
590 void *addr;
591 dma_addr_t bus_addr;
592 dma_addr_t table_mask;
593 struct drm_dma_handle *table_handle;
594 struct drm_local_map mapping;
595 int table_size;
596};
597
598/**
599 * This structure defines the drm_mm memory object, which will be used by the
600 * DRM for its buffer objects.
601 */
602struct drm_gem_object {
603 /** Reference count of this object */
604 struct kref refcount;
605
606 /**
607 * handle_count - gem file_priv handle count of this object
608 *
609 * Each handle also holds a reference. Note that when the handle_count
610 * drops to 0 any global names (e.g. the id in the flink namespace) will
611 * be cleared.
612 *
613 * Protected by dev->object_name_lock.
614 * */
615 unsigned handle_count;
616
617 /** Related drm device */
618 struct drm_device *dev;
619
620 /** File representing the shmem storage */
621 struct file *filp;
622
623 /* Mapping info for this object */
624 struct drm_vma_offset_node vma_node;
625
626 /**
627 * Size of the object, in bytes. Immutable over the object's
628 * lifetime.
629 */
630 size_t size;
631
632 /**
633 * Global name for this object, starts at 1. 0 means unnamed.
634 * Access is covered by the object_name_lock in the related drm_device
635 */
636 int name;
637
638 /**
639 * Memory domains. These monitor which caches contain read/write data
640 * related to the object. When transitioning from one set of domains
641 * to another, the driver is called to ensure that caches are suitably
642 * flushed and invalidated
643 */
644 uint32_t read_domains;
645 uint32_t write_domain;
646
647 /**
648 * While validating an exec operation, the
649 * new read/write domain values are computed here.
650 * They will be transferred to the above values
651 * at the point that any cache flushing occurs
652 */
653 uint32_t pending_read_domains;
654 uint32_t pending_write_domain;
655
656 /**
657 * dma_buf - dma buf associated with this GEM object
658 *
659 * Pointer to the dma-buf associated with this gem object (either
660 * through importing or exporting). We break the resulting reference
661 * loop when the last gem handle for this object is released.
662 *
663 * Protected by obj->object_name_lock
664 */
665 struct dma_buf *dma_buf;
666
667 /**
668 * import_attach - dma buf attachment backing this object
669 *
670 * Any foreign dma_buf imported as a gem object has this set to the
671 * attachment point for the device. This is invariant over the lifetime
672 * of a gem object.
673 *
674 * The driver's ->gem_free_object callback is responsible for cleaning
675 * up the dma_buf attachment and references acquired at import time.
676 *
677 * Note that the drm gem/prime core does not depend upon drivers setting
678 * this field any more. So for drivers where this doesn't make sense
679 * (e.g. virtual devices or a displaylink behind an usb bus) they can
680 * simply leave it as NULL.
681 */
682 struct dma_buf_attachment *import_attach;
683};
684
685#include <drm/drm_crtc.h>
686
687/**
688 * struct drm_master - drm master structure 336 * struct drm_master - drm master structure
689 * 337 *
690 * @refcount: Refcount for this master object. 338 * @refcount: Refcount for this master object.
691 * @minor: Link back to minor char device we are master for. Immutable. 339 * @minor: Link back to minor char device we are master for. Immutable.
692 * @unique: Unique identifier: e.g. busid. Protected by drm_global_mutex. 340 * @unique: Unique identifier: e.g. busid. Protected by drm_global_mutex.
693 * @unique_len: Length of unique field. Protected by drm_global_mutex. 341 * @unique_len: Length of unique field. Protected by drm_global_mutex.
694 * @unique_size: Amount allocated. Protected by drm_global_mutex.
695 * @magiclist: Hash of used authentication tokens. Protected by struct_mutex. 342 * @magiclist: Hash of used authentication tokens. Protected by struct_mutex.
696 * @magicfree: List of used authentication tokens. Protected by struct_mutex. 343 * @magicfree: List of used authentication tokens. Protected by struct_mutex.
697 * @lock: DRI lock information. 344 * @lock: DRI lock information.
@@ -702,7 +349,6 @@ struct drm_master {
702 struct drm_minor *minor; 349 struct drm_minor *minor;
703 char *unique; 350 char *unique;
704 int unique_len; 351 int unique_len;
705 int unique_size;
706 struct drm_open_hash magiclist; 352 struct drm_open_hash magiclist;
707 struct list_head magicfree; 353 struct list_head magicfree;
708 struct drm_lock_data lock; 354 struct drm_lock_data lock;
@@ -717,17 +363,13 @@ struct drm_master {
717/* Flags and return codes for get_vblank_timestamp() driver function. */ 363/* Flags and return codes for get_vblank_timestamp() driver function. */
718#define DRM_CALLED_FROM_VBLIRQ 1 364#define DRM_CALLED_FROM_VBLIRQ 1
719#define DRM_VBLANKTIME_SCANOUTPOS_METHOD (1 << 0) 365#define DRM_VBLANKTIME_SCANOUTPOS_METHOD (1 << 0)
720#define DRM_VBLANKTIME_INVBL (1 << 1) 366#define DRM_VBLANKTIME_IN_VBLANK (1 << 1)
721 367
722/* get_scanout_position() return flags */ 368/* get_scanout_position() return flags */
723#define DRM_SCANOUTPOS_VALID (1 << 0) 369#define DRM_SCANOUTPOS_VALID (1 << 0)
724#define DRM_SCANOUTPOS_INVBL (1 << 1) 370#define DRM_SCANOUTPOS_IN_VBLANK (1 << 1)
725#define DRM_SCANOUTPOS_ACCURATE (1 << 2) 371#define DRM_SCANOUTPOS_ACCURATE (1 << 2)
726 372
727struct drm_bus {
728 int (*set_busid)(struct drm_device *dev, struct drm_master *master);
729};
730
731/** 373/**
732 * DRM driver structure. This structure represent the common code for 374 * DRM driver structure. This structure represent the common code for
733 * a family of cards. There will one drm_device for each card present 375 * a family of cards. There will one drm_device for each card present
@@ -746,6 +388,7 @@ struct drm_driver {
746 int (*dma_ioctl) (struct drm_device *dev, void *data, struct drm_file *file_priv); 388 int (*dma_ioctl) (struct drm_device *dev, void *data, struct drm_file *file_priv);
747 int (*dma_quiescent) (struct drm_device *); 389 int (*dma_quiescent) (struct drm_device *);
748 int (*context_dtor) (struct drm_device *dev, int context); 390 int (*context_dtor) (struct drm_device *dev, int context);
391 int (*set_busid)(struct drm_device *dev, struct drm_master *master);
749 392
750 /** 393 /**
751 * get_vblank_counter - get raw hardware vblank counter 394 * get_vblank_counter - get raw hardware vblank counter
@@ -928,7 +571,8 @@ struct drm_driver {
928 struct drm_gem_object *obj); 571 struct drm_gem_object *obj);
929 struct sg_table *(*gem_prime_get_sg_table)(struct drm_gem_object *obj); 572 struct sg_table *(*gem_prime_get_sg_table)(struct drm_gem_object *obj);
930 struct drm_gem_object *(*gem_prime_import_sg_table)( 573 struct drm_gem_object *(*gem_prime_import_sg_table)(
931 struct drm_device *dev, size_t size, 574 struct drm_device *dev,
575 struct dma_buf_attachment *attach,
932 struct sg_table *sgt); 576 struct sg_table *sgt);
933 void *(*gem_prime_vmap)(struct drm_gem_object *obj); 577 void *(*gem_prime_vmap)(struct drm_gem_object *obj);
934 void (*gem_prime_vunmap)(struct drm_gem_object *obj, void *vaddr); 578 void (*gem_prime_vunmap)(struct drm_gem_object *obj, void *vaddr);
@@ -964,7 +608,6 @@ struct drm_driver {
964 const struct drm_ioctl_desc *ioctls; 608 const struct drm_ioctl_desc *ioctls;
965 int num_ioctls; 609 int num_ioctls;
966 const struct file_operations *fops; 610 const struct file_operations *fops;
967 struct drm_bus *bus;
968 611
969 /* List of devices hanging off this driver with stealth attach. */ 612 /* List of devices hanging off this driver with stealth attach. */
970 struct list_head legacy_dev_list; 613 struct list_head legacy_dev_list;
@@ -1119,6 +762,16 @@ struct drm_device {
1119 */ 762 */
1120 bool vblank_disable_allowed; 763 bool vblank_disable_allowed;
1121 764
765 /*
766 * If true, vblank interrupt will be disabled immediately when the
767 * refcount drops to zero, as opposed to via the vblank disable
768 * timer.
769 * This can be set to true it the hardware has a working vblank
770 * counter and the driver uses drm_vblank_on() and drm_vblank_off()
771 * appropriately.
772 */
773 bool vblank_disable_immediate;
774
1122 /* array of size num_crtcs */ 775 /* array of size num_crtcs */
1123 struct drm_vblank_crtc *vblank; 776 struct drm_vblank_crtc *vblank;
1124 777
@@ -1143,13 +796,16 @@ struct drm_device {
1143#endif 796#endif
1144 797
1145 struct platform_device *platformdev; /**< Platform device struture */ 798 struct platform_device *platformdev; /**< Platform device struture */
1146 struct usb_device *usbdev;
1147 799
1148 struct drm_sg_mem *sg; /**< Scatter gather memory */ 800 struct drm_sg_mem *sg; /**< Scatter gather memory */
1149 unsigned int num_crtcs; /**< Number of CRTCs on this device */ 801 unsigned int num_crtcs; /**< Number of CRTCs on this device */
1150 struct drm_sigdata sigdata; /**< For block_all_signals */
1151 sigset_t sigmask; 802 sigset_t sigmask;
1152 803
804 struct {
805 int context;
806 struct drm_hw_lock *lock;
807 } sigdata;
808
1153 struct drm_local_map *agp_buffer_map; 809 struct drm_local_map *agp_buffer_map;
1154 unsigned int agp_buffer_token; 810 unsigned int agp_buffer_token;
1155 811
@@ -1212,136 +868,32 @@ extern long drm_ioctl(struct file *filp,
1212 unsigned int cmd, unsigned long arg); 868 unsigned int cmd, unsigned long arg);
1213extern long drm_compat_ioctl(struct file *filp, 869extern long drm_compat_ioctl(struct file *filp,
1214 unsigned int cmd, unsigned long arg); 870 unsigned int cmd, unsigned long arg);
1215extern int drm_lastclose(struct drm_device *dev);
1216extern bool drm_ioctl_flags(unsigned int nr, unsigned int *flags); 871extern bool drm_ioctl_flags(unsigned int nr, unsigned int *flags);
1217 872
1218 /* Device support (drm_fops.h) */ 873 /* Device support (drm_fops.h) */
1219extern struct mutex drm_global_mutex;
1220extern int drm_open(struct inode *inode, struct file *filp); 874extern int drm_open(struct inode *inode, struct file *filp);
1221extern int drm_stub_open(struct inode *inode, struct file *filp);
1222extern ssize_t drm_read(struct file *filp, char __user *buffer, 875extern ssize_t drm_read(struct file *filp, char __user *buffer,
1223 size_t count, loff_t *offset); 876 size_t count, loff_t *offset);
1224extern int drm_release(struct inode *inode, struct file *filp); 877extern int drm_release(struct inode *inode, struct file *filp);
1225 878
1226 /* Mapping support (drm_vm.h) */ 879 /* Mapping support (drm_vm.h) */
1227extern int drm_mmap(struct file *filp, struct vm_area_struct *vma);
1228extern int drm_mmap_locked(struct file *filp, struct vm_area_struct *vma);
1229extern void drm_vm_open_locked(struct drm_device *dev, struct vm_area_struct *vma);
1230extern void drm_vm_close_locked(struct drm_device *dev, struct vm_area_struct *vma);
1231extern unsigned int drm_poll(struct file *filp, struct poll_table_struct *wait); 880extern unsigned int drm_poll(struct file *filp, struct poll_table_struct *wait);
1232 881
1233 /* Memory management support (drm_memory.h) */ 882/* Misc. IOCTL support (drm_ioctl.c) */
1234#include <drm/drm_memory.h> 883int drm_noop(struct drm_device *dev, void *data,
1235 884 struct drm_file *file_priv);
1236
1237 /* Misc. IOCTL support (drm_ioctl.h) */
1238extern int drm_irq_by_busid(struct drm_device *dev, void *data,
1239 struct drm_file *file_priv);
1240extern int drm_getunique(struct drm_device *dev, void *data,
1241 struct drm_file *file_priv);
1242extern int drm_setunique(struct drm_device *dev, void *data,
1243 struct drm_file *file_priv);
1244extern int drm_getmap(struct drm_device *dev, void *data,
1245 struct drm_file *file_priv);
1246extern int drm_getclient(struct drm_device *dev, void *data,
1247 struct drm_file *file_priv);
1248extern int drm_getstats(struct drm_device *dev, void *data,
1249 struct drm_file *file_priv);
1250extern int drm_getcap(struct drm_device *dev, void *data,
1251 struct drm_file *file_priv);
1252extern int drm_setclientcap(struct drm_device *dev, void *data,
1253 struct drm_file *file_priv);
1254extern int drm_setversion(struct drm_device *dev, void *data,
1255 struct drm_file *file_priv);
1256extern int drm_noop(struct drm_device *dev, void *data,
1257 struct drm_file *file_priv);
1258
1259 /* Context IOCTL support (drm_context.h) */
1260extern int drm_resctx(struct drm_device *dev, void *data,
1261 struct drm_file *file_priv);
1262extern int drm_addctx(struct drm_device *dev, void *data,
1263 struct drm_file *file_priv);
1264extern int drm_getctx(struct drm_device *dev, void *data,
1265 struct drm_file *file_priv);
1266extern int drm_switchctx(struct drm_device *dev, void *data,
1267 struct drm_file *file_priv);
1268extern int drm_newctx(struct drm_device *dev, void *data,
1269 struct drm_file *file_priv);
1270extern int drm_rmctx(struct drm_device *dev, void *data,
1271 struct drm_file *file_priv);
1272
1273extern int drm_ctxbitmap_init(struct drm_device *dev);
1274extern void drm_ctxbitmap_cleanup(struct drm_device *dev);
1275extern void drm_ctxbitmap_free(struct drm_device *dev, int ctx_handle);
1276
1277extern int drm_setsareactx(struct drm_device *dev, void *data,
1278 struct drm_file *file_priv);
1279extern int drm_getsareactx(struct drm_device *dev, void *data,
1280 struct drm_file *file_priv);
1281
1282 /* Authentication IOCTL support (drm_auth.h) */
1283extern int drm_getmagic(struct drm_device *dev, void *data,
1284 struct drm_file *file_priv);
1285extern int drm_authmagic(struct drm_device *dev, void *data,
1286 struct drm_file *file_priv);
1287extern int drm_remove_magic(struct drm_master *master, drm_magic_t magic);
1288 885
1289/* Cache management (drm_cache.c) */ 886/* Cache management (drm_cache.c) */
1290void drm_clflush_pages(struct page *pages[], unsigned long num_pages); 887void drm_clflush_pages(struct page *pages[], unsigned long num_pages);
1291void drm_clflush_sg(struct sg_table *st); 888void drm_clflush_sg(struct sg_table *st);
1292void drm_clflush_virt_range(void *addr, unsigned long length); 889void drm_clflush_virt_range(void *addr, unsigned long length);
1293 890
1294 /* Locking IOCTL support (drm_lock.h) */
1295extern int drm_lock(struct drm_device *dev, void *data,
1296 struct drm_file *file_priv);
1297extern int drm_unlock(struct drm_device *dev, void *data,
1298 struct drm_file *file_priv);
1299extern int drm_lock_free(struct drm_lock_data *lock_data, unsigned int context);
1300extern void drm_idlelock_take(struct drm_lock_data *lock_data);
1301extern void drm_idlelock_release(struct drm_lock_data *lock_data);
1302
1303/* 891/*
1304 * These are exported to drivers so that they can implement fencing using 892 * These are exported to drivers so that they can implement fencing using
1305 * DMA quiscent + idle. DMA quiescent usually requires the hardware lock. 893 * DMA quiscent + idle. DMA quiescent usually requires the hardware lock.
1306 */ 894 */
1307 895
1308extern int drm_i_have_hw_lock(struct drm_device *dev, struct drm_file *file_priv);
1309
1310 /* Buffer management support (drm_bufs.h) */
1311extern int drm_addbufs_agp(struct drm_device *dev, struct drm_buf_desc * request);
1312extern int drm_addbufs_pci(struct drm_device *dev, struct drm_buf_desc * request);
1313extern int drm_addmap(struct drm_device *dev, resource_size_t offset,
1314 unsigned int size, enum drm_map_type type,
1315 enum drm_map_flags flags, struct drm_local_map **map_ptr);
1316extern int drm_addmap_ioctl(struct drm_device *dev, void *data,
1317 struct drm_file *file_priv);
1318extern int drm_rmmap(struct drm_device *dev, struct drm_local_map *map);
1319extern int drm_rmmap_locked(struct drm_device *dev, struct drm_local_map *map);
1320extern int drm_rmmap_ioctl(struct drm_device *dev, void *data,
1321 struct drm_file *file_priv);
1322extern int drm_addbufs(struct drm_device *dev, void *data,
1323 struct drm_file *file_priv);
1324extern int drm_infobufs(struct drm_device *dev, void *data,
1325 struct drm_file *file_priv);
1326extern int drm_markbufs(struct drm_device *dev, void *data,
1327 struct drm_file *file_priv);
1328extern int drm_freebufs(struct drm_device *dev, void *data,
1329 struct drm_file *file_priv);
1330extern int drm_mapbufs(struct drm_device *dev, void *data,
1331 struct drm_file *file_priv);
1332extern int drm_dma_ioctl(struct drm_device *dev, void *data,
1333 struct drm_file *file_priv);
1334
1335 /* DMA support (drm_dma.h) */
1336extern int drm_legacy_dma_setup(struct drm_device *dev);
1337extern void drm_legacy_dma_takedown(struct drm_device *dev);
1338extern void drm_free_buffer(struct drm_device *dev, struct drm_buf * buf);
1339extern void drm_core_reclaim_buffers(struct drm_device *dev,
1340 struct drm_file *filp);
1341
1342 /* IRQ support (drm_irq.h) */ 896 /* IRQ support (drm_irq.h) */
1343extern int drm_control(struct drm_device *dev, void *data,
1344 struct drm_file *file_priv);
1345extern int drm_irq_install(struct drm_device *dev, int irq); 897extern int drm_irq_install(struct drm_device *dev, int irq);
1346extern int drm_irq_uninstall(struct drm_device *dev); 898extern int drm_irq_uninstall(struct drm_device *dev);
1347 899
@@ -1358,14 +910,14 @@ extern int drm_vblank_get(struct drm_device *dev, int crtc);
1358extern void drm_vblank_put(struct drm_device *dev, int crtc); 910extern void drm_vblank_put(struct drm_device *dev, int crtc);
1359extern int drm_crtc_vblank_get(struct drm_crtc *crtc); 911extern int drm_crtc_vblank_get(struct drm_crtc *crtc);
1360extern void drm_crtc_vblank_put(struct drm_crtc *crtc); 912extern void drm_crtc_vblank_put(struct drm_crtc *crtc);
913extern void drm_wait_one_vblank(struct drm_device *dev, int crtc);
914extern void drm_crtc_wait_one_vblank(struct drm_crtc *crtc);
1361extern void drm_vblank_off(struct drm_device *dev, int crtc); 915extern void drm_vblank_off(struct drm_device *dev, int crtc);
1362extern void drm_vblank_on(struct drm_device *dev, int crtc); 916extern void drm_vblank_on(struct drm_device *dev, int crtc);
1363extern void drm_crtc_vblank_off(struct drm_crtc *crtc); 917extern void drm_crtc_vblank_off(struct drm_crtc *crtc);
1364extern void drm_crtc_vblank_on(struct drm_crtc *crtc); 918extern void drm_crtc_vblank_on(struct drm_crtc *crtc);
1365extern void drm_vblank_cleanup(struct drm_device *dev); 919extern void drm_vblank_cleanup(struct drm_device *dev);
1366 920
1367extern u32 drm_get_last_vbltimestamp(struct drm_device *dev, int crtc,
1368 struct timeval *tvblank, unsigned flags);
1369extern int drm_calc_vbltimestamp_from_scanoutpos(struct drm_device *dev, 921extern int drm_calc_vbltimestamp_from_scanoutpos(struct drm_device *dev,
1370 int crtc, int *max_error, 922 int crtc, int *max_error,
1371 struct timeval *vblank_time, 923 struct timeval *vblank_time,
@@ -1375,60 +927,38 @@ extern int drm_calc_vbltimestamp_from_scanoutpos(struct drm_device *dev,
1375extern void drm_calc_timestamping_constants(struct drm_crtc *crtc, 927extern void drm_calc_timestamping_constants(struct drm_crtc *crtc,
1376 const struct drm_display_mode *mode); 928 const struct drm_display_mode *mode);
1377 929
930/**
931 * drm_crtc_vblank_waitqueue - get vblank waitqueue for the CRTC
932 * @crtc: which CRTC's vblank waitqueue to retrieve
933 *
934 * This function returns a pointer to the vblank waitqueue for the CRTC.
935 * Drivers can use this to implement vblank waits using wait_event() & co.
936 */
937static inline wait_queue_head_t *drm_crtc_vblank_waitqueue(struct drm_crtc *crtc)
938{
939 return &crtc->dev->vblank[drm_crtc_index(crtc)].queue;
940}
1378 941
1379/* Modesetting support */ 942/* Modesetting support */
1380extern void drm_vblank_pre_modeset(struct drm_device *dev, int crtc); 943extern void drm_vblank_pre_modeset(struct drm_device *dev, int crtc);
1381extern void drm_vblank_post_modeset(struct drm_device *dev, int crtc); 944extern void drm_vblank_post_modeset(struct drm_device *dev, int crtc);
1382extern int drm_modeset_ctl(struct drm_device *dev, void *data,
1383 struct drm_file *file_priv);
1384
1385 /* AGP/GART support (drm_agpsupport.h) */
1386
1387#include <drm/drm_agpsupport.h>
1388 945
1389 /* Stub support (drm_stub.h) */ 946 /* Stub support (drm_stub.h) */
1390extern int drm_setmaster_ioctl(struct drm_device *dev, void *data,
1391 struct drm_file *file_priv);
1392extern int drm_dropmaster_ioctl(struct drm_device *dev, void *data,
1393 struct drm_file *file_priv);
1394struct drm_master *drm_master_create(struct drm_minor *minor);
1395extern struct drm_master *drm_master_get(struct drm_master *master); 947extern struct drm_master *drm_master_get(struct drm_master *master);
1396extern void drm_master_put(struct drm_master **master); 948extern void drm_master_put(struct drm_master **master);
1397 949
1398extern void drm_put_dev(struct drm_device *dev); 950extern void drm_put_dev(struct drm_device *dev);
1399extern void drm_unplug_dev(struct drm_device *dev); 951extern void drm_unplug_dev(struct drm_device *dev);
1400extern unsigned int drm_debug; 952extern unsigned int drm_debug;
1401extern unsigned int drm_rnodes;
1402extern unsigned int drm_universal_planes;
1403
1404extern unsigned int drm_vblank_offdelay;
1405extern unsigned int drm_timestamp_precision;
1406extern unsigned int drm_timestamp_monotonic;
1407
1408extern struct class *drm_class;
1409extern struct dentry *drm_debugfs_root;
1410
1411extern struct idr drm_minors_idr;
1412
1413extern struct drm_local_map *drm_getsarea(struct drm_device *dev);
1414 953
1415 /* Debugfs support */ 954 /* Debugfs support */
1416#if defined(CONFIG_DEBUG_FS) 955#if defined(CONFIG_DEBUG_FS)
1417extern int drm_debugfs_init(struct drm_minor *minor, int minor_id,
1418 struct dentry *root);
1419extern int drm_debugfs_create_files(const struct drm_info_list *files, 956extern int drm_debugfs_create_files(const struct drm_info_list *files,
1420 int count, struct dentry *root, 957 int count, struct dentry *root,
1421 struct drm_minor *minor); 958 struct drm_minor *minor);
1422extern int drm_debugfs_remove_files(const struct drm_info_list *files, 959extern int drm_debugfs_remove_files(const struct drm_info_list *files,
1423 int count, struct drm_minor *minor); 960 int count, struct drm_minor *minor);
1424extern int drm_debugfs_cleanup(struct drm_minor *minor);
1425#else 961#else
1426static inline int drm_debugfs_init(struct drm_minor *minor, int minor_id,
1427 struct dentry *root)
1428{
1429 return 0;
1430}
1431
1432static inline int drm_debugfs_create_files(const struct drm_info_list *files, 962static inline int drm_debugfs_create_files(const struct drm_info_list *files,
1433 int count, struct dentry *root, 963 int count, struct dentry *root,
1434 struct drm_minor *minor) 964 struct drm_minor *minor)
@@ -1441,22 +971,8 @@ static inline int drm_debugfs_remove_files(const struct drm_info_list *files,
1441{ 971{
1442 return 0; 972 return 0;
1443} 973}
1444
1445static inline int drm_debugfs_cleanup(struct drm_minor *minor)
1446{
1447 return 0;
1448}
1449#endif 974#endif
1450 975
1451 /* Info file support */
1452extern int drm_name_info(struct seq_file *m, void *data);
1453extern int drm_vm_info(struct seq_file *m, void *data);
1454extern int drm_bufs_info(struct seq_file *m, void *data);
1455extern int drm_vblank_info(struct seq_file *m, void *data);
1456extern int drm_clients_info(struct seq_file *m, void* data);
1457extern int drm_gem_name_info(struct seq_file *m, void *data);
1458
1459
1460extern struct dma_buf *drm_gem_prime_export(struct drm_device *dev, 976extern struct dma_buf *drm_gem_prime_export(struct drm_device *dev,
1461 struct drm_gem_object *obj, int flags); 977 struct drm_gem_object *obj, int flags);
1462extern int drm_gem_prime_handle_to_fd(struct drm_device *dev, 978extern int drm_gem_prime_handle_to_fd(struct drm_device *dev,
@@ -1468,151 +984,20 @@ extern int drm_gem_prime_fd_to_handle(struct drm_device *dev,
1468 struct drm_file *file_priv, int prime_fd, uint32_t *handle); 984 struct drm_file *file_priv, int prime_fd, uint32_t *handle);
1469extern void drm_gem_dmabuf_release(struct dma_buf *dma_buf); 985extern void drm_gem_dmabuf_release(struct dma_buf *dma_buf);
1470 986
1471extern int drm_prime_handle_to_fd_ioctl(struct drm_device *dev, void *data,
1472 struct drm_file *file_priv);
1473extern int drm_prime_fd_to_handle_ioctl(struct drm_device *dev, void *data,
1474 struct drm_file *file_priv);
1475
1476extern int drm_prime_sg_to_page_addr_arrays(struct sg_table *sgt, struct page **pages, 987extern int drm_prime_sg_to_page_addr_arrays(struct sg_table *sgt, struct page **pages,
1477 dma_addr_t *addrs, int max_pages); 988 dma_addr_t *addrs, int max_pages);
1478extern struct sg_table *drm_prime_pages_to_sg(struct page **pages, int nr_pages); 989extern struct sg_table *drm_prime_pages_to_sg(struct page **pages, int nr_pages);
1479extern void drm_prime_gem_destroy(struct drm_gem_object *obj, struct sg_table *sg); 990extern void drm_prime_gem_destroy(struct drm_gem_object *obj, struct sg_table *sg);
1480 991
1481int drm_gem_dumb_destroy(struct drm_file *file,
1482 struct drm_device *dev,
1483 uint32_t handle);
1484 992
1485void drm_prime_init_file_private(struct drm_prime_file_private *prime_fpriv); 993extern struct drm_dma_handle *drm_pci_alloc(struct drm_device *dev, size_t size,
1486void drm_prime_destroy_file_private(struct drm_prime_file_private *prime_fpriv); 994 size_t align);
1487void drm_prime_remove_buf_handle_locked(struct drm_prime_file_private *prime_fpriv, struct dma_buf *dma_buf); 995extern void drm_pci_free(struct drm_device *dev, struct drm_dma_handle * dmah);
1488
1489#if DRM_DEBUG_CODE
1490extern int drm_vma_info(struct seq_file *m, void *data);
1491#endif
1492
1493 /* Scatter Gather Support (drm_scatter.h) */
1494extern void drm_legacy_sg_cleanup(struct drm_device *dev);
1495extern int drm_sg_alloc(struct drm_device *dev, void *data,
1496 struct drm_file *file_priv);
1497extern int drm_sg_free(struct drm_device *dev, void *data,
1498 struct drm_file *file_priv);
1499
1500 /* ATI PCIGART support (ati_pcigart.h) */
1501extern int drm_ati_pcigart_init(struct drm_device *dev,
1502 struct drm_ati_pcigart_info * gart_info);
1503extern int drm_ati_pcigart_cleanup(struct drm_device *dev,
1504 struct drm_ati_pcigart_info * gart_info);
1505
1506extern drm_dma_handle_t *drm_pci_alloc(struct drm_device *dev, size_t size,
1507 size_t align);
1508extern void __drm_pci_free(struct drm_device *dev, drm_dma_handle_t * dmah);
1509extern void drm_pci_free(struct drm_device *dev, drm_dma_handle_t * dmah);
1510extern int drm_pci_set_unique(struct drm_device *dev,
1511 struct drm_master *master,
1512 struct drm_unique *u);
1513 996
1514 /* sysfs support (drm_sysfs.c) */ 997 /* sysfs support (drm_sysfs.c) */
1515struct drm_sysfs_class;
1516extern struct class *drm_sysfs_create(struct module *owner, char *name);
1517extern void drm_sysfs_destroy(void);
1518extern int drm_sysfs_device_add(struct drm_minor *minor);
1519extern void drm_sysfs_hotplug_event(struct drm_device *dev); 998extern void drm_sysfs_hotplug_event(struct drm_device *dev);
1520extern void drm_sysfs_device_remove(struct drm_minor *minor);
1521extern int drm_sysfs_connector_add(struct drm_connector *connector);
1522extern void drm_sysfs_connector_remove(struct drm_connector *connector);
1523
1524/* Graphics Execution Manager library functions (drm_gem.c) */
1525int drm_gem_init(struct drm_device *dev);
1526void drm_gem_destroy(struct drm_device *dev);
1527void drm_gem_object_release(struct drm_gem_object *obj);
1528void drm_gem_object_free(struct kref *kref);
1529int drm_gem_object_init(struct drm_device *dev,
1530 struct drm_gem_object *obj, size_t size);
1531void drm_gem_private_object_init(struct drm_device *dev,
1532 struct drm_gem_object *obj, size_t size);
1533void drm_gem_vm_open(struct vm_area_struct *vma);
1534void drm_gem_vm_close(struct vm_area_struct *vma);
1535int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
1536 struct vm_area_struct *vma);
1537int drm_gem_mmap(struct file *filp, struct vm_area_struct *vma);
1538
1539#include <drm/drm_global.h>
1540
1541static inline void
1542drm_gem_object_reference(struct drm_gem_object *obj)
1543{
1544 kref_get(&obj->refcount);
1545}
1546
1547static inline void
1548drm_gem_object_unreference(struct drm_gem_object *obj)
1549{
1550 if (obj != NULL)
1551 kref_put(&obj->refcount, drm_gem_object_free);
1552}
1553
1554static inline void
1555drm_gem_object_unreference_unlocked(struct drm_gem_object *obj)
1556{
1557 if (obj && !atomic_add_unless(&obj->refcount.refcount, -1, 1)) {
1558 struct drm_device *dev = obj->dev;
1559
1560 mutex_lock(&dev->struct_mutex);
1561 if (likely(atomic_dec_and_test(&obj->refcount.refcount)))
1562 drm_gem_object_free(&obj->refcount);
1563 mutex_unlock(&dev->struct_mutex);
1564 }
1565}
1566
1567int drm_gem_handle_create_tail(struct drm_file *file_priv,
1568 struct drm_gem_object *obj,
1569 u32 *handlep);
1570int drm_gem_handle_create(struct drm_file *file_priv,
1571 struct drm_gem_object *obj,
1572 u32 *handlep);
1573int drm_gem_handle_delete(struct drm_file *filp, u32 handle);
1574 999
1575 1000
1576void drm_gem_free_mmap_offset(struct drm_gem_object *obj);
1577int drm_gem_create_mmap_offset(struct drm_gem_object *obj);
1578int drm_gem_create_mmap_offset_size(struct drm_gem_object *obj, size_t size);
1579
1580struct page **drm_gem_get_pages(struct drm_gem_object *obj, gfp_t gfpmask);
1581void drm_gem_put_pages(struct drm_gem_object *obj, struct page **pages,
1582 bool dirty, bool accessed);
1583
1584struct drm_gem_object *drm_gem_object_lookup(struct drm_device *dev,
1585 struct drm_file *filp,
1586 u32 handle);
1587int drm_gem_close_ioctl(struct drm_device *dev, void *data,
1588 struct drm_file *file_priv);
1589int drm_gem_flink_ioctl(struct drm_device *dev, void *data,
1590 struct drm_file *file_priv);
1591int drm_gem_open_ioctl(struct drm_device *dev, void *data,
1592 struct drm_file *file_priv);
1593void drm_gem_open(struct drm_device *dev, struct drm_file *file_private);
1594void drm_gem_release(struct drm_device *dev, struct drm_file *file_private);
1595
1596extern void drm_core_ioremap(struct drm_local_map *map, struct drm_device *dev);
1597extern void drm_core_ioremap_wc(struct drm_local_map *map, struct drm_device *dev);
1598extern void drm_core_ioremapfree(struct drm_local_map *map, struct drm_device *dev);
1599
1600static __inline__ struct drm_local_map *drm_core_findmap(struct drm_device *dev,
1601 unsigned int token)
1602{
1603 struct drm_map_list *_entry;
1604 list_for_each_entry(_entry, &dev->maplist, head)
1605 if (_entry->user_token == token)
1606 return _entry->map;
1607 return NULL;
1608}
1609
1610static __inline__ void drm_core_dropmap(struct drm_local_map *map)
1611{
1612}
1613
1614#include <drm/drm_mem_util.h>
1615
1616struct drm_device *drm_dev_alloc(struct drm_driver *driver, 1001struct drm_device *drm_dev_alloc(struct drm_driver *driver,
1617 struct device *parent); 1002 struct device *parent);
1618void drm_dev_ref(struct drm_device *dev); 1003void drm_dev_ref(struct drm_device *dev);
@@ -1646,6 +1031,7 @@ extern void drm_pci_exit(struct drm_driver *driver, struct pci_driver *pdriver);
1646extern int drm_get_pci_dev(struct pci_dev *pdev, 1031extern int drm_get_pci_dev(struct pci_dev *pdev,
1647 const struct pci_device_id *ent, 1032 const struct pci_device_id *ent,
1648 struct drm_driver *driver); 1033 struct drm_driver *driver);
1034extern int drm_pci_set_busid(struct drm_device *dev, struct drm_master *master);
1649 1035
1650#define DRM_PCIE_SPEED_25 1 1036#define DRM_PCIE_SPEED_25 1
1651#define DRM_PCIE_SPEED_50 2 1037#define DRM_PCIE_SPEED_50 2
@@ -1655,6 +1041,7 @@ extern int drm_pcie_get_speed_cap_mask(struct drm_device *dev, u32 *speed_mask);
1655 1041
1656/* platform section */ 1042/* platform section */
1657extern int drm_platform_init(struct drm_driver *driver, struct platform_device *platform_device); 1043extern int drm_platform_init(struct drm_driver *driver, struct platform_device *platform_device);
1044extern int drm_platform_set_busid(struct drm_device *d, struct drm_master *m);
1658 1045
1659/* returns true if currently okay to sleep */ 1046/* returns true if currently okay to sleep */
1660static __inline__ bool drm_can_sleep(void) 1047static __inline__ bool drm_can_sleep(void)
@@ -1664,5 +1051,4 @@ static __inline__ bool drm_can_sleep(void)
1664 return true; 1051 return true;
1665} 1052}
1666 1053
1667#endif /* __KERNEL__ */
1668#endif 1054#endif