Commit 351bb278 authored by Daniel Vetter's avatar Daniel Vetter Committed by Chris Wilson

intel-gtt: introduce pte write function for i8xx/i915/i945

And put it to use in the gtt configuration code that writes
the scratch page addr in all gtt ptes. This makes intel_i830_configure
generic, hence rename it to intel_fake_agp_configure.
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
parent 0e87d2b0
...@@ -90,6 +90,10 @@ struct intel_gtt_driver { ...@@ -90,6 +90,10 @@ struct intel_gtt_driver {
unsigned int is_ironlake : 1; unsigned int is_ironlake : 1;
/* Chipset specific GTT setup */ /* Chipset specific GTT setup */
int (*setup)(void); int (*setup)(void);
void (*write_entry)(dma_addr_t addr, unsigned int entry, unsigned int flags);
/* Flags is a more or less chipset specific opaque value.
* For chipsets that need to support old ums (non-gem) code, this
* needs to be identical to the various supported agp memory types! */
}; };
static struct _intel_private { static struct _intel_private {
...@@ -954,6 +958,23 @@ static void intel_i830_chipset_flush(struct agp_bridge_data *bridge) ...@@ -954,6 +958,23 @@ static void intel_i830_chipset_flush(struct agp_bridge_data *bridge)
printk(KERN_ERR "Timed out waiting for cache flush.\n"); printk(KERN_ERR "Timed out waiting for cache flush.\n");
} }
static void i830_write_entry(dma_addr_t addr, unsigned int entry,
unsigned int flags)
{
u32 pte_flags = I810_PTE_VALID;
switch (flags) {
case AGP_DCACHE_MEMORY:
pte_flags |= I810_PTE_LOCAL;
break;
case AGP_USER_CACHED_MEMORY:
pte_flags |= I830_PTE_SYSTEM_CACHED;
break;
}
writel(addr | pte_flags, intel_private.gtt + entry);
}
static void intel_enable_gtt(void) static void intel_enable_gtt(void)
{ {
u32 gma_addr; u32 gma_addr;
...@@ -1011,7 +1032,7 @@ static int intel_fake_agp_free_gatt_table(struct agp_bridge_data *bridge) ...@@ -1011,7 +1032,7 @@ static int intel_fake_agp_free_gatt_table(struct agp_bridge_data *bridge)
return 0; return 0;
} }
static int intel_i830_configure(void) static int intel_fake_agp_configure(void)
{ {
int i; int i;
...@@ -1019,13 +1040,12 @@ static int intel_i830_configure(void) ...@@ -1019,13 +1040,12 @@ static int intel_i830_configure(void)
agp_bridge->gart_bus_addr = intel_private.gma_bus_addr; agp_bridge->gart_bus_addr = intel_private.gma_bus_addr;
if (agp_bridge->driver->needs_scratch_page) {
for (i = intel_private.base.gtt_stolen_entries; for (i = intel_private.base.gtt_stolen_entries;
i < intel_private.base.gtt_total_entries; i++) { i < intel_private.base.gtt_total_entries; i++) {
writel(agp_bridge->scratch_page, intel_private.gtt+i); intel_private.driver->write_entry(intel_private.scratch_page_dma,
i, 0);
} }
readl(intel_private.gtt+i-1); /* PCI Posting. */ readl(intel_private.gtt+i-1); /* PCI Posting. */
}
global_cache_flush(); global_cache_flush();
...@@ -1417,7 +1437,7 @@ static const struct agp_bridge_driver intel_830_driver = { ...@@ -1417,7 +1437,7 @@ static const struct agp_bridge_driver intel_830_driver = {
.aperture_sizes = intel_fake_agp_sizes, .aperture_sizes = intel_fake_agp_sizes,
.num_aperture_sizes = ARRAY_SIZE(intel_fake_agp_sizes), .num_aperture_sizes = ARRAY_SIZE(intel_fake_agp_sizes),
.needs_scratch_page = true, .needs_scratch_page = true,
.configure = intel_i830_configure, .configure = intel_fake_agp_configure,
.fetch_size = intel_fake_agp_fetch_size, .fetch_size = intel_fake_agp_fetch_size,
.cleanup = intel_gtt_cleanup, .cleanup = intel_gtt_cleanup,
.mask_memory = intel_i810_mask_memory, .mask_memory = intel_i810_mask_memory,
...@@ -1444,7 +1464,7 @@ static const struct agp_bridge_driver intel_915_driver = { ...@@ -1444,7 +1464,7 @@ static const struct agp_bridge_driver intel_915_driver = {
.aperture_sizes = intel_fake_agp_sizes, .aperture_sizes = intel_fake_agp_sizes,
.num_aperture_sizes = ARRAY_SIZE(intel_fake_agp_sizes), .num_aperture_sizes = ARRAY_SIZE(intel_fake_agp_sizes),
.needs_scratch_page = true, .needs_scratch_page = true,
.configure = intel_i9xx_configure, .configure = intel_fake_agp_configure,
.fetch_size = intel_fake_agp_fetch_size, .fetch_size = intel_fake_agp_fetch_size,
.cleanup = intel_gtt_cleanup, .cleanup = intel_gtt_cleanup,
.mask_memory = intel_i810_mask_memory, .mask_memory = intel_i810_mask_memory,
...@@ -1573,10 +1593,13 @@ static const struct agp_bridge_driver intel_g33_driver = { ...@@ -1573,10 +1593,13 @@ static const struct agp_bridge_driver intel_g33_driver = {
static const struct intel_gtt_driver i8xx_gtt_driver = { static const struct intel_gtt_driver i8xx_gtt_driver = {
.gen = 2, .gen = 2,
.setup = i830_setup, .setup = i830_setup,
.write_entry = i830_write_entry,
}; };
static const struct intel_gtt_driver i915_gtt_driver = { static const struct intel_gtt_driver i915_gtt_driver = {
.gen = 3, .gen = 3,
.setup = i9xx_setup, .setup = i9xx_setup,
/* i945 is the last gpu to need phys mem (for overlay and cursors). */
.write_entry = i830_write_entry,
}; };
static const struct intel_gtt_driver g33_gtt_driver = { static const struct intel_gtt_driver g33_gtt_driver = {
.gen = 3, .gen = 3,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment