Correctly handle the case when BUFFER_OVERFLOW happens during unwrap but the readable bytes are bigger then the expected applicationBufferSize
Motivation: We need to ensure we handle the case when BUFFER_OVERFLOW happens during unwrap but the readable bytes are bigger then the expected applicationBufferSize. Otherwise we may produce an IllegalArgumentException as we will try to allocate a buffer with capacity < 0. Modifications: - Guard against this case. - Ensure we not double release buffer on exception when doing unwrap. Result: No more exception when running testsuite with java 9.
This commit is contained in:
parent
f342ab4234
commit
b1d6b303b8
@ -1042,8 +1042,20 @@ public class SslHandler extends ByteToMessageDecoder implements ChannelOutboundH
|
|||||||
if (readableBytes > 0) {
|
if (readableBytes > 0) {
|
||||||
decoded = true;
|
decoded = true;
|
||||||
ctx.fireChannelRead(decodeOut);
|
ctx.fireChannelRead(decodeOut);
|
||||||
|
|
||||||
|
// This buffer was handled, null it out.
|
||||||
|
decodeOut = null;
|
||||||
|
if (bufferSize <= 0) {
|
||||||
|
// It may happen that readableBytes >= engine.getSession().getApplicationBufferSize()
|
||||||
|
// while there is still more to unwrap, in this case we will just allocate a new buffer
|
||||||
|
// with the capacity of engine.getSession().getApplicationBufferSize() and call unwrap
|
||||||
|
// again.
|
||||||
|
bufferSize = engine.getSession().getApplicationBufferSize();
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
// This buffer was handled, null it out.
|
||||||
decodeOut.release();
|
decodeOut.release();
|
||||||
|
decodeOut = null;
|
||||||
}
|
}
|
||||||
// Allocate a new buffer which can hold all the rest data and loop again.
|
// Allocate a new buffer which can hold all the rest data and loop again.
|
||||||
// TODO: We may want to reconsider how we calculate the length here as we may
|
// TODO: We may want to reconsider how we calculate the length here as we may
|
||||||
@ -1120,12 +1132,14 @@ public class SslHandler extends ByteToMessageDecoder implements ChannelOutboundH
|
|||||||
sslCloseFuture.trySuccess(ctx.channel());
|
sslCloseFuture.trySuccess(ctx.channel());
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
if (decodeOut.isReadable()) {
|
if (decodeOut != null) {
|
||||||
decoded = true;
|
if (decodeOut.isReadable()) {
|
||||||
|
decoded = true;
|
||||||
|
|
||||||
ctx.fireChannelRead(decodeOut);
|
ctx.fireChannelRead(decodeOut);
|
||||||
} else {
|
} else {
|
||||||
decodeOut.release();
|
decodeOut.release();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return decoded;
|
return decoded;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user