diff options
author | Hans-Peter Nilsson <hp@axis.com> | 2005-04-18 03:08:46 +0000 |
---|---|---|
committer | Hans-Peter Nilsson <hp@axis.com> | 2005-04-18 03:08:46 +0000 |
commit | 69308976e8c42febe2c7a12953b0f2dd2e47d66f (patch) | |
tree | c6eddef65b0a047ee02b9999606ff48f355b2c81 /sim/cris | |
parent | a3b8c86ce6610e7c6718f86c07ee7363d6a7c523 (diff) | |
download | binutils-gdb-69308976e8c42febe2c7a12953b0f2dd2e47d66f.tar.gz |
* cris/traps.c (cris_break_13_handler) <case TARGET_SYS_mmap2>:
For ((len & 8191) != 0 && fd == (USI) -1), don't say this isn't
implemented. In call to create_map, pad length argument to 8k.
Diffstat (limited to 'sim/cris')
-rw-r--r-- | sim/cris/traps.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/sim/cris/traps.c b/sim/cris/traps.c index eadb744ff36..5b3718d3900 100644 --- a/sim/cris/traps.c +++ b/sim/cris/traps.c @@ -1530,8 +1530,7 @@ cris_break_13_handler (SIM_CPU *current_cpu, USI callnum, USI arg1, && flags != TARGET_MAP_PRIVATE && flags != TARGET_MAP_SHARED) || (fd != (USI) -1 && prot != TARGET_PROT_READ) - || pgoff != 0 - || ((len & 8191) != 0 && fd == (USI) -1)) + || pgoff != 0) { sim_io_eprintf (sd, "Unimplemented mmap2 call " "(0x%lx, 0x%lx, 0x%lx, 0x%lx, 0x%lx, 0x%lx)\n", @@ -1611,7 +1610,8 @@ cris_break_13_handler (SIM_CPU *current_cpu, USI callnum, USI arg1, else { USI newaddr - = create_map (sd, ¤t_cpu->highest_mmapped_page, addr, len); + = create_map (sd, ¤t_cpu->highest_mmapped_page, addr, + (len + 8191) & ~8191); if (newaddr >= (USI) -8191) retval = -cb_host_to_target_errno (cb, -(SI) newaddr); |