diff --git a/transport-native-epoll/src/main/java/io/netty/channel/epoll/EpollSocketChannel.java b/transport-native-epoll/src/main/java/io/netty/channel/epoll/EpollSocketChannel.java index 1d2f824259..49c5179ba4 100644 --- a/transport-native-epoll/src/main/java/io/netty/channel/epoll/EpollSocketChannel.java +++ b/transport-native-epoll/src/main/java/io/netty/channel/epoll/EpollSocketChannel.java @@ -253,6 +253,8 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So if (done) { // Release all buffers for (int i = msgCount; i > 0; i --) { + final ByteBuf buf = (ByteBuf) in.current(); + in.progress(buf.readableBytes()); in.remove(); } in.progress(writtenBytes); @@ -268,6 +270,7 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So final int readableBytes = buf.writerIndex() - readerIndex; if (readableBytes < writtenBytes) { + in.progress(readableBytes); in.remove(); writtenBytes -= readableBytes; } else if (readableBytes > writtenBytes) { @@ -275,6 +278,7 @@ public final class EpollSocketChannel extends AbstractEpollChannel implements So in.progress(writtenBytes); break; } else { // readable == writtenBytes + in.progress(readableBytes); in.remove(); break; } diff --git a/transport/src/main/java/io/netty/channel/oio/AbstractOioByteChannel.java b/transport/src/main/java/io/netty/channel/oio/AbstractOioByteChannel.java index 4215ad2771..c161505ba3 100644 --- a/transport/src/main/java/io/netty/channel/oio/AbstractOioByteChannel.java +++ b/transport/src/main/java/io/netty/channel/oio/AbstractOioByteChannel.java @@ -193,12 +193,19 @@ public abstract class AbstractOioByteChannel extends AbstractOioChannel { } if (msg instanceof ByteBuf) { ByteBuf buf = (ByteBuf) msg; - while (buf.isReadable()) { + int readableBytes = buf.readableBytes(); + while (readableBytes > 0) { doWriteBytes(buf); + int newReadableBytes = buf.readableBytes(); + in.progress(readableBytes - newReadableBytes); + readableBytes = newReadableBytes; } in.remove(); } else if (msg instanceof FileRegion) { - doWriteFileRegion((FileRegion) msg); + FileRegion region = (FileRegion) msg; + long transfered = region.transfered(); + doWriteFileRegion(region); + in.progress(region.transfered() - transfered); in.remove(); } else { in.remove(new UnsupportedOperationException( diff --git a/transport/src/main/java/io/netty/channel/socket/nio/NioSocketChannel.java b/transport/src/main/java/io/netty/channel/socket/nio/NioSocketChannel.java index 329877895d..29297d2fbd 100644 --- a/transport/src/main/java/io/netty/channel/socket/nio/NioSocketChannel.java +++ b/transport/src/main/java/io/netty/channel/socket/nio/NioSocketChannel.java @@ -278,7 +278,9 @@ public class NioSocketChannel extends AbstractNioByteChannel implements io.netty if (done) { // Release all buffers for (int i = msgCount; i > 0; i --) { - nioIn.remove(); + final ByteBuf buf = (ByteBuf) in.current(); + in.progress(buf.readableBytes()); + in.remove(); } // Finish the write loop if no new messages were flushed by in.remove().