|  | #ifndef _DRM_DEVICE_H_ | 
|  | #define _DRM_DEVICE_H_ | 
|  |  | 
|  | #include <linux/list.h> | 
|  | #include <linux/kref.h> | 
|  | #include <linux/mutex.h> | 
|  | #include <linux/idr.h> | 
|  |  | 
|  | #include <drm/drm_hashtab.h> | 
|  | #include <drm/drm_mode_config.h> | 
|  |  | 
|  | struct drm_driver; | 
|  | struct drm_minor; | 
|  | struct drm_master; | 
|  | struct drm_device_dma; | 
|  | struct drm_vblank_crtc; | 
|  | struct drm_sg_mem; | 
|  | struct drm_local_map; | 
|  | struct drm_vma_offset_manager; | 
|  | struct drm_fb_helper; | 
|  |  | 
|  | struct inode; | 
|  |  | 
|  | struct pci_dev; | 
|  | struct pci_controller; | 
|  |  | 
|  | /** | 
|  | * DRM device structure. This structure represent a complete card that | 
|  | * may contain multiple heads. | 
|  | */ | 
|  | struct drm_device { | 
|  | struct list_head legacy_dev_list;/**< list of devices per driver for stealth attach cleanup */ | 
|  | int if_version;			/**< Highest interface version set */ | 
|  |  | 
|  | /** \name Lifetime Management */ | 
|  | /*@{ */ | 
|  | struct kref ref;		/**< Object ref-count */ | 
|  | struct device *dev;		/**< Device structure of bus-device */ | 
|  | struct drm_driver *driver;	/**< DRM driver managing the device */ | 
|  | void *dev_private;		/**< DRM driver private data */ | 
|  | struct drm_minor *primary;		/**< Primary node */ | 
|  | struct drm_minor *render;		/**< Render node */ | 
|  | bool registered; | 
|  |  | 
|  | /* currently active master for this device. Protected by master_mutex */ | 
|  | struct drm_master *master; | 
|  |  | 
|  | /** | 
|  | * @unplugged: | 
|  | * | 
|  | * Flag to tell if the device has been unplugged. | 
|  | * See drm_dev_enter() and drm_dev_is_unplugged(). | 
|  | */ | 
|  | bool unplugged; | 
|  |  | 
|  | struct inode *anon_inode;		/**< inode for private address-space */ | 
|  | char *unique;				/**< unique name of the device */ | 
|  | /*@} */ | 
|  |  | 
|  | /** \name Locks */ | 
|  | /*@{ */ | 
|  | struct mutex struct_mutex;	/**< For others */ | 
|  | struct mutex master_mutex;      /**< For drm_minor::master and drm_file::is_master */ | 
|  | /*@} */ | 
|  |  | 
|  | /** \name Usage Counters */ | 
|  | /*@{ */ | 
|  | int open_count;			/**< Outstanding files open, protected by drm_global_mutex. */ | 
|  | spinlock_t buf_lock;		/**< For drm_device::buf_use and a few other things. */ | 
|  | int buf_use;			/**< Buffers in use -- cannot alloc */ | 
|  | atomic_t buf_alloc;		/**< Buffer allocation in progress */ | 
|  | /*@} */ | 
|  |  | 
|  | struct mutex filelist_mutex; | 
|  | struct list_head filelist; | 
|  |  | 
|  | /** | 
|  | * @filelist_internal: | 
|  | * | 
|  | * List of open DRM files for in-kernel clients. Protected by @filelist_mutex. | 
|  | */ | 
|  | struct list_head filelist_internal; | 
|  |  | 
|  | /** | 
|  | * @clientlist_mutex: | 
|  | * | 
|  | * Protects @clientlist access. | 
|  | */ | 
|  | struct mutex clientlist_mutex; | 
|  |  | 
|  | /** | 
|  | * @clientlist: | 
|  | * | 
|  | * List of in-kernel clients. Protected by @clientlist_mutex. | 
|  | */ | 
|  | struct list_head clientlist; | 
|  |  | 
|  | /** \name Memory management */ | 
|  | /*@{ */ | 
|  | struct list_head maplist;	/**< Linked list of regions */ | 
|  | struct drm_open_hash map_hash;	/**< User token hash table for maps */ | 
|  |  | 
|  | /** \name Context handle management */ | 
|  | /*@{ */ | 
|  | struct list_head ctxlist;	/**< Linked list of context handles */ | 
|  | struct mutex ctxlist_mutex;	/**< For ctxlist */ | 
|  |  | 
|  | struct idr ctx_idr; | 
|  |  | 
|  | struct list_head vmalist;	/**< List of vmas (for debugging) */ | 
|  |  | 
|  | /*@} */ | 
|  |  | 
|  | /** \name DMA support */ | 
|  | /*@{ */ | 
|  | struct drm_device_dma *dma;		/**< Optional pointer for DMA support */ | 
|  | /*@} */ | 
|  |  | 
|  | /** \name Context support */ | 
|  | /*@{ */ | 
|  |  | 
|  | __volatile__ long context_flag;	/**< Context swapping flag */ | 
|  | int last_context;		/**< Last current context */ | 
|  | /*@} */ | 
|  |  | 
|  | /** | 
|  | * @irq_enabled: | 
|  | * | 
|  | * Indicates that interrupt handling is enabled, specifically vblank | 
|  | * handling. Drivers which don't use drm_irq_install() need to set this | 
|  | * to true manually. | 
|  | */ | 
|  | bool irq_enabled; | 
|  | int irq; | 
|  |  | 
|  | /** | 
|  | * @vblank_disable_immediate: | 
|  | * | 
|  | * If true, vblank interrupt will be disabled immediately when the | 
|  | * refcount drops to zero, as opposed to via the vblank disable | 
|  | * timer. | 
|  | * | 
|  | * This can be set to true it the hardware has a working vblank counter | 
|  | * with high-precision timestamping (otherwise there are races) and the | 
|  | * driver uses drm_crtc_vblank_on() and drm_crtc_vblank_off() | 
|  | * appropriately. See also @max_vblank_count and | 
|  | * &drm_crtc_funcs.get_vblank_counter. | 
|  | */ | 
|  | bool vblank_disable_immediate; | 
|  |  | 
|  | /** | 
|  | * @vblank: | 
|  | * | 
|  | * Array of vblank tracking structures, one per &struct drm_crtc. For | 
|  | * historical reasons (vblank support predates kernel modesetting) this | 
|  | * is free-standing and not part of &struct drm_crtc itself. It must be | 
|  | * initialized explicitly by calling drm_vblank_init(). | 
|  | */ | 
|  | struct drm_vblank_crtc *vblank; | 
|  |  | 
|  | spinlock_t vblank_time_lock;    /**< Protects vblank count and time updates during vblank enable/disable */ | 
|  | spinlock_t vbl_lock; | 
|  |  | 
|  | /** | 
|  | * @max_vblank_count: | 
|  | * | 
|  | * Maximum value of the vblank registers. This value +1 will result in a | 
|  | * wrap-around of the vblank register. It is used by the vblank core to | 
|  | * handle wrap-arounds. | 
|  | * | 
|  | * If set to zero the vblank core will try to guess the elapsed vblanks | 
|  | * between times when the vblank interrupt is disabled through | 
|  | * high-precision timestamps. That approach is suffering from small | 
|  | * races and imprecision over longer time periods, hence exposing a | 
|  | * hardware vblank counter is always recommended. | 
|  | * | 
|  | * This is the statically configured device wide maximum. The driver | 
|  | * can instead choose to use a runtime configurable per-crtc value | 
|  | * &drm_vblank_crtc.max_vblank_count, in which case @max_vblank_count | 
|  | * must be left at zero. See drm_crtc_set_max_vblank_count() on how | 
|  | * to use the per-crtc value. | 
|  | * | 
|  | * If non-zero, &drm_crtc_funcs.get_vblank_counter must be set. | 
|  | */ | 
|  | u32 max_vblank_count;           /**< size of vblank counter register */ | 
|  |  | 
|  | /** | 
|  | * List of events | 
|  | */ | 
|  | struct list_head vblank_event_list; | 
|  | spinlock_t event_lock; | 
|  |  | 
|  | /*@} */ | 
|  |  | 
|  | struct drm_agp_head *agp;	/**< AGP data */ | 
|  |  | 
|  | struct pci_dev *pdev;		/**< PCI device structure */ | 
|  | #ifdef __alpha__ | 
|  | struct pci_controller *hose; | 
|  | #endif | 
|  |  | 
|  | struct drm_sg_mem *sg;	/**< Scatter gather memory */ | 
|  | unsigned int num_crtcs;                  /**< Number of CRTCs on this device */ | 
|  |  | 
|  | struct { | 
|  | int context; | 
|  | struct drm_hw_lock *lock; | 
|  | } sigdata; | 
|  |  | 
|  | struct drm_local_map *agp_buffer_map; | 
|  | unsigned int agp_buffer_token; | 
|  |  | 
|  | struct drm_mode_config mode_config;	/**< Current mode config */ | 
|  |  | 
|  | /** \name GEM information */ | 
|  | /*@{ */ | 
|  | struct mutex object_name_lock; | 
|  | struct idr object_name_idr; | 
|  | struct drm_vma_offset_manager *vma_offset_manager; | 
|  | /*@} */ | 
|  | int switch_power_state; | 
|  |  | 
|  | /** | 
|  | * @fb_helper: | 
|  | * | 
|  | * Pointer to the fbdev emulation structure. | 
|  | * Set by drm_fb_helper_init() and cleared by drm_fb_helper_fini(). | 
|  | */ | 
|  | struct drm_fb_helper *fb_helper; | 
|  | }; | 
|  |  | 
|  | #endif |