aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc/sgi-gru/grukservices.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/misc/sgi-gru/grukservices.c')
-rw-r--r--drivers/misc/sgi-gru/grukservices.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/drivers/misc/sgi-gru/grukservices.c b/drivers/misc/sgi-gru/grukservices.c
index ba6fcd963f30..7586b89fd0d3 100644
--- a/drivers/misc/sgi-gru/grukservices.c
+++ b/drivers/misc/sgi-gru/grukservices.c
@@ -98,6 +98,9 @@
98#define ASYNC_HAN_TO_BID(h) ((h) - 1) 98#define ASYNC_HAN_TO_BID(h) ((h) - 1)
99#define ASYNC_BID_TO_HAN(b) ((b) + 1) 99#define ASYNC_BID_TO_HAN(b) ((b) + 1)
100#define ASYNC_HAN_TO_BS(h) gru_base[ASYNC_HAN_TO_BID(h)] 100#define ASYNC_HAN_TO_BS(h) gru_base[ASYNC_HAN_TO_BID(h)]
101#define KCB_TO_GID(cb) ((cb - gru_start_vaddr) / \
102 (GRU_SIZE * GRU_CHIPLETS_PER_BLADE))
103#define KCB_TO_BS(cb) gru_base[KCB_TO_GID(cb)]
101 104
102#define GRU_NUM_KERNEL_CBR 1 105#define GRU_NUM_KERNEL_CBR 1
103#define GRU_NUM_KERNEL_DSR_BYTES 256 106#define GRU_NUM_KERNEL_DSR_BYTES 256
@@ -354,14 +357,19 @@ int gru_get_cb_exception_detail(void *cb,
354 struct control_block_extended_exc_detail *excdet) 357 struct control_block_extended_exc_detail *excdet)
355{ 358{
356 struct gru_control_block_extended *cbe; 359 struct gru_control_block_extended *cbe;
360 struct gru_blade_state *bs;
361 int cbrnum;
357 362
358 cbe = get_cbe(GRUBASE(cb), get_cb_number(cb)); 363 bs = KCB_TO_BS(cb);
359 prefetchw(cbe); /* Harmless on hardware, required for emulator */ 364 cbrnum = thread_cbr_number(bs->bs_kgts, get_cb_number(cb));
365 cbe = get_cbe(GRUBASE(cb), cbrnum);
366 gru_flush_cache(cbe); /* CBE not coherent */
360 excdet->opc = cbe->opccpy; 367 excdet->opc = cbe->opccpy;
361 excdet->exopc = cbe->exopccpy; 368 excdet->exopc = cbe->exopccpy;
362 excdet->ecause = cbe->ecause; 369 excdet->ecause = cbe->ecause;
363 excdet->exceptdet0 = cbe->idef1upd; 370 excdet->exceptdet0 = cbe->idef1upd;
364 excdet->exceptdet1 = cbe->idef3upd; 371 excdet->exceptdet1 = cbe->idef3upd;
372 gru_flush_cache(cbe);
365 return 0; 373 return 0;
366} 374}
367 375