diff options
Diffstat (limited to 'gnuradio-core/src/lib')
-rw-r--r-- | gnuradio-core/src/lib/runtime/gr_vmcircbuf_createfilemapping.cc | 111 |
1 files changed, 63 insertions, 48 deletions
diff --git a/gnuradio-core/src/lib/runtime/gr_vmcircbuf_createfilemapping.cc b/gnuradio-core/src/lib/runtime/gr_vmcircbuf_createfilemapping.cc index 8f3540b4b..ffad5ac7d 100644 --- a/gnuradio-core/src/lib/runtime/gr_vmcircbuf_createfilemapping.cc +++ b/gnuradio-core/src/lib/runtime/gr_vmcircbuf_createfilemapping.cc @@ -39,6 +39,25 @@ #include <gr_tmp_path.h> #include <gr_vmcircbuf_createfilemapping.h> +#ifdef HAVE_CREATEFILEMAPPING +// Print Windows error (could/should be global?) +static void +werror( char *where, DWORD last_error ) +{ + char buf[1024]; + + FormatMessage( FORMAT_MESSAGE_FROM_SYSTEM, + NULL, + last_error, + 0, // default language + buf, + sizeof(buf)/sizeof(TCHAR), // buffer size + NULL ); + fprintf( stderr, "%s: Error %d: %s", where, last_error, buf ); + return; +} +#endif + gr_vmcircbuf_createfilemapping::gr_vmcircbuf_createfilemapping (int size) : gr_vmcircbuf (size) @@ -67,63 +86,59 @@ gr_vmcircbuf_createfilemapping::gr_vmcircbuf_createfilemapping (int size) s_seg_counter++; if (d_handle == NULL || d_handle == INVALID_HANDLE_VALUE){ char msg[1024]; - snprintf (msg, sizeof (msg), "gr_vmcircbuf_mmap_createfilemapping: CreateFileMapping [%s] :%d", seg_name,(int)GetLastError()); - perror (msg); + snprintf( msg, sizeof(msg), + "gr_vmcircbuf_mmap_createfilemapping: CreateFileMapping [%s]", + seg_name ); + werror( msg, GetLastError() ); throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); } - int i = 0; - d_first_copy = d_second_copy = NULL; - - while (i++ < 8 && d_second_copy == NULL){ - // keep the first map allocation to force allocation in a new address - // space - LPVOID first_tmp = d_first_copy; - - d_first_copy = MapViewOfFile((HANDLE)d_handle, // handle to map object - FILE_MAP_WRITE, // read/write permission - 0, - 0, - size); - - if (d_first_copy == NULL){ - if (first_tmp) - UnmapViewOfFile(first_tmp); - - CloseHandle(d_handle); // cleanup - char msg[1024]; - snprintf (msg, sizeof (msg), - "gr_vmcircbuf_mmap_createfilemapping: MapViewOfFile (1) :%d", (int)GetLastError()); - perror (msg); - throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); - } - - // NOTE: d_second_copy will be NULL if MapViewFileEx() fails to allocate the - // requested address space - d_second_copy = MapViewOfFileEx((HANDLE)d_handle, // handle to map object - FILE_MAP_WRITE, // read/write permission - 0, - 0, - size, - (char *)d_first_copy + size);//(LPVOID) ((char *)d_first_copy + size)); - - if (first_tmp) - UnmapViewOfFile(first_tmp); + // Allocate virtual memory of the needed size, then free it so we can use it + LPVOID first_tmp; + first_tmp = VirtualAlloc( NULL, 2*size, MEM_RESERVE, PAGE_NOACCESS ); + if (first_tmp == NULL){ + werror( "gr_vmcircbuf_mmap_createfilemapping: VirtualAlloc", GetLastError()); + CloseHandle(d_handle); // cleanup + throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); + } -#ifdef DEBUG - fprintf (stderr,"gr_vmcircbuf_mmap_createfilemapping: contiguous? mmap %p %p %p %p, %d\n", - (char *)d_first_copy, (char *)d_second_copy, size, (char *)d_first_copy + size,i); -#endif + if (VirtualFree(first_tmp, 0, MEM_RELEASE) == 0){ + werror( "gr_vmcircbuf_mmap_createfilemapping: VirtualFree", GetLastError()); + CloseHandle(d_handle); // cleanup + throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); + } + + d_first_copy = MapViewOfFileEx((HANDLE)d_handle, // handle to map object + FILE_MAP_WRITE, // read/write permission + 0, + 0, + size, + first_tmp); + if (d_first_copy != first_tmp){ + werror( "gr_vmcircbuf_mmap_createfilemapping: MapViewOfFileEx(1)", GetLastError()); + CloseHandle(d_handle); // cleanup + throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); } - if (d_second_copy == NULL){ // cleanup - fprintf (stderr,"gr_vmcircbuf_mmap_createfilemapping: non contiguous mmap - %p %p %p %p\n", - d_first_copy, d_second_copy, size, (char *)d_first_copy + size); + d_second_copy = MapViewOfFileEx((HANDLE)d_handle, // handle to map object + FILE_MAP_WRITE, // read/write permission + 0, + 0, + size, + (char *)first_tmp + size);//(LPVOID) ((char *)d_first_copy + size)); + + if (d_second_copy != (char *)first_tmp + size){ + werror( "gr_vmcircbuf_mmap_createfilemapping: MapViewOfFileEx(2)", GetLastError()); UnmapViewOfFile(d_first_copy); CloseHandle(d_handle); // cleanup throw std::runtime_error ("gr_vmcircbuf_mmap_createfilemapping"); } +#ifdef DEBUG + fprintf (stderr,"gr_vmcircbuf_mmap_createfilemapping: contiguous? mmap %p %p %p %p\n", + (char *)d_first_copy, (char *)d_second_copy, size, (char *)d_first_copy + size); +#endif + // Now remember the important stuff d_base = (char *) d_first_copy; d_size = size; @@ -135,12 +150,12 @@ gr_vmcircbuf_createfilemapping::~gr_vmcircbuf_createfilemapping () #ifdef HAVE_CREATEFILEMAPPING if (UnmapViewOfFile(d_first_copy) == 0) { - perror ("gr_vmcircbuf_createfilemapping: UnmapViewOfFile(d_first_copy)"); + werror("gr_vmcircbuf_createfilemapping: UnmapViewOfFile(d_first_copy)", GetLastError()); } d_base=NULL; if (UnmapViewOfFile(d_second_copy) == 0) { - perror ("gr_vmcircbuf_createfilemapping: UnmapViewOfFile(d_second_copy)"); + werror("gr_vmcircbuf_createfilemapping: UnmapViewOfFile(d_second_copy)", GetLastError()); } //d_second=NULL; CloseHandle(d_handle); |