Skip to content

Commit

Permalink
[tuner]: add helper function
Browse files Browse the repository at this point in the history
Signed-off-by: Bangtian Liu <[email protected]>
  • Loading branch information
bangtianliu committed Dec 11, 2024
1 parent 404e3d5 commit bad9159
Show file tree
Hide file tree
Showing 6 changed files with 42 additions and 104 deletions.
2 changes: 1 addition & 1 deletion tuner/tuner/candidate_gen.py
Original file line number Diff line number Diff line change
Expand Up @@ -322,7 +322,7 @@ def get_transform_function_batch_mmt(
transform.iree.match.cast_compatible_type %rhs = tensor<{problem_size.rhs_type}> : !transform.any_value
%config = transform.param.constant #iree_codegen.compilation_info<
lowering_config = {configuration.lowering_config},
translation_info ={configuration.translation_info}
translation_info = {configuration.translation_info}
> -> !transform.any_param
transform.yield %generic, %config : !transform.any_op, !transform.any_param
}}
Expand Down
56 changes: 7 additions & 49 deletions tuner/tuner/candidate_gen_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,7 @@ def test_apply_params_mmt(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get(prefetch_shared_memory=True)
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("8")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 8)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [16, 16, 1], 16, config_dict
)
Expand Down Expand Up @@ -136,13 +130,7 @@ def test_apply_params_conv(tuner_ctx: common.TunerContext) -> None:
iree_gpu.ReorderWorkgroupsStrategy.Transpose
)
)
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [256, 1, 1], 64, config_dict
)
Expand Down Expand Up @@ -216,13 +204,7 @@ def test_apply_params_contract(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [256, 1, 1], 64, config_dict
)
Expand Down Expand Up @@ -282,13 +264,7 @@ def test_apply_params_batch_matmul(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [128, 2, 1], 64, config_dict
)
Expand Down Expand Up @@ -351,13 +327,7 @@ def test_apply_params_batch_mmt_float(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [128, 2, 1], 64, config_dict
)
Expand Down Expand Up @@ -418,13 +388,7 @@ def test_apply_params_batch_mmt_int(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("4")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 4)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [128, 2, 1], 64, config_dict
)
Expand Down Expand Up @@ -509,13 +473,7 @@ def test_apply_params_broadcast_rhs_mmt(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("4")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 4)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [128, 2, 1], 64, config_dict
)
Expand Down
25 changes: 25 additions & 0 deletions tuner/tuner/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,31 @@ def get_lowering_config(
return iree_gpu.LoweringConfigAttr.get(lowering_config_attrs)


def get_translation_info_config(
pipeline_options: iree_gpu.PipelineOptionsAttr, waves_per_eu: int | str
) -> ir.DictAttr:
if isinstance(waves_per_eu, int):
waves_per_eu = str(waves_per_eu)
elif not isinstance(waves_per_eu, str):
assert (
False
), f"waves_per_eu must be an int or str, but got {type(waves_per_eu).__name__}"

# Create the waves_per_eu dictionary attribute.
waves_per_eu_dict = ir.DictAttr.get(
{WAVES_PER_EU_KEY: ir.StringAttr.get(waves_per_eu)}
)

config_dict = ir.DictAttr.get(
{
GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)

return config_dict


def read_input_mlir(filename: str) -> list[str]:
with open(filename, "r") as f:
return f.readlines()
Expand Down
28 changes: 5 additions & 23 deletions tuner/tuner/common_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,39 +89,27 @@ def test_get_pipeline_config(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [16, 16, 1], 32, config_dict
)
config = common.Configuration(
translation_info=translation_info,
lowering_config=lowering_config,
)
config1_str: str = str(config.translation_info.configuration["llvm_func_attrs"])
config1_str: str = str(config.translation_info.configuration[common.LLVM_FUNC_ATTRS_KEY])
assert config1_str == '{"amdgpu-waves-per-eu" = "2"}'

pipeline_options = iree_gpu.PipelineOptionsAttr.get(prefetch_shared_memory=True)
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("4")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
"llvm_func_attrs": waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 4)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [16, 16, 1], 32, config_dict
)
config = common.Configuration(
translation_info=translation_info,
lowering_config=lowering_config,
)
config2_str: str = str(config.translation_info.configuration)
config2_str : str = str(config.translation_info.configuration)
assert (
config2_str
== '{gpu_pipeline_options = #iree_gpu.pipeline_options<prefetch_shared_memory = true>, llvm_func_attrs = {"amdgpu-waves-per-eu" = "4"}}'
Expand Down Expand Up @@ -231,13 +219,7 @@ def test_get_lowering_config(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
"llvm_func_attrs": waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [16, 16, 1], 32, config_dict
)
Expand Down
11 changes: 1 addition & 10 deletions tuner/tuner/dispatch_constraints.py
Original file line number Diff line number Diff line change
Expand Up @@ -248,16 +248,7 @@ def generate_solutions(
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get(
{WAVES_PER_EU_KEY: ir.StringAttr.get(str(lookup(waves_per_eu)))}
)
config_dict = ir.DictAttr.get(
{
GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)

config_dict = get_translation_info_config(pipeline_options, lookup(waves_per_eu))
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr,
None,
Expand Down
24 changes: 3 additions & 21 deletions tuner/tuner/dispatch_parser_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -55,13 +55,7 @@ def test_get_mmt_tile_sizes(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("0")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 0)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [], 0, config_dict
)
Expand Down Expand Up @@ -89,13 +83,7 @@ def test_get_conv_tile_sizes(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("1")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 1)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [256, 1, 1], 64, config_dict
)
Expand All @@ -122,13 +110,7 @@ def test_get_contract_tile_sizes(tuner_ctx: common.TunerContext) -> None:
iree_codegen.DispatchLoweringPassPipeline.LLVMGPUVectorDistribute
)
pipeline_options = iree_gpu.PipelineOptionsAttr.get()
waves_per_eu_dict = ir.DictAttr.get({"amdgpu-waves-per-eu": ir.StringAttr.get("2")})
config_dict = ir.DictAttr.get(
{
common.GPU_PIPELINE_OPTIONS_KEY: pipeline_options,
common.LLVM_FUNC_ATTRS_KEY: waves_per_eu_dict,
}
)
config_dict = common.get_translation_info_config(pipeline_options, 2)
translation_info = iree_codegen.TranslationInfoAttr.get(
pipeline_attr, None, [16, 16, 1], 32, config_dict
)
Expand Down

0 comments on commit bad9159

Please sign in to comment.