提交 388ad037 编写于 作者: B Behdad Esfahbod

[HB] Remove HB_MEMORY_MODE_READONLY_NEVER_DUPLICATE

Unlike the rest of the memory-mode enum, this one didn't only
describe the access mode of the input memory region.  Remove it.

If someone wants to inhibit duplicating, they can lock the blob
and throw away the key.

Based on mailing list discussion with Carl Worth.
上级 977eeb71
...@@ -59,7 +59,7 @@ static hb_blob_t _hb_blob_nil = { ...@@ -59,7 +59,7 @@ static hb_blob_t _hb_blob_nil = {
HB_MUTEX_INIT, /* lock */ HB_MUTEX_INIT, /* lock */
0, /* lock_count */ 0, /* lock_count */
HB_MEMORY_MODE_READONLY_NEVER_DUPLICATE, /* mode */ HB_MEMORY_MODE_READONLY, /* mode */
NULL, /* data */ NULL, /* data */
...@@ -286,6 +286,26 @@ _try_make_writable_inplace_unix_locked (hb_blob_t *blob) ...@@ -286,6 +286,26 @@ _try_make_writable_inplace_unix_locked (hb_blob_t *blob)
#endif #endif
} }
static void
_try_writable_inplace_locked (hb_blob_t *blob)
{
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable\n", blob, __FUNCTION__);
#endif
if (_try_make_writable_inplace_unix_locked (blob)) {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable -> succeeded\n", blob, __FUNCTION__);
#endif
blob->mode = HB_MEMORY_MODE_WRITABLE;
} else {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable -> FAILED\n", blob, __FUNCTION__);
#endif
/* Failed to make writable inplace, mark that */
blob->mode = HB_MEMORY_MODE_READONLY;
}
}
hb_bool_t hb_bool_t
hb_blob_try_writable_inplace (hb_blob_t *blob) hb_blob_try_writable_inplace (hb_blob_t *blob)
...@@ -297,25 +317,8 @@ hb_blob_try_writable_inplace (hb_blob_t *blob) ...@@ -297,25 +317,8 @@ hb_blob_try_writable_inplace (hb_blob_t *blob)
hb_mutex_lock (blob->lock); hb_mutex_lock (blob->lock);
if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE) { if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE)
_try_writable_inplace_locked (blob);
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable\n", blob, __FUNCTION__);
#endif
if (_try_make_writable_inplace_unix_locked (blob)) {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable -> succeeded\n", blob, __FUNCTION__);
#endif
blob->mode = HB_MEMORY_MODE_WRITABLE;
} else {
#if HB_DEBUG
fprintf (stderr, "%p %s: making writable -> FAILED\n", blob, __FUNCTION__);
#endif
/* Failed to make writable inplace, mark that */
blob->mode = HB_MEMORY_MODE_READONLY;
}
}
mode = blob->mode; mode = blob->mode;
...@@ -334,9 +337,6 @@ hb_blob_try_writable (hb_blob_t *blob) ...@@ -334,9 +337,6 @@ hb_blob_try_writable (hb_blob_t *blob)
hb_mutex_lock (blob->lock); hb_mutex_lock (blob->lock);
if (blob->mode == HB_MEMORY_MODE_READONLY_NEVER_DUPLICATE)
goto done;
if (blob->mode == HB_MEMORY_MODE_READONLY) if (blob->mode == HB_MEMORY_MODE_READONLY)
{ {
char *new_data; char *new_data;
...@@ -360,14 +360,13 @@ hb_blob_try_writable (hb_blob_t *blob) ...@@ -360,14 +360,13 @@ hb_blob_try_writable (hb_blob_t *blob)
_hb_blob_destroy_user_data (blob); _hb_blob_destroy_user_data (blob);
} }
} }
else if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE)
_try_writable_inplace_locked (blob);
done: done:
mode = blob->mode; mode = blob->mode;
hb_mutex_unlock (blob->lock); hb_mutex_unlock (blob->lock);
if (blob->mode == HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE)
return hb_blob_try_writable_inplace (blob);
return mode == HB_MEMORY_MODE_WRITABLE; return mode == HB_MEMORY_MODE_WRITABLE;
} }
...@@ -35,7 +35,6 @@ typedef enum { ...@@ -35,7 +35,6 @@ typedef enum {
HB_MEMORY_MODE_DUPLICATE, HB_MEMORY_MODE_DUPLICATE,
HB_MEMORY_MODE_READONLY, HB_MEMORY_MODE_READONLY,
HB_MEMORY_MODE_WRITABLE, HB_MEMORY_MODE_WRITABLE,
HB_MEMORY_MODE_READONLY_NEVER_DUPLICATE,
HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE
} hb_memory_mode_t; } hb_memory_mode_t;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册