Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [PATCH] sim: Fix -Wincompatible-pointer-types in frv/sem.c
@ 2024-01-21 23:06 Mark Wielaard
  2024-01-22  3:45 ` Mike Frysinger
  0 siblings, 1 reply; 4+ messages in thread
From: Mark Wielaard @ 2024-01-21 23:06 UTC (permalink / raw)
  To: gdb-patches; +Cc: Mark Wielaard

GCC errors on -Wincompatible-pointer-types

sim/frv/sem.c: In function ‘frvbf_sem_mmachu’:
sim/frv/sem.c:24345:41: error: passing argument 2 of ‘sim_queue_fn_di_write’ from incompatible pointer type [-Wincompatible-pointer-types]
24345 |     sim_queue_fn_di_write (current_cpu, frvbf_h_acc40U_set, FLD (f_ACC40Uk), opval);
      |                                         ^~~~~~~~~~~~~~~~~~
      |                                         |
      |                                         void (*)(SIM_CPU *, UINT,  UDI) {aka void (*)(struct _sim_cpu *, unsigned int,  long unsigned int)}
In file included from ../../binutils-gdb/sim/common/cgen-cpu.h:25,
                 from ../../binutils-gdb/sim/common/sim-cpu.h:32,
                 from ../../binutils-gdb/sim/common/sim-base.h:90,
                 from ../../binutils-gdb/sim/frv/sim-main.h:41,
                 from ../../binutils-gdb/sim/frv/sem.c:28:
../../binutils-gdb/sim/common/cgen-par.h:195:47: note: expected ‘void (*)(SIM_CPU *, UINT,  DI)’ {aka ‘void (*)(struct _sim_cpu *, unsigned int,  long int)’} but argument is of type ‘void (*)(SIM_CPU *, UINT,  UDI)’ {aka ‘void (*)(struct _sim_cpu *, unsigned int,  long unsigned int)’}
  195 | extern void sim_queue_fn_di_write (SIM_CPU *, void (*)(SIM_CPU *, UINT, DI), UINT, DI);
      |                                               ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The issue is that sim_queue_fn_di_write takes a function with a DI argument
but frvbf_h_acc40U_set takes a UDI. Since there is no sim_queue_fn that
takes a UDI just define frvbf_h_acc40U_set as if it takes a DI.
---
 sim/frv/cpu.c | 2 +-
 sim/frv/cpu.h | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/sim/frv/cpu.c b/sim/frv/cpu.c
index b28bcd72d66..2aaa3f22953 100644
--- a/sim/frv/cpu.c
+++ b/sim/frv/cpu.c
@@ -631,7 +631,7 @@ frvbf_h_acc40U_get (SIM_CPU *current_cpu, UINT regno)
 /* Set a value for h-acc40U.  */
 
 void
-frvbf_h_acc40U_set (SIM_CPU *current_cpu, UINT regno, UDI newval)
+frvbf_h_acc40U_set (SIM_CPU *current_cpu, UINT regno, DI newval)
 {
   SET_H_ACC40U (regno, newval);
 }
diff --git a/sim/frv/cpu.h b/sim/frv/cpu.h
index ab5f2d1b539..a099e975d8e 100644
--- a/sim/frv/cpu.h
+++ b/sim/frv/cpu.h
@@ -352,7 +352,7 @@ void frvbf_h_accg_set (SIM_CPU *, UINT, USI);
 DI frvbf_h_acc40S_get (SIM_CPU *, UINT);
 void frvbf_h_acc40S_set (SIM_CPU *, UINT, DI);
 UDI frvbf_h_acc40U_get (SIM_CPU *, UINT);
-void frvbf_h_acc40U_set (SIM_CPU *, UINT, UDI);
+void frvbf_h_acc40U_set (SIM_CPU *, UINT, DI);
 DI frvbf_h_iacc0_get (SIM_CPU *, UINT);
 void frvbf_h_iacc0_set (SIM_CPU *, UINT, DI);
 UQI frvbf_h_iccr_get (SIM_CPU *, UINT);
-- 
2.39.3


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2024-01-22 13:16 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-01-21 23:06 [PATCH] sim: Fix -Wincompatible-pointer-types in frv/sem.c Mark Wielaard
2024-01-22  3:45 ` Mike Frysinger
2024-01-22 11:30   ` Mark Wielaard
2024-01-22 13:15     ` Mike Frysinger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox