diff options
Diffstat (limited to 'include/asm-powerpc/spu.h')
-rw-r--r-- | include/asm-powerpc/spu.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/include/asm-powerpc/spu.h b/include/asm-powerpc/spu.h index b42b53c40f5d..e73ea00efd8b 100644 --- a/include/asm-powerpc/spu.h +++ b/include/asm-powerpc/spu.h | |||
@@ -138,6 +138,7 @@ struct spu { | |||
138 | void (* ibox_callback)(struct spu *spu); | 138 | void (* ibox_callback)(struct spu *spu); |
139 | void (* stop_callback)(struct spu *spu); | 139 | void (* stop_callback)(struct spu *spu); |
140 | void (* mfc_callback)(struct spu *spu); | 140 | void (* mfc_callback)(struct spu *spu); |
141 | void (* dma_callback)(struct spu *spu, int type); | ||
141 | 142 | ||
142 | char irq_c0[8]; | 143 | char irq_c0[8]; |
143 | char irq_c1[8]; | 144 | char irq_c1[8]; |
@@ -147,6 +148,7 @@ struct spu { | |||
147 | }; | 148 | }; |
148 | 149 | ||
149 | struct spu *spu_alloc(void); | 150 | struct spu *spu_alloc(void); |
151 | struct spu *spu_alloc_node(int node); | ||
150 | void spu_free(struct spu *spu); | 152 | void spu_free(struct spu *spu); |
151 | int spu_irq_class_0_bottom(struct spu *spu); | 153 | int spu_irq_class_0_bottom(struct spu *spu); |
152 | int spu_irq_class_1_bottom(struct spu *spu); | 154 | int spu_irq_class_1_bottom(struct spu *spu); |
@@ -168,6 +170,22 @@ extern struct spufs_calls { | |||
168 | struct module *owner; | 170 | struct module *owner; |
169 | } spufs_calls; | 171 | } spufs_calls; |
170 | 172 | ||
173 | /* return status from spu_run, same as in libspe */ | ||
174 | #define SPE_EVENT_DMA_ALIGNMENT 0x0008 /*A DMA alignment error */ | ||
175 | #define SPE_EVENT_SPE_ERROR 0x0010 /*An illegal instruction error*/ | ||
176 | #define SPE_EVENT_SPE_DATA_SEGMENT 0x0020 /*A DMA segmentation error */ | ||
177 | #define SPE_EVENT_SPE_DATA_STORAGE 0x0040 /*A DMA storage error */ | ||
178 | #define SPE_EVENT_INVALID_DMA 0x0800 /* Invalid MFC DMA */ | ||
179 | |||
180 | /* | ||
181 | * Flags for sys_spu_create. | ||
182 | */ | ||
183 | #define SPU_CREATE_EVENTS_ENABLED 0x0001 | ||
184 | #define SPU_CREATE_GANG 0x0002 | ||
185 | |||
186 | #define SPU_CREATE_FLAG_ALL 0x0003 /* mask of all valid flags */ | ||
187 | |||
188 | |||
171 | #ifdef CONFIG_SPU_FS_MODULE | 189 | #ifdef CONFIG_SPU_FS_MODULE |
172 | int register_spu_syscalls(struct spufs_calls *calls); | 190 | int register_spu_syscalls(struct spufs_calls *calls); |
173 | void unregister_spu_syscalls(struct spufs_calls *calls); | 191 | void unregister_spu_syscalls(struct spufs_calls *calls); |
@@ -183,6 +201,24 @@ static inline void unregister_spu_syscalls(struct spufs_calls *calls) | |||
183 | 201 | ||
184 | 202 | ||
185 | /* | 203 | /* |
204 | * Notifier blocks: | ||
205 | * | ||
206 | * oprofile can get notified when a context switch is performed | ||
207 | * on an spe. The notifer function that gets called is passed | ||
208 | * a pointer to the SPU structure as well as the object-id that | ||
209 | * identifies the binary running on that SPU now. | ||
210 | * | ||
211 | * For a context save, the object-id that is passed is zero, | ||
212 | * identifying that the kernel will run from that moment on. | ||
213 | * | ||
214 | * For a context restore, the object-id is the value written | ||
215 | * to object-id spufs file from user space and the notifer | ||
216 | * function can assume that spu->ctx is valid. | ||
217 | */ | ||
218 | int spu_switch_event_register(struct notifier_block * n); | ||
219 | int spu_switch_event_unregister(struct notifier_block * n); | ||
220 | |||
221 | /* | ||
186 | * This defines the Local Store, Problem Area and Privlege Area of an SPU. | 222 | * This defines the Local Store, Problem Area and Privlege Area of an SPU. |
187 | */ | 223 | */ |
188 | 224 | ||