Bug 592194 - Fix missing _SC_PAGE_SIZE macro

Autoconfiscate a simple call to mprotect() even more.
This commit is contained in:
Behdad Esfahbod 2009-08-18 15:49:23 -04:00
parent 3c69bd46e2
commit 4ff2a58952
1 changed files with 63 additions and 37 deletions

View File

@ -234,30 +234,27 @@ hb_blob_is_writeable (hb_blob_t *blob)
return mode == HB_MEMORY_MODE_WRITEABLE; return mode == HB_MEMORY_MODE_WRITEABLE;
} }
hb_bool_t
hb_blob_try_writeable_inplace (hb_blob_t *blob) static hb_bool_t
_try_make_writeable_inplace_unix_locked (hb_blob_t *blob)
{ {
hb_memory_mode_t mode; #if defined(HAVE_SYS_MMAN_H) && defined(HAVE_MPROTECT)
unsigned int pagesize = -1, mask, length;
if (HB_OBJECT_IS_INERT (blob))
return FALSE;
hb_mutex_lock (blob->lock);
#ifdef HAVE_SYS_MMAN_H
if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITEABLE) {
unsigned int pagesize, mask, length;
const char *addr; const char *addr;
#if HB_DEBUG #if defined(HAVE_SYSCONF) && defined(_SC_PAGE_SIZE)
fprintf (stderr, "%p %s: making writeable\n", blob, __FUNCTION__); pagesize = (unsigned int) sysconf (_SC_PAGE_SIZE);
#elif defined(HAVE_SYSCONF) && defined(_SC_PAGESIZE)
pagesize = (unsigned int) sysconf (_SC_PAGESIZE);
#elif defined(HAVE_GETPAGESIZE)
pagesize = (unsigned int) getpagesize ();
#endif #endif
pagesize = (unsigned int) sysconf(_SC_PAGE_SIZE);
if ((unsigned int) -1 == pagesize) { if ((unsigned int) -1 == pagesize) {
#if HB_DEBUG #if HB_DEBUG
fprintf (stderr, "%p %s: %s\n", blob, __FUNCTION__, strerror (errno)); fprintf (stderr, "%p %s: failed to get pagesize: %s\n", blob, __FUNCTION__, strerror (errno));
#endif #endif
goto done; return FALSE;
} }
#if HB_DEBUG #if HB_DEBUG
fprintf (stderr, "%p %s: pagesize is %u\n", blob, __FUNCTION__, pagesize); fprintf (stderr, "%p %s: pagesize is %u\n", blob, __FUNCTION__, pagesize);
@ -275,22 +272,51 @@ hb_blob_try_writeable_inplace (hb_blob_t *blob)
#if HB_DEBUG #if HB_DEBUG
fprintf (stderr, "%p %s: %s\n", blob, __FUNCTION__, strerror (errno)); fprintf (stderr, "%p %s: %s\n", blob, __FUNCTION__, strerror (errno));
#endif #endif
goto done; return FALSE;
} }
blob->mode = HB_MEMORY_MODE_WRITEABLE;
#if HB_DEBUG #if HB_DEBUG
fprintf (stderr, "%p %s: successfully made [%p..%p] (%d bytes) writeable\n", fprintf (stderr, "%p %s: successfully made [%p..%p] (%d bytes) writeable\n",
blob, __FUNCTION__, blob, __FUNCTION__,
addr, addr+length, length); addr, addr+length, length);
#endif #endif
} return TRUE;
#else /* !HAVE_SYS_MMAN_H */ #else
#warning "No way to make readonly memory writeable. This is suboptimal." return FALSE;
#endif
}
hb_bool_t
hb_blob_try_writeable_inplace (hb_blob_t *blob)
{
hb_memory_mode_t mode;
if (HB_OBJECT_IS_INERT (blob))
return FALSE;
hb_mutex_lock (blob->lock);
if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITEABLE) {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writeable\n", blob, __FUNCTION__);
#endif #endif
done: if (_try_make_writeable_inplace_unix_locked (blob)) {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writeable -> succeeded\n", blob, __FUNCTION__);
#endif
blob->mode = HB_MEMORY_MODE_WRITEABLE;
} else {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writeable -> FAILED\n", blob, __FUNCTION__);
#endif
/* Failed to make writeable inplace, mark that */
blob->mode = HB_MEMORY_MODE_READONLY;
}
}
mode = blob->mode; mode = blob->mode;
hb_mutex_unlock (blob->lock); hb_mutex_unlock (blob->lock);