1 /* 2 * Copyright 2015 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 24 #ifndef _vce_ib_h_ 25 #define _vce_ib_h_ 26 27 static const uint32_t vce_session[] = { 28 0x0000000c, 29 0x00000001, 30 0x400c0001, 31 }; 32 33 static uint32_t vce_taskinfo[8] = { 34 0x00000020, 35 0x00000002, 36 0xffffffff, 37 0x00000000, 38 0x00000000, 39 0x00000000, 40 0x00000000, 41 0x00000000, 42 }; 43 44 static const uint32_t vce_create[] = { 45 0x00000030, 46 0x01000001, 47 0x00000000, 48 0x00000042, 49 0x0000002a, 50 0x00000000, 51 0x000000a0, 52 0x00000080, 53 0x000000a0, 54 0x000000a0, 55 0x00000010, 56 0x00000000, 57 }; 58 59 static const uint32_t vce_rate_ctrl[] = { 60 0x00000070, 61 0x04000005, 62 0x00000000, 63 0x00000000, 64 0x00000000, 65 0x00000000, 66 0x00000000, 67 0x0000001c, 68 0x0000001c, 69 0x00000000, 70 0x00000000, 71 0x00000000, 72 0x00000000, 73 0x00000000, 74 0x00000000, 75 0x00000000, 76 0x00000000, 77 0x00000000, 78 0x00000000, 79 0x00000033, 80 0x00000000, 81 0x00000000, 82 0x00000000, 83 0x00000000, 84 0x00000000, 85 0x00000000, 86 0x00000000, 87 0x00000000, 88 }; 89 90 static const uint32_t vce_config_ext[] = { 91 0x0000000c, 92 0x04000001, 93 0x00000003, 94 }; 95 96 static const uint32_t vce_motion_est[] = { 97 0x00000068, 98 0x04000007, 99 0x00000001, 100 0x00000001, 101 0x00000000, 102 0x00000000, 103 0x00000000, 104 0x00000000, 105 0x00000010, 106 0x00000010, 107 0x00000010, 108 0x00000010, 109 0x00000000, 110 0x00000000, 111 0x00000000, 112 0x000000fe, 113 0x00000000, 114 0x00000000, 115 0x00000000, 116 0x00000000, 117 0x00000001, 118 0x00000001, 119 0x00000000, 120 0x00000000, 121 0x00000000, 122 0x00000000, 123 }; 124 125 static const uint32_t vce_rdo[] = { 126 0x0000004c, 127 0x04000008, 128 0x00000000, 129 0x00000000, 130 0x00000000, 131 0x00000000, 132 0x00000000, 133 0x00000000, 134 0x00000000, 135 0x00000000, 136 0x00000000, 137 0x00000000, 138 0x00000000, 139 0x00000000, 140 0x00000000, 141 0x00000000, 142 0x00000000, 143 0x00000000, 144 0x00000000, 145 }; 146 147 static const uint32_t vce_pic_ctrl[] = { 148 0x00000074, 149 0x04000002, 150 0x00000000, 151 0x00000000, 152 0x00000000, 153 0x00000000, 154 0x00000000, 155 0x00000000, 156 0x00000000, 157 0x00000000, 158 0x00000000, 159 0x00000000, 160 0x00000aa0, 161 0x00000000, 162 0x00000000, 163 0x00000000, 164 0x00000000, 165 0x00000000, 166 0x00000000, 167 0x00000000, 168 0x00000040, 169 0x00000000, 170 0x00000000, 171 0x00000001, 172 0x00000002, 173 0x00000001, 174 0x00000001, 175 0x00000000, 176 0x00000000, 177 }; 178 179 static const uint32_t vce_feedback[] = { 180 0x00000014, 181 0x05000005, 182 0x00000000, 183 0xffffffff, 184 0x00000001, 185 }; 186 187 static const uint32_t vce_context_buffer[] = { 188 0x00000010, 189 0x05000001, 190 0x00000000, 191 0xffffffff, 192 }; 193 194 static const uint32_t vce_bs_buffer[] = { 195 0x00000014, 196 0x05000004, 197 0x00000000, 198 0xffffffff, 199 0x00154000, 200 }; 201 202 static const uint32_t vce_aux_buffer[] = { 203 0x00000048, 204 0x05000002, 205 0x0000f000, 206 0x00016800, 207 0x0001e000, 208 0x00025800, 209 0x0002d000, 210 0x00034800, 211 0x0003c000, 212 0x00043800, 213 0x00007800, 214 0x00007800, 215 0x00007800, 216 0x00007800, 217 0x00007800, 218 0x00007800, 219 0x00007800, 220 0x00007800, 221 }; 222 223 static uint32_t vce_encode[88] = { 224 0x00000160, 225 0x03000001, 226 0x00000011, 227 0x00000000, 228 0x00154000, 229 0x00000000, 230 0x00000000, 231 0x00000000, 232 0x00000000, 233 0x00000000, 234 0xffffffff, 235 0x00000000, 236 0xffffffff, 237 0x00000080, 238 0x000000a0, 239 0x000000a0, 240 0x00010000, 241 0x00000000, 242 0x00000003, 243 0x00000001, 244 0x00000000, 245 0x00000000, 246 0x00000001, 247 0x00000000, 248 0x00000000, 249 0x00000000, 250 0x00000000, 251 0x00000000, 252 0x00000000, 253 0x00000000, 254 0x00000000, 255 0x00000000, 256 0x00000000, 257 0x00000000, 258 0x00000000, 259 0x00000000, 260 0x00000000, 261 0x00000000, 262 0x00000000, 263 0x00000000, 264 0x00000000, 265 0x00000000, 266 0x00000000, 267 0x00000000, 268 0x00000000, 269 0x00000000, 270 0x00000000, 271 0x00000000, 272 0x00000000, 273 0x00000000, 274 0x00000000, 275 0x00000000, 276 0x00000000, 277 0x00000000, 278 0x00000000, 279 0x00000000, 280 0x00000000, 281 0x00000000, 282 0x00000000, 283 0xffffffff, 284 0xffffffff, 285 0x00000000, 286 0x00000000, 287 0x00000000, 288 0x00000000, 289 0xffffffff, 290 0xffffffff, 291 0x00000000, 292 0x00000000, 293 0x00000000, 294 0x00000000, 295 0xffffffff, 296 0xffffffff, 297 0xffffffff, 298 0xffffffff, 299 0x00000000, 300 0x00000000, 301 0x00000000, 302 0x00000000, 303 0x00000000, 304 0x00000000, 305 0x00000000, 306 0x00000000, 307 0x00000000, 308 0x00000000, 309 0x00000000, 310 0x00000000, 311 0x00000000, 312 }; 313 314 static const uint32_t vce_destroy[] = { 315 0x00000008, 316 0x02000001, 317 }; 318 #endif /*_vce_ib_h*/ 319