|
@@ -36,6 +36,7 @@
|
|
|
#include "drm_sarea.h"
|
|
|
|
|
|
#include "nouveau_drv.h"
|
|
|
+#include "nouveau_agp.h"
|
|
|
#include "nouveau_pm.h"
|
|
|
#include <core/mm.h>
|
|
|
#include <subdev/vm.h>
|
|
@@ -172,26 +173,7 @@ void
|
|
|
nouveau_mem_gart_fini(struct drm_device *dev)
|
|
|
{
|
|
|
nouveau_sgdma_takedown(dev);
|
|
|
-
|
|
|
- if (drm_core_has_AGP(dev) && dev->agp) {
|
|
|
- struct drm_agp_mem *entry, *tempe;
|
|
|
-
|
|
|
- /* Remove AGP resources, but leave dev->agp
|
|
|
- intact until drv_cleanup is called. */
|
|
|
- list_for_each_entry_safe(entry, tempe, &dev->agp->memory, head) {
|
|
|
- if (entry->bound)
|
|
|
- drm_unbind_agp(entry->memory);
|
|
|
- drm_free_agp(entry->memory, entry->pages);
|
|
|
- kfree(entry);
|
|
|
- }
|
|
|
- INIT_LIST_HEAD(&dev->agp->memory);
|
|
|
-
|
|
|
- if (dev->agp->acquired)
|
|
|
- drm_agp_release(dev);
|
|
|
-
|
|
|
- dev->agp->acquired = 0;
|
|
|
- dev->agp->enabled = 0;
|
|
|
- }
|
|
|
+ nouveau_agp_fini(dev);
|
|
|
}
|
|
|
|
|
|
bool
|
|
@@ -203,121 +185,6 @@ nouveau_mem_flags_valid(struct drm_device *dev, u32 tile_flags)
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
-#if __OS_HAS_AGP
|
|
|
-static unsigned long
|
|
|
-get_agp_mode(struct drm_device *dev, unsigned long mode)
|
|
|
-{
|
|
|
- struct drm_nouveau_private *dev_priv = dev->dev_private;
|
|
|
-
|
|
|
- /*
|
|
|
- * FW seems to be broken on nv18, it makes the card lock up
|
|
|
- * randomly.
|
|
|
- */
|
|
|
- if (dev_priv->chipset == 0x18)
|
|
|
- mode &= ~PCI_AGP_COMMAND_FW;
|
|
|
-
|
|
|
- /*
|
|
|
- * AGP mode set in the command line.
|
|
|
- */
|
|
|
- if (nouveau_agpmode > 0) {
|
|
|
- bool agpv3 = mode & 0x8;
|
|
|
- int rate = agpv3 ? nouveau_agpmode / 4 : nouveau_agpmode;
|
|
|
-
|
|
|
- mode = (mode & ~0x7) | (rate & 0x7);
|
|
|
- }
|
|
|
-
|
|
|
- return mode;
|
|
|
-}
|
|
|
-#endif
|
|
|
-
|
|
|
-int
|
|
|
-nouveau_mem_reset_agp(struct drm_device *dev)
|
|
|
-{
|
|
|
-#if __OS_HAS_AGP
|
|
|
- uint32_t saved_pci_nv_1, pmc_enable;
|
|
|
- int ret;
|
|
|
-
|
|
|
- /* First of all, disable fast writes, otherwise if it's
|
|
|
- * already enabled in the AGP bridge and we disable the card's
|
|
|
- * AGP controller we might be locking ourselves out of it. */
|
|
|
- if ((nv_rd32(dev, NV04_PBUS_PCI_NV_19) |
|
|
|
- dev->agp->mode) & PCI_AGP_COMMAND_FW) {
|
|
|
- struct drm_agp_info info;
|
|
|
- struct drm_agp_mode mode;
|
|
|
-
|
|
|
- ret = drm_agp_info(dev, &info);
|
|
|
- if (ret)
|
|
|
- return ret;
|
|
|
-
|
|
|
- mode.mode = get_agp_mode(dev, info.mode) & ~PCI_AGP_COMMAND_FW;
|
|
|
- ret = drm_agp_enable(dev, mode);
|
|
|
- if (ret)
|
|
|
- return ret;
|
|
|
- }
|
|
|
-
|
|
|
- saved_pci_nv_1 = nv_rd32(dev, NV04_PBUS_PCI_NV_1);
|
|
|
-
|
|
|
- /* clear busmaster bit */
|
|
|
- nv_wr32(dev, NV04_PBUS_PCI_NV_1, saved_pci_nv_1 & ~0x4);
|
|
|
- /* disable AGP */
|
|
|
- nv_wr32(dev, NV04_PBUS_PCI_NV_19, 0);
|
|
|
-
|
|
|
- /* power cycle pgraph, if enabled */
|
|
|
- pmc_enable = nv_rd32(dev, NV03_PMC_ENABLE);
|
|
|
- if (pmc_enable & NV_PMC_ENABLE_PGRAPH) {
|
|
|
- nv_wr32(dev, NV03_PMC_ENABLE,
|
|
|
- pmc_enable & ~NV_PMC_ENABLE_PGRAPH);
|
|
|
- nv_wr32(dev, NV03_PMC_ENABLE, nv_rd32(dev, NV03_PMC_ENABLE) |
|
|
|
- NV_PMC_ENABLE_PGRAPH);
|
|
|
- }
|
|
|
-
|
|
|
- /* and restore (gives effect of resetting AGP) */
|
|
|
- nv_wr32(dev, NV04_PBUS_PCI_NV_1, saved_pci_nv_1);
|
|
|
-#endif
|
|
|
-
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
-int
|
|
|
-nouveau_mem_init_agp(struct drm_device *dev)
|
|
|
-{
|
|
|
-#if __OS_HAS_AGP
|
|
|
- struct drm_nouveau_private *dev_priv = dev->dev_private;
|
|
|
- struct drm_agp_info info;
|
|
|
- struct drm_agp_mode mode;
|
|
|
- int ret;
|
|
|
-
|
|
|
- if (!dev->agp->acquired) {
|
|
|
- ret = drm_agp_acquire(dev);
|
|
|
- if (ret) {
|
|
|
- NV_ERROR(dev, "Unable to acquire AGP: %d\n", ret);
|
|
|
- return ret;
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- nouveau_mem_reset_agp(dev);
|
|
|
-
|
|
|
- ret = drm_agp_info(dev, &info);
|
|
|
- if (ret) {
|
|
|
- NV_ERROR(dev, "Unable to get AGP info: %d\n", ret);
|
|
|
- return ret;
|
|
|
- }
|
|
|
-
|
|
|
- /* see agp.h for the AGPSTAT_* modes available */
|
|
|
- mode.mode = get_agp_mode(dev, info.mode);
|
|
|
- ret = drm_agp_enable(dev, mode);
|
|
|
- if (ret) {
|
|
|
- NV_ERROR(dev, "Unable to enable AGP: %d\n", ret);
|
|
|
- return ret;
|
|
|
- }
|
|
|
-
|
|
|
- dev_priv->gart_info.type = NOUVEAU_GART_AGP;
|
|
|
- dev_priv->gart_info.aper_base = info.aperture_base;
|
|
|
- dev_priv->gart_info.aper_size = info.aperture_size;
|
|
|
-#endif
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
static const struct vram_types {
|
|
|
int value;
|
|
|
const char *name;
|
|
@@ -441,15 +308,7 @@ nouveau_mem_gart_init(struct drm_device *dev)
|
|
|
struct ttm_bo_device *bdev = &dev_priv->ttm.bdev;
|
|
|
int ret;
|
|
|
|
|
|
- dev_priv->gart_info.type = NOUVEAU_GART_NONE;
|
|
|
-
|
|
|
-#if !defined(__powerpc__) && !defined(__ia64__)
|
|
|
- if (drm_pci_device_is_agp(dev) && dev->agp && nouveau_agpmode) {
|
|
|
- ret = nouveau_mem_init_agp(dev);
|
|
|
- if (ret)
|
|
|
- NV_ERROR(dev, "Error initialising AGP: %d\n", ret);
|
|
|
- }
|
|
|
-#endif
|
|
|
+ nouveau_agp_init(dev);
|
|
|
|
|
|
if (dev_priv->gart_info.type == NOUVEAU_GART_NONE) {
|
|
|
ret = nouveau_sgdma_init(dev);
|