• Jonathan Kim's avatar
    drm/amdkfd: update process interrupt handling for debug events · 12fb1ad7
    Jonathan Kim authored
    The debugger must be notified by any debugger subscribed exception
    that comes from hardware interrupts.
    
    If a debugger session exits, any exceptions it subscribed to may still
    have interrupts in the interrupt ring buffer or KGD/KFD pipeline.
    To prevent a new session from inheriting stale interrupts, when a new
    queue is created, open an interrupt drain and allow the IH ring to drain
    from a timestamped checkpoint.  Then inject a custom IV so that once
    the custom IV is picked up by the KFD, it's safe to close the drain
    and proceed with queue creation.
    
    The drain must also be on debug disable as SW interrupts may still
    be processed.  Drain at this time and clear all the exception status.
    
    The debugger may also not be attached nor subscibed to certain
    exceptions so forward them directly to the runtime.
    
    GFX10 also requires its own IV processing, hence the creation of
    kfd_int_process_v10.c.  This is because the IV from SQ interrupts are
    packed into a new continguous format unlike GFX9. To make this clear,
    a separate interrupting handling code file was created.
    Signed-off-by: default avatarJonathan Kim <jonathan.kim@amd.com>
    Reviewed-by: default avatarFelix Kuehling <felix.kuehling@amd.com>
    Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
    12fb1ad7
kfd_device.c 38.2 KB