diff options
author | Shaohua Li <shaohua.li@intel.com> | 2008-08-04 02:51:30 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-08-15 10:30:48 -0400 |
commit | 466ae837424dcc538b1af2a0eaf53be32edcdbe7 (patch) | |
tree | fb19282470b844aa6e1affc52b65dd707196d223 | |
parent | 1ac2f7d55b7ee1613c90631e87fea22ec06781e5 (diff) |
reduce tlb/cache flush times of agpgart memory allocation
To reduce tlb/cache flush, makes agp memory allocation do one flush
after all pages in a region are changed to uc.
All agp drivers except agp-sgi uses agp_generic_alloc_page()
for .agp_alloc_page, so the patch should work for them. agp-sgi is only
for ia64, so not a problem too.
Signed-off-by: Shaohua Li <shaohua.li@intel.com>
Cc: airlied@linux.ie
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Arjan van de Ven <arjan@infradead.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | drivers/char/agp/agp.h | 4 | ||||
-rw-r--r-- | drivers/char/agp/generic.c | 4 | ||||
-rw-r--r-- | include/asm-x86/agp.h | 3 |
3 files changed, 10 insertions, 1 deletions
diff --git a/drivers/char/agp/agp.h b/drivers/char/agp/agp.h index 81e14bea54bd..395168fb17e3 100644 --- a/drivers/char/agp/agp.h +++ b/drivers/char/agp/agp.h | |||
@@ -30,6 +30,10 @@ | |||
30 | #define _AGP_BACKEND_PRIV_H 1 | 30 | #define _AGP_BACKEND_PRIV_H 1 |
31 | 31 | ||
32 | #include <asm/agp.h> /* for flush_agp_cache() */ | 32 | #include <asm/agp.h> /* for flush_agp_cache() */ |
33 | #ifndef map_page_into_agp_noflush | ||
34 | #define map_page_into_agp_noflush(page) map_page_into_agp(page) | ||
35 | #define map_page_into_agp_global_flush() | ||
36 | #endif | ||
33 | 37 | ||
34 | #define PFX "agpgart: " | 38 | #define PFX "agpgart: " |
35 | 39 | ||
diff --git a/drivers/char/agp/generic.c b/drivers/char/agp/generic.c index eaa1a355bb32..bf239b8ecac5 100644 --- a/drivers/char/agp/generic.c +++ b/drivers/char/agp/generic.c | |||
@@ -274,6 +274,7 @@ struct agp_memory *agp_allocate_memory(struct agp_bridge_data *bridge, | |||
274 | new->memory[i] = virt_to_gart(addr); | 274 | new->memory[i] = virt_to_gart(addr); |
275 | new->page_count++; | 275 | new->page_count++; |
276 | } | 276 | } |
277 | map_page_into_agp_global_flush(); | ||
277 | new->bridge = bridge; | 278 | new->bridge = bridge; |
278 | 279 | ||
279 | return new; | 280 | return new; |
@@ -1186,7 +1187,8 @@ void *agp_generic_alloc_page(struct agp_bridge_data *bridge) | |||
1186 | if (page == NULL) | 1187 | if (page == NULL) |
1187 | return NULL; | 1188 | return NULL; |
1188 | 1189 | ||
1189 | map_page_into_agp(page); | 1190 | /* agp_allocate_memory will do flush */ |
1191 | map_page_into_agp_noflush(page); | ||
1190 | 1192 | ||
1191 | get_page(page); | 1193 | get_page(page); |
1192 | atomic_inc(&agp_bridge->current_memory_agp); | 1194 | atomic_inc(&agp_bridge->current_memory_agp); |
diff --git a/include/asm-x86/agp.h b/include/asm-x86/agp.h index e4004a9f6a9a..181b9e984b3a 100644 --- a/include/asm-x86/agp.h +++ b/include/asm-x86/agp.h | |||
@@ -15,6 +15,9 @@ | |||
15 | #define map_page_into_agp(page) set_pages_uc(page, 1) | 15 | #define map_page_into_agp(page) set_pages_uc(page, 1) |
16 | #define unmap_page_from_agp(page) set_pages_wb(page, 1) | 16 | #define unmap_page_from_agp(page) set_pages_wb(page, 1) |
17 | 17 | ||
18 | #define map_page_into_agp_noflush(page) set_pages_uc_noflush(page, 1) | ||
19 | #define map_page_into_agp_global_flush() set_memory_flush_all() | ||
20 | |||
18 | /* | 21 | /* |
19 | * Could use CLFLUSH here if the cpu supports it. But then it would | 22 | * Could use CLFLUSH here if the cpu supports it. But then it would |
20 | * need to be called for each cacheline of the whole page so it may | 23 | * need to be called for each cacheline of the whole page so it may |