1 /* 2 * Intel AGPGART routines. 3 */ 4 5 #include <linux/module.h> 6 #include <linux/pci.h> 7 #include <linux/slab.h> 8 #include <linux/init.h> 9 #include <linux/kernel.h> 10 #include <linux/pagemap.h> 11 #include <linux/agp_backend.h> 12 #include <asm/smp.h> 13 #include "agp.h" 14 #include "intel-agp.h" 15 16 int intel_agp_enabled; 17 EXPORT_SYMBOL(intel_agp_enabled); 18 19 static int intel_fetch_size(void) 20 { 21 int i; 22 u16 temp; 23 struct aper_size_info_16 *values; 24 25 pci_read_config_word(agp_bridge->dev, INTEL_APSIZE, &temp); 26 values = A_SIZE_16(agp_bridge->driver->aperture_sizes); 27 28 for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) { 29 if (temp == values[i].size_value) { 30 agp_bridge->previous_size = agp_bridge->current_size = (void *) (values + i); 31 agp_bridge->aperture_size_idx = i; 32 return values[i].size; 33 } 34 } 35 36 return 0; 37 } 38 39 static int __intel_8xx_fetch_size(u8 temp) 40 { 41 int i; 42 struct aper_size_info_8 *values; 43 44 values = A_SIZE_8(agp_bridge->driver->aperture_sizes); 45 46 for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) { 47 if (temp == values[i].size_value) { 48 agp_bridge->previous_size = 49 agp_bridge->current_size = (void *) (values + i); 50 agp_bridge->aperture_size_idx = i; 51 return values[i].size; 52 } 53 } 54 return 0; 55 } 56 57 static int intel_8xx_fetch_size(void) 58 { 59 u8 temp; 60 61 pci_read_config_byte(agp_bridge->dev, INTEL_APSIZE, &temp); 62 return __intel_8xx_fetch_size(temp); 63 } 64 65 static int intel_815_fetch_size(void) 66 { 67 u8 temp; 68 69 /* Intel 815 chipsets have a _weird_ APSIZE register with only 70 * one non-reserved bit, so mask the others out ... */ 71 pci_read_config_byte(agp_bridge->dev, INTEL_APSIZE, &temp); 72 temp &= (1 << 3); 73 74 return __intel_8xx_fetch_size(temp); 75 } 76 77 static void intel_tlbflush(struct agp_memory *mem) 78 { 79 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x2200); 80 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x2280); 81 } 82 83 84 static void intel_8xx_tlbflush(struct agp_memory *mem) 85 { 86 u32 temp; 87 pci_read_config_dword(agp_bridge->dev, INTEL_AGPCTRL, &temp); 88 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, temp & ~(1 << 7)); 89 pci_read_config_dword(agp_bridge->dev, INTEL_AGPCTRL, &temp); 90 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, temp | (1 << 7)); 91 } 92 93 94 static void intel_cleanup(void) 95 { 96 u16 temp; 97 struct aper_size_info_16 *previous_size; 98 99 previous_size = A_SIZE_16(agp_bridge->previous_size); 100 pci_read_config_word(agp_bridge->dev, INTEL_NBXCFG, &temp); 101 pci_write_config_word(agp_bridge->dev, INTEL_NBXCFG, temp & ~(1 << 9)); 102 pci_write_config_word(agp_bridge->dev, INTEL_APSIZE, previous_size->size_value); 103 } 104 105 106 static void intel_8xx_cleanup(void) 107 { 108 u16 temp; 109 struct aper_size_info_8 *previous_size; 110 111 previous_size = A_SIZE_8(agp_bridge->previous_size); 112 pci_read_config_word(agp_bridge->dev, INTEL_NBXCFG, &temp); 113 pci_write_config_word(agp_bridge->dev, INTEL_NBXCFG, temp & ~(1 << 9)); 114 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, previous_size->size_value); 115 } 116 117 118 static int intel_configure(void) 119 { 120 u32 temp; 121 u16 temp2; 122 struct aper_size_info_16 *current_size; 123 124 current_size = A_SIZE_16(agp_bridge->current_size); 125 126 /* aperture size */ 127 pci_write_config_word(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 128 129 /* address to map to */ 130 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 131 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 132 133 /* attbase - aperture base */ 134 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 135 136 /* agpctrl */ 137 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x2280); 138 139 /* paccfg/nbxcfg */ 140 pci_read_config_word(agp_bridge->dev, INTEL_NBXCFG, &temp2); 141 pci_write_config_word(agp_bridge->dev, INTEL_NBXCFG, 142 (temp2 & ~(1 << 10)) | (1 << 9)); 143 /* clear any possible error conditions */ 144 pci_write_config_byte(agp_bridge->dev, INTEL_ERRSTS + 1, 7); 145 return 0; 146 } 147 148 static int intel_815_configure(void) 149 { 150 u32 temp, addr; 151 u8 temp2; 152 struct aper_size_info_8 *current_size; 153 154 /* attbase - aperture base */ 155 /* the Intel 815 chipset spec. says that bits 29-31 in the 156 * ATTBASE register are reserved -> try not to write them */ 157 if (agp_bridge->gatt_bus_addr & INTEL_815_ATTBASE_MASK) { 158 dev_emerg(&agp_bridge->dev->dev, "gatt bus addr too high"); 159 return -EINVAL; 160 } 161 162 current_size = A_SIZE_8(agp_bridge->current_size); 163 164 /* aperture size */ 165 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, 166 current_size->size_value); 167 168 /* address to map to */ 169 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 170 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 171 172 pci_read_config_dword(agp_bridge->dev, INTEL_ATTBASE, &addr); 173 addr &= INTEL_815_ATTBASE_MASK; 174 addr |= agp_bridge->gatt_bus_addr; 175 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, addr); 176 177 /* agpctrl */ 178 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 179 180 /* apcont */ 181 pci_read_config_byte(agp_bridge->dev, INTEL_815_APCONT, &temp2); 182 pci_write_config_byte(agp_bridge->dev, INTEL_815_APCONT, temp2 | (1 << 1)); 183 184 /* clear any possible error conditions */ 185 /* Oddness : this chipset seems to have no ERRSTS register ! */ 186 return 0; 187 } 188 189 static void intel_820_tlbflush(struct agp_memory *mem) 190 { 191 return; 192 } 193 194 static void intel_820_cleanup(void) 195 { 196 u8 temp; 197 struct aper_size_info_8 *previous_size; 198 199 previous_size = A_SIZE_8(agp_bridge->previous_size); 200 pci_read_config_byte(agp_bridge->dev, INTEL_I820_RDCR, &temp); 201 pci_write_config_byte(agp_bridge->dev, INTEL_I820_RDCR, 202 temp & ~(1 << 1)); 203 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, 204 previous_size->size_value); 205 } 206 207 208 static int intel_820_configure(void) 209 { 210 u32 temp; 211 u8 temp2; 212 struct aper_size_info_8 *current_size; 213 214 current_size = A_SIZE_8(agp_bridge->current_size); 215 216 /* aperture size */ 217 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 218 219 /* address to map to */ 220 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 221 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 222 223 /* attbase - aperture base */ 224 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 225 226 /* agpctrl */ 227 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 228 229 /* global enable aperture access */ 230 /* This flag is not accessed through MCHCFG register as in */ 231 /* i850 chipset. */ 232 pci_read_config_byte(agp_bridge->dev, INTEL_I820_RDCR, &temp2); 233 pci_write_config_byte(agp_bridge->dev, INTEL_I820_RDCR, temp2 | (1 << 1)); 234 /* clear any possible AGP-related error conditions */ 235 pci_write_config_word(agp_bridge->dev, INTEL_I820_ERRSTS, 0x001c); 236 return 0; 237 } 238 239 static int intel_840_configure(void) 240 { 241 u32 temp; 242 u16 temp2; 243 struct aper_size_info_8 *current_size; 244 245 current_size = A_SIZE_8(agp_bridge->current_size); 246 247 /* aperture size */ 248 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 249 250 /* address to map to */ 251 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 252 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 253 254 /* attbase - aperture base */ 255 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 256 257 /* agpctrl */ 258 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 259 260 /* mcgcfg */ 261 pci_read_config_word(agp_bridge->dev, INTEL_I840_MCHCFG, &temp2); 262 pci_write_config_word(agp_bridge->dev, INTEL_I840_MCHCFG, temp2 | (1 << 9)); 263 /* clear any possible error conditions */ 264 pci_write_config_word(agp_bridge->dev, INTEL_I840_ERRSTS, 0xc000); 265 return 0; 266 } 267 268 static int intel_845_configure(void) 269 { 270 u32 temp; 271 u8 temp2; 272 struct aper_size_info_8 *current_size; 273 274 current_size = A_SIZE_8(agp_bridge->current_size); 275 276 /* aperture size */ 277 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 278 279 if (agp_bridge->apbase_config != 0) { 280 pci_write_config_dword(agp_bridge->dev, AGP_APBASE, 281 agp_bridge->apbase_config); 282 } else { 283 /* address to map to */ 284 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 285 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 286 agp_bridge->apbase_config = temp; 287 } 288 289 /* attbase - aperture base */ 290 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 291 292 /* agpctrl */ 293 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 294 295 /* agpm */ 296 pci_read_config_byte(agp_bridge->dev, INTEL_I845_AGPM, &temp2); 297 pci_write_config_byte(agp_bridge->dev, INTEL_I845_AGPM, temp2 | (1 << 1)); 298 /* clear any possible error conditions */ 299 pci_write_config_word(agp_bridge->dev, INTEL_I845_ERRSTS, 0x001c); 300 return 0; 301 } 302 303 static int intel_850_configure(void) 304 { 305 u32 temp; 306 u16 temp2; 307 struct aper_size_info_8 *current_size; 308 309 current_size = A_SIZE_8(agp_bridge->current_size); 310 311 /* aperture size */ 312 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 313 314 /* address to map to */ 315 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 316 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 317 318 /* attbase - aperture base */ 319 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 320 321 /* agpctrl */ 322 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 323 324 /* mcgcfg */ 325 pci_read_config_word(agp_bridge->dev, INTEL_I850_MCHCFG, &temp2); 326 pci_write_config_word(agp_bridge->dev, INTEL_I850_MCHCFG, temp2 | (1 << 9)); 327 /* clear any possible AGP-related error conditions */ 328 pci_write_config_word(agp_bridge->dev, INTEL_I850_ERRSTS, 0x001c); 329 return 0; 330 } 331 332 static int intel_860_configure(void) 333 { 334 u32 temp; 335 u16 temp2; 336 struct aper_size_info_8 *current_size; 337 338 current_size = A_SIZE_8(agp_bridge->current_size); 339 340 /* aperture size */ 341 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 342 343 /* address to map to */ 344 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 345 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 346 347 /* attbase - aperture base */ 348 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 349 350 /* agpctrl */ 351 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 352 353 /* mcgcfg */ 354 pci_read_config_word(agp_bridge->dev, INTEL_I860_MCHCFG, &temp2); 355 pci_write_config_word(agp_bridge->dev, INTEL_I860_MCHCFG, temp2 | (1 << 9)); 356 /* clear any possible AGP-related error conditions */ 357 pci_write_config_word(agp_bridge->dev, INTEL_I860_ERRSTS, 0xf700); 358 return 0; 359 } 360 361 static int intel_830mp_configure(void) 362 { 363 u32 temp; 364 u16 temp2; 365 struct aper_size_info_8 *current_size; 366 367 current_size = A_SIZE_8(agp_bridge->current_size); 368 369 /* aperture size */ 370 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 371 372 /* address to map to */ 373 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 374 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 375 376 /* attbase - aperture base */ 377 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 378 379 /* agpctrl */ 380 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 381 382 /* gmch */ 383 pci_read_config_word(agp_bridge->dev, INTEL_NBXCFG, &temp2); 384 pci_write_config_word(agp_bridge->dev, INTEL_NBXCFG, temp2 | (1 << 9)); 385 /* clear any possible AGP-related error conditions */ 386 pci_write_config_word(agp_bridge->dev, INTEL_I830_ERRSTS, 0x1c); 387 return 0; 388 } 389 390 static int intel_7505_configure(void) 391 { 392 u32 temp; 393 u16 temp2; 394 struct aper_size_info_8 *current_size; 395 396 current_size = A_SIZE_8(agp_bridge->current_size); 397 398 /* aperture size */ 399 pci_write_config_byte(agp_bridge->dev, INTEL_APSIZE, current_size->size_value); 400 401 /* address to map to */ 402 pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp); 403 agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK); 404 405 /* attbase - aperture base */ 406 pci_write_config_dword(agp_bridge->dev, INTEL_ATTBASE, agp_bridge->gatt_bus_addr); 407 408 /* agpctrl */ 409 pci_write_config_dword(agp_bridge->dev, INTEL_AGPCTRL, 0x0000); 410 411 /* mchcfg */ 412 pci_read_config_word(agp_bridge->dev, INTEL_I7505_MCHCFG, &temp2); 413 pci_write_config_word(agp_bridge->dev, INTEL_I7505_MCHCFG, temp2 | (1 << 9)); 414 415 return 0; 416 } 417 418 /* Setup function */ 419 static const struct gatt_mask intel_generic_masks[] = 420 { 421 {.mask = 0x00000017, .type = 0} 422 }; 423 424 static const struct aper_size_info_8 intel_815_sizes[2] = 425 { 426 {64, 16384, 4, 0}, 427 {32, 8192, 3, 8}, 428 }; 429 430 static const struct aper_size_info_8 intel_8xx_sizes[7] = 431 { 432 {256, 65536, 6, 0}, 433 {128, 32768, 5, 32}, 434 {64, 16384, 4, 48}, 435 {32, 8192, 3, 56}, 436 {16, 4096, 2, 60}, 437 {8, 2048, 1, 62}, 438 {4, 1024, 0, 63} 439 }; 440 441 static const struct aper_size_info_16 intel_generic_sizes[7] = 442 { 443 {256, 65536, 6, 0}, 444 {128, 32768, 5, 32}, 445 {64, 16384, 4, 48}, 446 {32, 8192, 3, 56}, 447 {16, 4096, 2, 60}, 448 {8, 2048, 1, 62}, 449 {4, 1024, 0, 63} 450 }; 451 452 static const struct aper_size_info_8 intel_830mp_sizes[4] = 453 { 454 {256, 65536, 6, 0}, 455 {128, 32768, 5, 32}, 456 {64, 16384, 4, 48}, 457 {32, 8192, 3, 56} 458 }; 459 460 static const struct agp_bridge_driver intel_generic_driver = { 461 .owner = THIS_MODULE, 462 .aperture_sizes = intel_generic_sizes, 463 .size_type = U16_APER_SIZE, 464 .num_aperture_sizes = 7, 465 .needs_scratch_page = true, 466 .configure = intel_configure, 467 .fetch_size = intel_fetch_size, 468 .cleanup = intel_cleanup, 469 .tlb_flush = intel_tlbflush, 470 .mask_memory = agp_generic_mask_memory, 471 .masks = intel_generic_masks, 472 .agp_enable = agp_generic_enable, 473 .cache_flush = global_cache_flush, 474 .create_gatt_table = agp_generic_create_gatt_table, 475 .free_gatt_table = agp_generic_free_gatt_table, 476 .insert_memory = agp_generic_insert_memory, 477 .remove_memory = agp_generic_remove_memory, 478 .alloc_by_type = agp_generic_alloc_by_type, 479 .free_by_type = agp_generic_free_by_type, 480 .agp_alloc_page = agp_generic_alloc_page, 481 .agp_alloc_pages = agp_generic_alloc_pages, 482 .agp_destroy_page = agp_generic_destroy_page, 483 .agp_destroy_pages = agp_generic_destroy_pages, 484 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 485 }; 486 487 static const struct agp_bridge_driver intel_815_driver = { 488 .owner = THIS_MODULE, 489 .aperture_sizes = intel_815_sizes, 490 .size_type = U8_APER_SIZE, 491 .num_aperture_sizes = 2, 492 .needs_scratch_page = true, 493 .configure = intel_815_configure, 494 .fetch_size = intel_815_fetch_size, 495 .cleanup = intel_8xx_cleanup, 496 .tlb_flush = intel_8xx_tlbflush, 497 .mask_memory = agp_generic_mask_memory, 498 .masks = intel_generic_masks, 499 .agp_enable = agp_generic_enable, 500 .cache_flush = global_cache_flush, 501 .create_gatt_table = agp_generic_create_gatt_table, 502 .free_gatt_table = agp_generic_free_gatt_table, 503 .insert_memory = agp_generic_insert_memory, 504 .remove_memory = agp_generic_remove_memory, 505 .alloc_by_type = agp_generic_alloc_by_type, 506 .free_by_type = agp_generic_free_by_type, 507 .agp_alloc_page = agp_generic_alloc_page, 508 .agp_alloc_pages = agp_generic_alloc_pages, 509 .agp_destroy_page = agp_generic_destroy_page, 510 .agp_destroy_pages = agp_generic_destroy_pages, 511 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 512 }; 513 514 static const struct agp_bridge_driver intel_820_driver = { 515 .owner = THIS_MODULE, 516 .aperture_sizes = intel_8xx_sizes, 517 .size_type = U8_APER_SIZE, 518 .num_aperture_sizes = 7, 519 .needs_scratch_page = true, 520 .configure = intel_820_configure, 521 .fetch_size = intel_8xx_fetch_size, 522 .cleanup = intel_820_cleanup, 523 .tlb_flush = intel_820_tlbflush, 524 .mask_memory = agp_generic_mask_memory, 525 .masks = intel_generic_masks, 526 .agp_enable = agp_generic_enable, 527 .cache_flush = global_cache_flush, 528 .create_gatt_table = agp_generic_create_gatt_table, 529 .free_gatt_table = agp_generic_free_gatt_table, 530 .insert_memory = agp_generic_insert_memory, 531 .remove_memory = agp_generic_remove_memory, 532 .alloc_by_type = agp_generic_alloc_by_type, 533 .free_by_type = agp_generic_free_by_type, 534 .agp_alloc_page = agp_generic_alloc_page, 535 .agp_alloc_pages = agp_generic_alloc_pages, 536 .agp_destroy_page = agp_generic_destroy_page, 537 .agp_destroy_pages = agp_generic_destroy_pages, 538 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 539 }; 540 541 static const struct agp_bridge_driver intel_830mp_driver = { 542 .owner = THIS_MODULE, 543 .aperture_sizes = intel_830mp_sizes, 544 .size_type = U8_APER_SIZE, 545 .num_aperture_sizes = 4, 546 .needs_scratch_page = true, 547 .configure = intel_830mp_configure, 548 .fetch_size = intel_8xx_fetch_size, 549 .cleanup = intel_8xx_cleanup, 550 .tlb_flush = intel_8xx_tlbflush, 551 .mask_memory = agp_generic_mask_memory, 552 .masks = intel_generic_masks, 553 .agp_enable = agp_generic_enable, 554 .cache_flush = global_cache_flush, 555 .create_gatt_table = agp_generic_create_gatt_table, 556 .free_gatt_table = agp_generic_free_gatt_table, 557 .insert_memory = agp_generic_insert_memory, 558 .remove_memory = agp_generic_remove_memory, 559 .alloc_by_type = agp_generic_alloc_by_type, 560 .free_by_type = agp_generic_free_by_type, 561 .agp_alloc_page = agp_generic_alloc_page, 562 .agp_alloc_pages = agp_generic_alloc_pages, 563 .agp_destroy_page = agp_generic_destroy_page, 564 .agp_destroy_pages = agp_generic_destroy_pages, 565 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 566 }; 567 568 static const struct agp_bridge_driver intel_840_driver = { 569 .owner = THIS_MODULE, 570 .aperture_sizes = intel_8xx_sizes, 571 .size_type = U8_APER_SIZE, 572 .num_aperture_sizes = 7, 573 .needs_scratch_page = true, 574 .configure = intel_840_configure, 575 .fetch_size = intel_8xx_fetch_size, 576 .cleanup = intel_8xx_cleanup, 577 .tlb_flush = intel_8xx_tlbflush, 578 .mask_memory = agp_generic_mask_memory, 579 .masks = intel_generic_masks, 580 .agp_enable = agp_generic_enable, 581 .cache_flush = global_cache_flush, 582 .create_gatt_table = agp_generic_create_gatt_table, 583 .free_gatt_table = agp_generic_free_gatt_table, 584 .insert_memory = agp_generic_insert_memory, 585 .remove_memory = agp_generic_remove_memory, 586 .alloc_by_type = agp_generic_alloc_by_type, 587 .free_by_type = agp_generic_free_by_type, 588 .agp_alloc_page = agp_generic_alloc_page, 589 .agp_alloc_pages = agp_generic_alloc_pages, 590 .agp_destroy_page = agp_generic_destroy_page, 591 .agp_destroy_pages = agp_generic_destroy_pages, 592 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 593 }; 594 595 static const struct agp_bridge_driver intel_845_driver = { 596 .owner = THIS_MODULE, 597 .aperture_sizes = intel_8xx_sizes, 598 .size_type = U8_APER_SIZE, 599 .num_aperture_sizes = 7, 600 .needs_scratch_page = true, 601 .configure = intel_845_configure, 602 .fetch_size = intel_8xx_fetch_size, 603 .cleanup = intel_8xx_cleanup, 604 .tlb_flush = intel_8xx_tlbflush, 605 .mask_memory = agp_generic_mask_memory, 606 .masks = intel_generic_masks, 607 .agp_enable = agp_generic_enable, 608 .cache_flush = global_cache_flush, 609 .create_gatt_table = agp_generic_create_gatt_table, 610 .free_gatt_table = agp_generic_free_gatt_table, 611 .insert_memory = agp_generic_insert_memory, 612 .remove_memory = agp_generic_remove_memory, 613 .alloc_by_type = agp_generic_alloc_by_type, 614 .free_by_type = agp_generic_free_by_type, 615 .agp_alloc_page = agp_generic_alloc_page, 616 .agp_alloc_pages = agp_generic_alloc_pages, 617 .agp_destroy_page = agp_generic_destroy_page, 618 .agp_destroy_pages = agp_generic_destroy_pages, 619 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 620 }; 621 622 static const struct agp_bridge_driver intel_850_driver = { 623 .owner = THIS_MODULE, 624 .aperture_sizes = intel_8xx_sizes, 625 .size_type = U8_APER_SIZE, 626 .num_aperture_sizes = 7, 627 .needs_scratch_page = true, 628 .configure = intel_850_configure, 629 .fetch_size = intel_8xx_fetch_size, 630 .cleanup = intel_8xx_cleanup, 631 .tlb_flush = intel_8xx_tlbflush, 632 .mask_memory = agp_generic_mask_memory, 633 .masks = intel_generic_masks, 634 .agp_enable = agp_generic_enable, 635 .cache_flush = global_cache_flush, 636 .create_gatt_table = agp_generic_create_gatt_table, 637 .free_gatt_table = agp_generic_free_gatt_table, 638 .insert_memory = agp_generic_insert_memory, 639 .remove_memory = agp_generic_remove_memory, 640 .alloc_by_type = agp_generic_alloc_by_type, 641 .free_by_type = agp_generic_free_by_type, 642 .agp_alloc_page = agp_generic_alloc_page, 643 .agp_alloc_pages = agp_generic_alloc_pages, 644 .agp_destroy_page = agp_generic_destroy_page, 645 .agp_destroy_pages = agp_generic_destroy_pages, 646 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 647 }; 648 649 static const struct agp_bridge_driver intel_860_driver = { 650 .owner = THIS_MODULE, 651 .aperture_sizes = intel_8xx_sizes, 652 .size_type = U8_APER_SIZE, 653 .num_aperture_sizes = 7, 654 .needs_scratch_page = true, 655 .configure = intel_860_configure, 656 .fetch_size = intel_8xx_fetch_size, 657 .cleanup = intel_8xx_cleanup, 658 .tlb_flush = intel_8xx_tlbflush, 659 .mask_memory = agp_generic_mask_memory, 660 .masks = intel_generic_masks, 661 .agp_enable = agp_generic_enable, 662 .cache_flush = global_cache_flush, 663 .create_gatt_table = agp_generic_create_gatt_table, 664 .free_gatt_table = agp_generic_free_gatt_table, 665 .insert_memory = agp_generic_insert_memory, 666 .remove_memory = agp_generic_remove_memory, 667 .alloc_by_type = agp_generic_alloc_by_type, 668 .free_by_type = agp_generic_free_by_type, 669 .agp_alloc_page = agp_generic_alloc_page, 670 .agp_alloc_pages = agp_generic_alloc_pages, 671 .agp_destroy_page = agp_generic_destroy_page, 672 .agp_destroy_pages = agp_generic_destroy_pages, 673 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 674 }; 675 676 static const struct agp_bridge_driver intel_7505_driver = { 677 .owner = THIS_MODULE, 678 .aperture_sizes = intel_8xx_sizes, 679 .size_type = U8_APER_SIZE, 680 .num_aperture_sizes = 7, 681 .needs_scratch_page = true, 682 .configure = intel_7505_configure, 683 .fetch_size = intel_8xx_fetch_size, 684 .cleanup = intel_8xx_cleanup, 685 .tlb_flush = intel_8xx_tlbflush, 686 .mask_memory = agp_generic_mask_memory, 687 .masks = intel_generic_masks, 688 .agp_enable = agp_generic_enable, 689 .cache_flush = global_cache_flush, 690 .create_gatt_table = agp_generic_create_gatt_table, 691 .free_gatt_table = agp_generic_free_gatt_table, 692 .insert_memory = agp_generic_insert_memory, 693 .remove_memory = agp_generic_remove_memory, 694 .alloc_by_type = agp_generic_alloc_by_type, 695 .free_by_type = agp_generic_free_by_type, 696 .agp_alloc_page = agp_generic_alloc_page, 697 .agp_alloc_pages = agp_generic_alloc_pages, 698 .agp_destroy_page = agp_generic_destroy_page, 699 .agp_destroy_pages = agp_generic_destroy_pages, 700 .agp_type_to_mask_type = agp_generic_type_to_mask_type, 701 }; 702 703 /* Table to describe Intel GMCH and AGP/PCIE GART drivers. At least one of 704 * driver and gmch_driver must be non-null, and find_gmch will determine 705 * which one should be used if a gmch_chip_id is present. 706 */ 707 static const struct intel_agp_driver_description { 708 unsigned int chip_id; 709 char *name; 710 const struct agp_bridge_driver *driver; 711 } intel_agp_chipsets[] = { 712 { PCI_DEVICE_ID_INTEL_82443LX_0, "440LX", &intel_generic_driver }, 713 { PCI_DEVICE_ID_INTEL_82443BX_0, "440BX", &intel_generic_driver }, 714 { PCI_DEVICE_ID_INTEL_82443GX_0, "440GX", &intel_generic_driver }, 715 { PCI_DEVICE_ID_INTEL_82815_MC, "i815", &intel_815_driver }, 716 { PCI_DEVICE_ID_INTEL_82820_HB, "i820", &intel_820_driver }, 717 { PCI_DEVICE_ID_INTEL_82820_UP_HB, "i820", &intel_820_driver }, 718 { PCI_DEVICE_ID_INTEL_82830_HB, "830M", &intel_830mp_driver }, 719 { PCI_DEVICE_ID_INTEL_82840_HB, "i840", &intel_840_driver }, 720 { PCI_DEVICE_ID_INTEL_82845_HB, "845G", &intel_845_driver }, 721 { PCI_DEVICE_ID_INTEL_82845G_HB, "830M", &intel_845_driver }, 722 { PCI_DEVICE_ID_INTEL_82850_HB, "i850", &intel_850_driver }, 723 { PCI_DEVICE_ID_INTEL_82854_HB, "854", &intel_845_driver }, 724 { PCI_DEVICE_ID_INTEL_82855PM_HB, "855PM", &intel_845_driver }, 725 { PCI_DEVICE_ID_INTEL_82855GM_HB, "855GM", &intel_845_driver }, 726 { PCI_DEVICE_ID_INTEL_82860_HB, "i860", &intel_860_driver }, 727 { PCI_DEVICE_ID_INTEL_82865_HB, "865", &intel_845_driver }, 728 { PCI_DEVICE_ID_INTEL_82875_HB, "i875", &intel_845_driver }, 729 { PCI_DEVICE_ID_INTEL_7505_0, "E7505", &intel_7505_driver }, 730 { PCI_DEVICE_ID_INTEL_7205_0, "E7205", &intel_7505_driver }, 731 { 0, NULL, NULL } 732 }; 733 734 static int __devinit agp_intel_probe(struct pci_dev *pdev, 735 const struct pci_device_id *ent) 736 { 737 struct agp_bridge_data *bridge; 738 u8 cap_ptr = 0; 739 struct resource *r; 740 int i, err; 741 742 cap_ptr = pci_find_capability(pdev, PCI_CAP_ID_AGP); 743 744 bridge = agp_alloc_bridge(); 745 if (!bridge) 746 return -ENOMEM; 747 748 bridge->capndx = cap_ptr; 749 750 if (intel_gmch_probe(pdev, bridge)) 751 goto found_gmch; 752 753 for (i = 0; intel_agp_chipsets[i].name != NULL; i++) { 754 /* In case that multiple models of gfx chip may 755 stand on same host bridge type, this can be 756 sure we detect the right IGD. */ 757 if (pdev->device == intel_agp_chipsets[i].chip_id) { 758 bridge->driver = intel_agp_chipsets[i].driver; 759 break; 760 } 761 } 762 763 if (!bridge->driver) { 764 if (cap_ptr) 765 dev_warn(&pdev->dev, "unsupported Intel chipset [%04x/%04x]\n", 766 pdev->vendor, pdev->device); 767 agp_put_bridge(bridge); 768 return -ENODEV; 769 } 770 771 bridge->dev = pdev; 772 bridge->dev_private_data = NULL; 773 774 dev_info(&pdev->dev, "Intel %s Chipset\n", intel_agp_chipsets[i].name); 775 776 /* 777 * If the device has not been properly setup, the following will catch 778 * the problem and should stop the system from crashing. 779 * 20030610 - hamish@zot.org 780 */ 781 if (pci_enable_device(pdev)) { 782 dev_err(&pdev->dev, "can't enable PCI device\n"); 783 agp_put_bridge(bridge); 784 return -ENODEV; 785 } 786 787 /* 788 * The following fixes the case where the BIOS has "forgotten" to 789 * provide an address range for the GART. 790 * 20030610 - hamish@zot.org 791 */ 792 r = &pdev->resource[0]; 793 if (!r->start && r->end) { 794 if (pci_assign_resource(pdev, 0)) { 795 dev_err(&pdev->dev, "can't assign resource 0\n"); 796 agp_put_bridge(bridge); 797 return -ENODEV; 798 } 799 } 800 801 /* Fill in the mode register */ 802 if (cap_ptr) { 803 pci_read_config_dword(pdev, 804 bridge->capndx+PCI_AGP_STATUS, 805 &bridge->mode); 806 } 807 808 found_gmch: 809 pci_set_drvdata(pdev, bridge); 810 err = agp_add_bridge(bridge); 811 if (!err) 812 intel_agp_enabled = 1; 813 return err; 814 } 815 816 static void __devexit agp_intel_remove(struct pci_dev *pdev) 817 { 818 struct agp_bridge_data *bridge = pci_get_drvdata(pdev); 819 820 agp_remove_bridge(bridge); 821 822 intel_gmch_remove(pdev); 823 824 agp_put_bridge(bridge); 825 } 826 827 #ifdef CONFIG_PM 828 static int agp_intel_resume(struct pci_dev *pdev) 829 { 830 struct agp_bridge_data *bridge = pci_get_drvdata(pdev); 831 int ret_val; 832 833 bridge->driver->configure(); 834 835 ret_val = agp_rebind_memory(); 836 if (ret_val != 0) 837 return ret_val; 838 839 return 0; 840 } 841 #endif 842 843 static struct pci_device_id agp_intel_pci_table[] = { 844 #define ID(x) \ 845 { \ 846 .class = (PCI_CLASS_BRIDGE_HOST << 8), \ 847 .class_mask = ~0, \ 848 .vendor = PCI_VENDOR_ID_INTEL, \ 849 .device = x, \ 850 .subvendor = PCI_ANY_ID, \ 851 .subdevice = PCI_ANY_ID, \ 852 } 853 ID(PCI_DEVICE_ID_INTEL_82443LX_0), 854 ID(PCI_DEVICE_ID_INTEL_82443BX_0), 855 ID(PCI_DEVICE_ID_INTEL_82443GX_0), 856 ID(PCI_DEVICE_ID_INTEL_82810_MC1), 857 ID(PCI_DEVICE_ID_INTEL_82810_MC3), 858 ID(PCI_DEVICE_ID_INTEL_82810E_MC), 859 ID(PCI_DEVICE_ID_INTEL_82815_MC), 860 ID(PCI_DEVICE_ID_INTEL_82820_HB), 861 ID(PCI_DEVICE_ID_INTEL_82820_UP_HB), 862 ID(PCI_DEVICE_ID_INTEL_82830_HB), 863 ID(PCI_DEVICE_ID_INTEL_82840_HB), 864 ID(PCI_DEVICE_ID_INTEL_82845_HB), 865 ID(PCI_DEVICE_ID_INTEL_82845G_HB), 866 ID(PCI_DEVICE_ID_INTEL_82850_HB), 867 ID(PCI_DEVICE_ID_INTEL_82854_HB), 868 ID(PCI_DEVICE_ID_INTEL_82855PM_HB), 869 ID(PCI_DEVICE_ID_INTEL_82855GM_HB), 870 ID(PCI_DEVICE_ID_INTEL_82860_HB), 871 ID(PCI_DEVICE_ID_INTEL_82865_HB), 872 ID(PCI_DEVICE_ID_INTEL_82875_HB), 873 ID(PCI_DEVICE_ID_INTEL_7505_0), 874 ID(PCI_DEVICE_ID_INTEL_7205_0), 875 ID(PCI_DEVICE_ID_INTEL_E7221_HB), 876 ID(PCI_DEVICE_ID_INTEL_82915G_HB), 877 ID(PCI_DEVICE_ID_INTEL_82915GM_HB), 878 ID(PCI_DEVICE_ID_INTEL_82945G_HB), 879 ID(PCI_DEVICE_ID_INTEL_82945GM_HB), 880 ID(PCI_DEVICE_ID_INTEL_82945GME_HB), 881 ID(PCI_DEVICE_ID_INTEL_PINEVIEW_M_HB), 882 ID(PCI_DEVICE_ID_INTEL_PINEVIEW_HB), 883 ID(PCI_DEVICE_ID_INTEL_82946GZ_HB), 884 ID(PCI_DEVICE_ID_INTEL_82G35_HB), 885 ID(PCI_DEVICE_ID_INTEL_82965Q_HB), 886 ID(PCI_DEVICE_ID_INTEL_82965G_HB), 887 ID(PCI_DEVICE_ID_INTEL_82965GM_HB), 888 ID(PCI_DEVICE_ID_INTEL_82965GME_HB), 889 ID(PCI_DEVICE_ID_INTEL_G33_HB), 890 ID(PCI_DEVICE_ID_INTEL_Q35_HB), 891 ID(PCI_DEVICE_ID_INTEL_Q33_HB), 892 ID(PCI_DEVICE_ID_INTEL_GM45_HB), 893 ID(PCI_DEVICE_ID_INTEL_EAGLELAKE_HB), 894 ID(PCI_DEVICE_ID_INTEL_Q45_HB), 895 ID(PCI_DEVICE_ID_INTEL_G45_HB), 896 ID(PCI_DEVICE_ID_INTEL_G41_HB), 897 ID(PCI_DEVICE_ID_INTEL_B43_HB), 898 ID(PCI_DEVICE_ID_INTEL_B43_1_HB), 899 ID(PCI_DEVICE_ID_INTEL_IRONLAKE_D_HB), 900 ID(PCI_DEVICE_ID_INTEL_IRONLAKE_M_HB), 901 ID(PCI_DEVICE_ID_INTEL_IRONLAKE_MA_HB), 902 ID(PCI_DEVICE_ID_INTEL_IRONLAKE_MC2_HB), 903 ID(PCI_DEVICE_ID_INTEL_SANDYBRIDGE_HB), 904 ID(PCI_DEVICE_ID_INTEL_SANDYBRIDGE_M_HB), 905 ID(PCI_DEVICE_ID_INTEL_SANDYBRIDGE_S_HB), 906 { } 907 }; 908 909 MODULE_DEVICE_TABLE(pci, agp_intel_pci_table); 910 911 static struct pci_driver agp_intel_pci_driver = { 912 .name = "agpgart-intel", 913 .id_table = agp_intel_pci_table, 914 .probe = agp_intel_probe, 915 .remove = __devexit_p(agp_intel_remove), 916 #ifdef CONFIG_PM 917 .resume = agp_intel_resume, 918 #endif 919 }; 920 921 static int __init agp_intel_init(void) 922 { 923 if (agp_off) 924 return -EINVAL; 925 return pci_register_driver(&agp_intel_pci_driver); 926 } 927 928 static void __exit agp_intel_cleanup(void) 929 { 930 pci_unregister_driver(&agp_intel_pci_driver); 931 } 932 933 module_init(agp_intel_init); 934 module_exit(agp_intel_cleanup); 935 936 MODULE_AUTHOR("Dave Jones <davej@redhat.com>"); 937 MODULE_LICENSE("GPL and additional rights"); 938