This source file includes following definitions.
- nv50_base_new
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 #include "base.h"
23
24 #include <nvif/class.h>
25
26 int
27 nv50_base_new(struct nouveau_drm *drm, int head, struct nv50_wndw **pwndw)
28 {
29 struct {
30 s32 oclass;
31 int version;
32 int (*new)(struct nouveau_drm *, int, s32, struct nv50_wndw **);
33 } bases[] = {
34 { GK110_DISP_BASE_CHANNEL_DMA, 0, base917c_new },
35 { GK104_DISP_BASE_CHANNEL_DMA, 0, base917c_new },
36 { GF110_DISP_BASE_CHANNEL_DMA, 0, base907c_new },
37 { GT214_DISP_BASE_CHANNEL_DMA, 0, base827c_new },
38 { GT200_DISP_BASE_CHANNEL_DMA, 0, base827c_new },
39 { G82_DISP_BASE_CHANNEL_DMA, 0, base827c_new },
40 { NV50_DISP_BASE_CHANNEL_DMA, 0, base507c_new },
41 {}
42 };
43 struct nv50_disp *disp = nv50_disp(drm->dev);
44 int cid;
45
46 cid = nvif_mclass(&disp->disp->object, bases);
47 if (cid < 0) {
48 NV_ERROR(drm, "No supported base class\n");
49 return cid;
50 }
51
52 return bases[cid].new(drm, head, bases[cid].oclass, pwndw);
53 }