mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-22 04:24:02 +08:00
drm/nouveau/gr/gf100-: virtualise tpc_per_gpc
GM20B now also shares the same code, as NVGPU shows it doesn't need special treatment. Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
fc740f545d
commit
e51f75d501
@ -1079,19 +1079,6 @@ gf100_grctx_generate_unkn(struct gf100_gr *gr)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
gf100_grctx_generate_r406028(struct gf100_gr *gr)
|
|
||||||
{
|
|
||||||
struct nvkm_device *device = gr->base.engine.subdev.device;
|
|
||||||
u32 tmp[GPC_MAX / 8] = {}, i = 0;
|
|
||||||
for (i = 0; i < gr->gpc_nr; i++)
|
|
||||||
tmp[i / 8] |= gr->tpc_nr[i] << ((i % 8) * 4);
|
|
||||||
for (i = 0; i < 4; i++) {
|
|
||||||
nvkm_wr32(device, 0x406028 + (i * 4), tmp[i]);
|
|
||||||
nvkm_wr32(device, 0x405870 + (i * 4), tmp[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
gf100_grctx_generate_r4060a8(struct gf100_gr *gr)
|
gf100_grctx_generate_r4060a8(struct gf100_gr *gr)
|
||||||
{
|
{
|
||||||
@ -1229,8 +1216,10 @@ gf100_grctx_generate_sm_id(struct gf100_gr *gr, int gpc, int tpc, int sm)
|
|||||||
void
|
void
|
||||||
gf100_grctx_generate_floorsweep(struct gf100_gr *gr)
|
gf100_grctx_generate_floorsweep(struct gf100_gr *gr)
|
||||||
{
|
{
|
||||||
|
struct nvkm_device *device = gr->base.engine.subdev.device;
|
||||||
const struct gf100_grctx_func *func = gr->func->grctx;
|
const struct gf100_grctx_func *func = gr->func->grctx;
|
||||||
int tpc, gpc, sm;
|
int tpc, gpc, sm, i, j;
|
||||||
|
u32 data;
|
||||||
|
|
||||||
for (tpc = 0, sm = 0; tpc < gr->tpc_max; tpc++) {
|
for (tpc = 0, sm = 0; tpc < gr->tpc_max; tpc++) {
|
||||||
for (gpc = 0; gpc < gr->gpc_nr; gpc++) {
|
for (gpc = 0; gpc < gr->gpc_nr; gpc++) {
|
||||||
@ -1240,6 +1229,13 @@ gf100_grctx_generate_floorsweep(struct gf100_gr *gr)
|
|||||||
func->tpc_nr(gr, gpc);
|
func->tpc_nr(gr, gpc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (gpc = 0, i = 0; i < 4; i++) {
|
||||||
|
for (data = 0, j = 0; j < 8 && gpc < gr->gpc_nr; j++, gpc++)
|
||||||
|
data |= gr->tpc_nr[gpc] << (j * 4);
|
||||||
|
nvkm_wr32(device, 0x406028 + (i * 4), data);
|
||||||
|
nvkm_wr32(device, 0x405870 + (i * 4), data);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -1271,7 +1267,6 @@ gf100_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gf100_grctx_generate_r4060a8(gr);
|
gf100_grctx_generate_r4060a8(gr);
|
||||||
gf100_grctx_generate_r418bb8(gr);
|
gf100_grctx_generate_r418bb8(gr);
|
||||||
gf100_grctx_generate_r406800(gr);
|
gf100_grctx_generate_r406800(gr);
|
||||||
|
@ -63,7 +63,6 @@ void gf100_grctx_generate_pagepool(struct gf100_grctx *);
|
|||||||
void gf100_grctx_generate_attrib(struct gf100_grctx *);
|
void gf100_grctx_generate_attrib(struct gf100_grctx *);
|
||||||
void gf100_grctx_generate_unkn(struct gf100_gr *);
|
void gf100_grctx_generate_unkn(struct gf100_gr *);
|
||||||
void gf100_grctx_generate_floorsweep(struct gf100_gr *);
|
void gf100_grctx_generate_floorsweep(struct gf100_gr *);
|
||||||
void gf100_grctx_generate_r406028(struct gf100_gr *);
|
|
||||||
void gf100_grctx_generate_r4060a8(struct gf100_gr *);
|
void gf100_grctx_generate_r4060a8(struct gf100_gr *);
|
||||||
void gf100_grctx_generate_r418bb8(struct gf100_gr *);
|
void gf100_grctx_generate_r418bb8(struct gf100_gr *);
|
||||||
void gf100_grctx_generate_r406800(struct gf100_gr *);
|
void gf100_grctx_generate_r406800(struct gf100_gr *);
|
||||||
|
@ -241,7 +241,6 @@ gf117_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gf100_grctx_generate_r4060a8(gr);
|
gf100_grctx_generate_r4060a8(gr);
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
gf100_grctx_generate_r406800(gr);
|
gf100_grctx_generate_r406800(gr);
|
||||||
|
@ -975,7 +975,6 @@ gk104_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
gf100_grctx_generate_r406800(gr);
|
gf100_grctx_generate_r406800(gr);
|
||||||
|
|
||||||
|
@ -43,7 +43,6 @@ gk20a_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
gf100_grctx_generate_r406800(gr);
|
gf100_grctx_generate_r406800(gr);
|
||||||
|
|
||||||
|
@ -961,7 +961,6 @@ gm107_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
gf100_grctx_generate_r406800(gr);
|
gf100_grctx_generate_r406800(gr);
|
||||||
|
|
||||||
|
@ -77,7 +77,6 @@ gm200_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
|
@ -21,20 +21,6 @@
|
|||||||
*/
|
*/
|
||||||
#include "ctxgf100.h"
|
#include "ctxgf100.h"
|
||||||
|
|
||||||
static void
|
|
||||||
gm20b_grctx_generate_r406028(struct gf100_gr *gr)
|
|
||||||
{
|
|
||||||
struct nvkm_device *device = gr->base.engine.subdev.device;
|
|
||||||
u32 tpc_per_gpc = 0;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < gr->gpc_nr; i++)
|
|
||||||
tpc_per_gpc |= gr->tpc_nr[i] << (4 * i);
|
|
||||||
|
|
||||||
nvkm_wr32(device, 0x406028, tpc_per_gpc);
|
|
||||||
nvkm_wr32(device, 0x405870, tpc_per_gpc);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gm20b_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
gm20b_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
||||||
{
|
{
|
||||||
@ -54,7 +40,6 @@ gm20b_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gm20b_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
|
@ -139,7 +139,6 @@ gp100_grctx_generate_main(struct gf100_gr *gr, struct gf100_grctx *info)
|
|||||||
grctx->unkn(gr);
|
grctx->unkn(gr);
|
||||||
|
|
||||||
gf100_grctx_generate_floorsweep(gr);
|
gf100_grctx_generate_floorsweep(gr);
|
||||||
gf100_grctx_generate_r406028(gr);
|
|
||||||
gk104_grctx_generate_r418bb8(gr);
|
gk104_grctx_generate_r418bb8(gr);
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
|
Loading…
Reference in New Issue
Block a user