.. | .. |
---|
25 | 25 | #define __AMDGPU_IRQ_H__ |
---|
26 | 26 | |
---|
27 | 27 | #include <linux/irqdomain.h> |
---|
| 28 | +#include "soc15_ih_clientid.h" |
---|
28 | 29 | #include "amdgpu_ih.h" |
---|
29 | 30 | |
---|
30 | | -#define AMDGPU_MAX_IRQ_SRC_ID 0x100 |
---|
| 31 | +#define AMDGPU_MAX_IRQ_SRC_ID 0x100 |
---|
31 | 32 | #define AMDGPU_MAX_IRQ_CLIENT_ID 0x100 |
---|
32 | 33 | |
---|
| 34 | +#define AMDGPU_IRQ_CLIENTID_LEGACY 0 |
---|
| 35 | +#define AMDGPU_IRQ_CLIENTID_MAX SOC15_IH_CLIENTID_MAX |
---|
| 36 | + |
---|
| 37 | +#define AMDGPU_IRQ_SRC_DATA_MAX_SIZE_DW 4 |
---|
| 38 | + |
---|
33 | 39 | struct amdgpu_device; |
---|
34 | | -struct amdgpu_iv_entry; |
---|
35 | 40 | |
---|
36 | 41 | enum amdgpu_interrupt_state { |
---|
37 | 42 | AMDGPU_IRQ_STATE_DISABLE, |
---|
38 | 43 | AMDGPU_IRQ_STATE_ENABLE, |
---|
| 44 | +}; |
---|
| 45 | + |
---|
| 46 | +struct amdgpu_iv_entry { |
---|
| 47 | + unsigned client_id; |
---|
| 48 | + unsigned src_id; |
---|
| 49 | + unsigned ring_id; |
---|
| 50 | + unsigned vmid; |
---|
| 51 | + unsigned vmid_src; |
---|
| 52 | + uint64_t timestamp; |
---|
| 53 | + unsigned timestamp_src; |
---|
| 54 | + unsigned pasid; |
---|
| 55 | + unsigned pasid_src; |
---|
| 56 | + unsigned src_data[AMDGPU_IRQ_SRC_DATA_MAX_SIZE_DW]; |
---|
| 57 | + const uint32_t *iv_entry; |
---|
39 | 58 | }; |
---|
40 | 59 | |
---|
41 | 60 | struct amdgpu_irq_src { |
---|
.. | .. |
---|
63 | 82 | bool installed; |
---|
64 | 83 | spinlock_t lock; |
---|
65 | 84 | /* interrupt sources */ |
---|
66 | | - struct amdgpu_irq_client client[AMDGPU_IH_CLIENTID_MAX]; |
---|
| 85 | + struct amdgpu_irq_client client[AMDGPU_IRQ_CLIENTID_MAX]; |
---|
67 | 86 | |
---|
68 | 87 | /* status, etc. */ |
---|
69 | 88 | bool msi_enabled; /* msi enabled */ |
---|
70 | 89 | |
---|
71 | | - /* interrupt ring */ |
---|
72 | | - struct amdgpu_ih_ring ih; |
---|
73 | | - const struct amdgpu_ih_funcs *ih_funcs; |
---|
| 90 | + /* interrupt rings */ |
---|
| 91 | + struct amdgpu_ih_ring ih, ih1, ih2; |
---|
| 92 | + const struct amdgpu_ih_funcs *ih_funcs; |
---|
| 93 | + struct work_struct ih1_work, ih2_work; |
---|
| 94 | + struct amdgpu_irq_src self_irq; |
---|
74 | 95 | |
---|
75 | 96 | /* gen irq stuff */ |
---|
76 | 97 | struct irq_domain *domain; /* GPU irq controller domain */ |
---|
.. | .. |
---|
87 | 108 | unsigned client_id, unsigned src_id, |
---|
88 | 109 | struct amdgpu_irq_src *source); |
---|
89 | 110 | void amdgpu_irq_dispatch(struct amdgpu_device *adev, |
---|
90 | | - struct amdgpu_iv_entry *entry); |
---|
| 111 | + struct amdgpu_ih_ring *ih); |
---|
91 | 112 | int amdgpu_irq_update(struct amdgpu_device *adev, struct amdgpu_irq_src *src, |
---|
92 | 113 | unsigned type); |
---|
93 | 114 | int amdgpu_irq_get(struct amdgpu_device *adev, struct amdgpu_irq_src *src, |
---|