From 186a0e42de9b19d267e2b5bb1f1ff108e2d9ae36 Mon Sep 17 00:00:00 2001 From: Corinna Vinschen <corinna@vinschen.de> Date: Fri, 26 Sep 2003 08:50:12 +0000 Subject: [PATCH] * mmap.cc (munmap): Use correct address and length parameters when calling fhandler's munmap. --- winsup/cygwin/ChangeLog | 5 +++++ winsup/cygwin/mmap.cc | 9 ++++++--- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index b0c3d7540..4bca458c2 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,8 @@ +2003-09-26 Corinna Vinschen <corinna@vinschen.de> + + * mmap.cc (munmap): Use correct address and length parameters when + calling fhandler's munmap. + 2003-09-26 Corinna Vinschen <corinna@vinschen.de> * spawn.cc (spawn_guts): Set errno to E2BIG if command line is diff --git a/winsup/cygwin/mmap.cc b/winsup/cygwin/mmap.cc index 5ed774273..79014310e 100644 --- a/winsup/cygwin/mmap.cc +++ b/winsup/cygwin/mmap.cc @@ -679,12 +679,15 @@ munmap (void *addr, size_t len) mmap_record *rec = map_list->get_record (record_idx); if (rec->unmap_pages (u_addr, u_len)) { - /* The whole record has been unmapped, so... */ + /* The whole record has been unmapped, so we now actually + unmap it from the system in full length... */ fhandler_base *fh = rec->alloc_fh (); - fh->munmap (rec->get_handle (), (caddr_t)addr, len); + fh->munmap (rec->get_handle (), + rec->get_address (), + rec->get_size ()); rec->free_fh (fh); - /* ...delete the record. */ + /* ...and delete the record. */ if (map_list->del_record (record_idx--)) { /* Yay, the last record has been removed from the list,