Commit 98b20c9a authored by Ben Skeggs's avatar Ben Skeggs

drm/nouveau/xtensa: convert to new-style nvkm_engine

Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 53e60da4
#ifndef __NVKM_BSP_H__ #ifndef __NVKM_BSP_H__
#define __NVKM_BSP_H__ #define __NVKM_BSP_H__
#include <engine/xtensa.h> #include <engine/xtensa.h>
extern struct nvkm_oclass g84_bsp_oclass; int g84_bsp_new(struct nvkm_device *, int, struct nvkm_engine **);
#endif #endif
#ifndef __NVKM_VP_H__ #ifndef __NVKM_VP_H__
#define __NVKM_VP_H__ #define __NVKM_VP_H__
#include <engine/xtensa.h> #include <engine/xtensa.h>
extern struct nvkm_oclass g84_vp_oclass; int g84_vp_new(struct nvkm_device *, int, struct nvkm_engine **);
#endif #endif
...@@ -4,30 +4,20 @@ ...@@ -4,30 +4,20 @@
#include <core/engine.h> #include <core/engine.h>
struct nvkm_xtensa { struct nvkm_xtensa {
struct nvkm_engine engine;
const struct nvkm_xtensa_func *func; const struct nvkm_xtensa_func *func;
u32 addr; u32 addr;
struct nvkm_engine engine;
struct nvkm_memory *gpu_fw; struct nvkm_memory *gpu_fw;
u32 fifo_val;
u32 unkd28;
}; };
int nvkm_xtensa_new_(const struct nvkm_xtensa_func *, struct nvkm_device *,
int index, bool enable, u32 addr, struct nvkm_engine **);
struct nvkm_xtensa_func { struct nvkm_xtensa_func {
void (*init)(struct nvkm_xtensa *); u32 pmc_enable;
u32 fifo_val;
u32 unkd28;
struct nvkm_sclass sclass[]; struct nvkm_sclass sclass[];
}; };
#define nvkm_xtensa_create(p,e,c,b,d,i,f,r) \
nvkm_xtensa_create_((p), (e), (c), (b), (d), (i), (f), \
sizeof(**r),(void **)r)
int nvkm_xtensa_create_(struct nvkm_object *,
struct nvkm_object *,
struct nvkm_oclass *, u32, bool,
const char *, const char *,
int, void **);
#define _nvkm_xtensa_dtor _nvkm_engine_dtor
int _nvkm_xtensa_init(struct nvkm_object *);
int _nvkm_xtensa_fini(struct nvkm_object *, bool);
#endif #endif
...@@ -26,41 +26,19 @@ ...@@ -26,41 +26,19 @@
#include <nvif/class.h> #include <nvif/class.h>
static const struct nvkm_xtensa_func static const struct nvkm_xtensa_func
g84_bsp_func = { g84_bsp = {
.pmc_enable = 0x04008000,
.fifo_val = 0x1111,
.unkd28 = 0x90044,
.sclass = { .sclass = {
{ -1, -1, NV74_BSP }, { -1, -1, NV74_BSP },
{} {}
} }
}; };
static int int
g84_bsp_ctor(struct nvkm_object *parent, struct nvkm_object *engine, g84_bsp_new(struct nvkm_device *device, int index, struct nvkm_engine **pengine)
struct nvkm_oclass *oclass, void *data, u32 size,
struct nvkm_object **pobject)
{ {
struct nvkm_xtensa *bsp; return nvkm_xtensa_new_(&g84_bsp, device, index,
int ret; true, 0x103000, pengine);
ret = nvkm_xtensa_create(parent, engine, oclass, 0x103000, true,
"PBSP", "bsp", &bsp);
*pobject = nv_object(bsp);
if (ret)
return ret;
bsp->func = &g84_bsp_func;
nv_subdev(bsp)->unit = 0x04008000;
bsp->fifo_val = 0x1111;
bsp->unkd28 = 0x90044;
return 0;
} }
struct nvkm_oclass
g84_bsp_oclass = {
.handle = NV_ENGINE(BSP, 0x84),
.ofuncs = &(struct nvkm_ofuncs) {
.ctor = g84_bsp_ctor,
.dtor = _nvkm_xtensa_dtor,
.init = _nvkm_xtensa_init,
.fini = _nvkm_xtensa_fini,
},
};
...@@ -897,7 +897,7 @@ nv84_chipset = { ...@@ -897,7 +897,7 @@ nv84_chipset = {
.therm = g84_therm_new, .therm = g84_therm_new,
.timer = nv41_timer_new, .timer = nv41_timer_new,
.volt = nv40_volt_new, .volt = nv40_volt_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .disp = g84_disp_new, // .disp = g84_disp_new,
// .dma = nv50_dma_new, // .dma = nv50_dma_new,
...@@ -906,7 +906,7 @@ nv84_chipset = { ...@@ -906,7 +906,7 @@ nv84_chipset = {
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .pm = g84_pm_new, // .pm = g84_pm_new,
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
}; };
static const struct nvkm_device_chip static const struct nvkm_device_chip
...@@ -928,7 +928,7 @@ nv86_chipset = { ...@@ -928,7 +928,7 @@ nv86_chipset = {
.therm = g84_therm_new, .therm = g84_therm_new,
.timer = nv41_timer_new, .timer = nv41_timer_new,
.volt = nv40_volt_new, .volt = nv40_volt_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .disp = g84_disp_new, // .disp = g84_disp_new,
// .dma = nv50_dma_new, // .dma = nv50_dma_new,
...@@ -937,7 +937,7 @@ nv86_chipset = { ...@@ -937,7 +937,7 @@ nv86_chipset = {
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .pm = g84_pm_new, // .pm = g84_pm_new,
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
}; };
static const struct nvkm_device_chip static const struct nvkm_device_chip
...@@ -959,7 +959,7 @@ nv92_chipset = { ...@@ -959,7 +959,7 @@ nv92_chipset = {
.therm = g84_therm_new, .therm = g84_therm_new,
.timer = nv41_timer_new, .timer = nv41_timer_new,
.volt = nv40_volt_new, .volt = nv40_volt_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .disp = g84_disp_new, // .disp = g84_disp_new,
// .dma = nv50_dma_new, // .dma = nv50_dma_new,
...@@ -968,7 +968,7 @@ nv92_chipset = { ...@@ -968,7 +968,7 @@ nv92_chipset = {
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .pm = g84_pm_new, // .pm = g84_pm_new,
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
}; };
static const struct nvkm_device_chip static const struct nvkm_device_chip
...@@ -990,7 +990,7 @@ nv94_chipset = { ...@@ -990,7 +990,7 @@ nv94_chipset = {
.therm = g84_therm_new, .therm = g84_therm_new,
.timer = nv41_timer_new, .timer = nv41_timer_new,
.volt = nv40_volt_new, .volt = nv40_volt_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .disp = g94_disp_new, // .disp = g94_disp_new,
// .dma = nv50_dma_new, // .dma = nv50_dma_new,
...@@ -999,7 +999,7 @@ nv94_chipset = { ...@@ -999,7 +999,7 @@ nv94_chipset = {
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .pm = g84_pm_new, // .pm = g84_pm_new,
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
}; };
static const struct nvkm_device_chip static const struct nvkm_device_chip
...@@ -1026,9 +1026,9 @@ nv96_chipset = { ...@@ -1026,9 +1026,9 @@ nv96_chipset = {
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .gr = nv50_gr_new, // .gr = nv50_gr_new,
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .disp = g94_disp_new, // .disp = g94_disp_new,
// .pm = g84_pm_new, // .pm = g84_pm_new,
}; };
...@@ -1083,7 +1083,7 @@ nva0_chipset = { ...@@ -1083,7 +1083,7 @@ nva0_chipset = {
.therm = g84_therm_new, .therm = g84_therm_new,
.timer = nv41_timer_new, .timer = nv41_timer_new,
.volt = nv40_volt_new, .volt = nv40_volt_new,
// .bsp = g84_bsp_new, .bsp = g84_bsp_new,
// .cipher = g84_cipher_new, // .cipher = g84_cipher_new,
// .disp = gt200_disp_new, // .disp = gt200_disp_new,
// .dma = nv50_dma_new, // .dma = nv50_dma_new,
...@@ -1092,7 +1092,7 @@ nva0_chipset = { ...@@ -1092,7 +1092,7 @@ nva0_chipset = {
// .mpeg = g84_mpeg_new, // .mpeg = g84_mpeg_new,
// .pm = gt200_pm_new, // .pm = gt200_pm_new,
// .sw = nv50_sw_new, // .sw = nv50_sw_new,
// .vp = g84_vp_new, .vp = g84_vp_new,
}; };
static const struct nvkm_device_chip static const struct nvkm_device_chip
......
...@@ -42,9 +42,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -42,9 +42,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass;
break; break;
...@@ -54,9 +52,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -54,9 +52,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass;
break; break;
...@@ -66,9 +62,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -66,9 +62,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = g84_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass;
break; break;
...@@ -78,9 +72,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -78,9 +72,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = g94_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = g94_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass;
break; break;
...@@ -90,9 +82,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -90,9 +82,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = g94_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = g94_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = g84_pm_oclass;
break; break;
...@@ -110,9 +100,7 @@ nv50_identify(struct nvkm_device *device) ...@@ -110,9 +100,7 @@ nv50_identify(struct nvkm_device *device)
device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass; device->oclass[NVDEV_ENGINE_SW ] = nv50_sw_oclass;
device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass; device->oclass[NVDEV_ENGINE_GR ] = &nv50_gr_oclass;
device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass; device->oclass[NVDEV_ENGINE_MPEG ] = &g84_mpeg_oclass;
device->oclass[NVDEV_ENGINE_VP ] = &g84_vp_oclass;
device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass; device->oclass[NVDEV_ENGINE_CIPHER ] = &g84_cipher_oclass;
device->oclass[NVDEV_ENGINE_BSP ] = &g84_bsp_oclass;
device->oclass[NVDEV_ENGINE_DISP ] = gt200_disp_oclass; device->oclass[NVDEV_ENGINE_DISP ] = gt200_disp_oclass;
device->oclass[NVDEV_ENGINE_PM ] = gt200_pm_oclass; device->oclass[NVDEV_ENGINE_PM ] = gt200_pm_oclass;
break; break;
......
...@@ -26,41 +26,19 @@ ...@@ -26,41 +26,19 @@
#include <nvif/class.h> #include <nvif/class.h>
static const struct nvkm_xtensa_func static const struct nvkm_xtensa_func
g84_vp_func = { g84_vp = {
.pmc_enable = 0x01020000,
.fifo_val = 0x111,
.unkd28 = 0x9c544,
.sclass = { .sclass = {
{ -1, -1, NV74_VP2 }, { -1, -1, NV74_VP2 },
{} {}
} }
}; };
static int int
g84_vp_ctor(struct nvkm_object *parent, struct nvkm_object *engine, g84_vp_new(struct nvkm_device *device, int index, struct nvkm_engine **pengine)
struct nvkm_oclass *oclass, void *data, u32 size,
struct nvkm_object **pobject)
{ {
struct nvkm_xtensa *vp; return nvkm_xtensa_new_(&g84_vp, device, index,
int ret; true, 0x00f000, pengine);
ret = nvkm_xtensa_create(parent, engine, oclass, 0xf000, true,
"PVP", "vp", &vp);
*pobject = nv_object(vp);
if (ret)
return ret;
vp->func = &g84_vp_func;
nv_subdev(vp)->unit = 0x01020000;
vp->fifo_val = 0x111;
vp->unkd28 = 0x9c544;
return 0;
} }
struct nvkm_oclass
g84_vp_oclass = {
.handle = NV_ENGINE(VP, 0x84),
.ofuncs = &(struct nvkm_ofuncs) {
.ctor = g84_vp_ctor,
.dtor = _nvkm_xtensa_dtor,
.init = _nvkm_xtensa_init,
.fini = _nvkm_xtensa_fini,
},
};
...@@ -51,11 +51,12 @@ nvkm_xtensa_cclass = { ...@@ -51,11 +51,12 @@ nvkm_xtensa_cclass = {
.bind = nvkm_xtensa_cclass_bind, .bind = nvkm_xtensa_cclass_bind,
}; };
void static void
_nvkm_xtensa_intr(struct nvkm_subdev *subdev) nvkm_xtensa_intr(struct nvkm_engine *engine)
{ {
struct nvkm_xtensa *xtensa = (void *)subdev; struct nvkm_xtensa *xtensa = nvkm_xtensa(engine);
struct nvkm_device *device = xtensa->engine.subdev.device; struct nvkm_subdev *subdev = &xtensa->engine.subdev;
struct nvkm_device *device = subdev->device;
const u32 base = xtensa->addr; const u32 base = xtensa->addr;
u32 unk104 = nvkm_rd32(device, base + 0xd04); u32 unk104 = nvkm_rd32(device, base + 0xd04);
u32 intr = nvkm_rd32(device, base + 0xc20); u32 intr = nvkm_rd32(device, base + 0xc20);
...@@ -68,41 +69,29 @@ _nvkm_xtensa_intr(struct nvkm_subdev *subdev) ...@@ -68,41 +69,29 @@ _nvkm_xtensa_intr(struct nvkm_subdev *subdev)
intr = nvkm_rd32(device, base + 0xc20); intr = nvkm_rd32(device, base + 0xc20);
if (unk104 == 0x10001 && unk10c == 0x200 && chan && !intr) { if (unk104 == 0x10001 && unk10c == 0x200 && chan && !intr) {
nvkm_debug(subdev, "Enabling FIFO_CTRL\n"); nvkm_debug(subdev, "Enabling FIFO_CTRL\n");
nvkm_mask(device, xtensa->addr + 0xd94, 0, xtensa->fifo_val); nvkm_mask(device, xtensa->addr + 0xd94, 0, xtensa->func->fifo_val);
} }
} }
static const struct nvkm_engine_func static int
nvkm_xtensa = { nvkm_xtensa_fini(struct nvkm_engine *engine, bool suspend)
.fifo.sclass = nvkm_xtensa_oclass_get,
.cclass = &nvkm_xtensa_cclass,
};
int
nvkm_xtensa_create_(struct nvkm_object *parent, struct nvkm_object *engine,
struct nvkm_oclass *oclass, u32 addr, bool enable,
const char *iname, const char *fname,
int length, void **pobject)
{ {
struct nvkm_xtensa *xtensa; struct nvkm_xtensa *xtensa = nvkm_xtensa(engine);
int ret; struct nvkm_device *device = xtensa->engine.subdev.device;
const u32 base = xtensa->addr;
ret = nvkm_engine_create_(parent, engine, oclass, enable, iname, nvkm_wr32(device, base + 0xd84, 0); /* INTR_EN */
fname, length, pobject); nvkm_wr32(device, base + 0xd94, 0); /* FIFO_CTRL */
xtensa = *pobject;
if (ret)
return ret;
xtensa->engine.subdev.intr = _nvkm_xtensa_intr; if (!suspend)
xtensa->engine.func = &nvkm_xtensa; nvkm_memory_del(&xtensa->gpu_fw);
xtensa->addr = addr;
return 0; return 0;
} }
int static int
_nvkm_xtensa_init(struct nvkm_object *object) nvkm_xtensa_init(struct nvkm_engine *engine)
{ {
struct nvkm_xtensa *xtensa = (void *)object; struct nvkm_xtensa *xtensa = nvkm_xtensa(engine);
struct nvkm_subdev *subdev = &xtensa->engine.subdev; struct nvkm_subdev *subdev = &xtensa->engine.subdev;
struct nvkm_device *device = subdev->device; struct nvkm_device *device = subdev->device;
const u32 base = xtensa->addr; const u32 base = xtensa->addr;
...@@ -112,10 +101,6 @@ _nvkm_xtensa_init(struct nvkm_object *object) ...@@ -112,10 +101,6 @@ _nvkm_xtensa_init(struct nvkm_object *object)
u64 addr, size; u64 addr, size;
u32 tmp; u32 tmp;
ret = nvkm_engine_init_old(&xtensa->engine);
if (ret)
return ret;
if (!xtensa->gpu_fw) { if (!xtensa->gpu_fw) {
snprintf(name, sizeof(name), "nouveau/nv84_xuc%03x", snprintf(name, sizeof(name), "nouveau/nv84_xuc%03x",
xtensa->addr >> 12); xtensa->addr >> 12);
...@@ -153,7 +138,7 @@ _nvkm_xtensa_init(struct nvkm_object *object) ...@@ -153,7 +138,7 @@ _nvkm_xtensa_init(struct nvkm_object *object)
nvkm_wr32(device, base + 0xd10, 0x1fffffff); /* ?? */ nvkm_wr32(device, base + 0xd10, 0x1fffffff); /* ?? */
nvkm_wr32(device, base + 0xd08, 0x0fffffff); /* ?? */ nvkm_wr32(device, base + 0xd08, 0x0fffffff); /* ?? */
nvkm_wr32(device, base + 0xd28, xtensa->unkd28); /* ?? */ nvkm_wr32(device, base + 0xd28, xtensa->func->unkd28); /* ?? */
nvkm_wr32(device, base + 0xc20, 0x3f); /* INTR */ nvkm_wr32(device, base + 0xc20, 0x3f); /* INTR */
nvkm_wr32(device, base + 0xd84, 0x3f); /* INTR_EN */ nvkm_wr32(device, base + 0xd84, 0x3f); /* INTR_EN */
...@@ -171,18 +156,35 @@ _nvkm_xtensa_init(struct nvkm_object *object) ...@@ -171,18 +156,35 @@ _nvkm_xtensa_init(struct nvkm_object *object)
return 0; return 0;
} }
int static void *
_nvkm_xtensa_fini(struct nvkm_object *object, bool suspend) nvkm_xtensa_dtor(struct nvkm_engine *engine)
{ {
struct nvkm_xtensa *xtensa = (void *)object; return nvkm_xtensa(engine);
struct nvkm_device *device = xtensa->engine.subdev.device; }
const u32 base = xtensa->addr;
nvkm_wr32(device, base + 0xd84, 0); /* INTR_EN */ static const struct nvkm_engine_func
nvkm_wr32(device, base + 0xd94, 0); /* FIFO_CTRL */ nvkm_xtensa = {
.dtor = nvkm_xtensa_dtor,
.init = nvkm_xtensa_init,
.fini = nvkm_xtensa_fini,
.intr = nvkm_xtensa_intr,
.fifo.sclass = nvkm_xtensa_oclass_get,
.cclass = &nvkm_xtensa_cclass,
};
if (!suspend) int
nvkm_memory_del(&xtensa->gpu_fw); nvkm_xtensa_new_(const struct nvkm_xtensa_func *func,
struct nvkm_device *device, int index, bool enable,
u32 addr, struct nvkm_engine **pengine)
{
struct nvkm_xtensa *xtensa;
if (!(xtensa = kzalloc(sizeof(*xtensa), GFP_KERNEL)))
return -ENOMEM;
xtensa->func = func;
xtensa->addr = addr;
*pengine = &xtensa->engine;
return nvkm_engine_fini_old(&xtensa->engine, suspend); return nvkm_engine_ctor(&nvkm_xtensa, device, index, func->pmc_enable,
enable, &xtensa->engine);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment