mirror of
https://github.com/harfbuzz/harfbuzz.git
synced 2025-04-04 21:15:06 +00:00
[GPOS] scratchpad varStore cache
This commit is contained in:
parent
18ab0f5522
commit
4677cc9a93
2 changed files with 56 additions and 16 deletions
|
@ -737,7 +737,8 @@ struct hb_ot_apply_context_t :
|
|||
hb_ot_apply_context_t (unsigned int table_index_,
|
||||
hb_font_t *font_,
|
||||
hb_buffer_t *buffer_,
|
||||
hb_blob_t *table_blob_) :
|
||||
hb_blob_t *table_blob_,
|
||||
ItemVariationStore::cache_t *var_store_cache_ = nullptr) :
|
||||
table_index (table_index_),
|
||||
font (font_), face (font->face), buffer (buffer_),
|
||||
sanitizer (table_blob_),
|
||||
|
@ -756,13 +757,7 @@ struct hb_ot_apply_context_t :
|
|||
#endif
|
||||
),
|
||||
var_store (gdef.get_var_store ()),
|
||||
var_store_cache (
|
||||
#ifndef HB_NO_VAR
|
||||
table_index == 1 && font->num_coords ? var_store.create_cache () : nullptr
|
||||
#else
|
||||
nullptr
|
||||
#endif
|
||||
),
|
||||
var_store_cache (var_store_cache_),
|
||||
direction (buffer_->props.direction),
|
||||
has_glyph_classes (gdef.has_glyph_classes ())
|
||||
{
|
||||
|
@ -770,13 +765,6 @@ struct hb_ot_apply_context_t :
|
|||
buffer->collect_codepoints (digest);
|
||||
}
|
||||
|
||||
~hb_ot_apply_context_t ()
|
||||
{
|
||||
#ifndef HB_NO_VAR
|
||||
ItemVariationStore::destroy_cache (var_store_cache);
|
||||
#endif
|
||||
}
|
||||
|
||||
void init_iters ()
|
||||
{
|
||||
iter_input.init (this, false);
|
||||
|
@ -4946,9 +4934,54 @@ struct GSUBGPOS
|
|||
return accel;
|
||||
}
|
||||
|
||||
void check_serial (hb_font_t *font) const
|
||||
{
|
||||
int font_serial = font->serial_coords.get_acquire ();
|
||||
if (likely (font_serial == coords_serial.get_acquire ()))
|
||||
return;
|
||||
|
||||
retry:
|
||||
ItemVariationStore::cache_t *cache = var_store_cache.get_acquire ();
|
||||
if (cache)
|
||||
{
|
||||
if (var_store_cache.cmpexch (cache, nullptr))
|
||||
ItemVariationStore::destroy_cache (cache);
|
||||
else
|
||||
goto retry;
|
||||
}
|
||||
|
||||
coords_serial.set_release (font_serial);
|
||||
}
|
||||
ItemVariationStore::cache_t *acquire_var_store_cache (hb_font_t *font) const
|
||||
{
|
||||
const OT::ItemVariationStore &var_store = font->face->table.GDEF->table->get_var_store ();
|
||||
|
||||
check_serial (font);
|
||||
|
||||
retry:
|
||||
ItemVariationStore::cache_t *cache = var_store_cache.get_acquire ();
|
||||
if (unlikely (!cache))
|
||||
return var_store.create_cache ();
|
||||
|
||||
if (var_store_cache.cmpexch (cache, nullptr))
|
||||
return cache;
|
||||
else
|
||||
goto retry;
|
||||
}
|
||||
void release_var_store_cache (ItemVariationStore::cache_t *cache) const
|
||||
{
|
||||
if (!cache) return;
|
||||
if (var_store_cache.cmpexch (nullptr, cache))
|
||||
return;
|
||||
ItemVariationStore::destroy_cache (cache);
|
||||
}
|
||||
|
||||
hb_blob_ptr_t<T> table;
|
||||
unsigned int lookup_count;
|
||||
hb_atomic_t<hb_ot_layout_lookup_accelerator_t *> *accels;
|
||||
|
||||
mutable hb_atomic_t<int> coords_serial;
|
||||
mutable hb_atomic_t<ItemVariationStore::cache_t *> var_store_cache;
|
||||
};
|
||||
|
||||
protected:
|
||||
|
|
|
@ -2015,7 +2015,12 @@ inline void hb_ot_map_t::apply (const Proxy &proxy,
|
|||
{
|
||||
const unsigned int table_index = proxy.table_index;
|
||||
unsigned int i = 0;
|
||||
OT::hb_ot_apply_context_t c (table_index, font, buffer, proxy.accel.get_blob ());
|
||||
|
||||
OT::ItemVariationStore::cache_t *var_store_cache = nullptr;
|
||||
if (proxy.table_index == 1 && font->num_coords)
|
||||
var_store_cache = proxy.accel.acquire_var_store_cache (font);
|
||||
|
||||
OT::hb_ot_apply_context_t c (table_index, font, buffer, proxy.accel.get_blob (), var_store_cache);
|
||||
c.set_recurse_func (Proxy::Lookup::template dispatch_recurse_func<OT::hb_ot_apply_context_t>);
|
||||
|
||||
for (unsigned int stage_index = 0; stage_index < stages[table_index].length; stage_index++)
|
||||
|
@ -2067,6 +2072,8 @@ inline void hb_ot_map_t::apply (const Proxy &proxy,
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
proxy.accel.release_var_store_cache (var_store_cache);
|
||||
}
|
||||
|
||||
void hb_ot_map_t::substitute (const hb_ot_shape_plan_t *plan, hb_font_t *font, hb_buffer_t *buffer) const
|
||||
|
|
Loading…
Add table
Reference in a new issue