提交 437a0706 编写于 作者: M Michael Ellerman 提交者: Paul Mackerras

[POWERPC] Fix sparse warning in xmon Cell code

My patch to add spu helpers to xmon (a8984970)
introduced a few sparse warnings, because I was dereferencing an __iomem
pointer.

I think the best way to handle it is to actually use the appropriate in_beXX
functions. Need to rejigger the DUMP macro a little to accomodate that.
Signed-off-by: NMichael Ellerman <michael@ellerman.id.au>
Signed-off-by: NArnd Bergmann <arnd.bergmann@de.ibm.com>
上级 5850dd8f
...@@ -2748,13 +2748,13 @@ static void restart_spus(void) ...@@ -2748,13 +2748,13 @@ static void restart_spus(void)
} }
#define DUMP_WIDTH 23 #define DUMP_WIDTH 23
#define DUMP_FIELD(obj, format, field) \ #define DUMP_VALUE(format, field, value) \
do { \ do { \
if (setjmp(bus_error_jmp) == 0) { \ if (setjmp(bus_error_jmp) == 0) { \
catch_memory_errors = 1; \ catch_memory_errors = 1; \
sync(); \ sync(); \
printf(" %-*s = "format"\n", DUMP_WIDTH, \ printf(" %-*s = "format"\n", DUMP_WIDTH, \
#field, obj->field); \ #field, value); \
sync(); \ sync(); \
__delay(200); \ __delay(200); \
} else { \ } else { \
...@@ -2765,6 +2765,9 @@ do { \ ...@@ -2765,6 +2765,9 @@ do { \
catch_memory_errors = 0; \ catch_memory_errors = 0; \
} while (0) } while (0)
#define DUMP_FIELD(obj, format, field) \
DUMP_VALUE(format, field, obj->field)
static void dump_spu_fields(struct spu *spu) static void dump_spu_fields(struct spu *spu)
{ {
printf("Dumping spu fields at address %p:\n", spu); printf("Dumping spu fields at address %p:\n", spu);
...@@ -2793,13 +2796,18 @@ static void dump_spu_fields(struct spu *spu) ...@@ -2793,13 +2796,18 @@ static void dump_spu_fields(struct spu *spu)
DUMP_FIELD(spu, "0x%p", timestamp); DUMP_FIELD(spu, "0x%p", timestamp);
DUMP_FIELD(spu, "0x%lx", problem_phys); DUMP_FIELD(spu, "0x%lx", problem_phys);
DUMP_FIELD(spu, "0x%p", problem); DUMP_FIELD(spu, "0x%p", problem);
DUMP_FIELD(spu, "0x%x", problem->spu_runcntl_RW); DUMP_VALUE("0x%x", problem->spu_runcntl_RW,
DUMP_FIELD(spu, "0x%x", problem->spu_status_R); in_be32(&spu->problem->spu_runcntl_RW));
DUMP_FIELD(spu, "0x%x", problem->spu_npc_RW); DUMP_VALUE("0x%x", problem->spu_status_R,
in_be32(&spu->problem->spu_status_R));
DUMP_VALUE("0x%x", problem->spu_npc_RW,
in_be32(&spu->problem->spu_npc_RW));
DUMP_FIELD(spu, "0x%p", priv1); DUMP_FIELD(spu, "0x%p", priv1);
if (spu->priv1) if (spu->priv1) {
DUMP_FIELD(spu, "0x%lx", priv1->mfc_sr1_RW); DUMP_VALUE("0x%lx", priv1->mfc_sr1_RW,
in_be64(&spu->priv1->mfc_sr1_RW));
}
DUMP_FIELD(spu, "0x%p", priv2); DUMP_FIELD(spu, "0x%p", priv2);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册