mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 06:26:15 +01:00
Allow using msort_r CHERI-enabled architectures
If we are sorting something that is a multiple of sizeof(void*), we have to ensure that we swap one pointer at a time since swapping using sub-pointer-size stores invalidate the pointers (pointers have a hidden validity tags that is invalidated when performing non-monotonic operations such as storing only part of the pointers). While touching this code also use G_ALIGNOF() instead of a macro that is generated at configure time. Helps: https://gitlab.gnome.org/GNOME/glib/-/issues/2842
This commit is contained in:
parent
eafd19da29
commit
d2bbd69fd5
@ -128,23 +128,23 @@ msort_with_tmp (const struct msort_param *p, void *b, size_t n)
|
|||||||
case 2:
|
case 2:
|
||||||
while (n1 > 0 && n2 > 0)
|
while (n1 > 0 && n2 > 0)
|
||||||
{
|
{
|
||||||
unsigned long *tmpl = (unsigned long *) tmp;
|
guintptr *tmpl = (guintptr *) tmp;
|
||||||
unsigned long *bl;
|
guintptr *bl;
|
||||||
|
|
||||||
tmp += s;
|
tmp += s;
|
||||||
if ((*cmp) (b1, b2, arg) <= 0)
|
if ((*cmp) (b1, b2, arg) <= 0)
|
||||||
{
|
{
|
||||||
bl = (unsigned long *) b1;
|
bl = (guintptr *) b1;
|
||||||
b1 += s;
|
b1 += s;
|
||||||
--n1;
|
--n1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bl = (unsigned long *) b2;
|
bl = (guintptr *) b2;
|
||||||
b2 += s;
|
b2 += s;
|
||||||
--n2;
|
--n2;
|
||||||
}
|
}
|
||||||
while (tmpl < (unsigned long *) tmp)
|
while (tmpl < (guintptr *) tmp)
|
||||||
*tmpl++ = *bl++;
|
*tmpl++ = *bl++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -265,15 +265,15 @@ msort_r (void *b, size_t n, size_t s, GCompareDataFunc cmp, void *arg)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ((s & (sizeof (guint32) - 1)) == 0
|
if ((s & (sizeof (guint32) - 1)) == 0
|
||||||
&& (guintptr) b % ALIGNOF_GUINT32 == 0)
|
&& (gsize) (guintptr) b % G_ALIGNOF(guint32) == 0)
|
||||||
{
|
{
|
||||||
if (s == sizeof (guint32))
|
if (s == sizeof (guint32))
|
||||||
p.var = 0;
|
p.var = 0;
|
||||||
else if (s == sizeof (guint64)
|
else if (s == sizeof (guint64)
|
||||||
&& (guintptr) b % ALIGNOF_GUINT64 == 0)
|
&& (gsize) (guintptr) b % G_ALIGNOF(guint64) == 0)
|
||||||
p.var = 1;
|
p.var = 1;
|
||||||
else if ((s & (sizeof (unsigned long) - 1)) == 0
|
else if ((s & (sizeof (void *) - 1)) == 0
|
||||||
&& (guintptr) b % ALIGNOF_UNSIGNED_LONG == 0)
|
&& (gsize) (guintptr) b % G_ALIGNOF(void *) == 0)
|
||||||
p.var = 2;
|
p.var = 2;
|
||||||
}
|
}
|
||||||
msort_with_tmp (&p, b, n);
|
msort_with_tmp (&p, b, n);
|
||||||
|
@ -1477,8 +1477,6 @@ long_long_align = cc.alignment('long long')
|
|||||||
# be 64-bit in C99, and it is available on all supported compilers
|
# be 64-bit in C99, and it is available on all supported compilers
|
||||||
sizet_align = cc.alignment('size_t')
|
sizet_align = cc.alignment('size_t')
|
||||||
|
|
||||||
glib_conf.set('ALIGNOF_UNSIGNED_LONG', long_align)
|
|
||||||
|
|
||||||
glib_conf.set('SIZEOF_CHAR', char_size)
|
glib_conf.set('SIZEOF_CHAR', char_size)
|
||||||
glib_conf.set('SIZEOF_INT', int_size)
|
glib_conf.set('SIZEOF_INT', int_size)
|
||||||
glib_conf.set('SIZEOF_SHORT', short_size)
|
glib_conf.set('SIZEOF_SHORT', short_size)
|
||||||
@ -1532,7 +1530,6 @@ glibconfig_conf.set('gint32', gint32)
|
|||||||
glibconfig_conf.set_quoted('gint32_modifier', gint32_modifier)
|
glibconfig_conf.set_quoted('gint32_modifier', gint32_modifier)
|
||||||
glibconfig_conf.set_quoted('gint32_format', gint32_format)
|
glibconfig_conf.set_quoted('gint32_format', gint32_format)
|
||||||
glibconfig_conf.set_quoted('guint32_format', guint32_format)
|
glibconfig_conf.set_quoted('guint32_format', guint32_format)
|
||||||
glib_conf.set('ALIGNOF_GUINT32', guint32_align)
|
|
||||||
|
|
||||||
if int_size == 8
|
if int_size == 8
|
||||||
gint64 = 'int'
|
gint64 = 'int'
|
||||||
@ -1571,7 +1568,6 @@ glibconfig_conf.set_quoted('gint64_format', gint64_format)
|
|||||||
glibconfig_conf.set_quoted('guint64_format', guint64_format)
|
glibconfig_conf.set_quoted('guint64_format', guint64_format)
|
||||||
glibconfig_conf.set('gint64_constant', gint64_constant)
|
glibconfig_conf.set('gint64_constant', gint64_constant)
|
||||||
glibconfig_conf.set('guint64_constant', guint64_constant)
|
glibconfig_conf.set('guint64_constant', guint64_constant)
|
||||||
glib_conf.set('ALIGNOF_GUINT64', guint64_align)
|
|
||||||
|
|
||||||
if host_system == 'windows'
|
if host_system == 'windows'
|
||||||
glibconfig_conf.set('g_pid_type', 'void*')
|
glibconfig_conf.set('g_pid_type', 'void*')
|
||||||
|
Loading…
Reference in New Issue
Block a user