Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5b1ab0c2 authored by Ben Skeggs's avatar Ben Skeggs
Browse files

drm/nouveau/imem/nv04-nv40: directly use instmem for vbios/ramfc/ramro



Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent adb53d27
Loading
Loading
Loading
Loading
+3 −3
Original line number Diff line number Diff line
@@ -13,10 +13,10 @@ struct nvkm_instmem {

	const struct nvkm_instmem_func *func;

	struct nvkm_gpuobj *vbios;
	struct nvkm_memory *vbios;
	struct nvkm_ramht  *ramht;
	struct nvkm_gpuobj *ramro;
	struct nvkm_gpuobj *ramfc;
	struct nvkm_memory *ramro;
	struct nvkm_memory *ramfc;
};

struct nvkm_instmem_func {
+24 −25
Original line number Diff line number Diff line
@@ -56,6 +56,7 @@ nv04_fifo_object_attach(struct nvkm_object *parent,
{
	struct nv04_fifo *fifo = (void *)parent->engine;
	struct nv04_fifo_chan *chan = (void *)parent;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	u32 context, chid = chan->base.chid;
	int ret;

@@ -83,7 +84,7 @@ nv04_fifo_object_attach(struct nvkm_object *parent,
	context |= chid << 24;

	mutex_lock(&nv_subdev(fifo)->mutex);
	ret = nvkm_ramht_insert(fifo->ramht, chid, handle, context);
	ret = nvkm_ramht_insert(imem->ramht, chid, handle, context);
	mutex_unlock(&nv_subdev(fifo)->mutex);
	return ret;
}
@@ -92,8 +93,9 @@ void
nv04_fifo_object_detach(struct nvkm_object *parent, int cookie)
{
	struct nv04_fifo *fifo = (void *)parent->engine;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	mutex_lock(&nv_subdev(fifo)->mutex);
	nvkm_ramht_remove(fifo->ramht, cookie);
	nvkm_ramht_remove(imem->ramht, cookie);
	mutex_unlock(&nv_subdev(fifo)->mutex);
}

@@ -115,6 +117,7 @@ nv04_fifo_chan_ctor(struct nvkm_object *parent,
		struct nv03_channel_dma_v0 v0;
	} *args = data;
	struct nv04_fifo *fifo = (void *)engine;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	struct nv04_fifo_chan *chan;
	int ret;

@@ -142,18 +145,18 @@ nv04_fifo_chan_ctor(struct nvkm_object *parent,
	nv_parent(chan)->context_attach = nv04_fifo_context_attach;
	chan->ramfc = chan->base.chid * 32;

	nvkm_kmap(fifo->ramfc);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x08, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x10,
	nvkm_kmap(imem->ramfc);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x08, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x10,
			     NV_PFIFO_CACHE1_DMA_FETCH_TRIG_128_BYTES |
			     NV_PFIFO_CACHE1_DMA_FETCH_SIZE_128_BYTES |
#ifdef __BIG_ENDIAN
			     NV_PFIFO_CACHE1_BIG_ENDIAN |
#endif
			     NV_PFIFO_CACHE1_DMA_FETCH_MAX_REQS_8);
	nvkm_done(fifo->ramfc);
	nvkm_done(imem->ramfc);
	return 0;
}

@@ -162,13 +165,14 @@ nv04_fifo_chan_dtor(struct nvkm_object *object)
{
	struct nv04_fifo *fifo = (void *)object->engine;
	struct nv04_fifo_chan *chan = (void *)object;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	struct ramfc_desc *c = fifo->ramfc_desc;

	nvkm_kmap(fifo->ramfc);
	nvkm_kmap(imem->ramfc);
	do {
		nvkm_wo32(fifo->ramfc, chan->ramfc + c->ctxp, 0x00000000);
		nvkm_wo32(imem->ramfc, chan->ramfc + c->ctxp, 0x00000000);
	} while ((++c)->bits);
	nvkm_done(fifo->ramfc);
	nvkm_done(imem->ramfc);

	nvkm_fifo_channel_destroy(&chan->base);
}
@@ -198,8 +202,8 @@ nv04_fifo_chan_fini(struct nvkm_object *object, bool suspend)
{
	struct nv04_fifo *fifo = (void *)object->engine;
	struct nv04_fifo_chan *chan = (void *)object;
	struct nvkm_gpuobj *fctx = fifo->ramfc;
	struct nvkm_device *device = fifo->base.engine.subdev.device;
	struct nvkm_memory *fctx = device->imem->ramfc;
	struct ramfc_desc *c;
	unsigned long flags;
	u32 data = chan->ramfc;
@@ -574,8 +578,6 @@ nv04_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	       struct nvkm_oclass *oclass, void *data, u32 size,
	       struct nvkm_object **pobject)
{
	struct nvkm_device *device = (void *)parent;
	struct nvkm_instmem *imem = device->imem;
	struct nv04_fifo *fifo;
	int ret;

@@ -584,10 +586,6 @@ nv04_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	if (ret)
		return ret;

	nvkm_ramht_ref(imem->ramht, &fifo->ramht);
	nvkm_gpuobj_ref(imem->ramro, &fifo->ramro);
	nvkm_gpuobj_ref(imem->ramfc, &fifo->ramfc);

	nv_subdev(fifo)->unit = 0x00000100;
	nv_subdev(fifo)->intr = nv04_fifo_intr;
	nv_engine(fifo)->cclass = &nv04_fifo_cclass;
@@ -602,9 +600,6 @@ void
nv04_fifo_dtor(struct nvkm_object *object)
{
	struct nv04_fifo *fifo = (void *)object;
	nvkm_gpuobj_ref(NULL, &fifo->ramfc);
	nvkm_gpuobj_ref(NULL, &fifo->ramro);
	nvkm_ramht_ref(NULL, &fifo->ramht);
	nvkm_fifo_destroy(&fifo->base);
}

@@ -613,6 +608,10 @@ nv04_fifo_init(struct nvkm_object *object)
{
	struct nv04_fifo *fifo = (void *)object;
	struct nvkm_device *device = fifo->base.engine.subdev.device;
	struct nvkm_instmem *imem = device->imem;
	struct nvkm_ramht *ramht = imem->ramht;
	struct nvkm_memory *ramro = imem->ramro;
	struct nvkm_memory *ramfc = imem->ramfc;
	int ret;

	ret = nvkm_fifo_init(&fifo->base);
@@ -623,10 +622,10 @@ nv04_fifo_init(struct nvkm_object *object)
	nvkm_wr32(device, NV04_PFIFO_DMA_TIMESLICE, 0x0101ffff);

	nvkm_wr32(device, NV03_PFIFO_RAMHT, (0x03 << 24) /* search 128 */ |
				       ((fifo->ramht->bits - 9) << 16) |
				        (fifo->ramht->gpuobj.addr >> 8));
	nvkm_wr32(device, NV03_PFIFO_RAMRO, fifo->ramro->addr >> 8);
	nvkm_wr32(device, NV03_PFIFO_RAMFC, fifo->ramfc->addr >> 8);
					    ((ramht->bits - 9) << 16) |
					    (ramht->gpuobj.addr >> 8));
	nvkm_wr32(device, NV03_PFIFO_RAMRO, nvkm_memory_addr(ramro) >> 8);
	nvkm_wr32(device, NV03_PFIFO_RAMFC, nvkm_memory_addr(ramfc) >> 8);

	nvkm_wr32(device, NV03_PFIFO_CACHE1_PUSH1, fifo->base.max);

+0 −3
Original line number Diff line number Diff line
@@ -142,9 +142,6 @@ struct ramfc_desc {
struct nv04_fifo {
	struct nvkm_fifo base;
	struct ramfc_desc *ramfc_desc;
	struct nvkm_ramht  *ramht;
	struct nvkm_gpuobj *ramro;
	struct nvkm_gpuobj *ramfc;
};

struct nv04_fifo_base {
+7 −13
Original line number Diff line number Diff line
@@ -25,7 +25,6 @@

#include <core/client.h>
#include <core/engctx.h>
#include <core/ramht.h>
#include <subdev/instmem.h>

#include <nvif/class.h>
@@ -59,6 +58,7 @@ nv10_fifo_chan_ctor(struct nvkm_object *parent,
		struct nv03_channel_dma_v0 v0;
	} *args = data;
	struct nv04_fifo *fifo = (void *)engine;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	struct nv04_fifo_chan *chan;
	int ret;

@@ -86,18 +86,18 @@ nv10_fifo_chan_ctor(struct nvkm_object *parent,
	nv_parent(chan)->context_attach = nv04_fifo_context_attach;
	chan->ramfc = chan->base.chid * 32;

	nvkm_kmap(fifo->ramfc);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x0c, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x14,
	nvkm_kmap(imem->ramfc);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x0c, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x14,
			     NV_PFIFO_CACHE1_DMA_FETCH_TRIG_128_BYTES |
			     NV_PFIFO_CACHE1_DMA_FETCH_SIZE_128_BYTES |
#ifdef __BIG_ENDIAN
			     NV_PFIFO_CACHE1_BIG_ENDIAN |
#endif
			     NV_PFIFO_CACHE1_DMA_FETCH_MAX_REQS_8);
	nvkm_done(fifo->ramfc);
	nvkm_done(imem->ramfc);
	return 0;
}

@@ -145,8 +145,6 @@ nv10_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	       struct nvkm_oclass *oclass, void *data, u32 size,
	       struct nvkm_object **pobject)
{
	struct nvkm_device *device = (void *)parent;
	struct nvkm_instmem *imem = device->imem;
	struct nv04_fifo *fifo;
	int ret;

@@ -155,10 +153,6 @@ nv10_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	if (ret)
		return ret;

	nvkm_ramht_ref(imem->ramht, &fifo->ramht);
	nvkm_gpuobj_ref(imem->ramro, &fifo->ramro);
	nvkm_gpuobj_ref(imem->ramfc, &fifo->ramfc);

	nv_subdev(fifo)->unit = 0x00000100;
	nv_subdev(fifo)->intr = nv04_fifo_intr;
	nv_engine(fifo)->cclass = &nv10_fifo_cclass;
+16 −16
Original line number Diff line number Diff line
@@ -64,6 +64,7 @@ nv17_fifo_chan_ctor(struct nvkm_object *parent,
		struct nv03_channel_dma_v0 v0;
	} *args = data;
	struct nv04_fifo *fifo = (void *)engine;
	struct nvkm_instmem *imem = fifo->base.engine.subdev.device->imem;
	struct nv04_fifo_chan *chan;
	int ret;

@@ -93,18 +94,18 @@ nv17_fifo_chan_ctor(struct nvkm_object *parent,
	nv_parent(chan)->context_attach = nv04_fifo_context_attach;
	chan->ramfc = chan->base.chid * 64;

	nvkm_kmap(fifo->ramfc);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x0c, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(fifo->ramfc, chan->ramfc + 0x14,
	nvkm_kmap(imem->ramfc);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x00, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x04, args->v0.offset);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x0c, chan->base.pushgpu->addr >> 4);
	nvkm_wo32(imem->ramfc, chan->ramfc + 0x14,
			     NV_PFIFO_CACHE1_DMA_FETCH_TRIG_128_BYTES |
			     NV_PFIFO_CACHE1_DMA_FETCH_SIZE_128_BYTES |
#ifdef __BIG_ENDIAN
			     NV_PFIFO_CACHE1_BIG_ENDIAN |
#endif
			     NV_PFIFO_CACHE1_DMA_FETCH_MAX_REQS_8);
	nvkm_done(fifo->ramfc);
	nvkm_done(imem->ramfc);
	return 0;
}

@@ -152,8 +153,6 @@ nv17_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	       struct nvkm_oclass *oclass, void *data, u32 size,
	       struct nvkm_object **pobject)
{
	struct nvkm_device *device = (void *)parent;
	struct nvkm_instmem *imem = device->imem;
	struct nv04_fifo *fifo;
	int ret;

@@ -162,10 +161,6 @@ nv17_fifo_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
	if (ret)
		return ret;

	nvkm_ramht_ref(imem->ramht, &fifo->ramht);
	nvkm_gpuobj_ref(imem->ramro, &fifo->ramro);
	nvkm_gpuobj_ref(imem->ramfc, &fifo->ramfc);

	nv_subdev(fifo)->unit = 0x00000100;
	nv_subdev(fifo)->intr = nv04_fifo_intr;
	nv_engine(fifo)->cclass = &nv17_fifo_cclass;
@@ -181,6 +176,10 @@ nv17_fifo_init(struct nvkm_object *object)
{
	struct nv04_fifo *fifo = (void *)object;
	struct nvkm_device *device = fifo->base.engine.subdev.device;
	struct nvkm_instmem *imem = device->imem;
	struct nvkm_ramht *ramht = imem->ramht;
	struct nvkm_memory *ramro = imem->ramro;
	struct nvkm_memory *ramfc = imem->ramfc;
	int ret;

	ret = nvkm_fifo_init(&fifo->base);
@@ -191,10 +190,11 @@ nv17_fifo_init(struct nvkm_object *object)
	nvkm_wr32(device, NV04_PFIFO_DMA_TIMESLICE, 0x0101ffff);

	nvkm_wr32(device, NV03_PFIFO_RAMHT, (0x03 << 24) /* search 128 */ |
				       ((fifo->ramht->bits - 9) << 16) |
				        (fifo->ramht->gpuobj.addr >> 8));
	nvkm_wr32(device, NV03_PFIFO_RAMRO, fifo->ramro->addr >> 8);
	nvkm_wr32(device, NV03_PFIFO_RAMFC, fifo->ramfc->addr >> 8 | 0x00010000);
					    ((ramht->bits - 9) << 16) |
					    (ramht->gpuobj.addr >> 8));
	nvkm_wr32(device, NV03_PFIFO_RAMRO, nvkm_memory_addr(ramro) >> 8);
	nvkm_wr32(device, NV03_PFIFO_RAMFC, nvkm_memory_addr(ramfc) >> 8 |
					    0x00010000);

	nvkm_wr32(device, NV03_PFIFO_CACHE1_PUSH1, fifo->base.max);

Loading