Author | Tokens | Token Proportion | Commits | Commit Proportion |
---|---|---|---|---|
Dave Airlie | 450 | 28.70% | 9 | 31.03% |
David Herrmann | 433 | 27.61% | 4 | 13.79% |
Thomas Zimmermann | 433 | 27.61% | 4 | 13.79% |
Daniel Vetter | 157 | 10.01% | 8 | 27.59% |
Al Viro | 70 | 4.46% | 2 | 6.90% |
Benjamin Gaignard | 17 | 1.08% | 1 | 3.45% |
Sam Ravnborg | 8 | 0.51% | 1 | 3.45% |
Total | 1568 | 29 |
#ifndef __DRM_LEGACY_H__ #define __DRM_LEGACY_H__ /* * Copyright (c) 2014 David Herrmann <dh.herrmann@gmail.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 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 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) 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. */ /* * This file contains legacy interfaces that modern drm drivers * should no longer be using. They cannot be removed as legacy * drivers use them, and removing them are API breaks. */ #include <linux/list.h> #include <drm/drm.h> #include <drm/drm_device.h> #include <drm/drm_legacy.h> struct agp_memory; struct drm_buf_desc; struct drm_device; struct drm_file; struct drm_hash_item; struct drm_open_hash; /* * Hash-table Support */ #define drm_hash_entry(_ptr, _type, _member) container_of(_ptr, _type, _member) /* drm_hashtab.c */ #if IS_ENABLED(CONFIG_DRM_LEGACY) int drm_ht_create(struct drm_open_hash *ht, unsigned int order); int drm_ht_insert_item(struct drm_open_hash *ht, struct drm_hash_item *item); int drm_ht_just_insert_please(struct drm_open_hash *ht, struct drm_hash_item *item, unsigned long seed, int bits, int shift, unsigned long add); int drm_ht_find_item(struct drm_open_hash *ht, unsigned long key, struct drm_hash_item **item); void drm_ht_verbose_list(struct drm_open_hash *ht, unsigned long key); int drm_ht_remove_key(struct drm_open_hash *ht, unsigned long key); int drm_ht_remove_item(struct drm_open_hash *ht, struct drm_hash_item *item); void drm_ht_remove(struct drm_open_hash *ht); #endif /* * RCU-safe interface * * The user of this API needs to make sure that two or more instances of the * hash table manipulation functions are never run simultaneously. * The lookup function drm_ht_find_item_rcu may, however, run simultaneously * with any of the manipulation functions as long as it's called from within * an RCU read-locked section. */ #define drm_ht_insert_item_rcu drm_ht_insert_item #define drm_ht_just_insert_please_rcu drm_ht_just_insert_please #define drm_ht_remove_key_rcu drm_ht_remove_key #define drm_ht_remove_item_rcu drm_ht_remove_item #define drm_ht_find_item_rcu drm_ht_find_item /* * Generic DRM Contexts */ #define DRM_KERNEL_CONTEXT 0 #define DRM_RESERVED_CONTEXTS 1 #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_ctxbitmap_init(struct drm_device *dev); void drm_legacy_ctxbitmap_cleanup(struct drm_device *dev); void drm_legacy_ctxbitmap_flush(struct drm_device *dev, struct drm_file *file); #else static inline void drm_legacy_ctxbitmap_init(struct drm_device *dev) {} static inline void drm_legacy_ctxbitmap_cleanup(struct drm_device *dev) {} static inline void drm_legacy_ctxbitmap_flush(struct drm_device *dev, struct drm_file *file) {} #endif void drm_legacy_ctxbitmap_free(struct drm_device *dev, int ctx_handle); #if IS_ENABLED(CONFIG_DRM_LEGACY) int drm_legacy_resctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_addctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_getctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_switchctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_newctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_rmctx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_setsareactx(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_getsareactx(struct drm_device *d, void *v, struct drm_file *f); #endif /* * Generic Buffer Management */ #define DRM_MAP_HASH_OFFSET 0x10000000 #if IS_ENABLED(CONFIG_DRM_LEGACY) static inline int drm_legacy_create_map_hash(struct drm_device *dev) { return drm_ht_create(&dev->map_hash, 12); } static inline void drm_legacy_remove_map_hash(struct drm_device *dev) { drm_ht_remove(&dev->map_hash); } #else static inline int drm_legacy_create_map_hash(struct drm_device *dev) { return 0; } static inline void drm_legacy_remove_map_hash(struct drm_device *dev) {} #endif #if IS_ENABLED(CONFIG_DRM_LEGACY) int drm_legacy_getmap_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_addmap_ioctl(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_rmmap_ioctl(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_addbufs(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_infobufs(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_markbufs(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_freebufs(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_mapbufs(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_dma_ioctl(struct drm_device *d, void *v, struct drm_file *f); #endif int __drm_legacy_infobufs(struct drm_device *, void *, int *, int (*)(void *, int, struct drm_buf_entry *)); int __drm_legacy_mapbufs(struct drm_device *, void *, int *, void __user **, int (*)(void *, int, unsigned long, struct drm_buf *), struct drm_file *); #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_master_rmmaps(struct drm_device *dev, struct drm_master *master); void drm_legacy_rmmaps(struct drm_device *dev); #else static inline void drm_legacy_master_rmmaps(struct drm_device *dev, struct drm_master *master) {} static inline void drm_legacy_rmmaps(struct drm_device *dev) {} #endif #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_vma_flush(struct drm_device *d); #else static inline void drm_legacy_vma_flush(struct drm_device *d) { /* do nothing */ } #endif /* * AGP Support */ struct drm_agp_mem { unsigned long handle; struct agp_memory *memory; unsigned long bound; int pages; struct list_head head; }; /* drm_agpsupport.c */ #if IS_ENABLED(CONFIG_DRM_LEGACY) && IS_ENABLED(CONFIG_AGP) void drm_legacy_agp_clear(struct drm_device *dev); int drm_legacy_agp_acquire_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_release_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_enable_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_info_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_alloc_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_free_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_unbind_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_agp_bind_ioctl(struct drm_device *dev, void *data, struct drm_file *file_priv); #else static inline void drm_legacy_agp_clear(struct drm_device *dev) {} #endif /* drm_lock.c */ #if IS_ENABLED(CONFIG_DRM_LEGACY) int drm_legacy_lock(struct drm_device *d, void *v, struct drm_file *f); int drm_legacy_unlock(struct drm_device *d, void *v, struct drm_file *f); void drm_legacy_lock_release(struct drm_device *dev, struct file *filp); #else static inline void drm_legacy_lock_release(struct drm_device *dev, struct file *filp) {} #endif /* DMA support */ #if IS_ENABLED(CONFIG_DRM_LEGACY) int drm_legacy_dma_setup(struct drm_device *dev); void drm_legacy_dma_takedown(struct drm_device *dev); #else static inline int drm_legacy_dma_setup(struct drm_device *dev) { return 0; } #endif void drm_legacy_free_buffer(struct drm_device *dev, struct drm_buf * buf); #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_reclaim_buffers(struct drm_device *dev, struct drm_file *filp); #else static inline void drm_legacy_reclaim_buffers(struct drm_device *dev, struct drm_file *filp) {} #endif /* Scatter Gather Support */ #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_sg_cleanup(struct drm_device *dev); int drm_legacy_sg_alloc(struct drm_device *dev, void *data, struct drm_file *file_priv); int drm_legacy_sg_free(struct drm_device *dev, void *data, struct drm_file *file_priv); #endif #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_init_members(struct drm_device *dev); void drm_legacy_destroy_members(struct drm_device *dev); void drm_legacy_dev_reinit(struct drm_device *dev); int drm_legacy_setup(struct drm_device * dev); #else static inline void drm_legacy_init_members(struct drm_device *dev) {} static inline void drm_legacy_destroy_members(struct drm_device *dev) {} static inline void drm_legacy_dev_reinit(struct drm_device *dev) {} static inline int drm_legacy_setup(struct drm_device * dev) { return 0; } #endif #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_legacy_lock_master_cleanup(struct drm_device *dev, struct drm_master *master); #else static inline void drm_legacy_lock_master_cleanup(struct drm_device *dev, struct drm_master *master) {} #endif #if IS_ENABLED(CONFIG_DRM_LEGACY) void drm_master_legacy_init(struct drm_master *master); #else static inline void drm_master_legacy_init(struct drm_master *master) {} #endif /* drm_pci.c */ #if IS_ENABLED(CONFIG_DRM_LEGACY) && IS_ENABLED(CONFIG_PCI) int drm_legacy_irq_by_busid(struct drm_device *dev, void *data, struct drm_file *file_priv); void drm_legacy_pci_agp_destroy(struct drm_device *dev); #else static inline int drm_legacy_irq_by_busid(struct drm_device *dev, void *data, struct drm_file *file_priv) { return -EINVAL; } static inline void drm_legacy_pci_agp_destroy(struct drm_device *dev) {} #endif #endif /* __DRM_LEGACY_H__ */
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with Cregit http://github.com/cregit/cregit
Version 2.0-RC1