From 4d350d31a67d4c17b23cf5b76ccd4738c90ef659 Mon Sep 17 00:00:00 2001 From: Norman Maurer Date: Thu, 5 Mar 2015 14:14:19 +0100 Subject: [PATCH] Fix possible AttributeMap corruption on double removal Motivation: When remove0() is called multiple times for an DefaultAttribute it can cause corruption of the internal linked-list structure. Modifications: - Ensure remove0() can not cause corruption by null out prev and next references. Result: No more corruption possible --- common/src/main/java/io/netty/util/DefaultAttributeMap.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/common/src/main/java/io/netty/util/DefaultAttributeMap.java b/common/src/main/java/io/netty/util/DefaultAttributeMap.java index 78ecdd12b0..f251683300 100644 --- a/common/src/main/java/io/netty/util/DefaultAttributeMap.java +++ b/common/src/main/java/io/netty/util/DefaultAttributeMap.java @@ -208,6 +208,11 @@ public class DefaultAttributeMap implements AttributeMap { if (next != null) { next.prev = prev; } + + // Null out prev and next - this will guard against multiple remove0() calls which may corrupt + // the linked list for the bucket. + prev = null; + next = null; } } }