1 /*************************************************************************/ /*!
2 @File rgx_fwif_hwperf.h
3 @Title RGX HWPerf support
4 @Copyright Copyright (c) Imagination Technologies Ltd. All Rights Reserved
5 @Description Shared header between RGX firmware and Init process
6 @License Dual MIT/GPLv2
8 The contents of this file are subject to the MIT license as set out below.
10 Permission is hereby granted, free of charge, to any person obtaining a copy
11 of this software and associated documentation files (the "Software"), to deal
12 in the Software without restriction, including without limitation the rights
13 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14 copies of the Software, and to permit persons to whom the Software is
15 furnished to do so, subject to the following conditions:
17 The above copyright notice and this permission notice shall be included in
18 all copies or substantial portions of the Software.
20 Alternatively, the contents of this file may be used under the terms of
21 the GNU General Public License Version 2 ("GPL") in which case the provisions
22 of GPL are applicable instead of those above.
24 If you wish to allow use of your version of this file only under the terms of
25 GPL, and not to allow others to use your version of this file under the terms
26 of the MIT license, indicate your decision by deleting the provisions above
27 and replace them with the notice and other provisions required by GPL as set
28 out in the file called "GPL-COPYING" included in this distribution. If you do
29 not delete the provisions above, a recipient may use your version of this file
30 under the terms of either the MIT license or GPL.
32 This License is also included in this distribution in the file called
35 EXCEPT AS OTHERWISE STATED IN A NEGOTIATED AGREEMENT: (A) THE SOFTWARE IS
36 PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
37 BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
38 PURPOSE AND NONINFRINGEMENT; AND (B) IN NO EVENT SHALL THE AUTHORS OR
39 COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
40 IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
41 CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
42 */ /**************************************************************************/
43 #ifndef RGX_FWIF_HWPERF_H
44 #define RGX_FWIF_HWPERF_H
46 #include "rgx_fwif_shared.h"
47 #include "rgx_hwperf_km.h"
48 #include "rgxdefs_km.h"
51 /*****************************************************************************/
53 /* Structure to hold a block's parameters for passing between the BG context
54 * and the IRQ context when applying a configuration request. */
55 typedef struct _RGXFWIF_HWPERF_CTL_BLK_
60 IMG_UINT32 uiCounterMask;
61 IMG_UINT64 RGXFW_ALIGN aui64CounterCfg[RGX_CNTBLK_COUNTERS_MAX];
62 } RGXFWIF_HWPERF_CTL_BLK;
64 /* Structure used to hold the configuration of the non-mux counters blocks */
65 typedef struct _RGXFW_HWPERF_SELECT_
67 IMG_UINT32 ui32NumSelectedCounters;
68 IMG_UINT32 aui32SelectedCountersIDs[RGX_HWPERF_MAX_CUSTOM_CNTRS];
69 } RGXFW_HWPERF_SELECT;
71 /* Structure to hold the whole configuration request details for all blocks
72 * The block masks and counts are used to optimise reading of this data. */
73 typedef struct _RGXFWIF_HWPERF_CTL_
75 IMG_BOOL bResetOrdinal;
77 IMG_UINT32 ui32SelectedCountersBlockMask;
78 RGXFW_HWPERF_SELECT RGXFW_ALIGN SelCntr[RGX_HWPERF_MAX_CUSTOM_BLKS];
80 IMG_UINT32 ui32EnabledBlksCount;
81 RGXFWIF_HWPERF_CTL_BLK RGXFW_ALIGN sBlkCfg[RGX_HWPERF_MAX_DEFINED_BLKS];
82 } UNCACHED_ALIGN RGXFWIF_HWPERF_CTL;
84 /* NOTE: The switch statement in this function must be kept in alignment with
85 * the enumeration RGX_HWPERF_CNTBLK_ID defined in rgx_hwperf_km.h. ASSERTs may
87 * The function provides a hash lookup to get a handle on the global store for
88 * a block's configuration store from it's block ID.
90 #ifdef INLINE_IS_PRAGMA
91 #pragma inline(rgxfw_hwperf_get_block_ctl)
93 static INLINE RGXFWIF_HWPERF_CTL_BLK* rgxfw_hwperf_get_block_ctl(
94 RGX_HWPERF_CNTBLK_ID eBlockID, RGXFWIF_HWPERF_CTL *psHWPerfInitData)
96 IMG_INT32 i32Idx = -1;
98 /* Hash the block ID into a control configuration array index */
101 case RGX_CNTBLK_ID_TA:
102 case RGX_CNTBLK_ID_RASTER:
103 case RGX_CNTBLK_ID_HUB:
104 case RGX_CNTBLK_ID_TORNADO:
105 case RGX_CNTBLK_ID_JONES:
106 case RGX_CNTBLK_ID_BF:
107 case RGX_CNTBLK_ID_BT:
108 case RGX_CNTBLK_ID_RT:
109 case RGX_CNTBLK_ID_SH:
114 case RGX_CNTBLK_ID_TPU_MCU0:
115 case RGX_CNTBLK_ID_TPU_MCU1:
116 case RGX_CNTBLK_ID_TPU_MCU2:
117 case RGX_CNTBLK_ID_TPU_MCU3:
118 case RGX_CNTBLK_ID_TPU_MCU4:
119 case RGX_CNTBLK_ID_TPU_MCU5:
120 case RGX_CNTBLK_ID_TPU_MCU6:
121 case RGX_CNTBLK_ID_TPU_MCU7:
123 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
124 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
127 case RGX_CNTBLK_ID_USC0:
128 case RGX_CNTBLK_ID_USC1:
129 case RGX_CNTBLK_ID_USC2:
130 case RGX_CNTBLK_ID_USC3:
131 case RGX_CNTBLK_ID_USC4:
132 case RGX_CNTBLK_ID_USC5:
133 case RGX_CNTBLK_ID_USC6:
134 case RGX_CNTBLK_ID_USC7:
135 case RGX_CNTBLK_ID_USC8:
136 case RGX_CNTBLK_ID_USC9:
137 case RGX_CNTBLK_ID_USC10:
138 case RGX_CNTBLK_ID_USC11:
139 case RGX_CNTBLK_ID_USC12:
140 case RGX_CNTBLK_ID_USC13:
141 case RGX_CNTBLK_ID_USC14:
142 case RGX_CNTBLK_ID_USC15:
144 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
145 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
146 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
149 case RGX_CNTBLK_ID_TEXAS0:
150 case RGX_CNTBLK_ID_TEXAS1:
151 case RGX_CNTBLK_ID_TEXAS2:
152 case RGX_CNTBLK_ID_TEXAS3:
153 case RGX_CNTBLK_ID_TEXAS4:
154 case RGX_CNTBLK_ID_TEXAS5:
155 case RGX_CNTBLK_ID_TEXAS6:
156 case RGX_CNTBLK_ID_TEXAS7:
158 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
159 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
160 RGX_CNTBLK_INDIRECT_COUNT(USC, 15) +
161 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
164 case RGX_CNTBLK_ID_RASTER0:
165 case RGX_CNTBLK_ID_RASTER1:
166 case RGX_CNTBLK_ID_RASTER2:
167 case RGX_CNTBLK_ID_RASTER3:
169 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
170 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
171 RGX_CNTBLK_INDIRECT_COUNT(USC, 15) +
172 RGX_CNTBLK_INDIRECT_COUNT(TEXAS, 7) +
173 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
176 case RGX_CNTBLK_ID_BLACKPEARL0:
177 case RGX_CNTBLK_ID_BLACKPEARL1:
178 case RGX_CNTBLK_ID_BLACKPEARL2:
179 case RGX_CNTBLK_ID_BLACKPEARL3:
181 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
182 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
183 RGX_CNTBLK_INDIRECT_COUNT(USC, 15) +
184 RGX_CNTBLK_INDIRECT_COUNT(TEXAS, 7) +
185 RGX_CNTBLK_INDIRECT_COUNT(RASTER, 3) +
186 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
189 case RGX_CNTBLK_ID_PBE0:
190 case RGX_CNTBLK_ID_PBE1:
191 case RGX_CNTBLK_ID_PBE2:
192 case RGX_CNTBLK_ID_PBE3:
193 case RGX_CNTBLK_ID_PBE4:
194 case RGX_CNTBLK_ID_PBE5:
195 case RGX_CNTBLK_ID_PBE6:
196 case RGX_CNTBLK_ID_PBE7:
197 case RGX_CNTBLK_ID_PBE8:
198 case RGX_CNTBLK_ID_PBE9:
199 case RGX_CNTBLK_ID_PBE10:
200 case RGX_CNTBLK_ID_PBE11:
201 case RGX_CNTBLK_ID_PBE12:
202 case RGX_CNTBLK_ID_PBE13:
203 case RGX_CNTBLK_ID_PBE14:
204 case RGX_CNTBLK_ID_PBE15:
206 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
207 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
208 RGX_CNTBLK_INDIRECT_COUNT(USC, 15) +
209 RGX_CNTBLK_INDIRECT_COUNT(TEXAS, 7) +
210 RGX_CNTBLK_INDIRECT_COUNT(RASTER, 3) +
211 RGX_CNTBLK_INDIRECT_COUNT(BLACKPEARL, 3) +
212 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
215 case RGX_CNTBLK_ID_BX_TU0:
216 case RGX_CNTBLK_ID_BX_TU1:
217 case RGX_CNTBLK_ID_BX_TU2:
218 case RGX_CNTBLK_ID_BX_TU3:
220 i32Idx = RGX_CNTBLK_ID_DIRECT_LAST +
221 RGX_CNTBLK_INDIRECT_COUNT(TPU_MCU, 7) +
222 RGX_CNTBLK_INDIRECT_COUNT(USC, 15) +
223 RGX_CNTBLK_INDIRECT_COUNT(TEXAS, 7) +
224 RGX_CNTBLK_INDIRECT_COUNT(RASTER, 3) +
225 RGX_CNTBLK_INDIRECT_COUNT(BLACKPEARL, 3) +
226 RGX_CNTBLK_INDIRECT_COUNT(PBE, 15) +
227 (eBlockID & RGX_CNTBLK_ID_UNIT_MASK);
235 if ((i32Idx < 0) || (i32Idx >= RGX_HWPERF_MAX_DEFINED_BLKS))
239 return &psHWPerfInitData->sBlkCfg[i32Idx];