From: Jack Steiner Add support for dumpping the GRU GSH state. This provides addition debugging information for GRU failures. Add missing cache flush instructions. For performance reasons, the CBE does not alway maintain cache-coherency. Signed-off-by: Jack Steiner --- drivers/misc/sgi-gru/grukdump.c | 17 ++++++++++++++++- drivers/misc/sgi-gru/grulib.h | 2 ++ 2 files changed, 18 insertions(+), 1 deletion(-) Index: linux/drivers/misc/sgi-gru/grukdump.c =================================================================== --- linux.orig/drivers/misc/sgi-gru/grukdump.c 2010-07-19 10:23:08.926244572 -0500 +++ linux/drivers/misc/sgi-gru/grukdump.c 2010-07-19 13:10:56.766719840 -0500 @@ -54,10 +54,16 @@ static int gru_dump_context_data(void *g cb = gseg + GRU_CB_BASE; cbe = grubase + GRU_CBE_BASE; tfh = grubase + GRU_TFH_BASE; + sync_core(); + gru_flush_cache(cbe); for_each_cbr_in_allocation_map(i, &cch->cbr_allocation_map, scr) { - if (flush_cbrs) + if (flush_cbrs) { gru_flush_cache(cb); + gru_flush_cache(tfh + i * GRU_HANDLE_STRIDE); + } + gru_flush_cache(cbe + i * GRU_HANDLE_STRIDE); + sync_core(); if (gru_user_copy_handle(&ubuf, cb)) goto fail; if (gru_user_copy_handle(&ubuf, tfh + i * GRU_HANDLE_STRIDE)) @@ -130,6 +136,7 @@ static int gru_dump_context(struct gru_s memset(&hdr, 0, sizeof(hdr)); grubase = gru->gs_gru_base_vaddr; cch = get_cch(grubase, ctxnum); + gru_flush_cache(cch); for (try = 0; try < CCH_LOCK_ATTEMPTS; try++) { cch_locked = trylock_cch_handle(cch); if (cch_locked) @@ -184,6 +191,12 @@ fail: unlock_cch_handle(cch); return -EFAULT; } +static void dump_gsh_state(struct gru_state *gru, + struct gru_dump_chiplet_state_req *req) +{ + memset(&req->gsh_cb_state, 0, sizeof(req->gsh_cb_state)); + memset(&req->gsh_cch_state, 0, sizeof(req->gsh_cch_state)); +} int gru_dump_chiplet_request(unsigned long arg) { @@ -214,6 +227,8 @@ int gru_dump_chiplet_request(unsigned lo goto fail; ubuf += ret; + dump_gsh_state(gru, &req); + for (ctxnum = 0; ctxnum < GRU_NUM_CCH; ctxnum++) { if (req.ctxnum == ctxnum || req.ctxnum < 0) { ret = gru_dump_context(gru, ctxnum, ubuf, ubufend, Index: linux/drivers/misc/sgi-gru/grulib.h =================================================================== --- linux.orig/drivers/misc/sgi-gru/grulib.h 2010-07-19 10:25:54.334243996 -0500 +++ linux/drivers/misc/sgi-gru/grulib.h 2010-07-19 13:10:35.154917927 -0500 @@ -130,6 +130,8 @@ struct gru_dump_chiplet_state_req { size_t buflen; /* ---- output --- */ unsigned int num_contexts; + unsigned long gsh_cb_state[16]; + unsigned long gsh_cch_state[16]; }; #define GRU_DUMP_MAGIC 0x3474ab6c -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/