summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXiang, Haihao <haihao.xiang@intel.com>2017-09-19 14:18:04 +0800
committerXiang, Haihao <haihao.xiang@intel.com>2018-01-29 12:40:02 +0800
commit1f76e441244fb4bd64919f8e484c62b9e66a8032 (patch)
treee8f72f7cd5b10aad7df38d4686e08d7de9d796b4
parent3746832e454ac1616e89eda2f0bca532946c0d9a (diff)
downloadlibva-intel-driver-1f76e441244fb4bd64919f8e484c62b9e66a8032.tar.gz
Add HuC common commands for CNL
It provides helper functions for low power encoding on CNL Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com> Signed-off-by: peng.chen <peng.c.chen@intel.com>
-rw-r--r--src/Makefile.sources2
-rw-r--r--src/gen10_huc_common.c206
-rw-r--r--src/gen10_huc_common.h114
3 files changed, 322 insertions, 0 deletions
diff --git a/src/Makefile.sources b/src/Makefile.sources
index 2b53381b..2f9e3049 100644
--- a/src/Makefile.sources
+++ b/src/Makefile.sources
@@ -70,6 +70,7 @@ source_c = \
gen10_hevc_enc_kernels_binary.c \
gen10_hevc_enc_common.c \
gen10_hevc_encoder.c \
+ gen10_huc_common.c \
$(NULL)
source_h = \
@@ -142,4 +143,5 @@ source_h = \
gen10_hevc_enc_common.h \
gen10_hevc_encoder.h \
gen10_hevc_enc_const_def.h \
+ gen10_huc_common.h \
$(NULL)
diff --git a/src/gen10_huc_common.c b/src/gen10_huc_common.c
new file mode 100644
index 00000000..ff935417
--- /dev/null
+++ b/src/gen10_huc_common.c
@@ -0,0 +1,206 @@
+/*
+ * Copyright © 2018 Intel Corporation
+ *
+ * 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, sub license, 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 (including the
+ * next paragraph) 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 NON-INFRINGEMENT.
+ * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS 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.
+ *
+ * Authors:
+ * Xiang Haihao <haihao.xiang@intel.com>
+ *
+ */
+
+#include <assert.h>
+
+#include "intel_batchbuffer.h"
+#include "i965_defines.h"
+#include "i965_drv_video.h"
+#include "gen10_huc_common.h"
+
+#define OUT_BUFFER_2DW(batch, bo, is_target, delta) do { \
+ if (bo) { \
+ OUT_BCS_RELOC64(batch, \
+ bo, \
+ I915_GEM_DOMAIN_RENDER, \
+ is_target ? I915_GEM_DOMAIN_RENDER : 0, \
+ delta); \
+ } else { \
+ OUT_BCS_BATCH(batch, 0); \
+ OUT_BCS_BATCH(batch, 0); \
+ } \
+ } while (0)
+
+#define OUT_BUFFER_3DW(batch, bo, is_target, delta) do { \
+ OUT_BUFFER_2DW(batch, bo, is_target, delta); \
+ if (bo) \
+ OUT_BCS_BATCH(batch, i965->intel.mocs_state); \
+ else \
+ OUT_BCS_BATCH(batch, 0); \
+ } while (0)
+
+void
+gen10_huc_pipe_mode_select(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_pipe_mode_select_parameter *params)
+{
+ BEGIN_BCS_BATCH(batch, 3);
+
+ OUT_BCS_BATCH(batch, HUC_PIPE_MODE_SELECT | (3 - 2));
+ OUT_BCS_BATCH(batch,
+ (!!params->huc_stream_object_enabled << 10) |
+ (!!params->indirect_stream_out_enabled << 4));
+ OUT_BCS_BATCH(batch,
+ params->media_soft_reset_counter);
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_imem_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_imem_state_parameter *params)
+{
+ assert(params->huc_firmware_descriptor >= 1 &&
+ params->huc_firmware_descriptor <= 255);
+
+ BEGIN_BCS_BATCH(batch, 5);
+
+ OUT_BCS_BATCH(batch, HUC_IMEM_STATE | (5 - 2));
+ OUT_BCS_BATCH(batch, 0);
+ OUT_BCS_BATCH(batch, 0);
+ OUT_BCS_BATCH(batch, 0);
+ OUT_BCS_BATCH(batch, params->huc_firmware_descriptor);
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_dmem_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_dmem_state_parameter *params)
+{
+ struct i965_driver_data *i965 = i965_driver_data(ctx);
+
+ BEGIN_BCS_BATCH(batch, 6);
+
+ OUT_BCS_BATCH(batch, HUC_DMEM_STATE | (6 - 2));
+ OUT_BUFFER_3DW(batch, params->huc_data_source_res->bo, 0, 0);
+ OUT_BCS_BATCH(batch, params->huc_data_destination_base_address);
+ OUT_BCS_BATCH(batch, params->huc_data_length);
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_virtual_addr_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_virtual_addr_parameter *params)
+{
+ struct i965_driver_data *i965 = i965_driver_data(ctx);
+ int i;
+
+ BEGIN_BCS_BATCH(batch, 49);
+
+ OUT_BCS_BATCH(batch, HUC_VIRTUAL_ADDR_STATE | (49 - 2));
+
+ for (i = 0; i < 16; i++) {
+ if (params->regions[i].huc_surface_res && params->regions[i].huc_surface_res->bo)
+ OUT_BUFFER_3DW(batch,
+ params->regions[i].huc_surface_res->bo,
+ !!params->regions[i].is_target,
+ params->regions[i].offset);
+ else
+ OUT_BUFFER_3DW(batch, NULL, 0, 0);
+ }
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_ind_obj_base_addr_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_ind_obj_base_addr_parameter *params)
+{
+ struct i965_driver_data *i965 = i965_driver_data(ctx);
+
+ BEGIN_BCS_BATCH(batch, 11);
+
+ OUT_BCS_BATCH(batch, HUC_IND_OBJ_BASE_ADDR_STATE | (11 - 2));
+
+ if (params->huc_indirect_stream_in_object_res)
+ OUT_BUFFER_3DW(batch,
+ params->huc_indirect_stream_in_object_res->bo,
+ 0,
+ 0);
+ else
+ OUT_BUFFER_3DW(batch, NULL, 0, 0);
+
+ OUT_BUFFER_2DW(batch, NULL, 0, 0); /* ignore access upper bound */
+
+ if (params->huc_indirect_stream_out_object_res)
+ OUT_BUFFER_3DW(batch,
+ params->huc_indirect_stream_out_object_res->bo,
+ 1,
+ 0);
+ else
+ OUT_BUFFER_3DW(batch, NULL, 0, 0);
+
+ OUT_BUFFER_2DW(batch, NULL, 0, 0); /* ignore access upper bound */
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_stream_object(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_stream_object_parameter *params)
+{
+ BEGIN_BCS_BATCH(batch, 5);
+
+ OUT_BCS_BATCH(batch, HUC_STREAM_OBJECT | (5 - 2));
+ OUT_BCS_BATCH(batch, params->indirect_stream_in_data_length);
+ OUT_BCS_BATCH(batch,
+ (1 << 31) | /* Must be 1 */
+ params->indirect_stream_in_start_address);
+ OUT_BCS_BATCH(batch, params->indirect_stream_out_start_address);
+ OUT_BCS_BATCH(batch,
+ (!!params->huc_bitstream_enabled << 29) |
+ (params->length_mode << 27) |
+ (!!params->stream_out << 26) |
+ (!!params->emulation_prevention_byte_removal << 25) |
+ (!!params->start_code_search_engine << 24) |
+ (params->start_code_byte2 << 16) |
+ (params->start_code_byte1 << 8) |
+ params->start_code_byte0);
+
+ ADVANCE_BCS_BATCH(batch);
+}
+
+void
+gen10_huc_start(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_start_parameter *params)
+{
+ BEGIN_BCS_BATCH(batch, 2);
+
+ OUT_BCS_BATCH(batch, HUC_START | (2 - 2));
+ OUT_BCS_BATCH(batch, !!params->last_stream_object);
+
+ ADVANCE_BCS_BATCH(batch);
+}
diff --git a/src/gen10_huc_common.h b/src/gen10_huc_common.h
new file mode 100644
index 00000000..103899a6
--- /dev/null
+++ b/src/gen10_huc_common.h
@@ -0,0 +1,114 @@
+/*
+ * Copyright © 2018 Intel Corporation
+ *
+ * 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, sub license, 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 (including the
+ * next paragraph) 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 NON-INFRINGEMENT.
+ * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS 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.
+ *
+ * Authors:
+ * Xiang Haihao <haihao.xiang@intel.com>
+ *
+ */
+
+#ifndef GEN10_HUC_COMMON_H
+#define GEN10_HUC_COMMON_H
+
+struct gen10_huc_pipe_mode_select_parameter {
+ uint32_t huc_stream_object_enabled;
+ uint32_t indirect_stream_out_enabled;
+ uint32_t media_soft_reset_counter;
+};
+
+struct gen10_huc_imem_state_parameter {
+ uint32_t huc_firmware_descriptor;
+};
+
+struct gen10_huc_dmem_state_parameter {
+ struct i965_gpe_resource *huc_data_source_res;
+ uint32_t huc_data_destination_base_address;
+ uint32_t huc_data_length;
+};
+
+struct gen10_huc_virtual_addr_parameter {
+ struct {
+ struct i965_gpe_resource *huc_surface_res;
+ uint32_t offset;
+ uint32_t is_target;
+ } regions[16];
+};
+
+struct gen10_huc_ind_obj_base_addr_parameter {
+ struct i965_gpe_resource *huc_indirect_stream_in_object_res;
+ struct i965_gpe_resource *huc_indirect_stream_out_object_res;
+};
+
+struct gen10_huc_stream_object_parameter {
+ uint32_t indirect_stream_in_data_length;
+ uint32_t indirect_stream_in_start_address;
+ uint32_t indirect_stream_out_start_address;
+ uint32_t huc_bitstream_enabled;
+ uint32_t length_mode;
+ uint32_t stream_out;
+ uint32_t emulation_prevention_byte_removal;
+ uint32_t start_code_search_engine;
+ uint8_t start_code_byte2;
+ uint8_t start_code_byte1;
+ uint8_t start_code_byte0;
+};
+
+struct gen10_huc_start_parameter {
+ uint32_t last_stream_object;
+};
+
+void
+gen10_huc_pipe_mode_select(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_pipe_mode_select_parameter *params);
+
+void
+gen10_huc_imem_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_imem_state_parameter *params);
+
+void
+gen10_huc_dmem_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_dmem_state_parameter *params);
+
+void
+gen10_huc_virtual_addr_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_virtual_addr_parameter *params);
+
+void
+gen10_huc_ind_obj_base_addr_state(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_ind_obj_base_addr_parameter *params);
+
+void
+gen10_huc_stream_object(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_stream_object_parameter *params);
+
+void
+gen10_huc_start(VADriverContextP ctx,
+ struct intel_batchbuffer *batch,
+ struct gen10_huc_start_parameter *params);
+
+#endif /* GEN10_HUC_COMMON_H */