aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2010-09-23 14:04:17 -0400
committerChris Wilson <chris@chris-wilson.co.uk>2010-10-27 18:31:06 -0400
commitb3eafc5af02a799650757f2c5b2b0d4835dd0a5f (patch)
treec20558a017505974e4ef26437af480d1ff04fb21 /drivers/char
parent53984635a659e360f206a81ada4ae813152d72f1 (diff)
intel-gtt: save PGETBL_CTL later in the setup process
... and switch to a more classical store-reg-on-suspend, restore-on-resume way of doing things. Obviously this is just preparation for the future, the code is not there at all, yet. This is needed because the next patch adjusts this register and everything in it (not just the pagetable address) needs to be restored on resume. Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'drivers/char')
-rw-r--r--drivers/char/agp/intel-gtt.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/drivers/char/agp/intel-gtt.c b/drivers/char/agp/intel-gtt.c
index 6b6760ea2435..fd3e94f8ab51 100644
--- a/drivers/char/agp/intel-gtt.c
+++ b/drivers/char/agp/intel-gtt.c
@@ -95,7 +95,7 @@ static struct _intel_private {
95 u8 __iomem *registers; 95 u8 __iomem *registers;
96 phys_addr_t gtt_bus_addr; 96 phys_addr_t gtt_bus_addr;
97 phys_addr_t gma_bus_addr; 97 phys_addr_t gma_bus_addr;
98 phys_addr_t pte_bus_addr; 98 u32 PGETBL_save;
99 u32 __iomem *gtt; /* I915G */ 99 u32 __iomem *gtt; /* I915G */
100 int num_dcache_entries; 100 int num_dcache_entries;
101 union { 101 union {
@@ -755,6 +755,11 @@ static int intel_gtt_init(void)
755 intel_private.base.gtt_mappable_entries = intel_gtt_mappable_entries(); 755 intel_private.base.gtt_mappable_entries = intel_gtt_mappable_entries();
756 intel_private.base.gtt_total_entries = intel_gtt_total_entries(); 756 intel_private.base.gtt_total_entries = intel_gtt_total_entries();
757 757
758 /* save the PGETBL reg for resume */
759 intel_private.PGETBL_save =
760 readl(intel_private.registers+I810_PGETBL_CTL)
761 & ~I810_PGETBL_ENABLED;
762
758 dev_info(&intel_private.bridge_dev->dev, 763 dev_info(&intel_private.bridge_dev->dev,
759 "detected gtt size: %dK total, %dK mappable\n", 764 "detected gtt size: %dK total, %dK mappable\n",
760 intel_private.base.gtt_total_entries * 4, 765 intel_private.base.gtt_total_entries * 4,
@@ -891,7 +896,7 @@ static void intel_enable_gtt(void)
891 gmch_ctrl |= I830_GMCH_ENABLED; 896 gmch_ctrl |= I830_GMCH_ENABLED;
892 pci_write_config_word(intel_private.bridge_dev, I830_GMCH_CTRL, gmch_ctrl); 897 pci_write_config_word(intel_private.bridge_dev, I830_GMCH_CTRL, gmch_ctrl);
893 898
894 writel(intel_private.pte_bus_addr|I810_PGETBL_ENABLED, 899 writel(intel_private.PGETBL_save|I810_PGETBL_ENABLED,
895 intel_private.registers+I810_PGETBL_CTL); 900 intel_private.registers+I810_PGETBL_CTL);
896 readl(intel_private.registers+I810_PGETBL_CTL); /* PCI Posting. */ 901 readl(intel_private.registers+I810_PGETBL_CTL); /* PCI Posting. */
897} 902}
@@ -908,8 +913,6 @@ static int i830_setup(void)
908 return -ENOMEM; 913 return -ENOMEM;
909 914
910 intel_private.gtt_bus_addr = reg_addr + I810_PTE_BASE; 915 intel_private.gtt_bus_addr = reg_addr + I810_PTE_BASE;
911 intel_private.pte_bus_addr =
912 readl(intel_private.registers+I810_PGETBL_CTL) & 0xfffff000;
913 916
914 intel_i830_setup_flush(); 917 intel_i830_setup_flush();
915 918
@@ -1265,9 +1268,6 @@ static int i9xx_setup(void)
1265 intel_private.gtt_bus_addr = reg_addr + gtt_offset; 1268 intel_private.gtt_bus_addr = reg_addr + gtt_offset;
1266 } 1269 }
1267 1270
1268 intel_private.pte_bus_addr =
1269 readl(intel_private.registers+I810_PGETBL_CTL) & 0xfffff000;
1270
1271 intel_i9xx_setup_flush(); 1271 intel_i9xx_setup_flush();
1272 1272
1273 return 0; 1273 return 0;