summaryrefslogtreecommitdiffstats
path: root/src/util
diff options
context:
space:
mode:
authorMichal Zidek <mzidek@redhat.com>2014-06-30 15:52:43 +0200
committerJakub Hrozek <jhrozek@redhat.com>2014-07-01 11:35:24 +0200
commit684405758a96bd9fb47480d44f2e1a2f038f8def (patch)
tree28ae2d800d29dd6e2c0aefc2ce71352f663ddd3e /src/util
parent90ac46f71068d131391492360a8553bdd005b5a7 (diff)
downloadsssd-684405758a96bd9fb47480d44f2e1a2f038f8def.tar.gz
sssd-684405758a96bd9fb47480d44f2e1a2f038f8def.tar.xz
sssd-684405758a96bd9fb47480d44f2e1a2f038f8def.zip
Suppress safealign warnings with DISCARD_ALIGN.
These warnings were all false positives. fixes: https://fedorahosted.org/sssd/ticket/1359 Reviewed-by: Lukáš Slebodník <lslebodn@redhat.com>
Diffstat (limited to 'src/util')
-rw-r--r--src/util/refcount.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/util/refcount.c b/src/util/refcount.c
index 735170d1b..69873d3df 100644
--- a/src/util/refcount.c
+++ b/src/util/refcount.c
@@ -48,6 +48,7 @@ _rc_alloc(const void *context, size_t size, size_t refcount_offset,
const char *type_name)
{
struct wrapper *wrapper;
+ char *refcount_pos;
wrapper = talloc(context, struct wrapper);
if (wrapper == NULL) {
@@ -60,7 +61,8 @@ _rc_alloc(const void *context, size_t size, size_t refcount_offset,
return NULL;
};
- wrapper->refcount = (int *)((char *)wrapper->ptr + refcount_offset);
+ refcount_pos = (char *)wrapper->ptr + refcount_offset;
+ wrapper->refcount = DISCARD_ALIGN(refcount_pos, int *);
*wrapper->refcount = 1;
talloc_set_destructor(wrapper, refcount_destructor);
@@ -72,6 +74,7 @@ void *
_rc_reference(const void *context, size_t refcount_offset, void *source)
{
struct wrapper *wrapper;
+ char *refcount_pos;
wrapper = talloc(context, struct wrapper);
if (wrapper == NULL) {
@@ -79,7 +82,8 @@ _rc_reference(const void *context, size_t refcount_offset, void *source)
}
wrapper->ptr = source;
- wrapper->refcount = (int *)((char *)wrapper->ptr + refcount_offset);
+ refcount_pos = (char *)wrapper->ptr + refcount_offset;
+ wrapper->refcount = DISCARD_ALIGN(refcount_pos, int *);
(*wrapper->refcount)++;
talloc_set_destructor(wrapper, refcount_destructor);