diff options
author | Michel Dänzer <daenzer@vmware.com> | 2009-08-04 07:51:03 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-08-19 20:29:26 -0400 |
commit | 52f072cb084bbb460d3a4ae09f0b6efc3e7e8a8c (patch) | |
tree | 178f85aa2dbd936b5e01b2fb6f610e3eb232e728 /drivers | |
parent | fb2881a7134576a6e95a63e3d2f34ea5629db4a1 (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.c | 16 |
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 @@ | |||
27 | static int uninorth_rev; | 27 | static int uninorth_rev; |
28 | static int is_u3; | 28 | static int is_u3; |
29 | 29 | ||
30 | #define DEFAULT_APERTURE_SIZE 256 | ||
31 | #define DEFAULT_APERTURE_STRING "256" | ||
30 | static char *aperture = NULL; | 32 | static char *aperture = NULL; |
31 | 33 | ||
32 | static int uninorth_fetch_size(void) | 34 | static 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 | ||
477 | static const struct aper_size_info_32 uninorth_sizes[7] = | 479 | static 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 | */ |
494 | static const struct aper_size_info_32 u3_sizes[8] = | 494 | static 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); | |||
717 | MODULE_PARM_DESC(aperture, | 717 | MODULE_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 | ||
722 | MODULE_AUTHOR("Ben Herrenschmidt & Paul Mackerras"); | 722 | MODULE_AUTHOR("Ben Herrenschmidt & Paul Mackerras"); |
723 | MODULE_LICENSE("GPL"); | 723 | MODULE_LICENSE("GPL"); |