case IP_VERSION(9, 4, 0): /* VEGA20 */
        case IP_VERSION(9, 4, 1): /* ARCTURUS */
        case IP_VERSION(9, 4, 2): /* ALDEBARAN */
-       case IP_VERSION(9, 4, 3): /* GC 9.4.3 */
                kfd->device_info.event_interrupt_class = &event_interrupt_class_v9;
                break;
+       case IP_VERSION(9, 4, 3): /* GC 9.4.3 */
+               kfd->device_info.event_interrupt_class =
+                                               &event_interrupt_class_v9_4_3;
+               break;
        case IP_VERSION(10, 3, 1): /* VANGOGH */
        case IP_VERSION(10, 3, 3): /* YELLOW_CARP */
        case IP_VERSION(10, 3, 6): /* GC 10.3.6 */
        }
 }
 
+static void kfd_setup_interrupt_bitmap(struct kfd_node *node,
+                                      unsigned int kfd_node_idx)
+{
+       struct amdgpu_device *adev = node->adev;
+       uint32_t xcc_mask = node->xcc_mask;
+       uint32_t xcc, mapped_xcc;
+       /*
+        * Interrupt bitmap is setup for processing interrupts from
+        * different XCDs and AIDs.
+        * Interrupt bitmap is defined as follows:
+        * 1. Bits 0-15 - correspond to the NodeId field.
+        *    Each bit corresponds to NodeId number. For example, if
+        *    a KFD node has interrupt bitmap set to 0x7, then this
+        *    KFD node will process interrupts with NodeId = 0, 1 and 2
+        *    in the IH cookie.
+        * 2. Bits 16-31 - unused.
+        *
+        * Please note that the kfd_node_idx argument passed to this
+        * function is not related to NodeId field received in the
+        * IH cookie.
+        *
+        * In CPX mode, a KFD node will process an interrupt if:
+        * - the Node Id matches the corresponding bit set in
+        *   Bits 0-15.
+        * - AND VMID reported in the interrupt lies within the
+        *   VMID range of the node.
+        */
+       for_each_inst(xcc, xcc_mask) {
+               mapped_xcc = GET_INST(GC, xcc);
+               node->interrupt_bitmap |= (mapped_xcc % 2 ? 5 : 3) << (4 * (mapped_xcc / 2));
+       }
+       dev_info(kfd_device, "Node: %d, interrupt_bitmap: %x\n", kfd_node_idx,
+                                                       node->interrupt_bitmap);
+}
+
 bool kgd2kfd_device_init(struct kfd_dev *kfd,
                         const struct kgd2kfd_shared_resources *gpu_resources)
 {
                amdgpu_amdkfd_get_local_mem_info(kfd->adev,
                                        &node->local_mem_info, node->xcp);
 
+               if (KFD_GC_VERSION(kfd) == IP_VERSION(9, 4, 3))
+                       kfd_setup_interrupt_bitmap(node, i);
+
                /* Initialize the KFD node */
                if (kfd_init_node(node)) {
                        dev_err(kfd_device, "Error initializing KFD node\n");
 
        }
 }
 
+static bool event_interrupt_isr_v9_4_3(struct kfd_node *node,
+                               const uint32_t *ih_ring_entry,
+                               uint32_t *patched_ihre,
+                               bool *patched_flag)
+{
+       uint16_t node_id, vmid;
+
+       /*
+        * For GFX 9.4.3, process the interrupt if:
+        * - NodeID field in IH entry matches the corresponding bit
+        *   set in interrupt_bitmap Bits 0-15.
+        *   OR
+        * - If partition mode is CPX and interrupt came from
+        *   Node_id 0,4,8,12, then check if the Bit (16 + client id)
+        *   is set in interrupt bitmap Bits 16-31.
+        */
+       node_id = SOC15_NODEID_FROM_IH_ENTRY(ih_ring_entry);
+       vmid = SOC15_VMID_FROM_IH_ENTRY(ih_ring_entry);
+       if (kfd_irq_is_from_node(node, node_id, vmid))
+               return event_interrupt_isr_v9(node, ih_ring_entry,
+                                       patched_ihre, patched_flag);
+       return false;
+}
+
 const struct kfd_event_interrupt_class event_interrupt_class_v9 = {
        .interrupt_isr = event_interrupt_isr_v9,
        .interrupt_wq = event_interrupt_wq_v9,
 };
+
+const struct kfd_event_interrupt_class event_interrupt_class_v9_4_3 = {
+       .interrupt_isr = event_interrupt_isr_v9_4_3,
+       .interrupt_wq = event_interrupt_wq_v9,
+};
 
 int kfd_process_drain_interrupts(struct kfd_process_device *pdd)
 {
        uint32_t irq_drain_fence[8];
+       uint8_t node_id = 0;
        int r = 0;
 
        if (!KFD_IS_SOC15(pdd->dev))
                                                        KFD_IRQ_FENCE_CLIENTID;
        irq_drain_fence[3] = pdd->process->pasid;
 
+       /*
+        * For GFX 9.4.3, send the NodeId also in IH cookie DW[3]
+        */
+       if (KFD_GC_VERSION(pdd->dev->kfd) == IP_VERSION(9, 4, 3)) {
+               node_id = ffs(pdd->dev->interrupt_bitmap) - 1;
+               irq_drain_fence[3] |= node_id << 16;
+       }
+
        /* ensure stale irqs scheduled KFD interrupts and send drain fence. */
        if (amdgpu_amdkfd_send_close_event_drain_irq(pdd->dev->adev,
                                                     irq_drain_fence)) {