1178476Sjb/* SPDX-License-Identifier: MIT */
2178476Sjb/*
3178476Sjb * Copyright 2023 Advanced Micro Devices, Inc.
4178476Sjb *
5178476Sjb * Permission is hereby granted, free of charge, to any person obtaining a
6178476Sjb * copy of this software and associated documentation files (the "Software"),
7178476Sjb * to deal in the Software without restriction, including without limitation
8178476Sjb * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9178476Sjb * and/or sell copies of the Software, and to permit persons to whom the
10178476Sjb * Software is furnished to do so, subject to the following conditions:
11178476Sjb *
12178476Sjb * The above copyright notice and this permission notice shall be included in
13178476Sjb * all copies or substantial portions of the Software.
14178476Sjb *
15178476Sjb * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16178476Sjb * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
19 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21 * OTHER DEALINGS IN THE SOFTWARE.
22 *
23 */
24
25#ifndef __DML2_POLICY_H__
26#define __DML2_POLICY_H__
27
28#include "display_mode_core_structs.h"
29
30struct dml2_policy_build_synthetic_soc_states_params {
31	const struct soc_bounding_box_st *in_bbox;
32	struct soc_states_st *in_states;
33	struct soc_states_st *out_states;
34	int *dcfclk_stas_mhz;
35	int num_dcfclk_stas;
36};
37
38struct dml2_policy_build_synthetic_soc_states_scratch {
39	struct soc_state_bounding_box_st entry;
40};
41
42int dml2_policy_build_synthetic_soc_states(struct dml2_policy_build_synthetic_soc_states_scratch *s,
43	struct dml2_policy_build_synthetic_soc_states_params *p);
44
45void build_unoptimized_policy_settings(enum dml_project_id project, struct dml_mode_eval_policy_st *policy);
46
47#endif
48