557 lines
23 KiB
Diff
557 lines
23 KiB
Diff
|
From 4d14df762e37f33615f7c83ed94dba9c7dc20c6f Mon Sep 17 00:00:00 2001
|
|||
|
From: denglei <denglei@eswincomputing.com>
|
|||
|
Date: Tue, 8 Oct 2024 16:36:27 +0800
|
|||
|
Subject: [PATCH 186/219] feat:NPU & DSP driver port.
|
|||
|
|
|||
|
Changelogs:
|
|||
|
1.delete NPU & DSP SDK drivers.
|
|||
|
2.port NPU & DSP SDK drivers to linux kernel.
|
|||
|
|
|||
|
Signed-off-by: denglei <denglei@eswincomputing.com>
|
|||
|
---
|
|||
|
.../{include => common/devices}/cdma_regs.h | 0
|
|||
|
.../{include => common/devices}/conv_regs.h | 0
|
|||
|
.../eswin/ai_driver/common/devices/drp_regs.h | 173 ++++++++++++++++++
|
|||
|
.../{include => common/devices}/edma_regs.h | 0
|
|||
|
.../devices}/mailbox_regs.h | 0
|
|||
|
.../devices}/npu_base_regs.h | 0
|
|||
|
.../{include => common/devices}/pdp_regs.h | 0
|
|||
|
.../eswin/ai_driver/common/devices/pec_reg.h | 139 ++++++++++++++
|
|||
|
.../{include => common/devices}/rubik_regs.h | 0
|
|||
|
.../{include => common/devices}/sdp_regs.h | 0
|
|||
|
.../{include => common/devices}/sys_regs.h | 0
|
|||
|
.../{include => common}/dla_interface.h | 0
|
|||
|
.../{include => common}/es_dsp_internal.h | 0
|
|||
|
.../{include => common}/es_dsp_op_types.h | 0
|
|||
|
.../{include => common}/es_dsp_types.h | 4 +
|
|||
|
.../{include => common}/es_nn_common.h | 0
|
|||
|
.../ai_driver/{include => common}/es_type.h | 0
|
|||
|
.../{include => common}/hetero_arch.h | 0
|
|||
|
.../{include => common}/hetero_common.h | 0
|
|||
|
.../{include => common}/hetero_env.h | 0
|
|||
|
.../{include => common}/hetero_host.h | 0
|
|||
|
.../{include => common}/hetero_ioctl.h | 6 +
|
|||
|
.../{include => common}/hetero_ipc.h | 0
|
|||
|
.../{include => common}/hetero_perf.h | 0
|
|||
|
.../{include => common}/hetero_processor.h | 0
|
|||
|
.../{include => common}/hetero_types.h | 0
|
|||
|
.../eswin/ai_driver/{include => common}/md5.h | 0
|
|||
|
drivers/soc/eswin/ai_driver/dsp/Makefile | 3 +-
|
|||
|
drivers/soc/eswin/ai_driver/npu/Makefile | 3 +-
|
|||
|
29 files changed, 326 insertions(+), 2 deletions(-)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/cdma_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/conv_regs.h (100%)
|
|||
|
create mode 100644 drivers/soc/eswin/ai_driver/common/devices/drp_regs.h
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/edma_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/mailbox_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/npu_base_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/pdp_regs.h (100%)
|
|||
|
create mode 100644 drivers/soc/eswin/ai_driver/common/devices/pec_reg.h
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/rubik_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/sdp_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common/devices}/sys_regs.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/dla_interface.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/es_dsp_internal.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/es_dsp_op_types.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/es_dsp_types.h (98%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/es_nn_common.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/es_type.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_arch.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_common.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_env.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_host.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_ioctl.h (99%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_ipc.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_perf.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_processor.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/hetero_types.h (100%)
|
|||
|
rename drivers/soc/eswin/ai_driver/{include => common}/md5.h (100%)
|
|||
|
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/cdma_regs.h b/drivers/soc/eswin/ai_driver/common/devices/cdma_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/cdma_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/cdma_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/conv_regs.h b/drivers/soc/eswin/ai_driver/common/devices/conv_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/conv_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/conv_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/common/devices/drp_regs.h b/drivers/soc/eswin/ai_driver/common/devices/drp_regs.h
|
|||
|
new file mode 100644
|
|||
|
index 000000000000..53fa23982c19
|
|||
|
--- /dev/null
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/common/devices/drp_regs.h
|
|||
|
@@ -0,0 +1,173 @@
|
|||
|
+// Copyright © 2023 ESWIN. All rights reserved.
|
|||
|
+//
|
|||
|
+// Beijing ESWIN Computing Technology Co., Ltd and its affiliated companies ("ESWIN") retain
|
|||
|
+// all intellectual property and proprietary rights in and to this software. Except as expressly
|
|||
|
+// authorized by ESWIN, no part of the software may be released, copied, distributed, reproduced,
|
|||
|
+// modified, adapted, translated, or created derivative work of, in whole or in part.
|
|||
|
+
|
|||
|
+#ifndef __DRP_REGS_H__
|
|||
|
+#define __DRP_REGS_H__
|
|||
|
+
|
|||
|
+#define SDP_POST_DRP_S_BASE_ADDR 0x13a000
|
|||
|
+#define SDP_POST_DRP_D_BASE_ADDR 0x13b000
|
|||
|
+
|
|||
|
+#define PDP_POST_DRP_S_BASE_ADDR 0x13c000
|
|||
|
+#define PDP_POST_DRP_D_BASE_ADDR 0x13d000
|
|||
|
+
|
|||
|
+#define POST_DRP_CLK_GATING_BIT_OFFSET 24
|
|||
|
+
|
|||
|
+typedef enum {
|
|||
|
+ POST_DRP_TYPE_PDP = 0,
|
|||
|
+ POST_DRP_TYPE_SDP,
|
|||
|
+} POST_DRP_TYPE;
|
|||
|
+
|
|||
|
+typedef enum {
|
|||
|
+ POST_DRP_S_REG_SOFT_RESET = 0x0,
|
|||
|
+ POST_DRP_S_REG_POINTER_FLAG = 0x4,
|
|||
|
+ POST_DRP_S_REG_PP_STATUS = 0x8,
|
|||
|
+ POST_DRP_S_REG_POST_NOC_AW_CNT = 0x100,
|
|||
|
+ POST_DRP_S_REG_POST_NOC_AW_BLOCK_CNT = 0x104,
|
|||
|
+ POST_DRP_S_REG_POST_NOC_W_CNT = 0x108,
|
|||
|
+ POST_DRP_S_REG_POST_NOC_W_BLOCK_CNT = 0x10c,
|
|||
|
+ POST_DRP_S_REG_POST_NOC_W_BUBBE_CNT = 0x110,
|
|||
|
+} POST_DRP_S_REG_E;
|
|||
|
+
|
|||
|
+typedef enum {
|
|||
|
+ POST_DRP_D_REG_OP_EN_TRIG = 0x00,
|
|||
|
+ POST_DRP_D_REG_OP_STATUS = 0x04,
|
|||
|
+ POST_DRP_D_REG_G_STRIDE_SRAM = 0x08,
|
|||
|
+ POST_DRP_D_REG_N_STRIDE_SRAM = 0x0c,
|
|||
|
+ POST_DRP_D_REG_H_STRIDE_SRAM = 0x10,
|
|||
|
+ POST_DRP_D_REG_C_STRIDE_SRAM = 0x14,
|
|||
|
+ POST_DRP_D_REG_H_EXT_STRIDE = 0x18,
|
|||
|
+ POST_DRP_D_REG_W_EXT_STRIDE = 0x1c,
|
|||
|
+ POST_DRP_D_REG_OMAP_PARA_RSP_H = 0x20,
|
|||
|
+ POST_DRP_D_REG_OMAP_PARA_RSP_L = 0x24,
|
|||
|
+ POST_DRP_D_REG_LAYER_PARA_L = 0x28,
|
|||
|
+ POST_DRP_D_REG_LAYER_PARA_M = 0x2c,
|
|||
|
+ POST_DRP_D_REG_LAYER_PARA_H = 0x30,
|
|||
|
+ POST_DRP_D_REG_OMAP_PARA_L = 0x34,
|
|||
|
+ POST_DRP_D_REG_BASE_ADDR_H = 0x38,
|
|||
|
+ POST_DRP_D_REG_BASE_ADDR_L = 0x3c,
|
|||
|
+ POST_DRP_D_REG_CTRL = 0x40,
|
|||
|
+ POST_DRP_D_REG_SPLIT = 0x44,
|
|||
|
+ POST_DRP_D_REG_PARTIAL_WIDTH = 0x48,
|
|||
|
+ POST_DRP_D_REG_SRAM_LOOP_PARA_H = 0x4c,
|
|||
|
+ POST_DRP_D_REG_SRAM_LOOP_PARA_L = 0x50,
|
|||
|
+} POST_DRP_D_REG_E;
|
|||
|
+
|
|||
|
+#define DRP_WR_D_OP_EN_TRIG 0x0
|
|||
|
+#define DRP_WR_D_OP_STATUS 0x4
|
|||
|
+
|
|||
|
+#define DRP_WR_D_CTRL 0x8
|
|||
|
+/**
|
|||
|
+ * @brief N2方向的步进值,n2_stride=N1*N0*E3*E2*E1*M2*M1*F0*M0,用于PE写DRP地址计算.
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_N2_STRIDE 0x10
|
|||
|
+/**
|
|||
|
+ * @brief 任务0,G2方向的步进值,g2_stride=N2*N1*E3*E2*E1*M2*M1*F0*M0*GF*GMF,用于PE写DRP地址计算。配置减1
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_G2_STRIDE 0x14
|
|||
|
+/**
|
|||
|
+ * @brief E3方向的步进值,e3_stride=E2*E1*M2*M1*F0*M0,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_E3_STRIDE 0x18
|
|||
|
+/**
|
|||
|
+ * @brief M2方向的步进值,m2_stride=M1*F0*M0,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_M2_STRIDE 0x1C
|
|||
|
+/**
|
|||
|
+ * @brief M方向的步进值,m_stride=F0*M0,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_M_STRIDE 0x20
|
|||
|
+/**
|
|||
|
+ * @brief G3阈值,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_G3_THRESHOLD 0x24
|
|||
|
+/**
|
|||
|
+ * @brief N3阈值,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_N3_THRESHOLD 0x28
|
|||
|
+/**
|
|||
|
+ * @brief M3阈值,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_M3_THRESHOLD 0x2C
|
|||
|
+/**
|
|||
|
+ * @brief E4阈值,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_E4_THRESHOLD 0x30
|
|||
|
+/**
|
|||
|
+ * @brief F3阈值,用于PE写DRP地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_F3_THRESHOLD 0x34
|
|||
|
+/**
|
|||
|
+ * @brief 写入lsram/ddr的基地址低32bit
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_BA_L 0x38
|
|||
|
+/**
|
|||
|
+ * @brief 写入lsram/ddr的基地址高32bit
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_BA_H 0x3C
|
|||
|
+/**
|
|||
|
+ * @brief 参与task计算的PE数量,用于last_pkt统计,当收到的last_pkt脉冲数等于pe_num则认为所有PE均完成当前ofmap cube的计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_PE_NUM 0x80
|
|||
|
+/**
|
|||
|
+ * @brief task一个glb level loop输出的ofmap的大小,用与glb level loop的基地址计算
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+#define DRP_WR_D_SIZE_GLB 0x94
|
|||
|
+
|
|||
|
+#define DRP_WR_S_SOFT_RESET 0x0
|
|||
|
+#define DRP_WR_S_POINTER_FLAG 0x4
|
|||
|
+#define DRP_WR_S_PP_STATUS 0x8
|
|||
|
+
|
|||
|
+#define DRP_RESHAPE_D_OP_EN_TRIG 0x0
|
|||
|
+#define DRP_RESHAPE_D_OP_STATUS 0x4
|
|||
|
+#define DRP_RESHAPE_D_CTRL 0x8
|
|||
|
+#define DRP_RESHAPE_D_GLB_G_STRIDE 0xC
|
|||
|
+#define DRP_RESHAPE_D_GLB_N_STRIDE 0x10
|
|||
|
+#define DRP_RESHAPE_D_GLB_E_STRIDE 0x14
|
|||
|
+#define DRP_RESHAPE_D_GLB_M_STRIDE 0x18
|
|||
|
+// #define DRP_RESHAPE_D_SRAM_G_STRIDE 0x1C
|
|||
|
+#define DRP_RESHAPE_D_SRAM_N_STRIDE 0x20
|
|||
|
+#define DRP_RESHAPE_D_SRAM_H_STRIDE 0x24
|
|||
|
+#define DRP_RESHAPE_D_SRAM_C_STRIDE 0x28
|
|||
|
+#define DRP_RESHAPE_D_IMPA_PARA_L 0x2C
|
|||
|
+// #define DRP_RESHAPE_D_IMPA_PAR_H 0x30
|
|||
|
+// #define DRP_RESHAPE_D_OMAP_RSP_H 0x34
|
|||
|
+#define DRP_RESHAPE_D_OMAP_PARA_RSP_W 0x38
|
|||
|
+#define DRP_RESHAPE_D_LAYER_PARA_L 0x3C
|
|||
|
+#define DRP_RESHAPE_D_LAYER_PARA_M 0x40
|
|||
|
+#define DRP_RESHAPE_D_LAYER_PARA_H 0x44
|
|||
|
+#define DRP_RESHAPE_D_GLB_PARA_L 0x48
|
|||
|
+#define DRP_RESHAPE_D_GLB_PARA_H 0x4C
|
|||
|
+#define DRP_RESHAPE_D_GLB_LAST_PARA_L 0x50
|
|||
|
+#define DRP_RESHAPE_D_GLB_LAST_PARA_H 0x54
|
|||
|
+#define DRP_RESHAPE_D_OMAP_L 0x58
|
|||
|
+#define DRP_RESHAPE_D_BASE_ADDR_IN_L 0x5C
|
|||
|
+#define DRP_RESHAPE_D_BASE_ADDR_IN_H 0x60
|
|||
|
+#define DRP_RESHAPE_D_BASE_ADDR_OUT_L 0x64
|
|||
|
+#define DRP_RESHAPE_D_BASE_ADDR_OUT_H 0x68
|
|||
|
+#define DRP_RESHAPE_D_SIZE_GLB 0x6C
|
|||
|
+#define DRP_RESHAPE_D_PRECISON_CTRL_L 0x80
|
|||
|
+#define DRP_RESHAPE_D_PRECISON_CTRL_H 0x84
|
|||
|
+
|
|||
|
+#define DRP_RESHAPE_S_SOFT_RESET 0x0
|
|||
|
+#define DRP_RESHAPE_S_POINTER_FLAG 0x4
|
|||
|
+#define DRP_RESHAPE_S_PP_STATUS 0x8
|
|||
|
+
|
|||
|
+#endif
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/edma_regs.h b/drivers/soc/eswin/ai_driver/common/devices/edma_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/edma_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/edma_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/mailbox_regs.h b/drivers/soc/eswin/ai_driver/common/devices/mailbox_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/mailbox_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/mailbox_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/npu_base_regs.h b/drivers/soc/eswin/ai_driver/common/devices/npu_base_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/npu_base_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/npu_base_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/pdp_regs.h b/drivers/soc/eswin/ai_driver/common/devices/pdp_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/pdp_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/pdp_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/common/devices/pec_reg.h b/drivers/soc/eswin/ai_driver/common/devices/pec_reg.h
|
|||
|
new file mode 100644
|
|||
|
index 000000000000..9fa0052b6aaa
|
|||
|
--- /dev/null
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/common/devices/pec_reg.h
|
|||
|
@@ -0,0 +1,139 @@
|
|||
|
+// Copyright © 2023 ESWIN. All rights reserved.
|
|||
|
+//
|
|||
|
+// Beijing ESWIN Computing Technology Co., Ltd and its affiliated companies ("ESWIN") retain
|
|||
|
+// all intellectual property and proprietary rights in and to this software. Except as expressly
|
|||
|
+// authorized by ESWIN, no part of the software may be released, copied, distributed, reproduced,
|
|||
|
+// modified, adapted, translated, or created derivative work of, in whole or in part.
|
|||
|
+
|
|||
|
+/*generated by gen_register_table.py author wubo */
|
|||
|
+#ifndef __PEC_REG_S__
|
|||
|
+#define __PEC_REG_S__
|
|||
|
+// #include <inttypes.h>
|
|||
|
+typedef struct PEC_REG_S {
|
|||
|
+ struct reg_op_en_trig {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union op_en_trig_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t op_en_trig : 1;
|
|||
|
+ uint32_t Reserved : 31;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } op_en_trig;
|
|||
|
+ } reg_op_en_trig;
|
|||
|
+
|
|||
|
+ struct reg_op_status {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union op_status_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t op_en_status : 1;
|
|||
|
+ uint32_t Reserved : 31;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } op_status;
|
|||
|
+ } reg_op_status;
|
|||
|
+
|
|||
|
+ struct reg_pec_spad_param0 {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_spad_param0_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t pe_c0 : 4;
|
|||
|
+ uint32_t pe_u : 4;
|
|||
|
+ uint32_t pe_s : 4;
|
|||
|
+ uint32_t pe_w0 : 10;
|
|||
|
+ uint32_t stride_v : 4;
|
|||
|
+ uint32_t Reserved : 6;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_spad_param0;
|
|||
|
+ } reg_pec_spad_param0;
|
|||
|
+
|
|||
|
+ struct reg_pec_spad_param1 {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_spad_param1_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t f0_m0 : 10;
|
|||
|
+ uint32_t pe_m0 : 5;
|
|||
|
+ uint32_t padding_pending : 1;
|
|||
|
+ uint32_t first_unit : 5;
|
|||
|
+ uint32_t Reserved : 11;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_spad_param1;
|
|||
|
+ } reg_pec_spad_param1;
|
|||
|
+
|
|||
|
+ struct reg_pec_glb_param0 {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_glb_param0_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t pec_m2 : 6;
|
|||
|
+ uint32_t pec_r3 : 6;
|
|||
|
+ uint32_t pec_e3 : 6;
|
|||
|
+ uint32_t pec_c2 : 6;
|
|||
|
+ uint32_t pec_n2 : 6;
|
|||
|
+ uint32_t Reserved : 2;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_glb_param0;
|
|||
|
+ } reg_pec_glb_param0;
|
|||
|
+
|
|||
|
+ struct reg_pec_calc_mode {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_calc_mode_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t nan_to_zero_en : 1;
|
|||
|
+ uint32_t w_csc_en : 1;
|
|||
|
+ uint32_t iact_csc_en : 1;
|
|||
|
+ uint32_t pe_dat_type : 2;
|
|||
|
+ uint32_t psum_use_last : 1;
|
|||
|
+ uint32_t pe_simd_mode : 4;
|
|||
|
+ uint32_t e3_c2_stride : 4;
|
|||
|
+ uint32_t r3_e3_stride : 10;
|
|||
|
+ uint32_t Reserved : 8;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_calc_mode;
|
|||
|
+ } reg_pec_calc_mode;
|
|||
|
+
|
|||
|
+ struct reg_router_cast_mode_padding {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union router_cast_mode_padding_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t iact_src_en : 5;
|
|||
|
+ uint32_t weight_src_en : 3;
|
|||
|
+ uint32_t iact_mode : 4;
|
|||
|
+ uint32_t weight_mode : 2;
|
|||
|
+ uint32_t psum_glbc_enable : 1;
|
|||
|
+ uint32_t pec_psum_in_sel : 1;
|
|||
|
+ uint32_t e1_last_cnt : 2;
|
|||
|
+ uint32_t r1_last_cnt : 2;
|
|||
|
+ uint32_t r2_last_en : 1;
|
|||
|
+ uint32_t r_all : 8;
|
|||
|
+ uint32_t Reserved : 3;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } router_cast_mode_padding;
|
|||
|
+ } reg_router_cast_mode_padding;
|
|||
|
+
|
|||
|
+ struct reg_pec_space_offset0 {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_space_offset0_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t pe0_base_addr : 18;
|
|||
|
+ uint32_t Reserved : 14;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_space_offset0;
|
|||
|
+ } reg_pec_space_offset0;
|
|||
|
+
|
|||
|
+ struct reg_pec_space_offset1 {
|
|||
|
+ uint32_t address_offset;
|
|||
|
+ union pec_space_offset1_ {
|
|||
|
+ struct {
|
|||
|
+ uint32_t m2_m1_f0_m0 : 18;
|
|||
|
+ uint32_t Reserved : 14;
|
|||
|
+ };
|
|||
|
+ uint32_t value;
|
|||
|
+ } pec_space_offset1;
|
|||
|
+ } reg_pec_space_offset1;
|
|||
|
+} PEC_REG_S;
|
|||
|
+#endif // __PEC_REG_S__
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/rubik_regs.h b/drivers/soc/eswin/ai_driver/common/devices/rubik_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/rubik_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/rubik_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/sdp_regs.h b/drivers/soc/eswin/ai_driver/common/devices/sdp_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/sdp_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/sdp_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/sys_regs.h b/drivers/soc/eswin/ai_driver/common/devices/sys_regs.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/sys_regs.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/devices/sys_regs.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/dla_interface.h b/drivers/soc/eswin/ai_driver/common/dla_interface.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/dla_interface.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/dla_interface.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/es_dsp_internal.h b/drivers/soc/eswin/ai_driver/common/es_dsp_internal.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/es_dsp_internal.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/es_dsp_internal.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/es_dsp_op_types.h b/drivers/soc/eswin/ai_driver/common/es_dsp_op_types.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/es_dsp_op_types.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/es_dsp_op_types.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/es_dsp_types.h b/drivers/soc/eswin/ai_driver/common/es_dsp_types.h
|
|||
|
similarity index 98%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/es_dsp_types.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/es_dsp_types.h
|
|||
|
index 473df42a41d3..646ea5e3ac55 100644
|
|||
|
--- a/drivers/soc/eswin/ai_driver/include/es_dsp_types.h
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/common/es_dsp_types.h
|
|||
|
@@ -9,7 +9,11 @@
|
|||
|
#define __ESWIN_DSP_TYPES_H__
|
|||
|
|
|||
|
#include "es_type.h"
|
|||
|
+#if defined(__KERNEL__)
|
|||
|
#include <uapi/linux/es_vb_user.h>
|
|||
|
+#else
|
|||
|
+#include "es_vb_user.h"
|
|||
|
+#endif
|
|||
|
|
|||
|
#ifdef __cplusplus
|
|||
|
#if __cplusplus
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/es_nn_common.h b/drivers/soc/eswin/ai_driver/common/es_nn_common.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/es_nn_common.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/es_nn_common.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/es_type.h b/drivers/soc/eswin/ai_driver/common/es_type.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/es_type.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/es_type.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_arch.h b/drivers/soc/eswin/ai_driver/common/hetero_arch.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_arch.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_arch.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_common.h b/drivers/soc/eswin/ai_driver/common/hetero_common.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_common.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_common.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_env.h b/drivers/soc/eswin/ai_driver/common/hetero_env.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_env.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_env.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_host.h b/drivers/soc/eswin/ai_driver/common/hetero_host.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_host.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_host.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_ioctl.h b/drivers/soc/eswin/ai_driver/common/hetero_ioctl.h
|
|||
|
similarity index 99%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_ioctl.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_ioctl.h
|
|||
|
index 77974acb3b0b..442be18ca88a 100644
|
|||
|
--- a/drivers/soc/eswin/ai_driver/include/hetero_ioctl.h
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/common/hetero_ioctl.h
|
|||
|
@@ -10,7 +10,13 @@
|
|||
|
|
|||
|
#include "hetero_types.h"
|
|||
|
#include "es_type.h"
|
|||
|
+
|
|||
|
+
|
|||
|
+#if defined(__KERNEL__)
|
|||
|
#include <uapi/linux/es_vb_user.h>
|
|||
|
+#else
|
|||
|
+#include "es_vb_user.h"
|
|||
|
+#endif
|
|||
|
|
|||
|
enum {
|
|||
|
mem_flag_swap,
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_ipc.h b/drivers/soc/eswin/ai_driver/common/hetero_ipc.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_ipc.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_ipc.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_perf.h b/drivers/soc/eswin/ai_driver/common/hetero_perf.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_perf.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_perf.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_processor.h b/drivers/soc/eswin/ai_driver/common/hetero_processor.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_processor.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_processor.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/hetero_types.h b/drivers/soc/eswin/ai_driver/common/hetero_types.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/hetero_types.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/hetero_types.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/include/md5.h b/drivers/soc/eswin/ai_driver/common/md5.h
|
|||
|
similarity index 100%
|
|||
|
rename from drivers/soc/eswin/ai_driver/include/md5.h
|
|||
|
rename to drivers/soc/eswin/ai_driver/common/md5.h
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/dsp/Makefile b/drivers/soc/eswin/ai_driver/dsp/Makefile
|
|||
|
index 22f9cf76b86e..cb53bc1850f3 100755
|
|||
|
--- a/drivers/soc/eswin/ai_driver/dsp/Makefile
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/dsp/Makefile
|
|||
|
@@ -31,7 +31,8 @@ ccflags-y := -I$(src)/
|
|||
|
ccflags-y += -I$(srctree)/drivers/soc/eswin
|
|||
|
ccflags-y += -I$(srctree)/drivers/memory/eswin/es_dev_buf/include/linux
|
|||
|
ccflags-y += -I$(srctree)/drivers/memory/eswin/es_iommu_rsv/include/linux
|
|||
|
-ccflags-y += -I$(srctree)/$(src)/../include
|
|||
|
+ccflags-y += -I$(srctree)/$(src)/../common
|
|||
|
+ccflags-y += -I$(srctree)/$(src)/../common/devices
|
|||
|
|
|||
|
obj-$(CONFIG_ESWIN_DSP) += eic7700_dsp.o
|
|||
|
|
|||
|
diff --git a/drivers/soc/eswin/ai_driver/npu/Makefile b/drivers/soc/eswin/ai_driver/npu/Makefile
|
|||
|
index 29de4587ff04..3602d3c9a0f6 100644
|
|||
|
--- a/drivers/soc/eswin/ai_driver/npu/Makefile
|
|||
|
+++ b/drivers/soc/eswin/ai_driver/npu/Makefile
|
|||
|
@@ -8,7 +8,8 @@ ccflags-y += -I$(srctree)/drivers/soc/eswin
|
|||
|
ccflags-y += -I$(srctree)/drivers/memory/eswin/codacache/
|
|||
|
ccflags-y += -I$(srctree)/$(src)/include
|
|||
|
ccflags-y += -I$(srctree)/$(src)/../dsp
|
|||
|
-ccflags-y += -I$(srctree)/$(src)/../include
|
|||
|
+ccflags-y += -I$(srctree)/$(src)/../common
|
|||
|
+ccflags-y += -I$(srctree)/$(src)/../common/devices
|
|||
|
ccflags-y += -I$(srctree)/drivers/memory/eswin/es_iommu_rsv/include/linux
|
|||
|
ccflags-y += -I$(srctree)/drivers/memory/eswin/es_dev_buf/include/linux
|
|||
|
|
|||
|
--
|
|||
|
2.47.0
|
|||
|
|