From becc31dda7a310dc69b39d7a177c55c04f1f5c9b Mon Sep 17 00:00:00 2001 From: tuxoko Date: Fri, 30 Oct 2015 14:34:22 -0700 Subject: [PATCH] Fix null pointer in arc_kmem_reap_now on 32-bit On 32 bit system, zio_buf_cache is limit to 1M. Larger than that is all NULL. So we need to avoid reaping them. Signed-off-by: Chunwei Chen Signed-off-by: Brian Behlendorf Issue #3973 --- module/zfs/arc.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/module/zfs/arc.c b/module/zfs/arc.c index b759e6483d..ec9b46b026 100644 --- a/module/zfs/arc.c +++ b/module/zfs/arc.c @@ -3373,6 +3373,11 @@ arc_kmem_reap_now(void) } for (i = 0; i < SPA_MAXBLOCKSIZE >> SPA_MINBLOCKSHIFT; i++) { +#ifdef _ILP32 + /* reach upper limit of cache size on 32-bit */ + if (zio_buf_cache[i] == NULL) + break; +#endif if (zio_buf_cache[i] != prev_cache) { prev_cache = zio_buf_cache[i]; kmem_cache_reap_now(zio_buf_cache[i]);