From 88e98d49a1b3e0f8103cdd4fd80d576ec33133ab Mon Sep 17 00:00:00 2001 From: Ben Skeggs Date: Mon, 3 Mar 2014 16:18:56 +1000 Subject: [PATCH] drm/gf100-/gr: split ppc state into its subunits Signed-off-by: Ben Skeggs --- .../drm/nouveau/core/engine/graph/ctxnv108.c | 16 ++++---------- .../drm/nouveau/core/engine/graph/ctxnvc0.h | 4 ++++ .../drm/nouveau/core/engine/graph/ctxnvd7.c | 16 ++++++++++++-- .../drm/nouveau/core/engine/graph/ctxnve4.c | 22 +++++++++---------- .../drm/nouveau/core/engine/graph/ctxnvf0.c | 16 ++++---------- .../gpu/drm/nouveau/core/engine/graph/nv108.c | 4 +++- .../gpu/drm/nouveau/core/engine/graph/nvc0.h | 4 +++- .../gpu/drm/nouveau/core/engine/graph/nvd7.c | 16 ++++++++++++-- .../gpu/drm/nouveau/core/engine/graph/nve4.c | 4 +++- .../gpu/drm/nouveau/core/engine/graph/nvf0.c | 4 +++- 10 files changed, 62 insertions(+), 44 deletions(-) diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnv108.c b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnv108.c index 2af03ddcc51..aa120c4996b 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnv108.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnv108.c @@ -511,27 +511,19 @@ nv108_grctx_pack_tpc[] = { }; static const struct nvc0_graph_init -nv108_grctx_init_ppc_0[] = { - { 0x41be24, 1, 0x04, 0x00000006 }, +nv108_grctx_init_cbm_0[] = { { 0x41bec0, 1, 0x04, 0x10000000 }, { 0x41bec4, 1, 0x04, 0x00037f7f }, { 0x41bee4, 1, 0x04, 0x00000000 }, { 0x41bef0, 1, 0x04, 0x000003ff }, - { 0x41bf00, 1, 0x04, 0x0a418820 }, - { 0x41bf04, 1, 0x04, 0x062080e6 }, - { 0x41bf08, 1, 0x04, 0x020398a4 }, - { 0x41bf0c, 1, 0x04, 0x0e629062 }, - { 0x41bf10, 1, 0x04, 0x0a418820 }, - { 0x41bf14, 1, 0x04, 0x000000e6 }, - { 0x41bfd0, 1, 0x04, 0x00900103 }, - { 0x41bfe0, 1, 0x04, 0x00400001 }, - { 0x41bfe4, 1, 0x04, 0x00000000 }, {} }; static const struct nvc0_graph_pack nv108_grctx_pack_ppc[] = { - { nv108_grctx_init_ppc_0 }, + { nve4_grctx_init_pes_0 }, + { nv108_grctx_init_cbm_0 }, + { nvd7_grctx_init_wwdx_0 }, {} }; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvc0.h b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvc0.h index fad89ad1191..ab36ceb983d 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvc0.h +++ b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvc0.h @@ -140,12 +140,16 @@ extern const struct nvc0_graph_init nvd9_grctx_init_sm_0[]; extern const struct nvc0_graph_init nvd7_grctx_init_pe_0[]; +extern const struct nvc0_graph_init nvd7_grctx_init_wwdx_0[]; + extern const struct nvc0_graph_init nve4_grctx_init_memfmt_0[]; extern const struct nvc0_graph_init nve4_grctx_init_ds_0[]; extern const struct nvc0_graph_init nve4_grctx_init_scc_0[]; extern const struct nvc0_graph_init nve4_grctx_init_gpm_0[]; +extern const struct nvc0_graph_init nve4_grctx_init_pes_0[]; + extern const struct nvc0_graph_pack nvf0_grctx_pack_mthd[]; extern const struct nvc0_graph_init nvf0_grctx_init_pri_0[]; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvd7.c b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvd7.c index 21a4cccecc1..1dbc8d7f2e8 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvd7.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvd7.c @@ -138,11 +138,21 @@ nvd7_grctx_pack_tpc[] = { }; static const struct nvc0_graph_init -nvd7_grctx_init_ppc_0[] = { +nvd7_grctx_init_pes_0[] = { { 0x41be24, 1, 0x04, 0x00000002 }, + {} +}; + +static const struct nvc0_graph_init +nvd7_grctx_init_cbm_0[] = { { 0x41bec0, 1, 0x04, 0x12180000 }, { 0x41bec4, 1, 0x04, 0x00003fff }, { 0x41bee4, 1, 0x04, 0x03240218 }, + {} +}; + +const struct nvc0_graph_init +nvd7_grctx_init_wwdx_0[] = { { 0x41bf00, 1, 0x04, 0x0a418820 }, { 0x41bf04, 1, 0x04, 0x062080e6 }, { 0x41bf08, 1, 0x04, 0x020398a4 }, @@ -157,7 +167,9 @@ nvd7_grctx_init_ppc_0[] = { static const struct nvc0_graph_pack nvd7_grctx_pack_ppc[] = { - { nvd7_grctx_init_ppc_0 }, + { nvd7_grctx_init_pes_0 }, + { nvd7_grctx_init_cbm_0 }, + { nvd7_grctx_init_wwdx_0 }, {} }; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnve4.c b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnve4.c index 126dbe27ed4..49a14b116a5 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnve4.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnve4.c @@ -812,27 +812,25 @@ nve4_grctx_pack_tpc[] = { {} }; -static const struct nvc0_graph_init -nve4_grctx_init_ppc_0[] = { +const struct nvc0_graph_init +nve4_grctx_init_pes_0[] = { { 0x41be24, 1, 0x04, 0x00000006 }, + {} +}; + +static const struct nvc0_graph_init +nve4_grctx_init_cbm_0[] = { { 0x41bec0, 1, 0x04, 0x12180000 }, { 0x41bec4, 1, 0x04, 0x00037f7f }, { 0x41bee4, 1, 0x04, 0x06480430 }, - { 0x41bf00, 1, 0x04, 0x0a418820 }, - { 0x41bf04, 1, 0x04, 0x062080e6 }, - { 0x41bf08, 1, 0x04, 0x020398a4 }, - { 0x41bf0c, 1, 0x04, 0x0e629062 }, - { 0x41bf10, 1, 0x04, 0x0a418820 }, - { 0x41bf14, 1, 0x04, 0x000000e6 }, - { 0x41bfd0, 1, 0x04, 0x00900103 }, - { 0x41bfe0, 1, 0x04, 0x00400001 }, - { 0x41bfe4, 1, 0x04, 0x00000000 }, {} }; static const struct nvc0_graph_pack nve4_grctx_pack_ppc[] = { - { nve4_grctx_init_ppc_0 }, + { nve4_grctx_init_pes_0 }, + { nve4_grctx_init_cbm_0 }, + { nvd7_grctx_init_wwdx_0 }, {} }; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvf0.c b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvf0.c index 9ee6f79596e..0fab95e49f5 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvf0.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/ctxnvf0.c @@ -790,26 +790,18 @@ nvf0_grctx_pack_tpc[] = { }; static const struct nvc0_graph_init -nvf0_grctx_init_ppc_0[] = { - { 0x41be24, 1, 0x04, 0x00000006 }, +nvf0_grctx_init_cbm_0[] = { { 0x41bec0, 1, 0x04, 0x10000000 }, { 0x41bec4, 1, 0x04, 0x00037f7f }, { 0x41bee4, 1, 0x04, 0x00000000 }, - { 0x41bf00, 1, 0x04, 0x0a418820 }, - { 0x41bf04, 1, 0x04, 0x062080e6 }, - { 0x41bf08, 1, 0x04, 0x020398a4 }, - { 0x41bf0c, 1, 0x04, 0x0e629062 }, - { 0x41bf10, 1, 0x04, 0x0a418820 }, - { 0x41bf14, 1, 0x04, 0x000000e6 }, - { 0x41bfd0, 1, 0x04, 0x00900103 }, - { 0x41bfe0, 1, 0x04, 0x00400001 }, - { 0x41bfe4, 1, 0x04, 0x00000000 }, {} }; static const struct nvc0_graph_pack nvf0_grctx_pack_ppc[] = { - { nvf0_grctx_init_ppc_0 }, + { nve4_grctx_init_pes_0 }, + { nvf0_grctx_init_cbm_0 }, + { nvd7_grctx_init_wwdx_0 }, {} }; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/nv108.c b/drivers/gpu/drm/nouveau/core/engine/graph/nv108.c index 19c3bd643ae..76a667132f8 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/nv108.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/nv108.c @@ -137,7 +137,9 @@ nv108_graph_pack_mmio[] = { { nv108_graph_init_l1c_0 }, { nvc0_graph_init_mpc_0 }, { nvf0_graph_init_sm_0 }, - { nvd7_graph_init_ppc_0 }, + { nvd7_graph_init_pes_0 }, + { nvd7_graph_init_wwdx_0 }, + { nvd7_graph_init_cbm_0 }, { nve4_graph_init_be_0 }, { nvc0_graph_init_fe_1 }, {} diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/nvc0.h b/drivers/gpu/drm/nouveau/core/engine/graph/nvc0.h index b158094ba71..4fe3e458933 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/nvc0.h +++ b/drivers/gpu/drm/nouveau/core/engine/graph/nvc0.h @@ -208,7 +208,9 @@ extern const struct nvc0_graph_init nvd9_graph_init_tex_0[]; extern const struct nvc0_graph_init nvd9_graph_init_sm_0[]; extern const struct nvc0_graph_init nvd9_graph_init_fe_1[]; -extern const struct nvc0_graph_init nvd7_graph_init_ppc_0[]; +extern const struct nvc0_graph_init nvd7_graph_init_pes_0[]; +extern const struct nvc0_graph_init nvd7_graph_init_wwdx_0[]; +extern const struct nvc0_graph_init nvd7_graph_init_cbm_0[]; extern const struct nvc0_graph_init nve4_graph_init_main_0[]; extern const struct nvc0_graph_init nve4_graph_init_tpccs_0[]; diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/nvd7.c b/drivers/gpu/drm/nouveau/core/engine/graph/nvd7.c index 2fd812cc1c8..2a6a94e2a04 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/nvd7.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/nvd7.c @@ -39,15 +39,25 @@ nvd7_graph_init_pe_0[] = { }; const struct nvc0_graph_init -nvd7_graph_init_ppc_0[] = { +nvd7_graph_init_pes_0[] = { { 0x41be04, 1, 0x04, 0x00000000 }, { 0x41be08, 1, 0x04, 0x00000004 }, { 0x41be0c, 1, 0x04, 0x00000000 }, { 0x41be10, 1, 0x04, 0x003b8bc7 }, { 0x41be14, 2, 0x04, 0x00000000 }, + {} +}; + +const struct nvc0_graph_init +nvd7_graph_init_wwdx_0[] = { { 0x41bfd4, 1, 0x04, 0x00800000 }, { 0x41bfdc, 1, 0x04, 0x00000000 }, { 0x41bff8, 2, 0x04, 0x00000000 }, + {} +}; + +const struct nvc0_graph_init +nvd7_graph_init_cbm_0[] = { { 0x41becc, 1, 0x04, 0x00000000 }, { 0x41bee8, 2, 0x04, 0x00000000 }, {} @@ -77,7 +87,9 @@ nvd7_graph_pack_mmio[] = { { nvc0_graph_init_l1c_0 }, { nvc0_graph_init_mpc_0 }, { nvd9_graph_init_sm_0 }, - { nvd7_graph_init_ppc_0 }, + { nvd7_graph_init_pes_0 }, + { nvd7_graph_init_wwdx_0 }, + { nvd7_graph_init_cbm_0 }, { nvc0_graph_init_be_0 }, { nvd9_graph_init_fe_1 }, {} diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/nve4.c b/drivers/gpu/drm/nouveau/core/engine/graph/nve4.c index c395a5a8a73..6e73b18920b 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/nve4.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/nve4.c @@ -177,7 +177,9 @@ nve4_graph_pack_mmio[] = { { nve4_graph_init_l1c_0 }, { nvc0_graph_init_mpc_0 }, { nve4_graph_init_sm_0 }, - { nvd7_graph_init_ppc_0 }, + { nvd7_graph_init_pes_0 }, + { nvd7_graph_init_wwdx_0 }, + { nvd7_graph_init_cbm_0 }, { nve4_graph_init_be_0 }, { nvc0_graph_init_fe_1 }, {} diff --git a/drivers/gpu/drm/nouveau/core/engine/graph/nvf0.c b/drivers/gpu/drm/nouveau/core/engine/graph/nvf0.c index 811a21559c6..c96762122b9 100644 --- a/drivers/gpu/drm/nouveau/core/engine/graph/nvf0.c +++ b/drivers/gpu/drm/nouveau/core/engine/graph/nvf0.c @@ -158,7 +158,9 @@ nvf0_graph_pack_mmio[] = { { nvf0_graph_init_l1c_0 }, { nvc0_graph_init_mpc_0 }, { nvf0_graph_init_sm_0 }, - { nvd7_graph_init_ppc_0 }, + { nvd7_graph_init_pes_0 }, + { nvd7_graph_init_wwdx_0 }, + { nvd7_graph_init_cbm_0 }, { nve4_graph_init_be_0 }, { nvc0_graph_init_fe_1 }, {} -- 2.41.0