diff --git a/.pick_status.json b/.pick_status.json index 6bfa5ebdb14..9810731617d 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -589,7 +589,7 @@ "description": "intel/vec4: force exec_all on float control instruction", "nominated": true, "nomination_type": 1, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": "daa8003e45c37d13f81958c0a74222e259d18538" }, diff --git a/src/intel/compiler/brw_vec4_visitor.cpp b/src/intel/compiler/brw_vec4_visitor.cpp index 82076cd1c8a..9d399a66ef5 100644 --- a/src/intel/compiler/brw_vec4_visitor.cpp +++ b/src/intel/compiler/brw_vec4_visitor.cpp @@ -1363,7 +1363,8 @@ vec4_visitor::emit_shader_float_controls_execution_mode() unsigned execution_mode = this->nir->info.float_controls_execution_mode; if (nir_has_any_rounding_mode_enabled(execution_mode)) { brw_rnd_mode rnd = brw_rnd_mode_from_execution_mode(execution_mode); - emit(SHADER_OPCODE_RND_MODE, dst_null_ud(), brw_imm_d(rnd)); + const vec4_builder bld = vec4_builder(this).at_end(); + bld.exec_all().emit(SHADER_OPCODE_RND_MODE, dst_null_ud(), brw_imm_d(rnd)); } }