mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 00:06:24 +01:00
grefcount: Optimise g_atomic_ref_count_inc
Currently, `g_atomic_ref_count_inc ()` does three operations. We try to get this down to one operation. Fixed by replacing `g_atomic_int_inc ()` with `g_atomic_int_add ()` which increments by 1 and returns old value Note: changes current behaviour, checks are now done after increment. Closes: #1583
This commit is contained in:
parent
2cb303b7aa
commit
827b4ec855
@ -235,16 +235,14 @@ void
|
||||
void
|
||||
(g_atomic_ref_count_inc) (gatomicrefcount *arc)
|
||||
{
|
||||
gint old_value;
|
||||
|
||||
g_return_if_fail (arc != NULL);
|
||||
g_return_if_fail (g_atomic_int_get (arc) > 0);
|
||||
old_value = g_atomic_int_add (arc, 1);
|
||||
g_return_if_fail (old_value > 0);
|
||||
|
||||
if (g_atomic_int_get (arc) == G_MAXINT)
|
||||
{
|
||||
g_critical ("Reference count has reached saturation");
|
||||
return;
|
||||
}
|
||||
|
||||
g_atomic_int_inc (arc);
|
||||
if (old_value == G_MAXINT)
|
||||
g_critical ("Reference count has reached saturation");
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user