Linux kernel & device driver programming

Cross-Referenced Linux and Device Driver Code

[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ]
Version: [ 2.6.11.8 ] [ 2.6.25 ] [ 2.6.25.8 ] [ 2.6.31.13 ] Architecture: [ i386 ]
  1 /*
  2  * AGPGART driver.
  3  * Copyright (C) 2004 Silicon Graphics, Inc.
  4  * Copyright (C) 2002-2005 Dave Jones.
  5  * Copyright (C) 1999 Jeff Hartmann.
  6  * Copyright (C) 1999 Precision Insight, Inc.
  7  * Copyright (C) 1999 Xi Graphics, Inc.
  8  *
  9  * Permission is hereby granted, free of charge, to any person obtaining a
 10  * copy of this software and associated documentation files (the "Software"),
 11  * to deal in the Software without restriction, including without limitation
 12  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 13  * and/or sell copies of the Software, and to permit persons to whom the
 14  * Software is furnished to do so, subject to the following conditions:
 15  *
 16  * The above copyright notice and this permission notice shall be included
 17  * in all copies or substantial portions of the Software.
 18  *
 19  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 20  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 21  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 22  * JEFF HARTMANN, OR ANY OTHER CONTRIBUTORS BE LIABLE FOR ANY CLAIM,
 23  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 24  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
 25  * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 26  *
 27  * TODO:
 28  * - Allocate more than order 0 pages to avoid too much linear map splitting.
 29  */
 30 #include <linux/module.h>
 31 #include <linux/pci.h>
 32 #include <linux/init.h>
 33 #include <linux/pagemap.h>
 34 #include <linux/miscdevice.h>
 35 #include <linux/pm.h>
 36 #include <linux/agp_backend.h>
 37 #include <linux/vmalloc.h>
 38 #include <linux/dma-mapping.h>
 39 #include <linux/mm.h>
 40 #include <linux/sched.h>
 41 #include <asm/io.h>
 42 #include <asm/cacheflush.h>
 43 #include <asm/pgtable.h>
 44 #include "agp.h"
 45 
 46 __u32 *agp_gatt_table;
 47 int agp_memory_reserved;
 48 
 49 /*
 50  * Needed by the Nforce GART driver for the time being. Would be
 51  * nice to do this some other way instead of needing this export.
 52  */
 53 EXPORT_SYMBOL_GPL(agp_memory_reserved);
 54 
 55 /*
 56  * Generic routines for handling agp_memory structures -
 57  * They use the basic page allocation routines to do the brunt of the work.
 58  */
 59 
 60 void agp_free_key(int key)
 61 {
 62         if (key < 0)
 63                 return;
 64 
 65         if (key < MAXKEY)
 66                 clear_bit(key, agp_bridge->key_list);
 67 }
 68 EXPORT_SYMBOL(agp_free_key);
 69 
 70 
 71 static int agp_get_key(void)
 72 {
 73         int bit;
 74 
 75         bit = find_first_zero_bit(agp_bridge->key_list, MAXKEY);
 76         if (bit < MAXKEY) {
 77                 set_bit(bit, agp_bridge->key_list);
 78                 return bit;
 79         }
 80         return -1;
 81 }
 82 
 83 void agp_flush_chipset(struct agp_bridge_data *bridge)
 84 {
 85         if (bridge->driver->chipset_flush)
 86                 bridge->driver->chipset_flush(bridge);
 87 }
 88 EXPORT_SYMBOL(agp_flush_chipset);
 89 
 90 /*
 91  * Use kmalloc if possible for the page list. Otherwise fall back to
 92  * vmalloc. This speeds things up and also saves memory for small AGP
 93  * regions.
 94  */
 95 
 96 void agp_alloc_page_array(size_t size, struct agp_memory *mem)
 97 {
 98         mem->pages = NULL;
 99         mem->vmalloc_flag = false;
100 
101         if (size <= 2*PAGE_SIZE)
102                 mem->pages = kmalloc(size, GFP_KERNEL | __GFP_NORETRY);
103         if (mem->pages == NULL) {
104                 mem->pages = vmalloc(size);
105                 mem->vmalloc_flag = true;
106         }
107 }
108 EXPORT_SYMBOL(agp_alloc_page_array);
109 
110 void agp_free_page_array(struct agp_memory *mem)
111 {
112         if (mem->vmalloc_flag) {
113                 vfree(mem->pages);
114         } else {
115                 kfree(mem->pages);
116         }
117 }
118 EXPORT_SYMBOL(agp_free_page_array);
119 
120 
121 static struct agp_memory *agp_create_user_memory(unsigned long num_agp_pages)
122 {
123         struct agp_memory *new;
124         unsigned long alloc_size = num_agp_pages*sizeof(struct page *);
125 
126         new = kzalloc(sizeof(struct agp_memory), GFP_KERNEL);
127         if (new == NULL)
128                 return NULL;
129 
130         new->key = agp_get_key();
131 
132         if (new->key < 0) {
133                 kfree(new);
134                 return NULL;
135         }
136 
137         agp_alloc_page_array(alloc_size, new);
138 
139         if (new->pages == NULL) {
140                 agp_free_key(new->key);
141                 kfree(new);
142                 return NULL;
143         }
144         new->num_scratch_pages = 0;
145         return new;
146 }
147 
148 struct agp_memory *agp_create_memory(int scratch_pages)
149 {
150         struct agp_memory *new;
151 
152         new = kzalloc(sizeof(struct agp_memory), GFP_KERNEL);
153         if (new == NULL)
154                 return NULL;
155 
156         new->key = agp_get_key();
157 
158         if (new->key < 0) {
159                 kfree(new);
160                 return NULL;
161         }
162 
163         agp_alloc_page_array(PAGE_SIZE * scratch_pages, new);
164 
165         if (new->pages == NULL) {
166                 agp_free_key(new->key);
167                 kfree(new);
168                 return NULL;
169         }
170         new->num_scratch_pages = scratch_pages;
171         new->type = AGP_NORMAL_MEMORY;
172         return new;
173 }
174 EXPORT_SYMBOL(agp_create_memory);
175 
176 /**
177  *      agp_free_memory - free memory associated with an agp_memory pointer.
178  *
179  *      @curr:          agp_memory pointer to be freed.
180  *
181  *      It is the only function that can be called when the backend is not owned
182  *      by the caller.  (So it can free memory on client death.)
183  */
184 void agp_free_memory(struct agp_memory *curr)
185 {
186         size_t i;
187 
188         if (curr == NULL)
189                 return;
190 
191         if (curr->is_bound)
192                 agp_unbind_memory(curr);
193 
194         if (curr->type >= AGP_USER_TYPES) {
195                 agp_generic_free_by_type(curr);
196                 return;
197         }
198 
199         if (curr->type != 0) {
200                 curr->bridge->driver->free_by_type(curr);
201                 return;
202         }
203         if (curr->page_count != 0) {
204                 if (curr->bridge->driver->agp_destroy_pages) {
205                         curr->bridge->driver->agp_destroy_pages(curr);
206                 } else {
207 
208                         for (i = 0; i < curr->page_count; i++) {
209                                 curr->bridge->driver->agp_destroy_page(
210                                         curr->pages[i],
211                                         AGP_PAGE_DESTROY_UNMAP);
212                         }
213                         for (i = 0; i < curr->page_count; i++) {
214                                 curr->bridge->driver->agp_destroy_page(
215                                         curr->pages[i],
216                                         AGP_PAGE_DESTROY_FREE);
217                         }
218                 }
219         }
220         agp_free_key(curr->key);
221         agp_free_page_array(curr);
222         kfree(curr);
223 }
224 EXPORT_SYMBOL(agp_free_memory);
225 
226 #define ENTRIES_PER_PAGE                (PAGE_SIZE / sizeof(unsigned long))
227 
228 /**
229  *      agp_allocate_memory  -  allocate a group of pages of a certain type.
230  *
231  *      @page_count:    size_t argument of the number of pages
232  *      @type:  u32 argument of the type of memory to be allocated.
233  *
234  *      Every agp bridge device will allow you to allocate AGP_NORMAL_MEMORY which
235  *      maps to physical ram.  Any other type is device dependent.
236  *
237  *      It returns NULL whenever memory is unavailable.
238  */
239 struct agp_memory *agp_allocate_memory(struct agp_bridge_data *bridge,
240                                         size_t page_count, u32 type)
241 {
242         int scratch_pages;
243         struct agp_memory *new;
244         size_t i;
245 
246         if (!bridge)
247                 return NULL;
248 
249         if ((atomic_read(&bridge->current_memory_agp) + page_count) > bridge->max_memory_agp)
250                 return NULL;
251 
252         if (type >= AGP_USER_TYPES) {
253                 new = agp_generic_alloc_user(page_count, type);
254                 if (new)
255                         new->bridge = bridge;
256                 return new;
257         }
258 
259         if (type != 0) {
260                 new = bridge->driver->alloc_by_type(page_count, type);
261                 if (new)
262                         new->bridge = bridge;
263                 return new;
264         }
265 
266         scratch_pages = (page_count + ENTRIES_PER_PAGE - 1) / ENTRIES_PER_PAGE;
267 
268         new = agp_create_memory(scratch_pages);
269 
270         if (new == NULL)
271                 return NULL;
272 
273         if (bridge->driver->agp_alloc_pages) {
274                 if (bridge->driver->agp_alloc_pages(bridge, new, page_count)) {
275                         agp_free_memory(new);
276                         return NULL;
277                 }
278                 new->bridge = bridge;
279                 return new;
280         }
281 
282         for (i = 0; i < page_count; i++) {
283                 struct page *page = bridge->driver->agp_alloc_page(bridge);
284 
285                 if (page == NULL) {
286                         agp_free_memory(new);
287                         return NULL;
288                 }
289                 new->pages[i] = page;
290                 new->page_count++;
291         }
292         new->bridge = bridge;
293 
294         return new;
295 }
296 EXPORT_SYMBOL(agp_allocate_memory);
297 
298 
299 /* End - Generic routines for handling agp_memory structures */
300 
301 
302 static int agp_return_size(void)
303 {
304         int current_size;
305         void *temp;
306 
307         temp = agp_bridge->current_size;
308 
309         switch (agp_bridge->driver->size_type) {
310         case U8_APER_SIZE:
311                 current_size = A_SIZE_8(temp)->size;
312                 break;
313         case U16_APER_SIZE:
314                 current_size = A_SIZE_16(temp)->size;
315                 break;
316         case U32_APER_SIZE:
317                 current_size = A_SIZE_32(temp)->size;
318                 break;
319         case LVL2_APER_SIZE:
320                 current_size = A_SIZE_LVL2(temp)->size;
321                 break;
322         case FIXED_APER_SIZE:
323                 current_size = A_SIZE_FIX(temp)->size;
324                 break;
325         default:
326                 current_size = 0;
327                 break;
328         }
329 
330         current_size -= (agp_memory_reserved / (1024*1024));
331         if (current_size <0)
332                 current_size = 0;
333         return current_size;
334 }
335 
336 
337 int agp_num_entries(void)
338 {
339         int num_entries;
340         void *temp;
341 
342         temp = agp_bridge->current_size;
343 
344         switch (agp_bridge->driver->size_type) {
345         case U8_APER_SIZE:
346                 num_entries = A_SIZE_8(temp)->num_entries;
347                 break;
348         case U16_APER_SIZE:
349                 num_entries = A_SIZE_16(temp)->num_entries;
350                 break;
351         case U32_APER_SIZE:
352                 num_entries = A_SIZE_32(temp)->num_entries;
353                 break;
354         case LVL2_APER_SIZE:
355                 num_entries = A_SIZE_LVL2(temp)->num_entries;
356                 break;
357         case FIXED_APER_SIZE:
358                 num_entries = A_SIZE_FIX(temp)->num_entries;
359                 break;
360         default:
361                 num_entries = 0;
362                 break;
363         }
364 
365         num_entries -= agp_memory_reserved>>PAGE_SHIFT;
366         if (num_entries<0)
367                 num_entries = 0;
368         return num_entries;
369 }
370 EXPORT_SYMBOL_GPL(agp_num_entries);
371 
372 
373 /**
374  *      agp_copy_info  -  copy bridge state information
375  *
376  *      @info:          agp_kern_info pointer.  The caller should insure that this pointer is valid.
377  *
378  *      This function copies information about the agp bridge device and the state of
379  *      the agp backend into an agp_kern_info pointer.
380  */
381 int agp_copy_info(struct agp_bridge_data *bridge, struct agp_kern_info *info)
382 {
383         memset(info, 0, sizeof(struct agp_kern_info));
384         if (!bridge) {
385                 info->chipset = NOT_SUPPORTED;
386                 return -EIO;
387         }
388 
389         info->version.major = bridge->version->major;
390         info->version.minor = bridge->version->minor;
391         info->chipset = SUPPORTED;
392         info->device = bridge->dev;
393         if (bridge->mode & AGPSTAT_MODE_3_0)
394                 info->mode = bridge->mode & ~AGP3_RESERVED_MASK;
395         else
396                 info->mode = bridge->mode & ~AGP2_RESERVED_MASK;
397         info->aper_base = bridge->gart_bus_addr;
398         info->aper_size = agp_return_size();
399         info->max_memory = bridge->max_memory_agp;
400         info->current_memory = atomic_read(&bridge->current_memory_agp);
401         info->cant_use_aperture = bridge->driver->cant_use_aperture;
402         info->vm_ops = bridge->vm_ops;
403         info->page_mask = ~0UL;
404         return 0;
405 }
406 EXPORT_SYMBOL(agp_copy_info);
407 
408 /* End - Routine to copy over information structure */
409 
410 /*
411  * Routines for handling swapping of agp_memory into the GATT -
412  * These routines take agp_memory and insert them into the GATT.
413  * They call device specific routines to actually write to the GATT.
414  */
415 
416 /**
417  *      agp_bind_memory  -  Bind an agp_memory structure into the GATT.
418  *
419  *      @curr:          agp_memory pointer
420  *      @pg_start:      an offset into the graphics aperture translation table
421  *
422  *      It returns -EINVAL if the pointer == NULL.
423  *      It returns -EBUSY if the area of the table requested is already in use.
424  */
425 int agp_bind_memory(struct agp_memory *curr, off_t pg_start)
426 {
427         int ret_val;
428 
429         if (curr == NULL)
430                 return -EINVAL;
431 
432         if (curr->is_bound) {
433                 printk(KERN_INFO PFX "memory %p is already bound!\n", curr);
434                 return -EINVAL;
435         }
436         if (!curr->is_flushed) {
437                 curr->bridge->driver->cache_flush();
438                 curr->is_flushed = true;
439         }
440         ret_val = curr->bridge->driver->insert_memory(curr, pg_start, curr->type);
441 
442         if (ret_val != 0)
443                 return ret_val;
444 
445         curr->is_bound = true;
446         curr->pg_start = pg_start;
447         spin_lock(&agp_bridge->mapped_lock);
448         list_add(&curr->mapped_list, &agp_bridge->mapped_list);
449         spin_unlock(&agp_bridge->mapped_lock);
450 
451         return 0;
452 }
453 EXPORT_SYMBOL(agp_bind_memory);
454 
455 
456 /**
457  *      agp_unbind_memory  -  Removes an agp_memory structure from the GATT
458  *
459  * @curr:       agp_memory pointer to be removed from the GATT.
460  *
461  * It returns -EINVAL if this piece of agp_memory is not currently bound to
462  * the graphics aperture translation table or if the agp_memory pointer == NULL
463  */
464 int agp_unbind_memory(struct agp_memory *curr)
465 {
466         int ret_val;
467 
468         if (curr == NULL)
469                 return -EINVAL;
470 
471         if (!curr->is_bound) {
472                 printk(KERN_INFO PFX "memory %p was not bound!\n", curr);
473                 return -EINVAL;
474         }
475 
476         ret_val = curr->bridge->driver->remove_memory(curr, curr->pg_start, curr->type);
477 
478         if (ret_val != 0)
479                 return ret_val;
480 
481         curr->is_bound = false;
482         curr->pg_start = 0;
483         spin_lock(&curr->bridge->mapped_lock);
484         list_del(&curr->mapped_list);
485         spin_unlock(&curr->bridge->mapped_lock);
486         return 0;
487 }
488 EXPORT_SYMBOL(agp_unbind_memory);
489 
490 /**
491  *      agp_rebind_emmory  -  Rewrite the entire GATT, useful on resume
492  */
493 int agp_rebind_memory(void)
494 {
495         struct agp_memory *curr;
496         int ret_val = 0;
497 
498         spin_lock(&agp_bridge->mapped_lock);
499         list_for_each_entry(curr, &agp_bridge->mapped_list, mapped_list) {
500                 ret_val = curr->bridge->driver->insert_memory(curr,
501                                                               curr->pg_start,
502                                                               curr->type);
503                 if (ret_val != 0)
504                         break;
505         }
506         spin_unlock(&agp_bridge->mapped_lock);
507         return ret_val;
508 }
509 EXPORT_SYMBOL(agp_rebind_memory);
510 
511 /* End - Routines for handling swapping of agp_memory into the GATT */
512 
513 
514 /* Generic Agp routines - Start */
515 static void agp_v2_parse_one(u32 *requested_mode, u32 *bridge_agpstat, u32 *vga_agpstat)
516 {
517         u32 tmp;
518 
519         if (*requested_mode & AGP2_RESERVED_MASK) {
520                 printk(KERN_INFO PFX "reserved bits set (%x) in mode 0x%x. Fixed.\n",
521                         *requested_mode & AGP2_RESERVED_MASK, *requested_mode);
522                 *requested_mode &= ~AGP2_RESERVED_MASK;
523         }
524 
525         /*
526          * Some dumb bridges are programmed to disobey the AGP2 spec.
527          * This is likely a BIOS misprogramming rather than poweron default, or
528          * it would be a lot more common.
529          * https://bugs.freedesktop.org/show_bug.cgi?id=8816
530          * AGPv2 spec 6.1.9 states:
531          *   The RATE field indicates the data transfer rates supported by this
532          *   device. A.G.P. devices must report all that apply.
533          * Fix them up as best we can.
534          */
535         switch (*bridge_agpstat & 7) {
536         case 4:
537                 *bridge_agpstat |= (AGPSTAT2_2X | AGPSTAT2_1X);
538                 printk(KERN_INFO PFX "BIOS bug. AGP bridge claims to only support x4 rate"
539                         "Fixing up support for x2 & x1\n");
540                 break;
541         case 2:
542                 *bridge_agpstat |= AGPSTAT2_1X;
543                 printk(KERN_INFO PFX "BIOS bug. AGP bridge claims to only support x2 rate"
544                         "Fixing up support for x1\n");
545                 break;
546         default:
547                 break;
548         }
549 
550         /* Check the speed bits make sense. Only one should be set. */
551         tmp = *requested_mode & 7;
552         switch (tmp) {
553                 case 0:
554                         printk(KERN_INFO PFX "%s tried to set rate=x0. Setting to x1 mode.\n", current->comm);
555                         *requested_mode |= AGPSTAT2_1X;
556                         break;
557                 case 1:
558                 case 2:
559                         break;
560                 case 3:
561                         *requested_mode &= ~(AGPSTAT2_1X);      /* rate=2 */
562                         break;
563                 case 4:
564                         break;
565                 case 5:
566                 case 6:
567                 case 7:
568                         *requested_mode &= ~(AGPSTAT2_1X|AGPSTAT2_2X); /* rate=4*/
569                         break;
570         }
571 
572         /* disable SBA if it's not supported */
573         if (!((*bridge_agpstat & AGPSTAT_SBA) && (*vga_agpstat & AGPSTAT_SBA) && (*requested_mode & AGPSTAT_SBA)))
574                 *bridge_agpstat &= ~AGPSTAT_SBA;
575 
576         /* Set rate */
577         if (!((*bridge_agpstat & AGPSTAT2_4X) && (*vga_agpstat & AGPSTAT2_4X) && (*requested_mode & AGPSTAT2_4X)))
578                 *bridge_agpstat &= ~AGPSTAT2_4X;
579 
580         if (!((*bridge_agpstat & AGPSTAT2_2X) && (*vga_agpstat & AGPSTAT2_2X) && (*requested_mode & AGPSTAT2_2X)))
581                 *bridge_agpstat &= ~AGPSTAT2_2X;
582 
583         if (!((*bridge_agpstat & AGPSTAT2_1X) && (*vga_agpstat & AGPSTAT2_1X) && (*requested_mode & AGPSTAT2_1X)))
584                 *bridge_agpstat &= ~AGPSTAT2_1X;
585 
586         /* Now we know what mode it should be, clear out the unwanted bits. */
587         if (*bridge_agpstat & AGPSTAT2_4X)
588                 *bridge_agpstat &= ~(AGPSTAT2_1X | AGPSTAT2_2X);        /* 4X */
589 
590         if (*bridge_agpstat & AGPSTAT2_2X)
591                 *bridge_agpstat &= ~(AGPSTAT2_1X | AGPSTAT2_4X);        /* 2X */
592 
593         if (*bridge_agpstat & AGPSTAT2_1X)
594                 *bridge_agpstat &= ~(AGPSTAT2_2X | AGPSTAT2_4X);        /* 1X */
595 
596         /* Apply any errata. */
597         if (agp_bridge->flags & AGP_ERRATA_FASTWRITES)
598                 *bridge_agpstat &= ~AGPSTAT_FW;
599 
600         if (agp_bridge->flags & AGP_ERRATA_SBA)
601                 *bridge_agpstat &= ~AGPSTAT_SBA;
602 
603         if (agp_bridge->flags & AGP_ERRATA_1X) {
604                 *bridge_agpstat &= ~(AGPSTAT2_2X | AGPSTAT2_4X);
605                 *bridge_agpstat |= AGPSTAT2_1X;
606         }
607 
608         /* If we've dropped down to 1X, disable fast writes. */
609         if (*bridge_agpstat & AGPSTAT2_1X)
610                 *bridge_agpstat &= ~AGPSTAT_FW;
611 }
612 
613 /*
614  * requested_mode = Mode requested by (typically) X.
615  * bridge_agpstat = PCI_AGP_STATUS from agp bridge.
616  * vga_agpstat = PCI_AGP_STATUS from graphic card.
617  */
618 static void agp_v3_parse_one(u32 *requested_mode, u32 *bridge_agpstat, u32 *vga_agpstat)
619 {
620         u32 origbridge=*bridge_agpstat, origvga=*vga_agpstat;
621         u32 tmp;
622 
623         if (*requested_mode & AGP3_RESERVED_MASK) {
624                 printk(KERN_INFO PFX "reserved bits set (%x) in mode 0x%x. Fixed.\n",
625                         *requested_mode & AGP3_RESERVED_MASK, *requested_mode);
626                 *requested_mode &= ~AGP3_RESERVED_MASK;
627         }
628 
629         /* Check the speed bits make sense. */
630         tmp = *requested_mode & 7;
631         if (tmp == 0) {
632                 printk(KERN_INFO PFX "%s tried to set rate=x0. Setting to AGP3 x4 mode.\n", current->comm);
633                 *requested_mode |= AGPSTAT3_4X;
634         }
635         if (tmp >= 3) {
636                 printk(KERN_INFO PFX "%s tried to set rate=x%d. Setting to AGP3 x8 mode.\n", current->comm, tmp * 4);
637                 *requested_mode = (*requested_mode & ~7) | AGPSTAT3_8X;
638         }
639 
640         /* ARQSZ - Set the value to the maximum one.
641          * Don't allow the mode register to override values. */
642         *bridge_agpstat = ((*bridge_agpstat & ~AGPSTAT_ARQSZ) |
643                 max_t(u32,(*bridge_agpstat & AGPSTAT_ARQSZ),(*vga_agpstat & AGPSTAT_ARQSZ)));
644 
645         /* Calibration cycle.
646          * Don't allow the mode register to override values. */
647         *bridge_agpstat = ((*bridge_agpstat & ~AGPSTAT_CAL_MASK) |
648                 min_t(u32,(*bridge_agpstat & AGPSTAT_CAL_MASK),(*vga_agpstat & AGPSTAT_CAL_MASK)));
649 
650         /* SBA *must* be supported for AGP v3 */
651         *bridge_agpstat |= AGPSTAT_SBA;
652 
653         /*
654          * Set speed.
655          * Check for invalid speeds. This can happen when applications
656          * written before the AGP 3.0 standard pass AGP2.x modes to AGP3 hardware
657          */
658         if (*requested_mode & AGPSTAT_MODE_3_0) {
659                 /*
660                  * Caller hasn't a clue what it is doing. Bridge is in 3.0 mode,
661                  * have been passed a 3.0 mode, but with 2.x speed bits set.
662                  * AGP2.x 4x -> AGP3.0 4x.
663                  */
664                 if (*requested_mode & AGPSTAT2_4X) {
665                         printk(KERN_INFO PFX "%s passes broken AGP3 flags (%x). Fixed.\n",
666                                                 current->comm, *requested_mode);
667                         *requested_mode &= ~AGPSTAT2_4X;
668                         *requested_mode |= AGPSTAT3_4X;
669                 }
670         } else {
671                 /*
672                  * The caller doesn't know what they are doing. We are in 3.0 mode,
673                  * but have been passed an AGP 2.x mode.
674                  * Convert AGP 1x,2x,4x -> AGP 3.0 4x.
675                  */
676                 printk(KERN_INFO PFX "%s passes broken AGP2 flags (%x) in AGP3 mode. Fixed.\n",
677                                         current->comm, *requested_mode);
678                 *requested_mode &= ~(AGPSTAT2_4X | AGPSTAT2_2X | AGPSTAT2_1X);
679                 *requested_mode |= AGPSTAT3_4X;
680         }
681 
682         if (*requested_mode & AGPSTAT3_8X) {
683                 if (!(*bridge_agpstat & AGPSTAT3_8X)) {
684                         *bridge_agpstat &= ~(AGPSTAT3_8X | AGPSTAT3_RSVD);
685                         *bridge_agpstat |= AGPSTAT3_4X;
686                         printk(KERN_INFO PFX "%s requested AGPx8 but bridge not capable.\n", current->comm);
687                         return;
688                 }
689                 if (!(*vga_agpstat & AGPSTAT3_8X)) {
690                         *bridge_agpstat &= ~(AGPSTAT3_8X | AGPSTAT3_RSVD);
691                         *bridge_agpstat |= AGPSTAT3_4X;
692                         printk(KERN_INFO PFX "%s requested AGPx8 but graphic card not capable.\n", current->comm);
693                         return;
694                 }
695                 /* All set, bridge & device can do AGP x8*/
696                 *bridge_agpstat &= ~(AGPSTAT3_4X | AGPSTAT3_RSVD);
697                 goto done;
698 
699         } else if (*requested_mode & AGPSTAT3_4X) {
700                 *bridge_agpstat &= ~(AGPSTAT3_8X | AGPSTAT3_RSVD);
701                 *bridge_agpstat |= AGPSTAT3_4X;
702                 goto done;
703 
704         } else {
705 
706                 /*
707                  * If we didn't specify an AGP mode, we see if both
708                  * the graphics card, and the bridge can do x8, and use if so.
709                  * If not, we fall back to x4 mode.
710                  */
711                 if ((*bridge_agpstat & AGPSTAT3_8X) && (*vga_agpstat & AGPSTAT3_8X)) {
712                         printk(KERN_INFO PFX "No AGP mode specified. Setting to highest mode "
713                                 "supported by bridge & card (x8).\n");
714                         *bridge_agpstat &= ~(AGPSTAT3_4X | AGPSTAT3_RSVD);
715                         *vga_agpstat &= ~(AGPSTAT3_4X | AGPSTAT3_RSVD);
716                 } else {
717                         printk(KERN_INFO PFX "Fell back to AGPx4 mode because");
718                         if (!(*bridge_agpstat & AGPSTAT3_8X)) {
719                                 printk(KERN_INFO PFX "bridge couldn't do x8. bridge_agpstat:%x (orig=%x)\n",
720                                         *bridge_agpstat, origbridge);
721                                 *bridge_agpstat &= ~(AGPSTAT3_8X | AGPSTAT3_RSVD);
722                                 *bridge_agpstat |= AGPSTAT3_4X;
723                         }
724                         if (!(*vga_agpstat & AGPSTAT3_8X)) {
725                                 printk(KERN_INFO PFX "graphics card couldn't do x8. vga_agpstat:%x (orig=%x)\n",
726                                         *vga_agpstat, origvga);
727                                 *vga_agpstat &= ~(AGPSTAT3_8X | AGPSTAT3_RSVD);
728                                 *vga_agpstat |= AGPSTAT3_4X;
729                         }
730                 }
731         }
732 
733 done:
734         /* Apply any errata. */
735         if (agp_bridge->flags & AGP_ERRATA_FASTWRITES)
736                 *bridge_agpstat &= ~AGPSTAT_FW;
737 
738         if (agp_bridge->flags & AGP_ERRATA_SBA)
739                 *bridge_agpstat &= ~AGPSTAT_SBA;
740 
741         if (agp_bridge->flags & AGP_ERRATA_1X) {
742                 *bridge_agpstat &= ~(AGPSTAT2_2X | AGPSTAT2_4X);
743                 *bridge_agpstat |= AGPSTAT2_1X;
744         }
745 }
746 
747 
748 /**
749  * agp_collect_device_status - determine correct agp_cmd from various agp_stat's
750  * @bridge: an agp_bridge_data struct allocated for the AGP host bridge.
751  * @requested_mode: requested agp_stat from userspace (Typically from X)
752  * @bridge_agpstat: current agp_stat from AGP bridge.
753  *
754  * This function will hunt for an AGP graphics card, and try to match
755  * the requested mode to the capabilities of both the bridge and the card.
756  */
757 u32 agp_collect_device_status(struct agp_bridge_data *bridge, u32 requested_mode, u32 bridge_agpstat)
758 {
759         struct pci_dev *device = NULL;
760         u32 vga_agpstat;
761         u8 cap_ptr;
762 
763         for (;;) {
764                 device = pci_get_class(PCI_CLASS_DISPLAY_VGA << 8, device);
765                 if (!device) {
766                         printk(KERN_INFO PFX "Couldn't find an AGP VGA controller.\n");
767                         return 0;
768                 }
769                 cap_ptr = pci_find_capability(device, PCI_CAP_ID_AGP);
770                 if (cap_ptr)
771                         break;
772         }
773 
774         /*
775          * Ok, here we have a AGP device. Disable impossible
776          * settings, and adjust the readqueue to the minimum.
777          */
778         pci_read_config_dword(device, cap_ptr+PCI_AGP_STATUS, &vga_agpstat);
779 
780         /* adjust RQ depth */
781         bridge_agpstat = ((bridge_agpstat & ~AGPSTAT_RQ_DEPTH) |
782              min_t(u32, (requested_mode & AGPSTAT_RQ_DEPTH),
783                  min_t(u32, (bridge_agpstat & AGPSTAT_RQ_DEPTH), (vga_agpstat & AGPSTAT_RQ_DEPTH))));
784 
785         /* disable FW if it's not supported */
786         if (!((bridge_agpstat & AGPSTAT_FW) &&
787                  (vga_agpstat & AGPSTAT_FW) &&
788                  (requested_mode & AGPSTAT_FW)))
789                 bridge_agpstat &= ~AGPSTAT_FW;
790 
791         /* Check to see if we are operating in 3.0 mode */
792         if (agp_bridge->mode & AGPSTAT_MODE_3_0)
793                 agp_v3_parse_one(&requested_mode, &bridge_agpstat, &vga_agpstat);
794         else
795                 agp_v2_parse_one(&requested_mode, &bridge_agpstat, &vga_agpstat);
796 
797         pci_dev_put(device);
798         return bridge_agpstat;
799 }
800 EXPORT_SYMBOL(agp_collect_device_status);
801 
802 
803 void agp_device_command(u32 bridge_agpstat, bool agp_v3)
804 {
805         struct pci_dev *device = NULL;
806         int mode;
807 
808         mode = bridge_agpstat & 0x7;
809         if (agp_v3)
810                 mode *= 4;
811 
812         for_each_pci_dev(device) {
813                 u8 agp = pci_find_capability(device, PCI_CAP_ID_AGP);
814                 if (!agp)
815                         continue;
816 
817                 dev_info(&device->dev, "putting AGP V%d device into %dx mode\n",
818                          agp_v3 ? 3 : 2, mode);
819                 pci_write_config_dword(device, agp + PCI_AGP_COMMAND, bridge_agpstat);
820         }
821 }
822 EXPORT_SYMBOL(agp_device_command);
823 
824 
825 void get_agp_version(struct agp_bridge_data *bridge)
826 {
827         u32 ncapid;
828 
829         /* Exit early if already set by errata workarounds. */
830         if (bridge->major_version != 0)
831                 return;
832 
833         pci_read_config_dword(bridge->dev, bridge->capndx, &ncapid);
834         bridge->major_version = (ncapid >> AGP_MAJOR_VERSION_SHIFT) & 0xf;
835         bridge->minor_version = (ncapid >> AGP_MINOR_VERSION_SHIFT) & 0xf;
836 }
837 EXPORT_SYMBOL(get_agp_version);
838 
839 
840 void agp_generic_enable(struct agp_bridge_data *bridge, u32 requested_mode)
841 {
842         u32 bridge_agpstat, temp;
843 
844         get_agp_version(agp_bridge);
845 
846         dev_info(&agp_bridge->dev->dev, "AGP %d.%d bridge\n",
847                  agp_bridge->major_version, agp_bridge->minor_version);
848 
849         pci_read_config_dword(agp_bridge->dev,
850                       agp_bridge->capndx + PCI_AGP_STATUS, &bridge_agpstat);
851 
852         bridge_agpstat = agp_collect_device_status(agp_bridge, requested_mode, bridge_agpstat);
853         if (bridge_agpstat == 0)
854                 /* Something bad happened. FIXME: Return error code? */
855                 return;
856 
857         bridge_agpstat |= AGPSTAT_AGP_ENABLE;
858 
859         /* Do AGP version specific frobbing. */
860         if (bridge->major_version >= 3) {
861                 if (bridge->mode & AGPSTAT_MODE_3_0) {
862                         /* If we have 3.5, we can do the isoch stuff. */
863                         if (bridge->minor_version >= 5)
864                                 agp_3_5_enable(bridge);
865                         agp_device_command(bridge_agpstat, true);
866                         return;
867                 } else {
868                     /* Disable calibration cycle in RX91<1> when not in AGP3.0 mode of operation.*/
869                     bridge_agpstat &= ~(7<<10) ;
870                     pci_read_config_dword(bridge->dev,
871                                         bridge->capndx+AGPCTRL, &temp);
872                     temp |= (1<<9);
873                     pci_write_config_dword(bridge->dev,
874                                         bridge->capndx+AGPCTRL, temp);
875 
876                     dev_info(&bridge->dev->dev, "bridge is in legacy mode, falling back to 2.x\n");
877                 }
878         }
879 
880         /* AGP v<3 */
881         agp_device_command(bridge_agpstat, false);
882 }
883 EXPORT_SYMBOL(agp_generic_enable);
884 
885 
886 int agp_generic_create_gatt_table(struct agp_bridge_data *bridge)
887 {
888         char *table;
889         char *table_end;
890         int size;
891         int page_order;
892         int num_entries;
893         int i;
894         void *temp;
895         struct page *page;
896 
897         /* The generic routines can't handle 2 level gatt's */
898         if (bridge->driver->size_type == LVL2_APER_SIZE)
899                 return -EINVAL;
900 
901         table = NULL;
902         i = bridge->aperture_size_idx;
903         temp = bridge->current_size;
904         size = page_order = num_entries = 0;
905 
906         if (bridge->driver->size_type != FIXED_APER_SIZE) {
907                 do {
908                         switch (bridge->driver->size_type) {
909                         case U8_APER_SIZE:
910                                 size = A_SIZE_8(temp)->size;
911                                 page_order =
912                                     A_SIZE_8(temp)->page_order;
913                                 num_entries =
914                                     A_SIZE_8(temp)->num_entries;
915                                 break;
916                         case U16_APER_SIZE:
917                                 size = A_SIZE_16(temp)->size;
918                                 page_order = A_SIZE_16(temp)->page_order;
919                                 num_entries = A_SIZE_16(temp)->num_entries;
920                                 break;
921                         case U32_APER_SIZE:
922                                 size = A_SIZE_32(temp)->size;
923                                 page_order = A_SIZE_32(temp)->page_order;
924                                 num_entries = A_SIZE_32(temp)->num_entries;
925                                 break;
926                                 /* This case will never really happen. */
927                         case FIXED_APER_SIZE:
928                         case LVL2_APER_SIZE:
929                         default:
930                                 size = page_order = num_entries = 0;
931                                 break;
932                         }
933 
934                         table = alloc_gatt_pages(page_order);
935 
936                         if (table == NULL) {
937                                 i++;
938                                 switch (bridge->driver->size_type) {
939                                 case U8_APER_SIZE:
940                                         bridge->current_size = A_IDX8(bridge);
941                                         break;
942                                 case U16_APER_SIZE:
943                                         bridge->current_size = A_IDX16(bridge);
944                                         break;
945                                 case U32_APER_SIZE:
946                                         bridge->current_size = A_IDX32(bridge);
947                                         break;
948                                 /* These cases will never really happen. */
949                                 case FIXED_APER_SIZE:
950                                 case LVL2_APER_SIZE:
951                                 default:
952                                         break;
953                                 }
954                                 temp = bridge->current_size;
955                         } else {
956                                 bridge->aperture_size_idx = i;
957                         }
958                 } while (!table && (i < bridge->driver->num_aperture_sizes));
959         } else {
960                 size = ((struct aper_size_info_fixed *) temp)->size;
961                 page_order = ((struct aper_size_info_fixed *) temp)->page_order;
962                 num_entries = ((struct aper_size_info_fixed *) temp)->num_entries;
963                 table = alloc_gatt_pages(page_order);
964         }
965 
966         if (table == NULL)
967                 return -ENOMEM;
968 
969         table_end = table + ((PAGE_SIZE * (1 << page_order)) - 1);
970 
971         for (page = virt_to_page(table); page <= virt_to_page(table_end); page++)
972                 SetPageReserved(page);
973 
974         bridge->gatt_table_real = (u32 *) table;
975         agp_gatt_table = (void *)table;
976 
977         bridge->driver->cache_flush();
978 #ifdef CONFIG_X86
979         set_memory_uc((unsigned long)table, 1 << page_order);
980         bridge->gatt_table = (void *)table;
981 #else
982         bridge->gatt_table = ioremap_nocache(virt_to_gart(table),
983                                         (PAGE_SIZE * (1 << page_order)));
984         bridge->driver->cache_flush();
985 #endif
986 
987         if (bridge->gatt_table == NULL) {
988                 for (page = virt_to_page(table); page <= virt_to_page(table_end); page++)
989                         ClearPageReserved(page);
990 
991                 free_gatt_pages(table, page_order);
992 
993                 return -ENOMEM;
994         }
995         bridge->gatt_bus_addr = virt_to_gart(bridge->gatt_table_real);
996 
997         /* AK: bogus, should encode addresses > 4GB */
998         for (i = 0; i < num_entries; i++) {
999                 writel(bridge->scratch_page, bridge->gatt_table+i);
1000                 readl(bridge->gatt_table+i);    /* PCI Posting. */
1001         }
1002 
1003         return 0;
1004 }
1005 EXPORT_SYMBOL(agp_generic_create_gatt_table);
1006 
1007 int agp_generic_free_gatt_table(struct agp_bridge_data *bridge)
1008 {
1009         int page_order;
1010         char *table, *table_end;
1011         void *temp;
1012         struct page *page;
1013 
1014         temp = bridge->current_size;
1015 
1016         switch (bridge->driver->size_type) {
1017         case U8_APER_SIZE:
1018                 page_order = A_SIZE_8(temp)->page_order;
1019                 break;
1020         case U16_APER_SIZE:
1021                 page_order = A_SIZE_16(temp)->page_order;
1022                 break;
1023         case U32_APER_SIZE:
1024                 page_order = A_SIZE_32(temp)->page_order;
1025                 break;
1026         case FIXED_APER_SIZE:
1027                 page_order = A_SIZE_FIX(temp)->page_order;
1028                 break;
1029         case LVL2_APER_SIZE:
1030                 /* The generic routines can't deal with 2 level gatt's */
1031                 return -EINVAL;
1032                 break;
1033         default:
1034                 page_order = 0;
1035                 break;
1036         }
1037 
1038         /* Do not worry about freeing memory, because if this is
1039          * called, then all agp memory is deallocated and removed
1040          * from the table. */
1041 
1042 #ifdef CONFIG_X86
1043         set_memory_wb((unsigned long)bridge->gatt_table, 1 << page_order);
1044 #else
1045         iounmap(bridge->gatt_table);
1046 #endif
1047         table = (char *) bridge->gatt_table_real;
1048         table_end = table + ((PAGE_SIZE * (1 << page_order)) - 1);
1049 
1050         for (page = virt_to_page(table); page <= virt_to_page(table_end); page++)
1051                 ClearPageReserved(page);
1052 
1053         free_gatt_pages(bridge->gatt_table_real, page_order);
1054 
1055         agp_gatt_table = NULL;
1056         bridge->gatt_table = NULL;
1057         bridge->gatt_table_real = NULL;
1058         bridge->gatt_bus_addr = 0;
1059 
1060         return 0;
1061 }
1062 EXPORT_SYMBOL(agp_generic_free_gatt_table);
1063 
1064 
1065 int agp_generic_insert_memory(struct agp_memory * mem, off_t pg_start, int type)
1066 {
1067         int num_entries;
1068         size_t i;
1069         off_t j;
1070         void *temp;
1071         struct agp_bridge_data *bridge;
1072         int mask_type;
1073 
1074         bridge = mem->bridge;
1075         if (!bridge)
1076                 return -EINVAL;
1077 
1078         if (mem->page_count == 0)
1079                 return 0;
1080 
1081         temp = bridge->current_size;
1082 
1083         switch (bridge->driver->size_type) {
1084         case U8_APER_SIZE:
1085                 num_entries = A_SIZE_8(temp)->num_entries;
1086                 break;
1087         case U16_APER_SIZE:
1088                 num_entries = A_SIZE_16(temp)->num_entries;
1089                 break;
1090         case U32_APER_SIZE:
1091                 num_entries = A_SIZE_32(temp)->num_entries;
1092                 break;
1093         case FIXED_APER_SIZE:
1094                 num_entries = A_SIZE_FIX(temp)->num_entries;
1095                 break;
1096         case LVL2_APER_SIZE:
1097                 /* The generic routines can't deal with 2 level gatt's */
1098                 return -EINVAL;
1099                 break;
1100         default:
1101                 num_entries = 0;
1102                 break;
1103         }
1104 
1105         num_entries -= agp_memory_reserved/PAGE_SIZE;
1106         if (num_entries < 0) num_entries = 0;
1107 
1108         if (type != mem->type)
1109                 return -EINVAL;
1110 
1111         mask_type = bridge->driver->agp_type_to_mask_type(bridge, type);
1112         if (mask_type != 0) {
1113                 /* The generic routines know nothing of memory types */
1114                 return -EINVAL;
1115         }
1116 
1117         /* AK: could wrap */
1118         if ((pg_start + mem->page_count) > num_entries)
1119                 return -EINVAL;
1120 
1121         j = pg_start;
1122 
1123         while (j < (pg_start + mem->page_count)) {
1124                 if (!PGE_EMPTY(bridge, readl(bridge->gatt_table+j)))
1125                         return -EBUSY;
1126                 j++;
1127         }
1128 
1129         if (!mem->is_flushed) {
1130                 bridge->driver->cache_flush();
1131                 mem->is_flushed = true;
1132         }
1133 
1134         for (i = 0, j = pg_start; i < mem->page_count; i++, j++) {
1135                 writel(bridge->driver->mask_memory(bridge, mem->pages[i], mask_type),
1136                        bridge->gatt_table+j);
1137         }
1138         readl(bridge->gatt_table+j-1);  /* PCI Posting. */
1139 
1140         bridge->driver->tlb_flush(mem);
1141         return 0;
1142 }
1143 EXPORT_SYMBOL(agp_generic_insert_memory);
1144 
1145 
1146 int agp_generic_remove_memory(struct agp_memory *mem, off_t pg_start, int type)
1147 {
1148         size_t i;
1149         struct agp_bridge_data *bridge;
1150         int mask_type;
1151 
1152         bridge = mem->bridge;
1153         if (!bridge)
1154                 return -EINVAL;
1155 
1156         if (mem->page_count == 0)
1157                 return 0;
1158 
1159         if (type != mem->type)
1160                 return -EINVAL;
1161 
1162         mask_type = bridge->driver->agp_type_to_mask_type(bridge, type);
1163         if (mask_type != 0) {
1164                 /* The generic routines know nothing of memory types */
1165                 return -EINVAL;
1166         }
1167 
1168         /* AK: bogus, should encode addresses > 4GB */
1169         for (i = pg_start; i < (mem->page_count + pg_start); i++) {
1170                 writel(bridge->scratch_page, bridge->gatt_table+i);
1171         }
1172         readl(bridge->gatt_table+i-1);  /* PCI Posting. */
1173 
1174         bridge->driver->tlb_flush(mem);
1175         return 0;
1176 }
1177 EXPORT_SYMBOL(agp_generic_remove_memory);
1178 
1179 struct agp_memory *agp_generic_alloc_by_type(size_t page_count, int type)
1180 {
1181         return NULL;
1182 }
1183 EXPORT_SYMBOL(agp_generic_alloc_by_type);
1184 
1185 void agp_generic_free_by_type(struct agp_memory *curr)
1186 {
1187         agp_free_page_array(curr);
1188         agp_free_key(curr->key);
1189         kfree(curr);
1190 }
1191 EXPORT_SYMBOL(agp_generic_free_by_type);
1192 
1193 struct agp_memory *agp_generic_alloc_user(size_t page_count, int type)
1194 {
1195         struct agp_memory *new;
1196         int i;
1197         int pages;
1198 
1199         pages = (page_count + ENTRIES_PER_PAGE - 1) / ENTRIES_PER_PAGE;
1200         new = agp_create_user_memory(page_count);
1201         if (new == NULL)
1202                 return NULL;
1203 
1204         for (i = 0; i < page_count; i++)
1205                 new->pages[i] = 0;
1206         new->page_count = 0;
1207         new->type = type;
1208         new->num_scratch_pages = pages;
1209 
1210         return new;
1211 }
1212 EXPORT_SYMBOL(agp_generic_alloc_user);
1213 
1214 /*
1215  * Basic Page Allocation Routines -
1216  * These routines handle page allocation and by default they reserve the allocated
1217  * memory.  They also handle incrementing the current_memory_agp value, Which is checked
1218  * against a maximum value.
1219  */
1220 
1221 int agp_generic_alloc_pages(struct agp_bridge_data *bridge, struct agp_memory *mem, size_t num_pages)
1222 {
1223         struct page * page;
1224         int i, ret = -ENOMEM;
1225 
1226         for (i = 0; i < num_pages; i++) {
1227                 page = alloc_page(GFP_KERNEL | GFP_DMA32 | __GFP_ZERO);
1228                 /* agp_free_memory() needs gart address */
1229                 if (page == NULL)
1230                         goto out;
1231 
1232 #ifndef CONFIG_X86
1233                 map_page_into_agp(page);
1234 #endif
1235                 get_page(page);
1236                 atomic_inc(&agp_bridge->current_memory_agp);
1237 
1238                 mem->pages[i] = page;
1239                 mem->page_count++;
1240         }
1241 
1242 #ifdef CONFIG_X86
1243         set_pages_array_uc(mem->pages, num_pages);
1244 #endif
1245         ret = 0;
1246 out:
1247         return ret;
1248 }
1249 EXPORT_SYMBOL(agp_generic_alloc_pages);
1250 
1251 struct page *agp_generic_alloc_page(struct agp_bridge_data *bridge)
1252 {
1253         struct page * page;
1254 
1255         page = alloc_page(GFP_KERNEL | GFP_DMA32 | __GFP_ZERO);
1256         if (page == NULL)
1257                 return NULL;
1258 
1259         map_page_into_agp(page);
1260 
1261         get_page(page);
1262         atomic_inc(&agp_bridge->current_memory_agp);
1263         return page;
1264 }
1265 EXPORT_SYMBOL(agp_generic_alloc_page);
1266 
1267 void agp_generic_destroy_pages(struct agp_memory *mem)
1268 {
1269         int i;
1270         struct page *page;
1271 
1272         if (!mem)
1273                 return;
1274 
1275 #ifdef CONFIG_X86
1276         set_pages_array_wb(mem->pages, mem->page_count);
1277 #endif
1278 
1279         for (i = 0; i < mem->page_count; i++) {
1280                 page = mem->pages[i];
1281 
1282 #ifndef CONFIG_X86
1283                 unmap_page_from_agp(page);
1284 #endif
1285                 put_page(page);
1286                 __free_page(page);
1287                 atomic_dec(&agp_bridge->current_memory_agp);
1288                 mem->pages[i] = NULL;
1289         }
1290 }
1291 EXPORT_SYMBOL(agp_generic_destroy_pages);
1292 
1293 void agp_generic_destroy_page(struct page *page, int flags)
1294 {
1295         if (page == NULL)
1296                 return;
1297 
1298         if (flags & AGP_PAGE_DESTROY_UNMAP)
1299                 unmap_page_from_agp(page);
1300 
1301         if (flags & AGP_PAGE_DESTROY_FREE) {
1302                 put_page(page);
1303                 __free_page(page);
1304                 atomic_dec(&agp_bridge->current_memory_agp);
1305         }
1306 }
1307 EXPORT_SYMBOL(agp_generic_destroy_page);
1308 
1309 /* End Basic Page Allocation Routines */
1310 
1311 
1312 /**
1313  * agp_enable  -  initialise the agp point-to-point connection.
1314  *
1315  * @mode:       agp mode register value to configure with.
1316  */
1317 void agp_enable(struct agp_bridge_data *bridge, u32 mode)
1318 {
1319         if (!bridge)
1320                 return;
1321         bridge->driver->agp_enable(bridge, mode);
1322 }
1323 EXPORT_SYMBOL(agp_enable);
1324 
1325 /* When we remove the global variable agp_bridge from all drivers
1326  * then agp_alloc_bridge and agp_generic_find_bridge need to be updated
1327  */
1328 
1329 struct agp_bridge_data *agp_generic_find_bridge(struct pci_dev *pdev)
1330 {
1331         if (list_empty(&agp_bridges))
1332                 return NULL;
1333 
1334         return agp_bridge;
1335 }
1336 
1337 static void ipi_handler(void *null)
1338 {
1339         flush_agp_cache();
1340 }
1341 
1342 void global_cache_flush(void)
1343 {
1344         if (on_each_cpu(ipi_handler, NULL, 1) != 0)
1345                 panic(PFX "timed out waiting for the other CPUs!\n");
1346 }
1347 EXPORT_SYMBOL(global_cache_flush);
1348 
1349 unsigned long agp_generic_mask_memory(struct agp_bridge_data *bridge,
1350                                       struct page *page, int type)
1351 {
1352         unsigned long addr = phys_to_gart(page_to_phys(page));
1353         /* memory type is ignored in the generic routine */
1354         if (bridge->driver->masks)
1355                 return addr | bridge->driver->masks[0].mask;
1356         else
1357                 return addr;
1358 }
1359 EXPORT_SYMBOL(agp_generic_mask_memory);
1360 
1361 int agp_generic_type_to_mask_type(struct agp_bridge_data *bridge,
1362                                   int type)
1363 {
1364         if (type >= AGP_USER_TYPES)
1365                 return 0;
1366         return type;
1367 }
1368 EXPORT_SYMBOL(agp_generic_type_to_mask_type);
1369 
1370 /*
1371  * These functions are implemented according to the AGPv3 spec,
1372  * which covers implementation details that had previously been
1373  * left open.
1374  */
1375 
1376 int agp3_generic_fetch_size(void)
1377 {
1378         u16 temp_size;
1379         int i;
1380         struct aper_size_info_16 *values;
1381 
1382         pci_read_config_word(agp_bridge->dev, agp_bridge->capndx+AGPAPSIZE, &temp_size);
1383         values = A_SIZE_16(agp_bridge->driver->aperture_sizes);
1384 
1385         for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) {
1386                 if (temp_size == values[i].size_value) {
1387                         agp_bridge->previous_size =
1388                                 agp_bridge->current_size = (void *) (values + i);
1389 
1390                         agp_bridge->aperture_size_idx = i;
1391                         return values[i].size;
1392                 }
1393         }
1394         return 0;
1395 }
1396 EXPORT_SYMBOL(agp3_generic_fetch_size);
1397 
1398 void agp3_generic_tlbflush(struct agp_memory *mem)
1399 {
1400         u32 ctrl;
1401         pci_read_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, &ctrl);
1402         pci_write_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, ctrl & ~AGPCTRL_GTLBEN);
1403         pci_write_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, ctrl);
1404 }
1405 EXPORT_SYMBOL(agp3_generic_tlbflush);
1406 
1407 int agp3_generic_configure(void)
1408 {
1409         u32 temp;
1410         struct aper_size_info_16 *current_size;
1411 
1412         current_size = A_SIZE_16(agp_bridge->current_size);
1413 
1414         pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp);
1415         agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK);
1416 
1417         /* set aperture size */
1418         pci_write_config_word(agp_bridge->dev, agp_bridge->capndx+AGPAPSIZE, current_size->size_value);
1419         /* set gart pointer */
1420         pci_write_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPGARTLO, agp_bridge->gatt_bus_addr);
1421         /* enable aperture and GTLB */
1422         pci_read_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, &temp);
1423         pci_write_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, temp | AGPCTRL_APERENB | AGPCTRL_GTLBEN);
1424         return 0;
1425 }
1426 EXPORT_SYMBOL(agp3_generic_configure);
1427 
1428 void agp3_generic_cleanup(void)
1429 {
1430         u32 ctrl;
1431         pci_read_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, &ctrl);
1432         pci_write_config_dword(agp_bridge->dev, agp_bridge->capndx+AGPCTRL, ctrl & ~AGPCTRL_APERENB);
1433 }
1434 EXPORT_SYMBOL(agp3_generic_cleanup);
1435 
1436 const struct aper_size_info_16 agp3_generic_sizes[AGP_GENERIC_SIZES_ENTRIES] =
1437 {
1438         {4096, 1048576, 10,0x000},
1439         {2048,  524288, 9, 0x800},
1440         {1024,  262144, 8, 0xc00},
1441         { 512,  131072, 7, 0xe00},
1442         { 256,   65536, 6, 0xf00},
1443         { 128,   32768, 5, 0xf20},
1444         {  64,   16384, 4, 0xf30},
1445         {  32,    8192, 3, 0xf38},
1446         {  16,    4096, 2, 0xf3c},
1447         {   8,    2048, 1, 0xf3e},
1448         {   4,    1024, 0, 0xf3f}
1449 };
1450 EXPORT_SYMBOL(agp3_generic_sizes);
1451 
1452 
  This page was automatically generated by the LXR engine.