528 lines
7.9 KiB
C
528 lines
7.9 KiB
C
|
/*
|
||
|
* Copyright 2017 Advanced Micro Devices, Inc.
|
||
|
*
|
||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||
|
* copy of this software and associated documentation files (the "Software"),
|
||
|
* to deal in the Software without restriction, including without limitation
|
||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||
|
* Software is furnished to do so, subject to the following conditions:
|
||
|
*
|
||
|
* The above copyright notice and this permission notice shall be included in
|
||
|
* all copies or substantial portions of the Software.
|
||
|
*
|
||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||
|
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||
|
* OTHER DEALINGS IN THE SOFTWARE.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef _uve_ib_h_
|
||
|
#define _uve_ib_h_
|
||
|
|
||
|
static const uint32_t uve_session_info[] = {
|
||
|
0x00000018,
|
||
|
0x00000001,
|
||
|
0x00000000,
|
||
|
0x00010000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_task_info[] = {
|
||
|
0x00000014,
|
||
|
0x00000002,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_session_init[] = {
|
||
|
0x00000020,
|
||
|
0x00000003,
|
||
|
0x000000c0,
|
||
|
0x00000080,
|
||
|
0x00000020,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_layer_ctrl[] = {
|
||
|
0x00000010,
|
||
|
0x00000004,
|
||
|
0x00000001,
|
||
|
0x00000001,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_layer_select[] = {
|
||
|
0x0000000c,
|
||
|
0x00000005,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_slice_ctrl[] = {
|
||
|
0x00000014,
|
||
|
0x00000006,
|
||
|
0x00000000,
|
||
|
0x00000006,
|
||
|
0x00000006,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_spec_misc[] = {
|
||
|
0x00000024,
|
||
|
0x00000007,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000001,
|
||
|
0x00000001,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_rc_session_init[] = {
|
||
|
0x00000010,
|
||
|
0x00000008,
|
||
|
0x00000000,
|
||
|
0x00000040,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_rc_layer_init[] = {
|
||
|
0x00000028,
|
||
|
0x00000009,
|
||
|
0x001e8480,
|
||
|
0x001e8480,
|
||
|
0x0000001e,
|
||
|
0x00000001,
|
||
|
0x0001046a,
|
||
|
0x0001046a,
|
||
|
0x0001046a,
|
||
|
0xaaaaaaaa,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_deblocking_filter[] = {
|
||
|
0x00000020,
|
||
|
0x0000000e,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_quality_params[] = {
|
||
|
0x00000014,
|
||
|
0x0000000d,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_feedback_buffer[] = {
|
||
|
0x0000001c,
|
||
|
0x00000012,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_feedback_buffer_additional[] = {
|
||
|
0x00000108,
|
||
|
0x00000014,
|
||
|
0x00000001,
|
||
|
0x00000010,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_nalu_buffer_1[] = {
|
||
|
0x00000018,
|
||
|
0x00000013,
|
||
|
0x00000001,
|
||
|
0x00000007,
|
||
|
0x00000001,
|
||
|
0x46011000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_nalu_buffer_2[] = {
|
||
|
0x0000002c,
|
||
|
0x00000013,
|
||
|
0x00000002,
|
||
|
0x0000001b,
|
||
|
0x00000001,
|
||
|
0x40010c01,
|
||
|
0xffff0160,
|
||
|
0x00000300,
|
||
|
0xb0000003,
|
||
|
0x00000300,
|
||
|
0x962c0900,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_nalu_buffer_3[] = {
|
||
|
0x00000034,
|
||
|
0x00000013,
|
||
|
0x00000003,
|
||
|
0x00000023,
|
||
|
0x00000001,
|
||
|
0x42010101,
|
||
|
0x60000003,
|
||
|
0x00b00000,
|
||
|
0x03000003,
|
||
|
0x0096a018,
|
||
|
0x2020708f,
|
||
|
0xcb924295,
|
||
|
0x12e08000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_nalu_buffer_4[] = {
|
||
|
0x0000001c,
|
||
|
0x00000013,
|
||
|
0x00000004,
|
||
|
0x0000000b,
|
||
|
0x00000001,
|
||
|
0x4401e0f1,
|
||
|
0x80992000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_slice_header[] = {
|
||
|
0x000000c8,
|
||
|
0x0000000b,
|
||
|
0x28010000,
|
||
|
0x40000000,
|
||
|
0x60000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000002,
|
||
|
0x00000010,
|
||
|
0x00000003,
|
||
|
0x00000000,
|
||
|
0x00000002,
|
||
|
0x00000002,
|
||
|
0x00000004,
|
||
|
0x00000000,
|
||
|
0x00000001,
|
||
|
0x00000000,
|
||
|
0x00000002,
|
||
|
0x00000003,
|
||
|
0x00000005,
|
||
|
0x00000000,
|
||
|
0x00000002,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_encode_param[] = {
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0xffffffff,
|
||
|
0x00000001,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_intra_refresh[] = {
|
||
|
0x00000014,
|
||
|
0x0000000f,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000001,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_ctx_buffer[] = {
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x000000a0,
|
||
|
0x000000a0,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_bitstream_buffer[] = {
|
||
|
0x0000001c,
|
||
|
0x00000011,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_rc_per_pic[] = {
|
||
|
0x00000024,
|
||
|
0x0000000a,
|
||
|
0x0000001a,
|
||
|
0x00000000,
|
||
|
0x00000033,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000000,
|
||
|
0x00000001,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_init[] = {
|
||
|
0x00000008,
|
||
|
0x08000001,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_close[] = {
|
||
|
0x00000008,
|
||
|
0x08000002,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_encode[] = {
|
||
|
0x00000008,
|
||
|
0x08000003,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_init_rc[] = {
|
||
|
0x00000008,
|
||
|
0x08000004,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_init_rc_vbv_level[] = {
|
||
|
0x00000008,
|
||
|
0x08000005,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_speed_enc_mode[] = {
|
||
|
0x00000008,
|
||
|
0x08000006,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_balance_enc_mode[] = {
|
||
|
0x00000008,
|
||
|
0x08000007,
|
||
|
};
|
||
|
|
||
|
static const uint32_t uve_op_quality_enc_mode[] = {
|
||
|
0x00000008,
|
||
|
0x08000008,
|
||
|
};
|
||
|
#endif /*_uve_ib_h*/
|