diff options
author | Sverker Eriksson <[email protected]> | 2014-06-04 10:55:49 +0200 |
---|---|---|
committer | Sverker Eriksson <[email protected]> | 2014-06-04 10:55:49 +0200 |
commit | aa3a7c229ca39400de7d281ae11c4ec78592e095 (patch) | |
tree | d0e375b788f4435337d811cff144d56d52881a1e | |
parent | 07b8f441ca711f9812fad9e9115bab3c3aa92f79 (diff) | |
download | otp-aa3a7c229ca39400de7d281ae11c4ec78592e095.tar.gz otp-aa3a7c229ca39400de7d281ae11c4ec78592e095.tar.bz2 otp-aa3a7c229ca39400de7d281ae11c4ec78592e095.zip |
erts: Fix cache line alignment bug for ts_event_pool
-rw-r--r-- | erts/lib_src/common/ethr_aux.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/erts/lib_src/common/ethr_aux.c b/erts/lib_src/common/ethr_aux.c index ceecdcef64..b77f2178f2 100644 --- a/erts/lib_src/common/ethr_aux.c +++ b/erts/lib_src/common/ethr_aux.c @@ -1,7 +1,7 @@ /* * %CopyrightBegin% * - * Copyright Ericsson AB 2010-2012. All Rights Reserved. + * Copyright Ericsson AB 2010-2014. All Rights Reserved. * * The contents of this file are subject to the Erlang Public License, * Version 1.1, (the "License"); you may not use this file except in @@ -360,10 +360,10 @@ static ethr_ts_event *ts_event_pool(int size, ethr_ts_event **endpp) int i; ethr_aligned_ts_event *atsev; atsev = ethr_mem__.std.alloc(sizeof(ethr_aligned_ts_event) * size - + ETHR_CACHE_LINE_SIZE); + + ETHR_CACHE_LINE_SIZE - 1); if (!atsev) return NULL; - if ((((ethr_uint_t) atsev) & ETHR_CACHE_LINE_MASK) == 0) + if ((((ethr_uint_t) atsev) & ETHR_CACHE_LINE_MASK) != 0) atsev = ((ethr_aligned_ts_event *) ((((ethr_uint_t) atsev) & ~ETHR_CACHE_LINE_MASK) + ETHR_CACHE_LINE_SIZE)); |