2  * VIA AGPGART routines.
 
   5 #include <linux/types.h>
 
   6 #include <linux/module.h>
 
   8 #include <linux/init.h>
 
   9 #include <linux/agp_backend.h>
 
  12 static const struct pci_device_id agp_via_pci_table[];
 
  14 #define VIA_GARTCTRL    0x80
 
  15 #define VIA_APSIZE      0x84
 
  16 #define VIA_ATTBASE     0x88
 
  18 #define VIA_AGP3_GARTCTRL       0x90
 
  19 #define VIA_AGP3_APSIZE         0x94
 
  20 #define VIA_AGP3_ATTBASE        0x98
 
  21 #define VIA_AGPSEL              0xfd
 
  23 static int via_fetch_size(void)
 
  27         struct aper_size_info_8 *values;
 
  29         values = A_SIZE_8(agp_bridge->driver->aperture_sizes);
 
  30         pci_read_config_byte(agp_bridge->dev, VIA_APSIZE, &temp);
 
  31         for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) {
 
  32                 if (temp == values[i].size_value) {
 
  33                         agp_bridge->previous_size =
 
  34                             agp_bridge->current_size = (void *) (values + i);
 
  35                         agp_bridge->aperture_size_idx = i;
 
  36                         return values[i].size;
 
  39         printk(KERN_ERR PFX "Unknown aperture size from AGP bridge (0x%x)\n", temp);
 
  44 static int via_configure(void)
 
  47         struct aper_size_info_8 *current_size;
 
  49         current_size = A_SIZE_8(agp_bridge->current_size);
 
  51         pci_write_config_byte(agp_bridge->dev, VIA_APSIZE,
 
  52                               current_size->size_value);
 
  53         /* address to map too */
 
  54         pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp);
 
  55         agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK);
 
  57         /* GART control register */
 
  58         pci_write_config_dword(agp_bridge->dev, VIA_GARTCTRL, 0x0000000f);
 
  60         /* attbase - aperture GATT base */
 
  61         pci_write_config_dword(agp_bridge->dev, VIA_ATTBASE,
 
  62                             (agp_bridge->gatt_bus_addr & 0xfffff000) | 3);
 
  67 static void via_cleanup(void)
 
  69         struct aper_size_info_8 *previous_size;
 
  71         previous_size = A_SIZE_8(agp_bridge->previous_size);
 
  72         pci_write_config_byte(agp_bridge->dev, VIA_APSIZE,
 
  73                               previous_size->size_value);
 
  74         /* Do not disable by writing 0 to VIA_ATTBASE, it screws things up
 
  75          * during reinitialization.
 
  80 static void via_tlbflush(struct agp_memory *mem)
 
  84         pci_read_config_dword(agp_bridge->dev, VIA_GARTCTRL, &temp);
 
  86         pci_write_config_dword(agp_bridge->dev, VIA_GARTCTRL, temp);
 
  88         pci_write_config_dword(agp_bridge->dev, VIA_GARTCTRL, temp);
 
  92 static const struct aper_size_info_8 via_generic_sizes[9] =
 
 106 static int via_fetch_size_agp3(void)
 
 110         struct aper_size_info_16 *values;
 
 112         values = A_SIZE_16(agp_bridge->driver->aperture_sizes);
 
 113         pci_read_config_word(agp_bridge->dev, VIA_AGP3_APSIZE, &temp);
 
 116         for (i = 0; i < agp_bridge->driver->num_aperture_sizes; i++) {
 
 117                 if (temp == values[i].size_value) {
 
 118                         agp_bridge->previous_size =
 
 119                                 agp_bridge->current_size = (void *) (values + i);
 
 120                         agp_bridge->aperture_size_idx = i;
 
 121                         return values[i].size;
 
 128 static int via_configure_agp3(void)
 
 131         struct aper_size_info_16 *current_size;
 
 133         current_size = A_SIZE_16(agp_bridge->current_size);
 
 135         /* address to map too */
 
 136         pci_read_config_dword(agp_bridge->dev, AGP_APBASE, &temp);
 
 137         agp_bridge->gart_bus_addr = (temp & PCI_BASE_ADDRESS_MEM_MASK);
 
 139         /* attbase - aperture GATT base */
 
 140         pci_write_config_dword(agp_bridge->dev, VIA_AGP3_ATTBASE,
 
 141                 agp_bridge->gatt_bus_addr & 0xfffff000);
 
 143         /* 1. Enable GTLB in RX90<7>, all AGP aperture access needs to fetch
 
 144          *    translation table first.
 
 145          * 2. Enable AGP aperture in RX91<0>. This bit controls the enabling of the
 
 146          *    graphics AGP aperture for the AGP3.0 port.
 
 148         pci_read_config_dword(agp_bridge->dev, VIA_AGP3_GARTCTRL, &temp);
 
 149         pci_write_config_dword(agp_bridge->dev, VIA_AGP3_GARTCTRL, temp | (3<<7));
 
 154 static void via_cleanup_agp3(void)
 
 156         struct aper_size_info_16 *previous_size;
 
 158         previous_size = A_SIZE_16(agp_bridge->previous_size);
 
 159         pci_write_config_byte(agp_bridge->dev, VIA_APSIZE, previous_size->size_value);
 
 163 static void via_tlbflush_agp3(struct agp_memory *mem)
 
 167         pci_read_config_dword(agp_bridge->dev, VIA_AGP3_GARTCTRL, &temp);
 
 168         pci_write_config_dword(agp_bridge->dev, VIA_AGP3_GARTCTRL, temp & ~(1<<7));
 
 169         pci_write_config_dword(agp_bridge->dev, VIA_AGP3_GARTCTRL, temp);
 
 173 static const struct agp_bridge_driver via_agp3_driver = {
 
 174         .owner                  = THIS_MODULE,
 
 175         .aperture_sizes         = agp3_generic_sizes,
 
 176         .size_type              = U8_APER_SIZE,
 
 177         .num_aperture_sizes     = 10,
 
 178         .configure              = via_configure_agp3,
 
 179         .fetch_size             = via_fetch_size_agp3,
 
 180         .cleanup                = via_cleanup_agp3,
 
 181         .tlb_flush              = via_tlbflush_agp3,
 
 182         .mask_memory            = agp_generic_mask_memory,
 
 184         .agp_enable             = agp_generic_enable,
 
 185         .cache_flush            = global_cache_flush,
 
 186         .create_gatt_table      = agp_generic_create_gatt_table,
 
 187         .free_gatt_table        = agp_generic_free_gatt_table,
 
 188         .insert_memory          = agp_generic_insert_memory,
 
 189         .remove_memory          = agp_generic_remove_memory,
 
 190         .alloc_by_type          = agp_generic_alloc_by_type,
 
 191         .free_by_type           = agp_generic_free_by_type,
 
 192         .agp_alloc_page         = agp_generic_alloc_page,
 
 193         .agp_alloc_pages        = agp_generic_alloc_pages,
 
 194         .agp_destroy_page       = agp_generic_destroy_page,
 
 195         .agp_destroy_pages      = agp_generic_destroy_pages,
 
 196         .agp_type_to_mask_type  = agp_generic_type_to_mask_type,
 
 199 static const struct agp_bridge_driver via_driver = {
 
 200         .owner                  = THIS_MODULE,
 
 201         .aperture_sizes         = via_generic_sizes,
 
 202         .size_type              = U8_APER_SIZE,
 
 203         .num_aperture_sizes     = 9,
 
 204         .configure              = via_configure,
 
 205         .fetch_size             = via_fetch_size,
 
 206         .cleanup                = via_cleanup,
 
 207         .tlb_flush              = via_tlbflush,
 
 208         .mask_memory            = agp_generic_mask_memory,
 
 210         .agp_enable             = agp_generic_enable,
 
 211         .cache_flush            = global_cache_flush,
 
 212         .create_gatt_table      = agp_generic_create_gatt_table,
 
 213         .free_gatt_table        = agp_generic_free_gatt_table,
 
 214         .insert_memory          = agp_generic_insert_memory,
 
 215         .remove_memory          = agp_generic_remove_memory,
 
 216         .alloc_by_type          = agp_generic_alloc_by_type,
 
 217         .free_by_type           = agp_generic_free_by_type,
 
 218         .agp_alloc_page         = agp_generic_alloc_page,
 
 219         .agp_alloc_pages        = agp_generic_alloc_pages,
 
 220         .agp_destroy_page       = agp_generic_destroy_page,
 
 221         .agp_destroy_pages      = agp_generic_destroy_pages,
 
 222         .agp_type_to_mask_type  = agp_generic_type_to_mask_type,
 
 225 static struct agp_device_ids via_agp_device_ids[] __devinitdata =
 
 228                 .device_id      = PCI_DEVICE_ID_VIA_82C597_0,
 
 229                 .chipset_name   = "Apollo VP3",
 
 233                 .device_id      = PCI_DEVICE_ID_VIA_82C598_0,
 
 234                 .chipset_name   = "Apollo MVP3",
 
 238                 .device_id      = PCI_DEVICE_ID_VIA_8501_0,
 
 239                 .chipset_name   = "Apollo MVP4",
 
 244                 .device_id      = PCI_DEVICE_ID_VIA_8601_0,
 
 245                 .chipset_name   = "Apollo ProMedia/PLE133Ta",
 
 248         /* VT82C693A / VT28C694T */
 
 250                 .device_id      = PCI_DEVICE_ID_VIA_82C691_0,
 
 251                 .chipset_name   = "Apollo Pro 133",
 
 255                 .device_id      = PCI_DEVICE_ID_VIA_8371_0,
 
 256                 .chipset_name   = "KX133",
 
 261                 .device_id      = PCI_DEVICE_ID_VIA_8633_0,
 
 262                 .chipset_name   = "Pro 266",
 
 266                 .device_id      = PCI_DEVICE_ID_VIA_XN266,
 
 267                 .chipset_name   = "Apollo Pro266",
 
 272                 .device_id      = PCI_DEVICE_ID_VIA_8361,
 
 273                 .chipset_name   = "KLE133",
 
 276         /* VT8365 / VT8362 */
 
 278                 .device_id      = PCI_DEVICE_ID_VIA_8363_0,
 
 279                 .chipset_name   = "Twister-K/KT133x/KM133",
 
 284                 .device_id      = PCI_DEVICE_ID_VIA_8753_0,
 
 285                 .chipset_name   = "P4X266",
 
 290                 .device_id      = PCI_DEVICE_ID_VIA_8367_0,
 
 291                 .chipset_name   = "KT266/KY266x/KT333",
 
 294         /* VT8633 (for CuMine/ Celeron) */
 
 296                 .device_id      = PCI_DEVICE_ID_VIA_8653_0,
 
 297                 .chipset_name   = "Pro266T",
 
 302                 .device_id      = PCI_DEVICE_ID_VIA_XM266,
 
 303                 .chipset_name   = "PM266/KM266",
 
 308                 .device_id      = PCI_DEVICE_ID_VIA_862X_0,
 
 309                 .chipset_name   = "CLE266",
 
 313                 .device_id      = PCI_DEVICE_ID_VIA_8377_0,
 
 314                 .chipset_name   = "KT400/KT400A/KT600",
 
 317         /* VT8604 / VT8605 / VT8603
 
 318          * (Apollo Pro133A chipset with S3 Savage4) */
 
 320                 .device_id      = PCI_DEVICE_ID_VIA_8605_0,
 
 321                 .chipset_name   = "ProSavage PM133/PL133/PN133"
 
 326                 .device_id      = PCI_DEVICE_ID_VIA_8703_51_0,
 
 327                 .chipset_name   = "P4M266x/P4N266",
 
 332                 .device_id      = PCI_DEVICE_ID_VIA_8754C_0,
 
 333                 .chipset_name   = "PT800",
 
 338                 .device_id      = PCI_DEVICE_ID_VIA_8763_0,
 
 339                 .chipset_name   = "P4X600"
 
 344                 .device_id      = PCI_DEVICE_ID_VIA_8378_0,
 
 345                 .chipset_name   = "KM400/KM400A",
 
 350                 .device_id      = PCI_DEVICE_ID_VIA_PT880,
 
 351                 .chipset_name   = "PT880",
 
 356                 .device_id      = PCI_DEVICE_ID_VIA_PT880ULTRA,
 
 357                 .chipset_name   = "PT880 Ultra",
 
 362                 .device_id      = PCI_DEVICE_ID_VIA_8783_0,
 
 363                 .chipset_name   = "PT890",
 
 366         /* PM800/PN800/PM880/PN880 */
 
 368                 .device_id      = PCI_DEVICE_ID_VIA_PX8X0_0,
 
 369                 .chipset_name   = "PM800/PN800/PM880/PN880",
 
 373                 .device_id      = PCI_DEVICE_ID_VIA_3269_0,
 
 374                 .chipset_name   = "KT880",
 
 378                 .device_id      = PCI_DEVICE_ID_VIA_83_87XX_1,
 
 379                 .chipset_name   = "VT83xx/VT87xx/KTxxx/Px8xx",
 
 383                 .device_id      = PCI_DEVICE_ID_VIA_3296_0,
 
 384                 .chipset_name   = "P4M800",
 
 388                 .device_id      = PCI_DEVICE_ID_VIA_P4M800CE,
 
 389                 .chipset_name   = "VT3314",
 
 393                 .device_id  = PCI_DEVICE_ID_VIA_VT3324,
 
 394                 .chipset_name   = "CX700",
 
 396         /* VT3336 - this is a chipset for AMD Athlon/K8 CPU. Due to K8's unique
 
 397          * architecture, the AGP resource and behavior are different from
 
 398          * the traditional AGP which resides only in chipset. AGP is used
 
 399          * by 3D driver which wasn't available for the VT3336 and VT3364
 
 400          * generation until now.  Unfortunately, by testing, VT3364 works
 
 401          * but VT3336 doesn't. - explaination from via, just leave this as
 
 402          * as a placeholder to avoid future patches adding it back in.
 
 406                 .device_id  = PCI_DEVICE_ID_VIA_VT3336,
 
 407                 .chipset_name   = "VT3336",
 
 412                 .device_id  = PCI_DEVICE_ID_VIA_P4M890,
 
 413                 .chipset_name   = "P4M890",
 
 417                 .device_id  = PCI_DEVICE_ID_VIA_VT3364,
 
 418                 .chipset_name   = "P4M900",
 
 420         { }, /* dummy final entry, always present */
 
 425  * VIA's AGP3 chipsets do magick to put the AGP bridge compliant
 
 426  * with the same standards version as the graphics card.
 
 428 static void check_via_agp3 (struct agp_bridge_data *bridge)
 
 432         pci_read_config_byte(bridge->dev, VIA_AGPSEL, ®);
 
 433         /* Check AGP 2.0 compatibility mode. */
 
 434         if ((reg & (1<<1))==0)
 
 435                 bridge->driver = &via_agp3_driver;
 
 439 static int __devinit agp_via_probe(struct pci_dev *pdev,
 
 440                                    const struct pci_device_id *ent)
 
 442         struct agp_device_ids *devs = via_agp_device_ids;
 
 443         struct agp_bridge_data *bridge;
 
 447         cap_ptr = pci_find_capability(pdev, PCI_CAP_ID_AGP);
 
 451         j = ent - agp_via_pci_table;
 
 452         printk (KERN_INFO PFX "Detected VIA %s chipset\n", devs[j].chipset_name);
 
 454         bridge = agp_alloc_bridge();
 
 459         bridge->capndx = cap_ptr;
 
 460         bridge->driver = &via_driver;
 
 463          * Garg, there are KT400s with KT266 IDs.
 
 465         if (pdev->device == PCI_DEVICE_ID_VIA_8367_0) {
 
 466                 /* Is there a KT400 subsystem ? */
 
 467                 if (pdev->subsystem_device == PCI_DEVICE_ID_VIA_8377_0) {
 
 468                         printk(KERN_INFO PFX "Found KT400 in disguise as a KT266.\n");
 
 469                         check_via_agp3(bridge);
 
 473         /* If this is an AGP3 bridge, check which mode its in and adjust. */
 
 474         get_agp_version(bridge);
 
 475         if (bridge->major_version >= 3)
 
 476                 check_via_agp3(bridge);
 
 478         /* Fill in the mode register */
 
 479         pci_read_config_dword(pdev,
 
 480                         bridge->capndx+PCI_AGP_STATUS, &bridge->mode);
 
 482         pci_set_drvdata(pdev, bridge);
 
 483         return agp_add_bridge(bridge);
 
 486 static void __devexit agp_via_remove(struct pci_dev *pdev)
 
 488         struct agp_bridge_data *bridge = pci_get_drvdata(pdev);
 
 490         agp_remove_bridge(bridge);
 
 491         agp_put_bridge(bridge);
 
 496 static int agp_via_suspend(struct pci_dev *pdev, pm_message_t state)
 
 498         pci_save_state (pdev);
 
 499         pci_set_power_state (pdev, PCI_D3hot);
 
 504 static int agp_via_resume(struct pci_dev *pdev)
 
 506         struct agp_bridge_data *bridge = pci_get_drvdata(pdev);
 
 508         pci_set_power_state (pdev, PCI_D0);
 
 509         pci_restore_state(pdev);
 
 511         if (bridge->driver == &via_agp3_driver)
 
 512                 return via_configure_agp3();
 
 513         else if (bridge->driver == &via_driver)
 
 514                 return via_configure();
 
 519 #endif /* CONFIG_PM */
 
 521 /* must be the same order as name table above */
 
 522 static const struct pci_device_id agp_via_pci_table[] = {
 
 525         .class          = (PCI_CLASS_BRIDGE_HOST << 8), \
 
 527         .vendor         = PCI_VENDOR_ID_VIA,            \
 
 529         .subvendor      = PCI_ANY_ID,                   \
 
 530         .subdevice      = PCI_ANY_ID,                   \
 
 532         ID(PCI_DEVICE_ID_VIA_82C597_0),
 
 533         ID(PCI_DEVICE_ID_VIA_82C598_0),
 
 534         ID(PCI_DEVICE_ID_VIA_8501_0),
 
 535         ID(PCI_DEVICE_ID_VIA_8601_0),
 
 536         ID(PCI_DEVICE_ID_VIA_82C691_0),
 
 537         ID(PCI_DEVICE_ID_VIA_8371_0),
 
 538         ID(PCI_DEVICE_ID_VIA_8633_0),
 
 539         ID(PCI_DEVICE_ID_VIA_XN266),
 
 540         ID(PCI_DEVICE_ID_VIA_8361),
 
 541         ID(PCI_DEVICE_ID_VIA_8363_0),
 
 542         ID(PCI_DEVICE_ID_VIA_8753_0),
 
 543         ID(PCI_DEVICE_ID_VIA_8367_0),
 
 544         ID(PCI_DEVICE_ID_VIA_8653_0),
 
 545         ID(PCI_DEVICE_ID_VIA_XM266),
 
 546         ID(PCI_DEVICE_ID_VIA_862X_0),
 
 547         ID(PCI_DEVICE_ID_VIA_8377_0),
 
 548         ID(PCI_DEVICE_ID_VIA_8605_0),
 
 549         ID(PCI_DEVICE_ID_VIA_8703_51_0),
 
 550         ID(PCI_DEVICE_ID_VIA_8754C_0),
 
 551         ID(PCI_DEVICE_ID_VIA_8763_0),
 
 552         ID(PCI_DEVICE_ID_VIA_8378_0),
 
 553         ID(PCI_DEVICE_ID_VIA_PT880),
 
 554         ID(PCI_DEVICE_ID_VIA_PT880ULTRA),
 
 555         ID(PCI_DEVICE_ID_VIA_8783_0),
 
 556         ID(PCI_DEVICE_ID_VIA_PX8X0_0),
 
 557         ID(PCI_DEVICE_ID_VIA_3269_0),
 
 558         ID(PCI_DEVICE_ID_VIA_83_87XX_1),
 
 559         ID(PCI_DEVICE_ID_VIA_3296_0),
 
 560         ID(PCI_DEVICE_ID_VIA_P4M800CE),
 
 561         ID(PCI_DEVICE_ID_VIA_VT3324),
 
 562         ID(PCI_DEVICE_ID_VIA_P4M890),
 
 563         ID(PCI_DEVICE_ID_VIA_VT3364),
 
 567 MODULE_DEVICE_TABLE(pci, agp_via_pci_table);
 
 570 static struct pci_driver agp_via_pci_driver = {
 
 571         .name           = "agpgart-via",
 
 572         .id_table       = agp_via_pci_table,
 
 573         .probe          = agp_via_probe,
 
 574         .remove         = agp_via_remove,
 
 576         .suspend        = agp_via_suspend,
 
 577         .resume         = agp_via_resume,
 
 582 static int __init agp_via_init(void)
 
 586         return pci_register_driver(&agp_via_pci_driver);
 
 589 static void __exit agp_via_cleanup(void)
 
 591         pci_unregister_driver(&agp_via_pci_driver);
 
 594 module_init(agp_via_init);
 
 595 module_exit(agp_via_cleanup);
 
 597 MODULE_LICENSE("GPL");
 
 598 MODULE_AUTHOR("Dave Jones <davej@codemonkey.org.uk>");