diff --git a/jemalloc-fix-32bit-tests.patch b/jemalloc-fix-32bit-tests.patch new file mode 100644 index 0000000..82d2966 --- /dev/null +++ b/jemalloc-fix-32bit-tests.patch @@ -0,0 +1,234 @@ +diff --git a/test/integration/aligned_alloc.c b/test/integration/aligned_alloc.c +index 17c2151..6090014 100644 +--- a/test/integration/aligned_alloc.c ++++ b/test/integration/aligned_alloc.c +@@ -47,10 +47,10 @@ TEST_BEGIN(test_oom_errors) + + #if LG_SIZEOF_PTR == 3 + alignment = UINT64_C(0x4000000000000000); +- size = UINT64_C(0x8400000000000001); ++ size = UINT64_C(0xc000000000000001); + #else + alignment = 0x40000000LU; +- size = 0x84000001LU; ++ size = 0xc0000001LU; + #endif + set_errno(0); + p = aligned_alloc(alignment, size); +diff --git a/test/integration/mallocx.c b/test/integration/mallocx.c +index c26f6c5..f37a74b 100644 +--- a/test/integration/mallocx.c ++++ b/test/integration/mallocx.c +@@ -34,26 +34,6 @@ TEST_BEGIN(test_basic) + } + TEST_END + +-TEST_BEGIN(test_alignment_errors) +-{ +- void *p; +- size_t nsz, sz, alignment; +- +-#if LG_SIZEOF_PTR == 3 +- alignment = UINT64_C(0x4000000000000000); +- sz = UINT64_C(0x8400000000000001); +-#else +- alignment = 0x40000000LU; +- sz = 0x84000001LU; +-#endif +- nsz = nallocx(sz, MALLOCX_ALIGN(alignment)); +- assert_zu_ne(nsz, 0, "Unexpected nallocx() error"); +- p = mallocx(sz, MALLOCX_ALIGN(alignment)); +- assert_ptr_null(p, "Expected error for mallocx(%zu, %#x)", sz, +- MALLOCX_ALIGN(alignment)); +-} +-TEST_END +- + TEST_BEGIN(test_alignment_and_size) + { + size_t nsz, rsz, sz, alignment, total; +@@ -114,6 +94,5 @@ main(void) + + return (test( + test_basic, +- test_alignment_errors, + test_alignment_and_size)); + } +diff --git a/test/integration/posix_memalign.c b/test/integration/posix_memalign.c +index c88a4dc..19741c6 100644 +--- a/test/integration/posix_memalign.c ++++ b/test/integration/posix_memalign.c +@@ -43,10 +43,10 @@ TEST_BEGIN(test_oom_errors) + + #if LG_SIZEOF_PTR == 3 + alignment = UINT64_C(0x4000000000000000); +- size = UINT64_C(0x8400000000000001); ++ size = UINT64_C(0xc000000000000001); + #else + alignment = 0x40000000LU; +- size = 0x84000001LU; ++ size = 0xc0000001LU; + #endif + assert_d_ne(posix_memalign(&p, alignment, size), 0, + "Expected error for posix_memalign(&p, %zu, %zu)", +diff --git a/test/unit/stats.c b/test/unit/stats.c +index 6cd9773..03a55c7 100644 +--- a/test/unit/stats.c ++++ b/test/unit/stats.c +@@ -31,21 +31,25 @@ TEST_END + + TEST_BEGIN(test_stats_chunks) + { +- size_t current, total, high; +- size_t sz = sizeof(size_t); ++ size_t current, high; ++ uint64_t total; ++ size_t sz; + int expected = config_stats ? 0 : ENOENT; + ++ sz = sizeof(size_t); + assert_d_eq(mallctl("stats.chunks.current", ¤t, &sz, NULL, 0), + expected, "Unexpected mallctl() result"); ++ sz = sizeof(uint64_t); + assert_d_eq(mallctl("stats.chunks.total", &total, &sz, NULL, 0), + expected, "Unexpected mallctl() result"); ++ sz = sizeof(size_t); + assert_d_eq(mallctl("stats.chunks.high", &high, &sz, NULL, 0), expected, + "Unexpected mallctl() result"); + + if (config_stats) { + assert_zu_le(current, high, + "current should be no larger than high"); +- assert_zu_le(high, total, ++ assert_u64_le((uint64_t)high, total, + "high should be no larger than total"); + } + } +@@ -247,9 +251,9 @@ TEST_BEGIN(test_stats_arenas_bins) + { + unsigned arena; + void *p; +- size_t sz, allocated; ++ size_t sz, allocated, curruns; + uint64_t epoch, nmalloc, ndalloc, nrequests, nfills, nflushes; +- uint64_t nruns, nreruns, curruns; ++ uint64_t nruns, nreruns; + int expected = config_stats ? 0 : ENOENT; + + arena = 0; +@@ -287,6 +291,7 @@ TEST_BEGIN(test_stats_arenas_bins) + NULL, 0), expected, "Unexpected mallctl() result"); + assert_d_eq(mallctl("stats.arenas.0.bins.0.nreruns", &nreruns, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); ++ sz = sizeof(size_t); + assert_d_eq(mallctl("stats.arenas.0.bins.0.curruns", &curruns, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); + +@@ -307,7 +312,7 @@ TEST_BEGIN(test_stats_arenas_bins) + } + assert_u64_gt(nruns, 0, + "At least one run should have been allocated"); +- assert_u64_gt(curruns, 0, ++ assert_zu_gt(curruns, 0, + "At least one run should be currently allocated"); + } + +@@ -319,8 +324,8 @@ TEST_BEGIN(test_stats_arenas_lruns) + { + unsigned arena; + void *p; +- uint64_t epoch, nmalloc, ndalloc, nrequests, curruns; +- size_t sz = sizeof(uint64_t); ++ uint64_t epoch, nmalloc, ndalloc, nrequests; ++ size_t curruns, sz; + int expected = config_stats ? 0 : ENOENT; + + arena = 0; +@@ -333,12 +338,14 @@ TEST_BEGIN(test_stats_arenas_lruns) + assert_d_eq(mallctl("epoch", NULL, NULL, &epoch, sizeof(epoch)), 0, + "Unexpected mallctl() failure"); + ++ sz = sizeof(uint64_t); + assert_d_eq(mallctl("stats.arenas.0.lruns.0.nmalloc", &nmalloc, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); + assert_d_eq(mallctl("stats.arenas.0.lruns.0.ndalloc", &ndalloc, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); + assert_d_eq(mallctl("stats.arenas.0.lruns.0.nrequests", &nrequests, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); ++ sz = sizeof(size_t); + assert_d_eq(mallctl("stats.arenas.0.lruns.0.curruns", &curruns, &sz, + NULL, 0), expected, "Unexpected mallctl() result"); + +diff --git a/test/integration/allocm.c b/test/integration/allocm.c +index bd7a3ca..66ecf86 100644 +--- a/test/integration/allocm.c ++++ b/test/integration/allocm.c +@@ -39,28 +39,6 @@ TEST_BEGIN(test_basic) + } + TEST_END + +-TEST_BEGIN(test_alignment_errors) +-{ +- void *p; +- size_t nsz, rsz, sz, alignment; +- +-#if LG_SIZEOF_PTR == 3 +- alignment = UINT64_C(0x4000000000000000); +- sz = UINT64_C(0x8400000000000001); +-#else +- alignment = 0x40000000LU; +- sz = 0x84000001LU; +-#endif +- nsz = 0; +- assert_d_eq(nallocm(&nsz, sz, ALLOCM_ALIGN(alignment)), ALLOCM_SUCCESS, +- "Unexpected nallocm() error"); +- rsz = 0; +- assert_d_ne(allocm(&p, &rsz, sz, ALLOCM_ALIGN(alignment)), +- ALLOCM_SUCCESS, "Expected error for allocm(&p, %zu, %#x)", +- sz, ALLOCM_ALIGN(alignment)); +-} +-TEST_END +- + TEST_BEGIN(test_alignment_and_size) + { + int r; +@@ -126,6 +104,5 @@ main(void) + + return (test( + test_basic, +- test_alignment_errors, + test_alignment_and_size)); + } +diff --git a/test/unit/prof_accum.c b/test/unit/prof_accum.c +index cf3f287..08be419 100644 +--- a/test/unit/prof_accum.c ++++ b/test/unit/prof_accum.c +@@ -22,10 +22,10 @@ prof_dump_open_intercept(bool propagate_err, const char *filename) + } + + #define alloc_n_proto(n) \ +-static void *alloc_##n(unsigned bits); ++JEMALLOC_NOINLINE static void *alloc_##n(unsigned bits); + + #define alloc_n_gen(n) \ +-static void * \ ++JEMALLOC_NOINLINE static void * \ + alloc_##n(unsigned bits) \ + { \ + void *p; \ +diff --git a/include/jemalloc/internal/prof.h b/include/jemalloc/internal/prof.h +index db056fc..6f162d2 100644 +--- a/include/jemalloc/internal/prof.h ++++ b/include/jemalloc/internal/prof.h +@@ -8,7 +8,11 @@ typedef struct prof_ctx_s prof_ctx_t; + typedef struct prof_tdata_s prof_tdata_t; + + /* Option defaults. */ +-#define PROF_PREFIX_DEFAULT "jeprof" ++#ifdef JEMALLOC_PROF ++# define PROF_PREFIX_DEFAULT "jeprof" ++#else ++# define PROF_PREFIX_DEFAULT "" ++#endif + #define LG_PROF_SAMPLE_DEFAULT 19 + #define LG_PROF_INTERVAL_DEFAULT -1 + diff --git a/jemalloc.changes b/jemalloc.changes index 4bda0ac..3d9a819 100644 --- a/jemalloc.changes +++ b/jemalloc.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Wed Jan 29 12:24:21 UTC 2014 - idonmez@suse.com + +- Add jemalloc-fix-32bit-tests.patch to fix test failures on i586 + ------------------------------------------------------------------- Fri Jan 24 12:02:33 UTC 2014 - idonmez@suse.com @@ -47,7 +52,6 @@ Fri Jan 24 12:02:33 UTC 2014 - idonmez@suse.com bugs had no impact except for malformed inputs. * Fix numerous bugs in malloc_snprintf(). These bugs were not exercised by existing calls, so they had no impact. -- Enable profiling support ------------------------------------------------------------------- Tue Oct 22 09:28:50 UTC 2013 - idonmez@suse.com diff --git a/jemalloc.spec b/jemalloc.spec index 44be003..c9000a1 100644 --- a/jemalloc.spec +++ b/jemalloc.spec @@ -27,6 +27,7 @@ Url: http://canonware.com/jemalloc/ #Git-Clone: git://canonware.com/jemalloc Source: http://www.canonware.com/download/jemalloc/jemalloc-%{version}.tar.bz2 +Patch1: jemalloc-fix-32bit-tests.patch BuildRequires: docbook-xsl-stylesheets BuildRequires: libxslt Requires: %lname = %{version} @@ -64,11 +65,11 @@ malloc(3) implementation. %prep %setup -q +%patch1 -p1 %build -export CFLAGS="%{optflags} -g2 -std=gnu99" -%configure --enable-cc-silence \ - --enable-prof +export EXTRA_CFLAGS="%{optflags} -std=gnu99" +%configure --enable-cc-silence make %{?_smp_mflags} %install @@ -86,6 +87,7 @@ fi; mv %{buildroot}/%{_bindir}/pprof %{buildroot}/%{_bindir}/pprof-jemalloc %check +export LD_LIBRARY_PATH=$PWD/lib:$LD_LIBRARY_PATH make check %files