mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-29 22:14:41 +08:00
ddfd2da484
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
56 lines
1.2 KiB
C
56 lines
1.2 KiB
C
#include "drmP.h"
|
|
#include "drm.h"
|
|
#include "nouveau_drv.h"
|
|
#include "nouveau_drm.h"
|
|
|
|
int
|
|
nv04_fb_vram_init(struct drm_device *dev)
|
|
{
|
|
struct drm_nouveau_private *dev_priv = dev->dev_private;
|
|
u32 boot0 = nv_rd32(dev, NV04_PFB_BOOT_0);
|
|
|
|
if (boot0 & 0x00000100) {
|
|
dev_priv->vram_size = ((boot0 >> 12) & 0xf) * 2 + 2;
|
|
dev_priv->vram_size *= 1024 * 1024;
|
|
} else {
|
|
switch (boot0 & NV04_PFB_BOOT_0_RAM_AMOUNT) {
|
|
case NV04_PFB_BOOT_0_RAM_AMOUNT_32MB:
|
|
dev_priv->vram_size = 32 * 1024 * 1024;
|
|
break;
|
|
case NV04_PFB_BOOT_0_RAM_AMOUNT_16MB:
|
|
dev_priv->vram_size = 16 * 1024 * 1024;
|
|
break;
|
|
case NV04_PFB_BOOT_0_RAM_AMOUNT_8MB:
|
|
dev_priv->vram_size = 8 * 1024 * 1024;
|
|
break;
|
|
case NV04_PFB_BOOT_0_RAM_AMOUNT_4MB:
|
|
dev_priv->vram_size = 4 * 1024 * 1024;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if ((boot0 & 0x00000038) <= 0x10)
|
|
dev_priv->vram_type = NV_MEM_TYPE_SGRAM;
|
|
else
|
|
dev_priv->vram_type = NV_MEM_TYPE_SDRAM;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
nv04_fb_init(struct drm_device *dev)
|
|
{
|
|
/* This is what the DDX did for NV_ARCH_04, but a mmio-trace shows
|
|
* nvidia reading PFB_CFG_0, then writing back its original value.
|
|
* (which was 0x701114 in this case)
|
|
*/
|
|
|
|
nv_wr32(dev, NV04_PFB_CFG0, 0x1114);
|
|
return 0;
|
|
}
|
|
|
|
void
|
|
nv04_fb_takedown(struct drm_device *dev)
|
|
{
|
|
}
|