diff options
-rw-r--r-- | drivers/char/agp/agp.h | 3 | ||||
-rw-r--r-- | drivers/char/agp/intel-agp.c | 31 |
2 files changed, 29 insertions, 5 deletions
diff --git a/drivers/char/agp/agp.h b/drivers/char/agp/agp.h index 9ec9374ccc42..c69f79598e47 100644 --- a/drivers/char/agp/agp.h +++ b/drivers/char/agp/agp.h | |||
@@ -236,6 +236,9 @@ struct agp_bridge_data { | |||
236 | #define I965_PGETBL_SIZE_512KB (0 << 1) | 236 | #define I965_PGETBL_SIZE_512KB (0 << 1) |
237 | #define I965_PGETBL_SIZE_256KB (1 << 1) | 237 | #define I965_PGETBL_SIZE_256KB (1 << 1) |
238 | #define I965_PGETBL_SIZE_128KB (2 << 1) | 238 | #define I965_PGETBL_SIZE_128KB (2 << 1) |
239 | #define I965_PGETBL_SIZE_1MB (3 << 1) | ||
240 | #define I965_PGETBL_SIZE_2MB (4 << 1) | ||
241 | #define I965_PGETBL_SIZE_1_5MB (5 << 1) | ||
239 | #define G33_PGETBL_SIZE_MASK (3 << 8) | 242 | #define G33_PGETBL_SIZE_MASK (3 << 8) |
240 | #define G33_PGETBL_SIZE_1M (1 << 8) | 243 | #define G33_PGETBL_SIZE_1M (1 << 8) |
241 | #define G33_PGETBL_SIZE_2M (2 << 8) | 244 | #define G33_PGETBL_SIZE_2M (2 << 8) |
diff --git a/drivers/char/agp/intel-agp.c b/drivers/char/agp/intel-agp.c index 8e61a0530485..6fa97ae6a126 100644 --- a/drivers/char/agp/intel-agp.c +++ b/drivers/char/agp/intel-agp.c | |||
@@ -32,13 +32,16 @@ | |||
32 | #define PCI_DEVICE_ID_INTEL_Q35_IG 0x29B2 | 32 | #define PCI_DEVICE_ID_INTEL_Q35_IG 0x29B2 |
33 | #define PCI_DEVICE_ID_INTEL_Q33_HB 0x29D0 | 33 | #define PCI_DEVICE_ID_INTEL_Q33_HB 0x29D0 |
34 | #define PCI_DEVICE_ID_INTEL_Q33_IG 0x29D2 | 34 | #define PCI_DEVICE_ID_INTEL_Q33_IG 0x29D2 |
35 | #define PCI_DEVICE_ID_INTEL_IGD_HB 0x2A40 | ||
36 | #define PCI_DEVICE_ID_INTEL_IGD_IG 0x2A42 | ||
35 | 37 | ||
36 | #define IS_I965 (agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82946GZ_HB || \ | 38 | #define IS_I965 (agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82946GZ_HB || \ |
37 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965G_1_HB || \ | 39 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965G_1_HB || \ |
38 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965Q_HB || \ | 40 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965Q_HB || \ |
39 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965G_HB || \ | 41 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965G_HB || \ |
40 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965GM_HB || \ | 42 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965GM_HB || \ |
41 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965GME_HB) | 43 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_82965GME_HB || \ |
44 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_IGD_HB) | ||
42 | 45 | ||
43 | #define IS_G33 (agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_G33_HB || \ | 46 | #define IS_G33 (agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_G33_HB || \ |
44 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_Q35_HB || \ | 47 | agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_Q35_HB || \ |
@@ -461,6 +464,15 @@ static void intel_i830_init_gtt_entries(void) | |||
461 | case I965_PGETBL_SIZE_512KB: | 464 | case I965_PGETBL_SIZE_512KB: |
462 | size = 512; | 465 | size = 512; |
463 | break; | 466 | break; |
467 | case I965_PGETBL_SIZE_1MB: | ||
468 | size = 1024; | ||
469 | break; | ||
470 | case I965_PGETBL_SIZE_2MB: | ||
471 | size = 2048; | ||
472 | break; | ||
473 | case I965_PGETBL_SIZE_1_5MB: | ||
474 | size = 1024 + 512; | ||
475 | break; | ||
464 | default: | 476 | default: |
465 | printk(KERN_INFO PFX "Unknown page table size, " | 477 | printk(KERN_INFO PFX "Unknown page table size, " |
466 | "assuming 512KB\n"); | 478 | "assuming 512KB\n"); |
@@ -1124,6 +1136,7 @@ static int intel_i965_create_gatt_table(struct agp_bridge_data *bridge) | |||
1124 | struct aper_size_info_fixed *size; | 1136 | struct aper_size_info_fixed *size; |
1125 | int num_entries; | 1137 | int num_entries; |
1126 | u32 temp; | 1138 | u32 temp; |
1139 | int gtt_offset, gtt_size; | ||
1127 | 1140 | ||
1128 | size = agp_bridge->current_size; | 1141 | size = agp_bridge->current_size; |
1129 | page_order = size->page_order; | 1142 | page_order = size->page_order; |
@@ -1133,13 +1146,18 @@ static int intel_i965_create_gatt_table(struct agp_bridge_data *bridge) | |||
1133 | pci_read_config_dword(intel_private.pcidev, I915_MMADDR, &temp); | 1146 | pci_read_config_dword(intel_private.pcidev, I915_MMADDR, &temp); |
1134 | 1147 | ||
1135 | temp &= 0xfff00000; | 1148 | temp &= 0xfff00000; |
1136 | intel_private.gtt = ioremap((temp + (512 * 1024)) , 512 * 1024); | ||
1137 | 1149 | ||
1138 | if (!intel_private.gtt) | 1150 | if (agp_bridge->dev->device == PCI_DEVICE_ID_INTEL_IGD_HB) |
1139 | return -ENOMEM; | 1151 | gtt_offset = gtt_size = MB(2); |
1152 | else | ||
1153 | gtt_offset = gtt_size = KB(512); | ||
1154 | |||
1155 | intel_private.gtt = ioremap((temp + gtt_offset) , gtt_size); | ||
1140 | 1156 | ||
1157 | if (!intel_private.gtt) | ||
1158 | return -ENOMEM; | ||
1141 | 1159 | ||
1142 | intel_private.registers = ioremap(temp,128 * 4096); | 1160 | intel_private.registers = ioremap(temp, 128 * 4096); |
1143 | if (!intel_private.registers) { | 1161 | if (!intel_private.registers) { |
1144 | iounmap(intel_private.gtt); | 1162 | iounmap(intel_private.gtt); |
1145 | return -ENOMEM; | 1163 | return -ENOMEM; |
@@ -2036,6 +2054,8 @@ static const struct intel_driver_description { | |||
2036 | NULL, &intel_g33_driver }, | 2054 | NULL, &intel_g33_driver }, |
2037 | { PCI_DEVICE_ID_INTEL_Q33_HB, PCI_DEVICE_ID_INTEL_Q33_IG, 0, "Q33", | 2055 | { PCI_DEVICE_ID_INTEL_Q33_HB, PCI_DEVICE_ID_INTEL_Q33_IG, 0, "Q33", |
2038 | NULL, &intel_g33_driver }, | 2056 | NULL, &intel_g33_driver }, |
2057 | { PCI_DEVICE_ID_INTEL_IGD_HB, PCI_DEVICE_ID_INTEL_IGD_IG, 0, | ||
2058 | "Intel Integrated Graphics Device", NULL, &intel_i965_driver }, | ||
2039 | { 0, 0, 0, NULL, NULL, NULL } | 2059 | { 0, 0, 0, NULL, NULL, NULL } |
2040 | }; | 2060 | }; |
2041 | 2061 | ||
@@ -2226,6 +2246,7 @@ static struct pci_device_id agp_intel_pci_table[] = { | |||
2226 | ID(PCI_DEVICE_ID_INTEL_G33_HB), | 2246 | ID(PCI_DEVICE_ID_INTEL_G33_HB), |
2227 | ID(PCI_DEVICE_ID_INTEL_Q35_HB), | 2247 | ID(PCI_DEVICE_ID_INTEL_Q35_HB), |
2228 | ID(PCI_DEVICE_ID_INTEL_Q33_HB), | 2248 | ID(PCI_DEVICE_ID_INTEL_Q33_HB), |
2249 | ID(PCI_DEVICE_ID_INTEL_IGD_HB), | ||
2229 | { } | 2250 | { } |
2230 | }; | 2251 | }; |
2231 | 2252 | ||