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

* Re: [PATCH] sim: Fix -Wincompatible-pointer-types in frv/sem.c
  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
  0 siblings, 1 reply; 4+ messages in thread
From: Mike Frysinger @ 2024-01-22  3:45 UTC (permalink / raw)
  To: Mark Wielaard; +Cc: gdb-patches

[-- Attachment #1: Type: text/plain, Size: 1949 bytes --]

On 22 Jan 2024 00:06, Mark Wielaard wrote:
> 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 +-

unfortunately this doesn't work as cpu.[ch] is generated.

https://sourceware.org/pipermail/gdb-patches/2023-December/205492.html
https://sourceware.org/PR29752
-mike

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

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

* Re: [PATCH] sim: Fix -Wincompatible-pointer-types in frv/sem.c
  2024-01-22  3:45 ` Mike Frysinger
@ 2024-01-22 11:30   ` Mark Wielaard
  2024-01-22 13:15     ` Mike Frysinger
  0 siblings, 1 reply; 4+ messages in thread
From: Mark Wielaard @ 2024-01-22 11:30 UTC (permalink / raw)
  To: Mike Frysinger; +Cc: gdb-patches

Hi Mike,

On Sun, 2024-01-21 at 22:45 -0500, Mike Frysinger wrote:
> On 22 Jan 2024 00:06, Mark Wielaard wrote:
> > 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 +-
> 
> unfortunately this doesn't work as cpu.[ch] is generated.
> 
> https://sourceware.org/pipermail/gdb-patches/2023-December/205492.html
> https://sourceware.org/PR29752

O, that is unfortunate. I admit to not know how to actually regenerate
these files. Also it seems PR29752 does include a solution. What kind
of testing would you like to see to make sure it is correct?

Thanks,

Mark

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

* Re: [PATCH] sim: Fix -Wincompatible-pointer-types in frv/sem.c
  2024-01-22 11:30   ` Mark Wielaard
@ 2024-01-22 13:15     ` Mike Frysinger
  0 siblings, 0 replies; 4+ messages in thread
From: Mike Frysinger @ 2024-01-22 13:15 UTC (permalink / raw)
  To: Mark Wielaard; +Cc: gdb-patches

[-- Attachment #1: Type: text/plain, Size: 1120 bytes --]

On 22 Jan 2024 12:30, Mark Wielaard wrote:
> On Sun, 2024-01-21 at 22:45 -0500, Mike Frysinger wrote:
> > On 22 Jan 2024 00:06, Mark Wielaard wrote:
> > > 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 +-
> > 
> > unfortunately this doesn't work as cpu.[ch] is generated.
> > 
> > https://sourceware.org/pipermail/gdb-patches/2023-December/205492.html
> > https://sourceware.org/PR29752
> 
> O, that is unfortunate. I admit to not know how to actually regenerate
> these files.

`make frv/cgen` would do it for frv

> Also it seems PR29752 does include a solution. What kind
> of testing would you like to see to make sure it is correct?

i don't understand frv internals/whatever well enough to know if my proposal
is reasonable.  although if we don't get a response, i guess there isn't much
choice as things fail to build with newer compilers.
-mike

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

^ 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