1#include "drmP.h"
2#include "drm.h"
3#include "nouveau_drv.h"
4#include "nouveau_drm.h"
5
6void
7nv40_fb_set_tile_region(struct drm_device *dev, int i)
8{
9 struct drm_nouveau_private *dev_priv = dev->dev_private;
10 struct nouveau_tile_reg *tile = &dev_priv->tile.reg[i];
11
12 switch (dev_priv->chipset) {
13 case 0x40:
14 nv_wr32(dev, NV10_PFB_TLIMIT(i), tile->limit);
15 nv_wr32(dev, NV10_PFB_TSIZE(i), tile->pitch);
16 nv_wr32(dev, NV10_PFB_TILE(i), tile->addr);
17 break;
18
19 default:
20 nv_wr32(dev, NV40_PFB_TLIMIT(i), tile->limit);
21 nv_wr32(dev, NV40_PFB_TSIZE(i), tile->pitch);
22 nv_wr32(dev, NV40_PFB_TILE(i), tile->addr);
23 break;
24 }
25}
26
27int
28nv40_fb_init(struct drm_device *dev)
29{
30 struct drm_nouveau_private *dev_priv = dev->dev_private;
31 struct nouveau_fb_engine *pfb = &dev_priv->engine.fb;
32 uint32_t tmp;
33 int i;
34
35
36
37
38
39
40 nv_wr32(dev, NV40_PFB_UNK_800, 0x1);
41
42 switch (dev_priv->chipset) {
43 case 0x40:
44 case 0x45:
45 tmp = nv_rd32(dev, NV10_PFB_CLOSE_PAGE2);
46 nv_wr32(dev, NV10_PFB_CLOSE_PAGE2, tmp & ~(1 << 15));
47 pfb->num_tiles = NV10_PFB_TILE__SIZE;
48 break;
49 case 0x46:
50 case 0x47:
51 case 0x49:
52 case 0x4b:
53 case 0x4c:
54 pfb->num_tiles = NV40_PFB_TILE__SIZE_1;
55 break;
56 default:
57 pfb->num_tiles = NV40_PFB_TILE__SIZE_0;
58 break;
59 }
60
61
62 for (i = 0; i < pfb->num_tiles; i++)
63 pfb->set_tile_region(dev, i);
64
65 return 0;
66}
67
68void
69nv40_fb_takedown(struct drm_device *dev)
70{
71}
72