mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-19 20:08:06 +02:00
Some code in gallium was making assumptions of how the gpu_id is laid out, which will not work for 64 bit gpu_ids. Expose pan_prod_id and pan_rev from the model to collect this logic in a single place. Reviewed-by: Marc Alcala Prieto <marc.alcalaprieto@arm.com> Reviewed-by: Christoph Pillmayer <christoph.pillmayer@arm.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/40921>
133 lines
6.8 KiB
C
133 lines
6.8 KiB
C
/*
|
|
* Copyright (C) 2019 Collabora, Ltd.
|
|
* Copyright (C) 2026 Arm Ltd.
|
|
* SPDX-License-Identifier: MIT
|
|
*/
|
|
|
|
#include "pan_model.h"
|
|
|
|
/* Fixed "minimum revisions" */
|
|
#define GPU_REV_NONE (~0)
|
|
#define GPU_REV_ALL PAN_REV(0, 0)
|
|
#define GPU_REV_R0P3 PAN_REV(0, 3)
|
|
#define GPU_REV_R1P1 PAN_REV(1, 1)
|
|
|
|
#define MODEL(gpu_prod_id_, gpu_variant_, shortname, counters, ...) \
|
|
{ \
|
|
.gpu_prod_id = gpu_prod_id_, \
|
|
.gpu_variant = gpu_variant_, \
|
|
.name = "Mali-" shortname, \
|
|
.performance_counters = counters, \
|
|
##__VA_ARGS__, \
|
|
}
|
|
|
|
#define MIDGARD_MODEL(gpu_prod_id, shortname, counters, ...) \
|
|
MODEL(gpu_prod_id, 0, shortname, counters, ##__VA_ARGS__)
|
|
|
|
#define BIFROST_MODEL(gpu_prod_id, shortname, counters, ...) \
|
|
MODEL(gpu_prod_id, 0, shortname, counters, ##__VA_ARGS__)
|
|
|
|
#define VALHALL_MODEL(gpu_prod_id, gpu_variant, shortname, counters, ...) \
|
|
MODEL(gpu_prod_id, gpu_variant, shortname, counters, ##__VA_ARGS__)
|
|
|
|
#define FIFTHGEN_MODEL(gpu_prod_id, gpu_variant, shortname, counters, ...) \
|
|
MODEL(gpu_prod_id, gpu_variant, shortname, counters, ##__VA_ARGS__)
|
|
|
|
#define MODEL_ANISO(rev) .min_rev_anisotropic = GPU_REV_##rev
|
|
|
|
#define MODEL_TB_SIZES(color_tb_size, z_tb_size) \
|
|
.tilebuffer = { \
|
|
.color_size = color_tb_size, \
|
|
.z_size = z_tb_size, \
|
|
}
|
|
|
|
#define MODEL_RATES(pixel_rate, texel_rate, fma_rate) \
|
|
.rates = { \
|
|
.pixel = pixel_rate, \
|
|
.texel = texel_rate, \
|
|
.fma = fma_rate, \
|
|
}
|
|
|
|
#define MODEL_QUIRKS(...) .quirks = {__VA_ARGS__}
|
|
|
|
/* Table of supported Mali GPUs */
|
|
/* clang-format off */
|
|
const struct pan_model pan_model_list[] = {
|
|
MIDGARD_MODEL(0x600, "T600", "T60x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 4096, 4096),
|
|
MODEL_QUIRKS( .max_4x_msaa = true )),
|
|
MIDGARD_MODEL(0x620, "T620", "T62x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 4096, 4096)),
|
|
MIDGARD_MODEL(0x720, "T720", "T72x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 4096, 4096),
|
|
MODEL_QUIRKS( .no_hierarchical_tiling = true, .max_4x_msaa = true )),
|
|
MIDGARD_MODEL(0x750, "T760", "T76x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 8192, 8192)),
|
|
MIDGARD_MODEL(0x820, "T820", "T82x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 8192, 8192),
|
|
MODEL_QUIRKS( .no_hierarchical_tiling = true, .max_4x_msaa = true )),
|
|
MIDGARD_MODEL(0x830, "T830", "T83x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 8192, 8192),
|
|
MODEL_QUIRKS( .no_hierarchical_tiling = true, .max_4x_msaa = true )),
|
|
MIDGARD_MODEL(0x860, "T860", "T86x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 8192, 8192)),
|
|
MIDGARD_MODEL(0x880, "T880", "T88x", MODEL_ANISO(NONE), MODEL_TB_SIZES( 8192, 8192)),
|
|
|
|
BIFROST_MODEL(PAN_PROD_ID(6, 0, 0), "G71", "TMIx", MODEL_ANISO(NONE), MODEL_TB_SIZES( 4096, 4096)),
|
|
BIFROST_MODEL(PAN_PROD_ID(6, 2, 1), "G72", "THEx", MODEL_ANISO(R0P3), MODEL_TB_SIZES( 8192, 4096)),
|
|
BIFROST_MODEL(PAN_PROD_ID(7, 0, 0), "G51", "TSIx", MODEL_ANISO(R1P1), MODEL_TB_SIZES( 8192, 8192)),
|
|
BIFROST_MODEL(PAN_PROD_ID(7, 0, 3), "G31", "TDVx", MODEL_ANISO(ALL), MODEL_TB_SIZES( 8192, 8192)),
|
|
BIFROST_MODEL(PAN_PROD_ID(7, 2, 1), "G76", "TNOx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192)),
|
|
BIFROST_MODEL(PAN_PROD_ID(7, 2, 2), "G52", "TGOx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192)),
|
|
BIFROST_MODEL(PAN_PROD_ID(7, 4, 2), "G52 r1", "TGOx", MODEL_ANISO(ALL), MODEL_TB_SIZES( 8192, 8192)),
|
|
|
|
VALHALL_MODEL(PAN_PROD_ID(9, 0, 1), 0, "G57", "TNAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192),
|
|
MODEL_RATES(2, 4, 32)),
|
|
VALHALL_MODEL(PAN_PROD_ID(9, 0, 3), 0, "G57", "TNAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192),
|
|
MODEL_RATES(2, 4, 32)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 8, 7), 0, "G610", "TVIx", MODEL_ANISO(ALL), MODEL_TB_SIZES(32768, 16384),
|
|
MODEL_RATES(4, 8, 64)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 12, 4), 0, "G310v1", "TVAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192),
|
|
MODEL_RATES(2, 2, 16)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 12, 4), 1, "G310v2", "TVAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192),
|
|
MODEL_RATES(2, 4, 32)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 12, 4), 2, "G310v3", "TVAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(16384, 8192),
|
|
MODEL_RATES(4, 4, 48)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 12, 4), 3, "G310v4", "TVAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(32768, 16384),
|
|
MODEL_RATES(4, 8, 48)),
|
|
VALHALL_MODEL(PAN_PROD_ID(10, 12, 4), 4, "G310v5", "TVAx", MODEL_ANISO(ALL), MODEL_TB_SIZES(32768, 16384),
|
|
MODEL_RATES(4, 8, 64)),
|
|
|
|
FIFTHGEN_MODEL(PAN_PROD_ID(12, 8, 0), 4, "G720", "TTIx", MODEL_ANISO(ALL), MODEL_TB_SIZES(65536, 32768),
|
|
MODEL_RATES(4, 8, 128)),
|
|
FIFTHGEN_MODEL(PAN_PROD_ID(13, 8, 0), 4, "G725", "TKRx", MODEL_ANISO(ALL), MODEL_TB_SIZES(65536, 65536),
|
|
MODEL_RATES(4, 8, 128)),
|
|
};
|
|
/* clang-format on */
|
|
|
|
#undef GPU_REV
|
|
#undef GPU_REV_NONE
|
|
#undef GPU_REV_ALL
|
|
#undef GPU_REV_R0P3
|
|
#undef GPU_REV_R1P1
|
|
|
|
#undef MIDGARD_MODEL
|
|
#undef BIFROST_MODEL
|
|
#undef VALHALL_MODEL
|
|
#undef FIFTHGEN_MODEL
|
|
#undef MODEL
|
|
|
|
#undef MODEL_ANISO
|
|
#undef MODEL_TB_SIZES
|
|
#undef MODEL_RATES
|
|
#undef MODEL_QUIRKS
|
|
|
|
/*
|
|
* Look up a supported model by its GPU ID, or return NULL if the model is not
|
|
* supported at this time.
|
|
*/
|
|
const struct pan_model *
|
|
pan_get_model(uint64_t gpu_id, uint32_t gpu_variant)
|
|
{
|
|
uint32_t gpu_prod_id = pan_prod_id(gpu_id);
|
|
for (unsigned i = 0; i < ARRAY_SIZE(pan_model_list); ++i) {
|
|
if (pan_model_list[i].gpu_prod_id == gpu_prod_id &&
|
|
pan_model_list[i].gpu_variant == gpu_variant)
|
|
return &pan_model_list[i];
|
|
}
|
|
|
|
return NULL;
|
|
}
|