#define HL_MEM_OP_UNMAP                        3
 /* Opcode to map a hw block */
 #define HL_MEM_OP_MAP_BLOCK            4
+/* Opcode to create DMA-BUF object for an existing device memory allocation
+ * and to export an FD of that DMA-BUF back to the caller
+ */
+#define HL_MEM_OP_EXPORT_DMABUF_FD     5
 
 /* Memory flags */
 #define HL_MEM_CONTIGUOUS      0x1
                        /* Virtual address returned from HL_MEM_OP_MAP */
                        __u64 device_virt_addr;
                } unmap;
+
+               /* HL_MEM_OP_EXPORT_DMABUF_FD */
+               struct {
+                       /* Handle returned from HL_MEM_OP_ALLOC. In Gaudi,
+                        * where we don't have MMU for the device memory, the
+                        * driver expects a physical address (instead of
+                        * a handle) in the device memory space.
+                        */
+                       __u64 handle;
+                       /* Size of memory allocation. Relevant only for GAUDI */
+                       __u64 mem_size;
+               } export_dmabuf_fd;
        };
 
        /* HL_MEM_OP_* */
        __u32 op;
-       /* HL_MEM_* flags */
+       /* HL_MEM_* flags.
+        * For the HL_MEM_OP_EXPORT_DMABUF_FD opcode, this field holds the
+        * DMA-BUF file/FD flags.
+        */
        __u32 flags;
        /* Context ID - Currently not in use */
        __u32 ctx_id;
 
                        __u32 pad;
                };
+
+               /* Returned in HL_MEM_OP_EXPORT_DMABUF_FD. Represents the
+                * DMA-BUF object that was created to describe a memory
+                * allocation on the device's memory space. The FD should be
+                * passed to the importer driver
+                */
+               __s32 fd;
        };
 };