提交 d297f464 编写于 作者: E edgar_igl

Avoid CRIS related warnings by Jan Kiszka.

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4804 c046a42c-6fe2-441c-8c8c-71466251a162
上级 a50f5b91
...@@ -214,6 +214,7 @@ static inline int fs_channel(target_phys_addr_t base, target_phys_addr_t addr) ...@@ -214,6 +214,7 @@ static inline int fs_channel(target_phys_addr_t base, target_phys_addr_t addr)
return (addr - base) >> 13; return (addr - base) >> 13;
} }
#ifdef USE_THIS_DEAD_CODE
static void channel_load_g(struct fs_dma_ctrl *ctrl, int c) static void channel_load_g(struct fs_dma_ctrl *ctrl, int c)
{ {
target_phys_addr_t addr = channel_reg(ctrl, c, RW_GROUP); target_phys_addr_t addr = channel_reg(ctrl, c, RW_GROUP);
...@@ -227,23 +228,24 @@ static void channel_load_g(struct fs_dma_ctrl *ctrl, int c) ...@@ -227,23 +228,24 @@ static void channel_load_g(struct fs_dma_ctrl *ctrl, int c)
static void dump_c(int ch, struct dma_descr_context *c) static void dump_c(int ch, struct dma_descr_context *c)
{ {
printf("%s ch=%d\n", __func__, ch); printf("%s ch=%d\n", __func__, ch);
printf("next=%x\n", (uint32_t) c->next); printf("next=%p\n", c->next);
printf("saved_data=%x\n", (uint32_t) c->saved_data); printf("saved_data=%p\n", c->saved_data);
printf("saved_data_buf=%x\n", (uint32_t) c->saved_data_buf); printf("saved_data_buf=%p\n", c->saved_data_buf);
printf("eol=%x\n", (uint32_t) c->eol); printf("eol=%x\n", (uint32_t) c->eol);
} }
static void dump_d(int ch, struct dma_descr_data *d) static void dump_d(int ch, struct dma_descr_data *d)
{ {
printf("%s ch=%d\n", __func__, ch); printf("%s ch=%d\n", __func__, ch);
printf("next=%x\n", (uint32_t) d->next); printf("next=%p\n", d->next);
printf("buf=%x\n", (uint32_t) d->buf); printf("buf=%p\n", d->buf);
printf("after=%x\n", (uint32_t) d->after); printf("after=%p\n", d->after);
printf("intr=%x\n", (uint32_t) d->intr); printf("intr=%x\n", (uint32_t) d->intr);
printf("out_eop=%x\n", (uint32_t) d->out_eop); printf("out_eop=%x\n", (uint32_t) d->out_eop);
printf("in_eop=%x\n", (uint32_t) d->in_eop); printf("in_eop=%x\n", (uint32_t) d->in_eop);
printf("eol=%x\n", (uint32_t) d->eol); printf("eol=%x\n", (uint32_t) d->eol);
} }
#endif
static void channel_load_c(struct fs_dma_ctrl *ctrl, int c) static void channel_load_c(struct fs_dma_ctrl *ctrl, int c)
{ {
...@@ -256,10 +258,10 @@ static void channel_load_c(struct fs_dma_ctrl *ctrl, int c) ...@@ -256,10 +258,10 @@ static void channel_load_c(struct fs_dma_ctrl *ctrl, int c)
D(dump_c(c, &ctrl->channels[c].current_c)); D(dump_c(c, &ctrl->channels[c].current_c));
/* I guess this should update the current pos. */ /* I guess this should update the current pos. */
ctrl->channels[c].regs[RW_SAVED_DATA] = ctrl->channels[c].regs[RW_SAVED_DATA] =
(uint32_t)ctrl->channels[c].current_c.saved_data; (uint32_t)(unsigned long)ctrl->channels[c].current_c.saved_data;
ctrl->channels[c].regs[RW_SAVED_DATA_BUF] = ctrl->channels[c].regs[RW_SAVED_DATA_BUF] =
(uint32_t)ctrl->channels[c].current_c.saved_data_buf; (uint32_t)(unsigned long)ctrl->channels[c].current_c.saved_data_buf;
} }
static void channel_load_d(struct fs_dma_ctrl *ctrl, int c) static void channel_load_d(struct fs_dma_ctrl *ctrl, int c)
...@@ -339,12 +341,12 @@ static void channel_continue(struct fs_dma_ctrl *ctrl, int c) ...@@ -339,12 +341,12 @@ static void channel_continue(struct fs_dma_ctrl *ctrl, int c)
D(printf("continue %d ok %p\n", c, D(printf("continue %d ok %p\n", c,
ctrl->channels[c].current_d.next)); ctrl->channels[c].current_d.next));
ctrl->channels[c].regs[RW_SAVED_DATA] = ctrl->channels[c].regs[RW_SAVED_DATA] =
(uint32_t) ctrl->channels[c].current_d.next; (uint32_t)(unsigned long)ctrl->channels[c].current_d.next;
channel_load_d(ctrl, c); channel_load_d(ctrl, c);
channel_start(ctrl, c); channel_start(ctrl, c);
} }
ctrl->channels[c].regs[RW_SAVED_DATA_BUF] = ctrl->channels[c].regs[RW_SAVED_DATA_BUF] =
(uint32_t) ctrl->channels[c].current_d.buf; (uint32_t)(unsigned long)ctrl->channels[c].current_d.buf;
} }
static void channel_stream_cmd(struct fs_dma_ctrl *ctrl, int c, uint32_t v) static void channel_stream_cmd(struct fs_dma_ctrl *ctrl, int c, uint32_t v)
...@@ -402,7 +404,7 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c) ...@@ -402,7 +404,7 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c)
(uint32_t)ctrl->channels[c].current_d.after, (uint32_t)ctrl->channels[c].current_d.after,
saved_data_buf)); saved_data_buf));
len = (uint32_t) ctrl->channels[c].current_d.after; len = (uint32_t)(unsigned long) ctrl->channels[c].current_d.after;
len -= saved_data_buf; len -= saved_data_buf;
if (len > sizeof buf) if (len > sizeof buf)
...@@ -420,7 +422,8 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c) ...@@ -420,7 +422,8 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c)
saved_data_buf += len; saved_data_buf += len;
if (saved_data_buf == (uint32_t)ctrl->channels[c].current_d.after) { if (saved_data_buf ==
(uint32_t)(unsigned long)ctrl->channels[c].current_d.after) {
/* Done. Step to next. */ /* Done. Step to next. */
if (ctrl->channels[c].current_d.out_eop) { if (ctrl->channels[c].current_d.out_eop) {
/* TODO: signal eop to the client. */ /* TODO: signal eop to the client. */
...@@ -444,10 +447,10 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c) ...@@ -444,10 +447,10 @@ static void channel_out_run(struct fs_dma_ctrl *ctrl, int c)
channel_stop(ctrl, c); channel_stop(ctrl, c);
} else { } else {
ctrl->channels[c].regs[RW_SAVED_DATA] = ctrl->channels[c].regs[RW_SAVED_DATA] =
(uint32_t) ctrl->channels[c].current_d.next; (uint32_t)(unsigned long) ctrl->channels[c].current_d.next;
/* Load new descriptor. */ /* Load new descriptor. */
channel_load_d(ctrl, c); channel_load_d(ctrl, c);
saved_data_buf = (uint32_t) saved_data_buf = (uint32_t)(unsigned long)
ctrl->channels[c].current_d.buf; ctrl->channels[c].current_d.buf;
} }
...@@ -468,7 +471,7 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c, ...@@ -468,7 +471,7 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c,
return 0; return 0;
saved_data_buf = channel_reg(ctrl, c, RW_SAVED_DATA_BUF); saved_data_buf = channel_reg(ctrl, c, RW_SAVED_DATA_BUF);
len = (uint32_t) ctrl->channels[c].current_d.after; len = (uint32_t)(unsigned long) ctrl->channels[c].current_d.after;
len -= saved_data_buf; len -= saved_data_buf;
if (len > buflen) if (len > buflen)
...@@ -477,7 +480,8 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c, ...@@ -477,7 +480,8 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c,
cpu_physical_memory_write (saved_data_buf, buf, len); cpu_physical_memory_write (saved_data_buf, buf, len);
saved_data_buf += len; saved_data_buf += len;
if (saved_data_buf == (uint32_t)ctrl->channels[c].current_d.after if (saved_data_buf ==
(uint32_t)(unsigned long)ctrl->channels[c].current_d.after
|| eop) { || eop) {
uint32_t r_intr = ctrl->channels[c].regs[R_INTR]; uint32_t r_intr = ctrl->channels[c].regs[R_INTR];
...@@ -485,7 +489,7 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c, ...@@ -485,7 +489,7 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c,
ctrl->channels[c].current_d.after ctrl->channels[c].current_d.after
- ctrl->channels[c].current_d.buf)); - ctrl->channels[c].current_d.buf));
ctrl->channels[c].current_d.after = ctrl->channels[c].current_d.after =
(void *) saved_data_buf; (void *)(unsigned long) saved_data_buf;
/* Done. Step to next. */ /* Done. Step to next. */
if (ctrl->channels[c].current_d.intr) { if (ctrl->channels[c].current_d.intr) {
...@@ -514,10 +518,10 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c, ...@@ -514,10 +518,10 @@ static int channel_in_process(struct fs_dma_ctrl *ctrl, int c,
channel_stop(ctrl, c); channel_stop(ctrl, c);
} else { } else {
ctrl->channels[c].regs[RW_SAVED_DATA] = ctrl->channels[c].regs[RW_SAVED_DATA] =
(uint32_t) ctrl->channels[c].current_d.next; (uint32_t)(unsigned long) ctrl->channels[c].current_d.next;
/* Load new descriptor. */ /* Load new descriptor. */
channel_load_d(ctrl, c); channel_load_d(ctrl, c);
saved_data_buf = (uint32_t) saved_data_buf = (uint32_t)(unsigned long)
ctrl->channels[c].current_d.buf; ctrl->channels[c].current_d.buf;
} }
} }
...@@ -537,8 +541,8 @@ static uint32_t dma_rinvalid (void *opaque, target_phys_addr_t addr) ...@@ -537,8 +541,8 @@ static uint32_t dma_rinvalid (void *opaque, target_phys_addr_t addr)
{ {
struct fs_dma_ctrl *ctrl = opaque; struct fs_dma_ctrl *ctrl = opaque;
CPUState *env = ctrl->env; CPUState *env = ctrl->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
return 0; return 0;
} }
...@@ -574,8 +578,8 @@ dma_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value) ...@@ -574,8 +578,8 @@ dma_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value)
{ {
struct fs_dma_ctrl *ctrl = opaque; struct fs_dma_ctrl *ctrl = opaque;
CPUState *env = ctrl->env; CPUState *env = ctrl->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
} }
static void static void
......
...@@ -154,11 +154,13 @@ mdio_attach(struct qemu_mdio *bus, struct qemu_phy *phy, unsigned int addr) ...@@ -154,11 +154,13 @@ mdio_attach(struct qemu_mdio *bus, struct qemu_phy *phy, unsigned int addr)
bus->devs[addr & 0x1f] = phy; bus->devs[addr & 0x1f] = phy;
} }
#ifdef USE_THIS_DEAD_CODE
static void static void
mdio_detach(struct qemu_mdio *bus, struct qemu_phy *phy, unsigned int addr) mdio_detach(struct qemu_mdio *bus, struct qemu_phy *phy, unsigned int addr)
{ {
bus->devs[addr & 0x1f] = NULL; bus->devs[addr & 0x1f] = NULL;
} }
#endif
static void mdio_read_req(struct qemu_mdio *bus) static void mdio_read_req(struct qemu_mdio *bus)
{ {
...@@ -328,8 +330,8 @@ static uint32_t eth_rinvalid (void *opaque, target_phys_addr_t addr) ...@@ -328,8 +330,8 @@ static uint32_t eth_rinvalid (void *opaque, target_phys_addr_t addr)
{ {
struct fs_eth *eth = opaque; struct fs_eth *eth = opaque;
CPUState *env = eth->env; CPUState *env = eth->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
return 0; return 0;
} }
...@@ -359,8 +361,8 @@ eth_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value) ...@@ -359,8 +361,8 @@ eth_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value)
{ {
struct fs_eth *eth = opaque; struct fs_eth *eth = opaque;
CPUState *env = eth->env; CPUState *env = eth->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
} }
static void eth_update_ma(struct fs_eth *eth, int ma) static void eth_update_ma(struct fs_eth *eth, int ma)
......
...@@ -80,8 +80,8 @@ static uint32_t timer_rinvalid (void *opaque, target_phys_addr_t addr) ...@@ -80,8 +80,8 @@ static uint32_t timer_rinvalid (void *opaque, target_phys_addr_t addr)
{ {
struct fs_timer_t *t = opaque; struct fs_timer_t *t = opaque;
CPUState *env = t->env; CPUState *env = t->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
return 0; return 0;
} }
...@@ -120,8 +120,8 @@ timer_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value) ...@@ -120,8 +120,8 @@ timer_winvalid (void *opaque, target_phys_addr_t addr, uint32_t value)
{ {
struct fs_timer_t *t = opaque; struct fs_timer_t *t = opaque;
CPUState *env = t->env; CPUState *env = t->env;
cpu_abort(env, "Unsupported short access. reg=%x pc=%x.\n", cpu_abort(env, "Unsupported short access. reg=" TARGET_FMT_plx
addr, env->pc); " pc=%x.\n", addr, env->pc);
} }
#define TIMER_SLOWDOWN 1 #define TIMER_SLOWDOWN 1
...@@ -309,7 +309,7 @@ timer_writel (void *opaque, target_phys_addr_t addr, uint32_t value) ...@@ -309,7 +309,7 @@ timer_writel (void *opaque, target_phys_addr_t addr, uint32_t value)
t->rw_ack_intr = 0; t->rw_ack_intr = 0;
break; break;
default: default:
printf ("%s %x %x pc=%x\n", printf ("%s " TARGET_FMT_plx " %x pc=%x\n",
__func__, addr, value, env->pc); __func__, addr, value, env->pc);
break; break;
} }
......
...@@ -30,7 +30,11 @@ ...@@ -30,7 +30,11 @@
#include "mmu.h" #include "mmu.h"
#include "exec-all.h" #include "exec-all.h"
#ifdef DEBUG
#define D(x) x
#else
#define D(x) #define D(x)
#endif
void cris_mmu_init(CPUState *env) void cris_mmu_init(CPUState *env)
{ {
...@@ -95,6 +99,7 @@ static inline void set_field(uint32_t *dst, unsigned int val, ...@@ -95,6 +99,7 @@ static inline void set_field(uint32_t *dst, unsigned int val,
*dst |= val; *dst |= val;
} }
#ifdef DEBUG
static void dump_tlb(CPUState *env, int mmu) static void dump_tlb(CPUState *env, int mmu)
{ {
int set; int set;
...@@ -113,6 +118,7 @@ static void dump_tlb(CPUState *env, int mmu) ...@@ -113,6 +118,7 @@ static void dump_tlb(CPUState *env, int mmu)
} }
} }
} }
#endif
/* rw 0 = read, 1 = write, 2 = exec. */ /* rw 0 = read, 1 = write, 2 = exec. */
static int cris_mmu_translate_page(struct cris_mmu_result_t *res, static int cris_mmu_translate_page(struct cris_mmu_result_t *res,
......
...@@ -3075,14 +3075,15 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb, ...@@ -3075,14 +3075,15 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb,
if (loglevel & CPU_LOG_TB_IN_ASM) { if (loglevel & CPU_LOG_TB_IN_ASM) {
fprintf(logfile, fprintf(logfile,
"srch=%d pc=%x %x flg=%llx bt=%x ds=%lld ccs=%x\n" "srch=%d pc=%x %x flg=%llx bt=%x ds=%u ccs=%x\n"
"pid=%x usp=%x\n" "pid=%x usp=%x\n"
"%x.%x.%x.%x\n" "%x.%x.%x.%x\n"
"%x.%x.%x.%x\n" "%x.%x.%x.%x\n"
"%x.%x.%x.%x\n" "%x.%x.%x.%x\n"
"%x.%x.%x.%x\n", "%x.%x.%x.%x\n",
search_pc, dc->pc, dc->ppc, tb->flags, search_pc, dc->pc, dc->ppc,
env->btarget, tb->flags & 7, (unsigned long long)tb->flags,
env->btarget, (unsigned)tb->flags & 7,
env->pregs[PR_CCS], env->pregs[PR_CCS],
env->pregs[PR_PID], env->pregs[PR_USP], env->pregs[PR_PID], env->pregs[PR_USP],
env->regs[0], env->regs[1], env->regs[2], env->regs[3], env->regs[0], env->regs[1], env->regs[2], env->regs[3],
...@@ -3228,7 +3229,7 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb, ...@@ -3228,7 +3229,7 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb,
fprintf(logfile, "--------------\n"); fprintf(logfile, "--------------\n");
fprintf(logfile, "IN: %s\n", lookup_symbol(pc_start)); fprintf(logfile, "IN: %s\n", lookup_symbol(pc_start));
target_disas(logfile, pc_start, dc->pc - pc_start, 0); target_disas(logfile, pc_start, dc->pc - pc_start, 0);
fprintf(logfile, "\nisize=%d osize=%d\n", fprintf(logfile, "\nisize=%d osize=%zd\n",
dc->pc - pc_start, gen_opc_ptr - gen_opc_buf); dc->pc - pc_start, gen_opc_ptr - gen_opc_buf);
} }
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册