Uploaded image for project: 'Undertow'
  1. Undertow
  2. UNDERTOW-2072

DefaultByteBufferPool.getBuffer() may return null

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Done
    • Icon: Major Major
    • 2.3.9.Final, 2.2.27.Final
    • None
    • None
    • None

      DefaultByteBufferPool.allocate() returns a PooledByteBuffer that provides a method getBuffer() granting access to the actual buffer. PooledByteBuffer has a method close() that performs some administrative work and finally nulls the internal buffer field.

      To prevent PooledByteBuffer.getBuffer() from returning null, a reference counter is zeroed in close() and checked in getBuffer(), which will throw an IllegalStateException upon a zeroed reference counter.

      This is unfortunately not enough, as close() may be called after the check and before actually returning the wrapped buffer; this has been observed, possibly when clients connected to an undertow-based server disconnect while the request is being read, manifesting in a NullPointerException at io.undertow.servlet.spec.ServletInputStreamImpl.readIntoBuffer() (line 202 in version 2.2.9).

              rhn-cservice-bbaranow Bartosz Baranowski
              moses.palmer.rhel Henrik Palmér (Inactive)
              Votes:
              1 Vote for this issue
              Watchers:
              6 Start watching this issue

                Created:
                Updated:
                Resolved: