|
@@ -31,67 +31,7 @@
|
|
|
#include <subdev/instmem.h>
|
|
|
|
|
|
#include <engine/mpeg.h>
|
|
|
-#include <engine/graph/nv40.h>
|
|
|
-
|
|
|
-struct nv40_mpeg_priv {
|
|
|
- struct nouveau_mpeg base;
|
|
|
-};
|
|
|
-
|
|
|
-struct nv40_mpeg_chan {
|
|
|
- struct nouveau_mpeg_chan base;
|
|
|
-};
|
|
|
-
|
|
|
-/*******************************************************************************
|
|
|
- * PMPEG context
|
|
|
- ******************************************************************************/
|
|
|
-
|
|
|
-static int
|
|
|
-nv40_mpeg_context_ctor(struct nouveau_object *parent,
|
|
|
- struct nouveau_object *engine,
|
|
|
- struct nouveau_oclass *oclass, void *data, u32 size,
|
|
|
- struct nouveau_object **pobject)
|
|
|
-{
|
|
|
- struct nv40_mpeg_chan *chan;
|
|
|
- int ret;
|
|
|
-
|
|
|
- ret = nouveau_mpeg_context_create(parent, engine, oclass, NULL,
|
|
|
- 264 * 4, 16,
|
|
|
- NVOBJ_FLAG_ZERO_ALLOC, &chan);
|
|
|
- *pobject = nv_object(chan);
|
|
|
- if (ret)
|
|
|
- return ret;
|
|
|
-
|
|
|
- nv_wo32(&chan->base.base, 0x78, 0x02001ec1);
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
-static int
|
|
|
-nv40_mpeg_context_fini(struct nouveau_object *object, bool suspend)
|
|
|
-{
|
|
|
-
|
|
|
- struct nv40_mpeg_priv *priv = (void *)object->engine;
|
|
|
- struct nv40_mpeg_chan *chan = (void *)object;
|
|
|
- u32 inst = 0x80000000 | nv_gpuobj(chan)->addr >> 4;
|
|
|
-
|
|
|
- nv_mask(priv, 0x00b32c, 0x00000001, 0x00000000);
|
|
|
- if (nv_rd32(priv, 0x00b318) == inst)
|
|
|
- nv_mask(priv, 0x00b318, 0x80000000, 0x00000000);
|
|
|
- nv_mask(priv, 0x00b32c, 0x00000001, 0x00000001);
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
-static struct nouveau_oclass
|
|
|
-nv40_mpeg_cclass = {
|
|
|
- .handle = NV_ENGCTX(MPEG, 0x40),
|
|
|
- .ofuncs = &(struct nouveau_ofuncs) {
|
|
|
- .ctor = nv40_mpeg_context_ctor,
|
|
|
- .dtor = _nouveau_mpeg_context_dtor,
|
|
|
- .init = _nouveau_mpeg_context_init,
|
|
|
- .fini = nv40_mpeg_context_fini,
|
|
|
- .rd32 = _nouveau_mpeg_context_rd32,
|
|
|
- .wr32 = _nouveau_mpeg_context_wr32,
|
|
|
- },
|
|
|
-};
|
|
|
+#include <engine/mpeg/nv31.h>
|
|
|
|
|
|
/*******************************************************************************
|
|
|
* PMPEG engine/subdev functions
|
|
@@ -100,7 +40,7 @@ nv40_mpeg_cclass = {
|
|
|
static void
|
|
|
nv40_mpeg_intr(struct nouveau_subdev *subdev)
|
|
|
{
|
|
|
- struct nv40_mpeg_priv *priv = (void *)subdev;
|
|
|
+ struct nv31_mpeg_priv *priv = (void *)subdev;
|
|
|
u32 stat;
|
|
|
|
|
|
if ((stat = nv_rd32(priv, 0x00b100)))
|
|
@@ -117,7 +57,7 @@ nv40_mpeg_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
|
|
|
struct nouveau_oclass *oclass, void *data, u32 size,
|
|
|
struct nouveau_object **pobject)
|
|
|
{
|
|
|
- struct nv40_mpeg_priv *priv;
|
|
|
+ struct nv31_mpeg_priv *priv;
|
|
|
int ret;
|
|
|
|
|
|
ret = nouveau_mpeg_create(parent, engine, oclass, &priv);
|
|
@@ -127,7 +67,7 @@ nv40_mpeg_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
|
|
|
|
|
|
nv_subdev(priv)->unit = 0x00000002;
|
|
|
nv_subdev(priv)->intr = nv40_mpeg_intr;
|
|
|
- nv_engine(priv)->cclass = &nv40_mpeg_cclass;
|
|
|
+ nv_engine(priv)->cclass = &nv31_mpeg_cclass;
|
|
|
nv_engine(priv)->sclass = nv31_mpeg_sclass;
|
|
|
nv_engine(priv)->tile_prog = nv31_mpeg_tile_prog;
|
|
|
return 0;
|