memcpy(shmem->cpu, &shmemp, sizeof(shmemp));
- struct mali_shader_meta meta = {
- .shader = shader->gpu,
- .attribute_count = 1,
- .varying_count = 1,
- .bifrost1 = {
- .unk1 = 0x800200,
- .uniform_buffer_count = 1,
- },
- .bifrost2 = {
- .unk3 = 0x0,
- .preload_regs = 0xc0,
- .uniform_count = sz_ubo / 16,
- .unk4 = 0x0,
- },
- };
+ pan_pack(shader_desc->cpu, STATE, cfg) {
+ cfg.shader.shader = shader->gpu;
+ cfg.shader.attribute_count = cfg.shader.varying_count = 1;
+ cfg.properties = 0x80020001;
+ cfg.preload.uniform_count = (sz_ubo / 16);
+ }
- memcpy(shader_desc->cpu, &meta, sizeof(meta));
memcpy(shader->cpu, prog.compiled.data, prog.compiled.size);
struct bifrost_payload_vertex payload = {
.prefix = {
- },
- .postfix = {
- .gl_enables = 0x2,
- .shared_memory = shmem->gpu,
- .shader = shader_desc->gpu,
- .uniforms = ubo->gpu + 1024,
- .uniform_buffers = ubo->gpu,
- .attribute_meta = attr->gpu,
- .attributes = attr->gpu + 256,
- .varying_meta = var->gpu,
- .varyings = var->gpu + 256,
+ .primitive = {
+ .opaque = { (5) << 26 }
+ }
},
};
- panfrost_pack_work_groups_compute(&payload.prefix,
+ struct mali_draw_packed draw;
+ struct mali_invocation_packed invocation;
+
+ pan_pack(&draw, DRAW, cfg) {
+ cfg.unknown_1 = 0x2;
+ cfg.shared = shmem->gpu;
+ cfg.state = shader_desc->gpu;
+ cfg.push_uniforms = ubo->gpu + 1024;
+ cfg.uniform_buffers = ubo->gpu;
+ cfg.attributes = attr->gpu;
+ cfg.attribute_buffers = attr->gpu + 256;
+ cfg.varyings = var->gpu;
+ cfg.varying_buffers = var->gpu + 256;
+ }
+
+
+ panfrost_pack_work_groups_compute(&invocation,
1, 1, 1,
1, 1, 1,
true);
- payload.prefix.workgroups_x_shift_3 = 5;
+ payload.prefix.invocation = invocation;
+ payload.postfix = draw;
struct panfrost_bo *bos[] = {
scratchpad, shmem, shader, shader_desc, ubo, var, attr