2 * AGPGART module version 0.99
3 * Copyright (C) 1999 Jeff Hartmann
4 * Copyright (C) 1999 Precision Insight, Inc.
5 * Copyright (C) 1999 Xi Graphics, Inc.
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the "Software"),
9 * to deal in the Software without restriction, including without limitation
10 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11 * and/or sell copies of the Software, and to permit persons to whom the
12 * Software is furnished to do so, subject to the following conditions:
14 * The above copyright notice and this permission notice shall be included
15 * in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * JEFF HARTMANN, OR ANY OTHER CONTRIBUTORS BE LIABLE FOR ANY CLAIM,
21 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
22 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
23 * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 #include <linux/mutex.h>
30 #include <linux/agp_backend.h>
31 #include <uapi/linux/agpgart.h>
34 struct agp_version version; /* version of the driver */
35 u32 bridge_id; /* bridge vendor/device */
36 u32 agp_mode; /* mode info of bridge */
37 unsigned long aper_base;/* base of aperture */
38 size_t aper_size; /* size of aperture */
39 size_t pg_total; /* max pages (swap + system) */
40 size_t pg_system; /* max pages (system) */
41 size_t pg_used; /* current pages used */
45 u32 agp_mode; /* mode info of bridge */
49 * The "prot" down below needs still a "sleep" flag somehow ...
52 off_t pg_start; /* starting page to populate */
53 size_t pg_count; /* number of pages */
54 int prot; /* prot flags for mmap */
57 struct agp_segment_priv {
64 pid_t pid; /* pid of process */
65 size_t seg_count; /* number of segments */
66 struct agp_segment *seg_list;
70 int key; /* tag of allocation */
71 size_t pg_count; /* number of pages */
72 u32 type; /* 0 == normal, other devspec */
73 u32 physical; /* device specific (some devices
74 * need a phys address of the
75 * actual page behind the gatt
80 int key; /* tag of allocation */
81 off_t pg_start; /* starting page to populate */
85 int key; /* tag of allocation */
86 u32 priority; /* priority for paging out */
90 struct agp_client *next;
91 struct agp_client *prev;
94 struct agp_segment_priv **segments;
97 struct agp_controller {
98 struct agp_controller *next;
99 struct agp_controller *prev;
102 struct agp_memory *pool;
103 struct agp_client *clients;
106 #define AGP_FF_ALLOW_CLIENT 0
107 #define AGP_FF_ALLOW_CONTROLLER 1
108 #define AGP_FF_IS_CLIENT 2
109 #define AGP_FF_IS_CONTROLLER 3
110 #define AGP_FF_IS_VALID 4
112 struct agp_file_private {
113 struct agp_file_private *next;
114 struct agp_file_private *prev;
116 unsigned long access_flags; /* long req'd for set_bit --RR */
119 struct agp_front_data {
120 struct mutex agp_mutex;
121 struct agp_controller *current_controller;
122 struct agp_controller *controllers;
123 struct agp_file_private *file_priv_list;
124 bool used_by_controller;
125 bool backend_acquired;