From: Mike Frysinger Date: Mon, 21 Jun 2021 03:42:20 +0000 (-0400) Subject: sim: cris: override getpid callback X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e91488f739f0dbb93bfd9d96164c25d9674846c4;p=binutils-gdb.git sim: cris: override getpid callback The cris linux syscall layers assume getpid returns a constant, so add a custom function to provide that. --- diff --git a/sim/cris/ChangeLog b/sim/cris/ChangeLog index 78b106535ba..1f4bd8bb3c3 100644 --- a/sim/cris/ChangeLog +++ b/sim/cris/ChangeLog @@ -1,3 +1,8 @@ +2021-06-23 Mike Frysinger + + * traps.c (cris_getpid): New function. + (cris_set_callbacks): Assign cris_getpid. + 2021-06-22 Mike Frysinger * sim-if.c: Include sim-hw.h. diff --git a/sim/cris/traps.c b/sim/cris/traps.c index f92bb7cdebe..fd7f9bc7ae2 100644 --- a/sim/cris/traps.c +++ b/sim/cris/traps.c @@ -3336,6 +3336,12 @@ cris_time (host_callback *cb ATTRIBUTE_UNUSED) return TARGET_TIME (current_cpu_for_cb_callback); } +static int +cris_getpid (host_callback *cb ATTRIBUTE_UNUSED) +{ + return TARGET_PID; +} + /* Set target-specific callback data. */ void @@ -3345,6 +3351,8 @@ cris_set_callbacks (host_callback *cb) cb->syscall_map = (CB_TARGET_DEFS_MAP *) syscall_map; cb->errno_map = (CB_TARGET_DEFS_MAP *) errno_map; + cb->getpid = cris_getpid; + /* The kernel stat64 layout. If we see a file > 2G, the "long" parameter to cb_store_target_endian will make st_size negative. Similarly for st_ino. FIXME: Find a 64-bit type, and use it