1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * Copyright (C) 2020-2023 Intel Corporation
6 #ifndef __IVPU_HW_BTRS_MTL_REG_H__
7 #define __IVPU_HW_BTRS_MTL_REG_H__
9 #include <linux/bits.h>
11 #define VPU_HW_BTRS_MTL_INTERRUPT_TYPE 0x00000000u
13 #define VPU_HW_BTRS_MTL_INTERRUPT_STAT 0x00000004u
14 #define VPU_HW_BTRS_MTL_INTERRUPT_STAT_FREQ_CHANGE_MASK BIT_MASK(0)
15 #define VPU_HW_BTRS_MTL_INTERRUPT_STAT_ATS_ERR_MASK BIT_MASK(1)
16 #define VPU_HW_BTRS_MTL_INTERRUPT_STAT_UFI_ERR_MASK BIT_MASK(2)
18 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD0 0x00000008u
19 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD0_MIN_RATIO_MASK GENMASK(15, 0)
20 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD0_MAX_RATIO_MASK GENMASK(31, 16)
22 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD1 0x0000000cu
23 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD1_TARGET_RATIO_MASK GENMASK(15, 0)
24 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD1_EPP_MASK GENMASK(31, 16)
26 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD2 0x00000010u
27 #define VPU_HW_BTRS_MTL_WP_REQ_PAYLOAD2_CONFIG_MASK GENMASK(15, 0)
29 #define VPU_HW_BTRS_MTL_WP_REQ_CMD 0x00000014u
30 #define VPU_HW_BTRS_MTL_WP_REQ_CMD_SEND_MASK BIT_MASK(0)
32 #define VPU_HW_BTRS_MTL_WP_DOWNLOAD 0x00000018u
33 #define VPU_HW_BTRS_MTL_WP_DOWNLOAD_TARGET_RATIO_MASK GENMASK(15, 0)
35 #define VPU_HW_BTRS_MTL_CURRENT_PLL 0x0000001cu
36 #define VPU_HW_BTRS_MTL_CURRENT_PLL_RATIO_MASK GENMASK(15, 0)
38 #define VPU_HW_BTRS_MTL_PLL_ENABLE 0x00000020u
40 #define VPU_HW_BTRS_MTL_FMIN_FUSE 0x00000024u
41 #define VPU_HW_BTRS_MTL_FMIN_FUSE_MIN_RATIO_MASK GENMASK(7, 0)
42 #define VPU_HW_BTRS_MTL_FMIN_FUSE_PN_RATIO_MASK GENMASK(15, 8)
44 #define VPU_HW_BTRS_MTL_FMAX_FUSE 0x00000028u
45 #define VPU_HW_BTRS_MTL_FMAX_FUSE_MAX_RATIO_MASK GENMASK(7, 0)
47 #define VPU_HW_BTRS_MTL_TILE_FUSE 0x0000002cu
48 #define VPU_HW_BTRS_MTL_TILE_FUSE_VALID_MASK BIT_MASK(0)
49 #define VPU_HW_BTRS_MTL_TILE_FUSE_SKU_MASK GENMASK(3, 2)
51 #define VPU_HW_BTRS_MTL_LOCAL_INT_MASK 0x00000030u
52 #define VPU_HW_BTRS_MTL_GLOBAL_INT_MASK 0x00000034u
54 #define VPU_HW_BTRS_MTL_PLL_STATUS 0x00000040u
55 #define VPU_HW_BTRS_MTL_PLL_STATUS_LOCK_MASK BIT_MASK(1)
57 #define VPU_HW_BTRS_MTL_VPU_STATUS 0x00000044u
58 #define VPU_HW_BTRS_MTL_VPU_STATUS_READY_MASK BIT_MASK(0)
59 #define VPU_HW_BTRS_MTL_VPU_STATUS_IDLE_MASK BIT_MASK(1)
61 #define VPU_HW_BTRS_MTL_VPU_D0I3_CONTROL 0x00000060u
62 #define VPU_HW_BTRS_MTL_VPU_D0I3_CONTROL_INPROGRESS_MASK BIT_MASK(0)
63 #define VPU_HW_BTRS_MTL_VPU_D0I3_CONTROL_I3_MASK BIT_MASK(2)
65 #define VPU_HW_BTRS_MTL_VPU_IP_RESET 0x00000050u
66 #define VPU_HW_BTRS_MTL_VPU_IP_RESET_TRIGGER_MASK BIT_MASK(0)
68 #define VPU_HW_BTRS_MTL_VPU_TELEMETRY_OFFSET 0x00000080u
69 #define VPU_HW_BTRS_MTL_VPU_TELEMETRY_SIZE 0x00000084u
70 #define VPU_HW_BTRS_MTL_VPU_TELEMETRY_ENABLE 0x00000088u
72 #define VPU_HW_BTRS_MTL_ATS_ERR_LOG_0 0x000000a0u
73 #define VPU_HW_BTRS_MTL_ATS_ERR_LOG_1 0x000000a4u
74 #define VPU_HW_BTRS_MTL_ATS_ERR_CLEAR 0x000000a8u
76 #define VPU_HW_BTRS_MTL_UFI_ERR_LOG 0x000000b0u
77 #define VPU_HW_BTRS_MTL_UFI_ERR_LOG_CQ_ID_MASK GENMASK(11, 0)
78 #define VPU_HW_BTRS_MTL_UFI_ERR_LOG_AXI_ID_MASK GENMASK(19, 12)
79 #define VPU_HW_BTRS_MTL_UFI_ERR_LOG_OPCODE_MASK GENMASK(24, 20)
81 #define VPU_HW_BTRS_MTL_UFI_ERR_CLEAR 0x000000b4u
83 #endif /* __IVPU_HW_BTRS_MTL_REG_H__ */