Loading...
Note: File does not exist in v3.1.
1/*
2 * Copyright 2019 Advanced Micro Devices, Inc.
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
21 *
22 */
23#ifndef __SMU_V11_0_H__
24#define __SMU_V11_0_H__
25
26#include "amdgpu_smu.h"
27
28#define SMU11_DRIVER_IF_VERSION_INV 0xFFFFFFFF
29#define SMU11_DRIVER_IF_VERSION_VG20 0x13
30#define SMU11_DRIVER_IF_VERSION_ARCT 0x09
31#define SMU11_DRIVER_IF_VERSION_NV10 0x33
32#define SMU11_DRIVER_IF_VERSION_NV14 0x34
33
34/* MP Apertures */
35#define MP0_Public 0x03800000
36#define MP0_SRAM 0x03900000
37#define MP1_Public 0x03b00000
38#define MP1_SRAM 0x03c00004
39#define MP1_SMC_SIZE 0x40000
40
41/* address block */
42#define smnMP1_FIRMWARE_FLAGS 0x3010024
43#define smnMP0_FW_INTF 0x30101c0
44#define smnMP1_PUB_CTRL 0x3010b14
45
46#define TEMP_RANGE_MIN (0)
47#define TEMP_RANGE_MAX (80 * 1000)
48
49#define SMU11_TOOL_SIZE 0x19000
50
51#define CLK_MAP(clk, index) \
52 [SMU_##clk] = {1, (index)}
53
54#define FEA_MAP(fea) \
55 [SMU_FEATURE_##fea##_BIT] = {1, FEATURE_##fea##_BIT}
56
57#define TAB_MAP(tab) \
58 [SMU_TABLE_##tab] = {1, TABLE_##tab}
59
60#define PWR_MAP(tab) \
61 [SMU_POWER_SOURCE_##tab] = {1, POWER_SOURCE_##tab}
62
63#define WORKLOAD_MAP(profile, workload) \
64 [profile] = {1, (workload)}
65
66static const struct smu_temperature_range smu11_thermal_policy[] =
67{
68 {-273150, 99000, 99000, -273150, 99000, 99000, -273150, 99000, 99000},
69 { 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000, 120000},
70};
71
72struct smu_11_0_cmn2aisc_mapping {
73 int valid_mapping;
74 int map_to;
75};
76
77struct smu_11_0_max_sustainable_clocks {
78 uint32_t display_clock;
79 uint32_t phy_clock;
80 uint32_t pixel_clock;
81 uint32_t uclock;
82 uint32_t dcef_clock;
83 uint32_t soc_clock;
84};
85
86struct smu_11_0_dpm_table {
87 uint32_t min; /* MHz */
88 uint32_t max; /* MHz */
89};
90
91struct smu_11_0_dpm_tables {
92 struct smu_11_0_dpm_table soc_table;
93 struct smu_11_0_dpm_table gfx_table;
94 struct smu_11_0_dpm_table uclk_table;
95 struct smu_11_0_dpm_table eclk_table;
96 struct smu_11_0_dpm_table vclk_table;
97 struct smu_11_0_dpm_table dclk_table;
98 struct smu_11_0_dpm_table dcef_table;
99 struct smu_11_0_dpm_table pixel_table;
100 struct smu_11_0_dpm_table display_table;
101 struct smu_11_0_dpm_table phy_table;
102 struct smu_11_0_dpm_table fclk_table;
103};
104
105struct smu_11_0_dpm_context {
106 struct smu_11_0_dpm_tables dpm_tables;
107 uint32_t workload_policy_mask;
108 uint32_t dcef_min_ds_clk;
109};
110
111enum smu_11_0_power_state {
112 SMU_11_0_POWER_STATE__D0 = 0,
113 SMU_11_0_POWER_STATE__D1,
114 SMU_11_0_POWER_STATE__D3, /* Sleep*/
115 SMU_11_0_POWER_STATE__D4, /* Hibernate*/
116 SMU_11_0_POWER_STATE__D5, /* Power off*/
117};
118
119struct smu_11_0_power_context {
120 uint32_t power_source;
121 uint8_t in_power_limit_boost_mode;
122 enum smu_11_0_power_state power_state;
123};
124
125enum smu_v11_0_baco_seq {
126 BACO_SEQ_BACO = 0,
127 BACO_SEQ_MSR,
128 BACO_SEQ_BAMACO,
129 BACO_SEQ_ULPS,
130 BACO_SEQ_COUNT,
131};
132
133void smu_v11_0_set_smu_funcs(struct smu_context *smu);
134
135#endif