aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorMichel Dänzer <daenzer@vmware.com>2009-08-04 07:51:03 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2009-08-19 20:29:26 -0400
commit52f072cb084bbb460d3a4ae09f0b6efc3e7e8a8c (patch)
tree178f85aa2dbd936b5e01b2fb6f610e3eb232e728 /drivers
parentfb2881a7134576a6e95a63e3d2f34ea5629db4a1 (diff)
agp/uninorth: Allow larger aperture sizes on pre-U3 bridges.
Using the radeon KMS test functionality, I verified that the AGP bridge of the Intrepid2 chipset in my PowerBook supports aperture sizes up to 256M. So allow aperture sizes up to 256M on pre-U3 bridges as well, and bump the default size to 256M. It's possible that older revisions only support smaller sizes, but it'll be easy to verify that with the raden KMS test functionality. Also, there's only a problem on an actual attempt to access the aperture beyond the maximum size supported by the hardware, and non-KMS X still defaults to using only 32M. Also use ARRAY_SIZE for the aperture size arrays. Signed-off-by: Michel Dänzer <daenzer@vmware.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/char/agp/uninorth-agp.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/drivers/char/agp/uninorth-agp.c b/drivers/char/agp/uninorth-agp.c
index f192c3b9ad4..37ff3bd56d6 100644
--- a/drivers/char/agp/uninorth-agp.c
+++ b/drivers/char/agp/uninorth-agp.c
@@ -27,6 +27,8 @@
27static int uninorth_rev; 27static int uninorth_rev;
28static int is_u3; 28static int is_u3;
29 29
30#define DEFAULT_APERTURE_SIZE 256
31#define DEFAULT_APERTURE_STRING "256"
30static char *aperture = NULL; 32static char *aperture = NULL;
31 33
32static int uninorth_fetch_size(void) 34static int uninorth_fetch_size(void)
@@ -55,7 +57,7 @@ static int uninorth_fetch_size(void)
55 57
56 if (!size) { 58 if (!size) {
57 for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) 59 for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++)
58 if (values[i].size == 32) 60 if (values[i].size == DEFAULT_APERTURE_SIZE)
59 break; 61 break;
60 } 62 }
61 63
@@ -474,13 +476,11 @@ void null_cache_flush(void)
474 476
475/* Setup function */ 477/* Setup function */
476 478
477static const struct aper_size_info_32 uninorth_sizes[7] = 479static const struct aper_size_info_32 uninorth_sizes[] =
478{ 480{
479#if 0 /* Not sure uninorth supports that high aperture sizes */
480 {256, 65536, 6, 64}, 481 {256, 65536, 6, 64},
481 {128, 32768, 5, 32}, 482 {128, 32768, 5, 32},
482 {64, 16384, 4, 16}, 483 {64, 16384, 4, 16},
483#endif
484 {32, 8192, 3, 8}, 484 {32, 8192, 3, 8},
485 {16, 4096, 2, 4}, 485 {16, 4096, 2, 4},
486 {8, 2048, 1, 2}, 486 {8, 2048, 1, 2},
@@ -491,7 +491,7 @@ static const struct aper_size_info_32 uninorth_sizes[7] =
491 * Not sure that u3 supports that high aperture sizes but it 491 * Not sure that u3 supports that high aperture sizes but it
492 * would strange if it did not :) 492 * would strange if it did not :)
493 */ 493 */
494static const struct aper_size_info_32 u3_sizes[8] = 494static const struct aper_size_info_32 u3_sizes[] =
495{ 495{
496 {512, 131072, 7, 128}, 496 {512, 131072, 7, 128},
497 {256, 65536, 6, 64}, 497 {256, 65536, 6, 64},
@@ -507,7 +507,7 @@ const struct agp_bridge_driver uninorth_agp_driver = {
507 .owner = THIS_MODULE, 507 .owner = THIS_MODULE,
508 .aperture_sizes = (void *)uninorth_sizes, 508 .aperture_sizes = (void *)uninorth_sizes,
509 .size_type = U32_APER_SIZE, 509 .size_type = U32_APER_SIZE,
510 .num_aperture_sizes = 4, 510 .num_aperture_sizes = ARRAY_SIZE(uninorth_sizes),
511 .configure = uninorth_configure, 511 .configure = uninorth_configure,
512 .fetch_size = uninorth_fetch_size, 512 .fetch_size = uninorth_fetch_size,
513 .cleanup = uninorth_cleanup, 513 .cleanup = uninorth_cleanup,
@@ -534,7 +534,7 @@ const struct agp_bridge_driver u3_agp_driver = {
534 .owner = THIS_MODULE, 534 .owner = THIS_MODULE,
535 .aperture_sizes = (void *)u3_sizes, 535 .aperture_sizes = (void *)u3_sizes,
536 .size_type = U32_APER_SIZE, 536 .size_type = U32_APER_SIZE,
537 .num_aperture_sizes = 8, 537 .num_aperture_sizes = ARRAY_SIZE(u3_sizes),
538 .configure = uninorth_configure, 538 .configure = uninorth_configure,
539 .fetch_size = uninorth_fetch_size, 539 .fetch_size = uninorth_fetch_size,
540 .cleanup = uninorth_cleanup, 540 .cleanup = uninorth_cleanup,
@@ -717,7 +717,7 @@ module_param(aperture, charp, 0);
717MODULE_PARM_DESC(aperture, 717MODULE_PARM_DESC(aperture,
718 "Aperture size, must be power of two between 4MB and an\n" 718 "Aperture size, must be power of two between 4MB and an\n"
719 "\t\tupper limit specific to the UniNorth revision.\n" 719 "\t\tupper limit specific to the UniNorth revision.\n"
720 "\t\tDefault: 32M"); 720 "\t\tDefault: " DEFAULT_APERTURE_STRING "M");
721 721
722MODULE_AUTHOR("Ben Herrenschmidt & Paul Mackerras"); 722MODULE_AUTHOR("Ben Herrenschmidt & Paul Mackerras");
723MODULE_LICENSE("GPL"); 723MODULE_LICENSE("GPL");