| .. | .. |
|---|
| 1 | 1 | #ifndef __DRM_DRM_LEGACY_H__ |
|---|
| 2 | 2 | #define __DRM_DRM_LEGACY_H__ |
|---|
| 3 | | - |
|---|
| 4 | | -#include <drm/drm_auth.h> |
|---|
| 5 | | - |
|---|
| 6 | 3 | /* |
|---|
| 7 | 4 | * Legacy driver interfaces for the Direct Rendering Manager |
|---|
| 8 | 5 | * |
|---|
| .. | .. |
|---|
| 36 | 33 | * OTHER DEALINGS IN THE SOFTWARE. |
|---|
| 37 | 34 | */ |
|---|
| 38 | 35 | |
|---|
| 36 | +#include <drm/drm.h> |
|---|
| 37 | +#include <drm/drm_auth.h> |
|---|
| 38 | +#include <drm/drm_hashtab.h> |
|---|
| 39 | + |
|---|
| 40 | +struct drm_device; |
|---|
| 41 | +struct drm_driver; |
|---|
| 42 | +struct file; |
|---|
| 43 | +struct pci_driver; |
|---|
| 39 | 44 | |
|---|
| 40 | 45 | /* |
|---|
| 41 | 46 | * Legacy Support for palateontologic DRM drivers |
|---|
| .. | .. |
|---|
| 131 | 136 | * Kernel side of a mapping |
|---|
| 132 | 137 | */ |
|---|
| 133 | 138 | struct drm_local_map { |
|---|
| 134 | | - resource_size_t offset; /**< Requested physical address (0 for SAREA)*/ |
|---|
| 139 | + dma_addr_t offset; /**< Requested physical address (0 for SAREA)*/ |
|---|
| 135 | 140 | unsigned long size; /**< Requested physical size (bytes) */ |
|---|
| 136 | 141 | enum drm_map_type type; /**< Type of memory to map */ |
|---|
| 137 | 142 | enum drm_map_flags flags; /**< Flags */ |
|---|
| .. | .. |
|---|
| 156 | 161 | int drm_legacy_addmap(struct drm_device *d, resource_size_t offset, |
|---|
| 157 | 162 | unsigned int size, enum drm_map_type type, |
|---|
| 158 | 163 | enum drm_map_flags flags, struct drm_local_map **map_p); |
|---|
| 164 | +struct drm_local_map *drm_legacy_findmap(struct drm_device *dev, unsigned int token); |
|---|
| 159 | 165 | void drm_legacy_rmmap(struct drm_device *d, struct drm_local_map *map); |
|---|
| 160 | 166 | int drm_legacy_rmmap_locked(struct drm_device *d, struct drm_local_map *map); |
|---|
| 161 | | -void drm_legacy_master_rmmaps(struct drm_device *dev, |
|---|
| 162 | | - struct drm_master *master); |
|---|
| 163 | 167 | struct drm_local_map *drm_legacy_getsarea(struct drm_device *dev); |
|---|
| 164 | 168 | int drm_legacy_mmap(struct file *filp, struct vm_area_struct *vma); |
|---|
| 165 | 169 | |
|---|
| .. | .. |
|---|
| 186 | 190 | void drm_legacy_idlelock_take(struct drm_lock_data *lock); |
|---|
| 187 | 191 | void drm_legacy_idlelock_release(struct drm_lock_data *lock); |
|---|
| 188 | 192 | |
|---|
| 189 | | -/* drm_pci.c dma alloc wrappers */ |
|---|
| 190 | | -void __drm_legacy_pci_free(struct drm_device *dev, drm_dma_handle_t * dmah); |
|---|
| 193 | +/* drm_pci.c */ |
|---|
| 194 | + |
|---|
| 195 | +#ifdef CONFIG_PCI |
|---|
| 196 | + |
|---|
| 197 | +struct drm_dma_handle *drm_pci_alloc(struct drm_device *dev, size_t size, |
|---|
| 198 | + size_t align); |
|---|
| 199 | +void drm_pci_free(struct drm_device *dev, struct drm_dma_handle *dmah); |
|---|
| 200 | + |
|---|
| 201 | +int drm_legacy_pci_init(struct drm_driver *driver, struct pci_driver *pdriver); |
|---|
| 202 | +void drm_legacy_pci_exit(struct drm_driver *driver, struct pci_driver *pdriver); |
|---|
| 203 | + |
|---|
| 204 | +#else |
|---|
| 205 | + |
|---|
| 206 | +static inline struct drm_dma_handle *drm_pci_alloc(struct drm_device *dev, |
|---|
| 207 | + size_t size, size_t align) |
|---|
| 208 | +{ |
|---|
| 209 | + return NULL; |
|---|
| 210 | +} |
|---|
| 211 | + |
|---|
| 212 | +static inline void drm_pci_free(struct drm_device *dev, |
|---|
| 213 | + struct drm_dma_handle *dmah) |
|---|
| 214 | +{ |
|---|
| 215 | +} |
|---|
| 216 | + |
|---|
| 217 | +static inline int drm_legacy_pci_init(struct drm_driver *driver, |
|---|
| 218 | + struct pci_driver *pdriver) |
|---|
| 219 | +{ |
|---|
| 220 | + return -EINVAL; |
|---|
| 221 | +} |
|---|
| 222 | + |
|---|
| 223 | +static inline void drm_legacy_pci_exit(struct drm_driver *driver, |
|---|
| 224 | + struct pci_driver *pdriver) |
|---|
| 225 | +{ |
|---|
| 226 | +} |
|---|
| 227 | + |
|---|
| 228 | +#endif |
|---|
| 191 | 229 | |
|---|
| 192 | 230 | /* drm_memory.c */ |
|---|
| 193 | 231 | void drm_legacy_ioremap(struct drm_local_map *map, struct drm_device *dev); |
|---|
| 194 | 232 | void drm_legacy_ioremap_wc(struct drm_local_map *map, struct drm_device *dev); |
|---|
| 195 | 233 | void drm_legacy_ioremapfree(struct drm_local_map *map, struct drm_device *dev); |
|---|
| 196 | | - |
|---|
| 197 | | -static inline struct drm_local_map *drm_legacy_findmap(struct drm_device *dev, |
|---|
| 198 | | - unsigned int token) |
|---|
| 199 | | -{ |
|---|
| 200 | | - struct drm_map_list *_entry; |
|---|
| 201 | | - list_for_each_entry(_entry, &dev->maplist, head) |
|---|
| 202 | | - if (_entry->user_token == token) |
|---|
| 203 | | - return _entry->map; |
|---|
| 204 | | - return NULL; |
|---|
| 205 | | -} |
|---|
| 206 | 234 | |
|---|
| 207 | 235 | #endif /* __DRM_DRM_LEGACY_H__ */ |
|---|