base.c (1590700d94ac53772491ed3103a4e8b8de01640a) | base.c (ccd27db8c731817ef36e75de2b5fdc2e79550213) |
---|---|
1/* 2 * Copyright 2018 Red Hat Inc. 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the --- 17 unchanged lines hidden (view full) --- 26int 27nv50_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[] = { | 1/* 2 * Copyright 2018 Red Hat Inc. 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the --- 17 unchanged lines hidden (view full) --- 26int 27nv50_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, base507c_new }, 35 { GK104_DISP_BASE_CHANNEL_DMA, 0, base507c_new }, 36 { GF110_DISP_BASE_CHANNEL_DMA, 0, base507c_new }, 37 { GT214_DISP_BASE_CHANNEL_DMA, 0, base507c_new }, 38 { GT200_DISP_BASE_CHANNEL_DMA, 0, base507c_new }, 39 { G82_DISP_BASE_CHANNEL_DMA, 0, base507c_new }, | 34 { GK110_DISP_BASE_CHANNEL_DMA, 0, base907c_new }, 35 { GK104_DISP_BASE_CHANNEL_DMA, 0, base907c_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} | 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} |