ctxnvc4.c revision eeb0558e074215656ae11a170059a5f2ce29963f
130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs/*
230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * Copyright 2013 Red Hat Inc.
330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs *
430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * Permission is hereby granted, free of charge, to any person obtaining a
530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * copy of this software and associated documentation files (the "Software"),
630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * to deal in the Software without restriction, including without limitation
730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * the rights to use, copy, modify, merge, publish, distribute, sublicense,
830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * and/or sell copies of the Software, and to permit persons to whom the
930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * Software is furnished to do so, subject to the following conditions:
1030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs *
1130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * The above copyright notice and this permission notice shall be included in
1230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * all copies or substantial portions of the Software.
1330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs *
1430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
1730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
1830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
1930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
2030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * OTHER DEALINGS IN THE SOFTWARE.
2130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs *
2230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs * Authors: Ben Skeggs <bskeggs@redhat.com>
2330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs */
2430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs
2530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs#include "nvc0.h"
2630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs
2730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggsstatic struct nvc0_graph_init
28eeb0558e074215656ae11a170059a5f2ce29963fBen Skeggsnvc4_grctx_init_tpc[] = {
2930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419818,   1, 0x04, 0x00000000 },
3030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x41983c,   1, 0x04, 0x00038bc7 },
3130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419848,   1, 0x04, 0x00000000 },
3230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419864,   1, 0x04, 0x0000012a },
3330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419888,   1, 0x04, 0x00000000 },
3430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a00,   1, 0x04, 0x000001f0 },
3530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a04,   1, 0x04, 0x00000001 },
3630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a08,   1, 0x04, 0x00000023 },
3730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a0c,   1, 0x04, 0x00020000 },
3830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a10,   1, 0x04, 0x00000000 },
3930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a14,   1, 0x04, 0x00000200 },
4030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a1c,   1, 0x04, 0x00000000 },
4130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419a20,   1, 0x04, 0x00000800 },
4230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419ac4,   1, 0x04, 0x0007f440 },
4330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b00,   1, 0x04, 0x0a418820 },
4430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b04,   1, 0x04, 0x062080e6 },
4530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b08,   1, 0x04, 0x020398a4 },
4630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b0c,   1, 0x04, 0x0e629062 },
4730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b10,   1, 0x04, 0x0a418820 },
4830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419b14,   1, 0x04, 0x000000e6 },
4930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419bd0,   1, 0x04, 0x00900103 },
5030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419be0,   1, 0x04, 0x00000001 },
5130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419be4,   1, 0x04, 0x00000000 },
5230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419c00,   1, 0x04, 0x00000002 },
5330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419c04,   1, 0x04, 0x00000006 },
5430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419c08,   1, 0x04, 0x00000002 },
5530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419c20,   1, 0x04, 0x00000000 },
5630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419cb0,   1, 0x04, 0x00020048 },
5730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419ce8,   1, 0x04, 0x00000000 },
5830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419cf4,   1, 0x04, 0x00000183 },
5930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419d20,   1, 0x04, 0x02180000 },
6030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419d24,   1, 0x04, 0x00001fff },
6130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e04,   3, 0x04, 0x00000000 },
6230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e10,   1, 0x04, 0x00000002 },
6330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e44,   1, 0x04, 0x001beff2 },
6430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e48,   1, 0x04, 0x00000000 },
6530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e4c,   1, 0x04, 0x0000000f },
6630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e50,  17, 0x04, 0x00000000 },
6730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419e98,   1, 0x04, 0x00000000 },
6830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419ee0,   1, 0x04, 0x00011110 },
6930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{ 0x419f30,  11, 0x04, 0x00000000 },
7030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	{}
7130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs};
7230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs
7370f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggsstruct nvc0_graph_init *
74eeb0558e074215656ae11a170059a5f2ce29963fBen Skeggsnvc4_grctx_init_gpc[] = {
7570f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs	nvc0_grctx_init_gpc_0,
7670f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs	nvc0_grctx_init_gpc_1,
77eeb0558e074215656ae11a170059a5f2ce29963fBen Skeggs	nvc4_grctx_init_tpc,
7870f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs	NULL
7970f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs};
8070f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs
8130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggsstruct nouveau_oclass *
82eeb0558e074215656ae11a170059a5f2ce29963fBen Skeggsnvc4_grctx_oclass = &(struct nvc0_grctx_oclass) {
8330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.base.handle = NV_ENGCTX(GR, 0xc3),
8430f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.base.ofuncs = &(struct nouveau_ofuncs) {
8530f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.ctor = nvc0_graph_context_ctor,
8630f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.dtor = nvc0_graph_context_dtor,
8730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.init = _nouveau_graph_context_init,
8830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.fini = _nouveau_graph_context_fini,
8930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.rd32 = _nouveau_graph_context_rd32,
9030f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs		.wr32 = _nouveau_graph_context_wr32,
9130f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	},
9230f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.main = nvc0_grctx_generate_main,
9330f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.mods = nvc0_grctx_generate_mods,
94d196e16ebf8bc9489ee3dc41dc5dfd84a70cec18Ben Skeggs	.unkn = nvc0_grctx_generate_unkn,
9570f824ac8c369194e9499c59e687c6aa8b1a10c8Ben Skeggs	.hub  = nvc0_grctx_init_hub,
96eeb0558e074215656ae11a170059a5f2ce29963fBen Skeggs	.gpc  = nvc4_grctx_init_gpc,
9730f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.icmd = nvc0_grctx_init_icmd,
9830f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs	.mthd = nvc0_grctx_init_mthd,
9930f4e0870d1726f31aa59804337cfd5e0a3f2ec7Ben Skeggs}.base;
100