|
|
@ -486,41 +486,51 @@ void Maxwell3D::ProcessQueryGet() {
|
|
|
|
|
|
|
|
|
|
|
|
void Maxwell3D::ProcessQueryCondition() {
|
|
|
|
void Maxwell3D::ProcessQueryCondition() {
|
|
|
|
const GPUVAddr condition_address{regs.render_enable.Address()};
|
|
|
|
const GPUVAddr condition_address{regs.render_enable.Address()};
|
|
|
|
switch (regs.render_enable.mode) {
|
|
|
|
switch (regs.render_enable_override) {
|
|
|
|
case Regs::RenderEnable::Mode::True: {
|
|
|
|
case Regs::RenderEnable::Override::AlwaysRender:
|
|
|
|
execute_on = true;
|
|
|
|
execute_on = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case Regs::RenderEnable::Override::NeverRender:
|
|
|
|
case Regs::RenderEnable::Mode::False: {
|
|
|
|
|
|
|
|
execute_on = false;
|
|
|
|
execute_on = false;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case Regs::RenderEnable::Override::UseRenderEnable:
|
|
|
|
case Regs::RenderEnable::Mode::Conditional: {
|
|
|
|
switch (regs.render_enable.mode) {
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
case Regs::RenderEnable::Mode::True: {
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
execute_on = true;
|
|
|
|
execute_on = cmp.initial_sequence != 0U && cmp.initial_mode != 0U;
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Regs::RenderEnable::Mode::False: {
|
|
|
|
|
|
|
|
execute_on = false;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Regs::RenderEnable::Mode::Conditional: {
|
|
|
|
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
|
|
|
|
execute_on = cmp.initial_sequence != 0U && cmp.initial_mode != 0U;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Regs::RenderEnable::Mode::IfEqual: {
|
|
|
|
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
|
|
|
|
execute_on = cmp.initial_sequence == cmp.current_sequence &&
|
|
|
|
|
|
|
|
cmp.initial_mode == cmp.current_mode;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Regs::RenderEnable::Mode::IfNotEqual: {
|
|
|
|
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
|
|
|
|
execute_on = cmp.initial_sequence != cmp.current_sequence ||
|
|
|
|
|
|
|
|
cmp.initial_mode != cmp.current_mode;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
default: {
|
|
|
|
|
|
|
|
UNIMPLEMENTED_MSG("Uninplemented Condition Mode!");
|
|
|
|
|
|
|
|
execute_on = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case Regs::RenderEnable::Mode::IfEqual: {
|
|
|
|
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
|
|
|
|
execute_on =
|
|
|
|
|
|
|
|
cmp.initial_sequence == cmp.current_sequence && cmp.initial_mode == cmp.current_mode;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Regs::RenderEnable::Mode::IfNotEqual: {
|
|
|
|
|
|
|
|
Regs::ReportSemaphore::Compare cmp;
|
|
|
|
|
|
|
|
memory_manager.ReadBlock(condition_address, &cmp, sizeof(cmp));
|
|
|
|
|
|
|
|
execute_on =
|
|
|
|
|
|
|
|
cmp.initial_sequence != cmp.current_sequence || cmp.initial_mode != cmp.current_mode;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
default: {
|
|
|
|
|
|
|
|
UNIMPLEMENTED_MSG("Uninplemented Condition Mode!");
|
|
|
|
|
|
|
|
execute_on = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Maxwell3D::ProcessCounterReset() {
|
|
|
|
void Maxwell3D::ProcessCounterReset() {
|
|
|
|