Update to v5.8 kernel headers.
Kernel headers coming from:
Git: https://android.googlesource.com/kernel/common/
Branch: android-mainline
Tag: android-mainline-5.8
Test: NA
Change-Id: I2231c877589820fc09800a200cf4ac62ba74b04c
diff --git a/libc/kernel/uapi/misc/habanalabs.h b/libc/kernel/uapi/misc/habanalabs.h
index 91849ec..3ae1722 100644
--- a/libc/kernel/uapi/misc/habanalabs.h
+++ b/libc/kernel/uapi/misc/habanalabs.h
@@ -21,6 +21,9 @@
#include <linux/types.h>
#include <linux/ioctl.h>
#define GOYA_KMD_SRAM_RESERVED_SIZE_FROM_START 0x8000
+#define GAUDI_DRIVER_SRAM_RESERVED_SIZE_FROM_START 0x80
+#define GAUDI_FIRST_AVAILABLE_W_S_SYNC_OBJECT 48
+#define GAUDI_FIRST_AVAILABLE_W_S_MONITOR 24
enum goya_queue_id {
GOYA_QUEUE_ID_DMA_0 = 0,
GOYA_QUEUE_ID_DMA_1 = 1,
@@ -39,6 +42,122 @@
GOYA_QUEUE_ID_TPC7 = 14,
GOYA_QUEUE_ID_SIZE
};
+enum gaudi_queue_id {
+ GAUDI_QUEUE_ID_DMA_0_0 = 0,
+ GAUDI_QUEUE_ID_DMA_0_1 = 1,
+ GAUDI_QUEUE_ID_DMA_0_2 = 2,
+ GAUDI_QUEUE_ID_DMA_0_3 = 3,
+ GAUDI_QUEUE_ID_DMA_1_0 = 4,
+ GAUDI_QUEUE_ID_DMA_1_1 = 5,
+ GAUDI_QUEUE_ID_DMA_1_2 = 6,
+ GAUDI_QUEUE_ID_DMA_1_3 = 7,
+ GAUDI_QUEUE_ID_CPU_PQ = 8,
+ GAUDI_QUEUE_ID_DMA_2_0 = 9,
+ GAUDI_QUEUE_ID_DMA_2_1 = 10,
+ GAUDI_QUEUE_ID_DMA_2_2 = 11,
+ GAUDI_QUEUE_ID_DMA_2_3 = 12,
+ GAUDI_QUEUE_ID_DMA_3_0 = 13,
+ GAUDI_QUEUE_ID_DMA_3_1 = 14,
+ GAUDI_QUEUE_ID_DMA_3_2 = 15,
+ GAUDI_QUEUE_ID_DMA_3_3 = 16,
+ GAUDI_QUEUE_ID_DMA_4_0 = 17,
+ GAUDI_QUEUE_ID_DMA_4_1 = 18,
+ GAUDI_QUEUE_ID_DMA_4_2 = 19,
+ GAUDI_QUEUE_ID_DMA_4_3 = 20,
+ GAUDI_QUEUE_ID_DMA_5_0 = 21,
+ GAUDI_QUEUE_ID_DMA_5_1 = 22,
+ GAUDI_QUEUE_ID_DMA_5_2 = 23,
+ GAUDI_QUEUE_ID_DMA_5_3 = 24,
+ GAUDI_QUEUE_ID_DMA_6_0 = 25,
+ GAUDI_QUEUE_ID_DMA_6_1 = 26,
+ GAUDI_QUEUE_ID_DMA_6_2 = 27,
+ GAUDI_QUEUE_ID_DMA_6_3 = 28,
+ GAUDI_QUEUE_ID_DMA_7_0 = 29,
+ GAUDI_QUEUE_ID_DMA_7_1 = 30,
+ GAUDI_QUEUE_ID_DMA_7_2 = 31,
+ GAUDI_QUEUE_ID_DMA_7_3 = 32,
+ GAUDI_QUEUE_ID_MME_0_0 = 33,
+ GAUDI_QUEUE_ID_MME_0_1 = 34,
+ GAUDI_QUEUE_ID_MME_0_2 = 35,
+ GAUDI_QUEUE_ID_MME_0_3 = 36,
+ GAUDI_QUEUE_ID_MME_1_0 = 37,
+ GAUDI_QUEUE_ID_MME_1_1 = 38,
+ GAUDI_QUEUE_ID_MME_1_2 = 39,
+ GAUDI_QUEUE_ID_MME_1_3 = 40,
+ GAUDI_QUEUE_ID_TPC_0_0 = 41,
+ GAUDI_QUEUE_ID_TPC_0_1 = 42,
+ GAUDI_QUEUE_ID_TPC_0_2 = 43,
+ GAUDI_QUEUE_ID_TPC_0_3 = 44,
+ GAUDI_QUEUE_ID_TPC_1_0 = 45,
+ GAUDI_QUEUE_ID_TPC_1_1 = 46,
+ GAUDI_QUEUE_ID_TPC_1_2 = 47,
+ GAUDI_QUEUE_ID_TPC_1_3 = 48,
+ GAUDI_QUEUE_ID_TPC_2_0 = 49,
+ GAUDI_QUEUE_ID_TPC_2_1 = 50,
+ GAUDI_QUEUE_ID_TPC_2_2 = 51,
+ GAUDI_QUEUE_ID_TPC_2_3 = 52,
+ GAUDI_QUEUE_ID_TPC_3_0 = 53,
+ GAUDI_QUEUE_ID_TPC_3_1 = 54,
+ GAUDI_QUEUE_ID_TPC_3_2 = 55,
+ GAUDI_QUEUE_ID_TPC_3_3 = 56,
+ GAUDI_QUEUE_ID_TPC_4_0 = 57,
+ GAUDI_QUEUE_ID_TPC_4_1 = 58,
+ GAUDI_QUEUE_ID_TPC_4_2 = 59,
+ GAUDI_QUEUE_ID_TPC_4_3 = 60,
+ GAUDI_QUEUE_ID_TPC_5_0 = 61,
+ GAUDI_QUEUE_ID_TPC_5_1 = 62,
+ GAUDI_QUEUE_ID_TPC_5_2 = 63,
+ GAUDI_QUEUE_ID_TPC_5_3 = 64,
+ GAUDI_QUEUE_ID_TPC_6_0 = 65,
+ GAUDI_QUEUE_ID_TPC_6_1 = 66,
+ GAUDI_QUEUE_ID_TPC_6_2 = 67,
+ GAUDI_QUEUE_ID_TPC_6_3 = 68,
+ GAUDI_QUEUE_ID_TPC_7_0 = 69,
+ GAUDI_QUEUE_ID_TPC_7_1 = 70,
+ GAUDI_QUEUE_ID_TPC_7_2 = 71,
+ GAUDI_QUEUE_ID_TPC_7_3 = 72,
+ GAUDI_QUEUE_ID_NIC_0_0 = 73,
+ GAUDI_QUEUE_ID_NIC_0_1 = 74,
+ GAUDI_QUEUE_ID_NIC_0_2 = 75,
+ GAUDI_QUEUE_ID_NIC_0_3 = 76,
+ GAUDI_QUEUE_ID_NIC_1_0 = 77,
+ GAUDI_QUEUE_ID_NIC_1_1 = 78,
+ GAUDI_QUEUE_ID_NIC_1_2 = 79,
+ GAUDI_QUEUE_ID_NIC_1_3 = 80,
+ GAUDI_QUEUE_ID_NIC_2_0 = 81,
+ GAUDI_QUEUE_ID_NIC_2_1 = 82,
+ GAUDI_QUEUE_ID_NIC_2_2 = 83,
+ GAUDI_QUEUE_ID_NIC_2_3 = 84,
+ GAUDI_QUEUE_ID_NIC_3_0 = 85,
+ GAUDI_QUEUE_ID_NIC_3_1 = 86,
+ GAUDI_QUEUE_ID_NIC_3_2 = 87,
+ GAUDI_QUEUE_ID_NIC_3_3 = 88,
+ GAUDI_QUEUE_ID_NIC_4_0 = 89,
+ GAUDI_QUEUE_ID_NIC_4_1 = 90,
+ GAUDI_QUEUE_ID_NIC_4_2 = 91,
+ GAUDI_QUEUE_ID_NIC_4_3 = 92,
+ GAUDI_QUEUE_ID_NIC_5_0 = 93,
+ GAUDI_QUEUE_ID_NIC_5_1 = 94,
+ GAUDI_QUEUE_ID_NIC_5_2 = 95,
+ GAUDI_QUEUE_ID_NIC_5_3 = 96,
+ GAUDI_QUEUE_ID_NIC_6_0 = 97,
+ GAUDI_QUEUE_ID_NIC_6_1 = 98,
+ GAUDI_QUEUE_ID_NIC_6_2 = 99,
+ GAUDI_QUEUE_ID_NIC_6_3 = 100,
+ GAUDI_QUEUE_ID_NIC_7_0 = 101,
+ GAUDI_QUEUE_ID_NIC_7_1 = 102,
+ GAUDI_QUEUE_ID_NIC_7_2 = 103,
+ GAUDI_QUEUE_ID_NIC_7_3 = 104,
+ GAUDI_QUEUE_ID_NIC_8_0 = 105,
+ GAUDI_QUEUE_ID_NIC_8_1 = 106,
+ GAUDI_QUEUE_ID_NIC_8_2 = 107,
+ GAUDI_QUEUE_ID_NIC_8_3 = 108,
+ GAUDI_QUEUE_ID_NIC_9_0 = 109,
+ GAUDI_QUEUE_ID_NIC_9_1 = 110,
+ GAUDI_QUEUE_ID_NIC_9_2 = 111,
+ GAUDI_QUEUE_ID_NIC_9_3 = 112,
+ GAUDI_QUEUE_ID_SIZE
+};
enum goya_engine_id {
GOYA_ENGINE_ID_DMA_0 = 0,
GOYA_ENGINE_ID_DMA_1,
@@ -56,6 +175,39 @@
GOYA_ENGINE_ID_TPC_7,
GOYA_ENGINE_ID_SIZE
};
+enum gaudi_engine_id {
+ GAUDI_ENGINE_ID_DMA_0 = 0,
+ GAUDI_ENGINE_ID_DMA_1,
+ GAUDI_ENGINE_ID_DMA_2,
+ GAUDI_ENGINE_ID_DMA_3,
+ GAUDI_ENGINE_ID_DMA_4,
+ GAUDI_ENGINE_ID_DMA_5,
+ GAUDI_ENGINE_ID_DMA_6,
+ GAUDI_ENGINE_ID_DMA_7,
+ GAUDI_ENGINE_ID_MME_0,
+ GAUDI_ENGINE_ID_MME_1,
+ GAUDI_ENGINE_ID_MME_2,
+ GAUDI_ENGINE_ID_MME_3,
+ GAUDI_ENGINE_ID_TPC_0,
+ GAUDI_ENGINE_ID_TPC_1,
+ GAUDI_ENGINE_ID_TPC_2,
+ GAUDI_ENGINE_ID_TPC_3,
+ GAUDI_ENGINE_ID_TPC_4,
+ GAUDI_ENGINE_ID_TPC_5,
+ GAUDI_ENGINE_ID_TPC_6,
+ GAUDI_ENGINE_ID_TPC_7,
+ GAUDI_ENGINE_ID_NIC_0,
+ GAUDI_ENGINE_ID_NIC_1,
+ GAUDI_ENGINE_ID_NIC_2,
+ GAUDI_ENGINE_ID_NIC_3,
+ GAUDI_ENGINE_ID_NIC_4,
+ GAUDI_ENGINE_ID_NIC_5,
+ GAUDI_ENGINE_ID_NIC_6,
+ GAUDI_ENGINE_ID_NIC_7,
+ GAUDI_ENGINE_ID_NIC_8,
+ GAUDI_ENGINE_ID_NIC_9,
+ GAUDI_ENGINE_ID_SIZE
+};
enum hl_device_status {
HL_DEVICE_STATUS_OPERATIONAL,
HL_DEVICE_STATUS_IN_RESET,
@@ -70,6 +222,7 @@
#define HL_INFO_HW_EVENTS_AGGREGATE 7
#define HL_INFO_CLK_RATE 8
#define HL_INFO_RESET_COUNT 9
+#define HL_INFO_TIME_SYNC 10
#define HL_INFO_VERSION_MAX_LEN 128
#define HL_INFO_CARD_NAME_MAX_LEN 16
struct hl_info_hw_ip_info {
@@ -79,7 +232,8 @@
__u32 sram_size;
__u32 num_of_events;
__u32 device_id;
- __u32 reserved[3];
+ __u32 module_id;
+ __u32 reserved[2];
__u32 armcp_cpld_version;
__u32 psoc_pci_pll_nr;
__u32 psoc_pci_pll_nf;
@@ -115,6 +269,10 @@
__u32 hard_reset_cnt;
__u32 soft_reset_cnt;
};
+struct hl_info_time_sync {
+ __u64 device_time;
+ __u64 host_time;
+};
struct hl_info_args {
__u64 return_pointer;
__u32 return_size;
@@ -127,7 +285,7 @@
};
#define HL_CB_OP_CREATE 0
#define HL_CB_OP_DESTROY 1
-#define HL_MAX_CB_SIZE 0x200000
+#define HL_MAX_CB_SIZE (0x200000 - 32)
struct hl_cb_in {
__u64 cb_handle;
__u32 op;
@@ -143,13 +301,21 @@
struct hl_cb_out out;
};
struct hl_cs_chunk {
- __u64 cb_handle;
+ union {
+ __u64 cb_handle;
+ __u64 signal_seq_arr;
+ };
__u32 queue_index;
- __u32 cb_size;
+ union {
+ __u32 cb_size;
+ __u32 num_signal_seq_arr;
+ };
__u32 cs_chunk_flags;
__u32 pad[11];
};
#define HL_CS_FLAGS_FORCE_RESTORE 0x1
+#define HL_CS_FLAGS_SIGNAL 0x2
+#define HL_CS_FLAGS_WAIT 0x4
#define HL_CS_STATUS_SUCCESS 0
#define HL_MAX_JOBS_PER_CS 512
struct hl_cs_in {