OSDN Git Service

2004-04-21 Michael Koch <konqueror@gmx.de>
authormkoch <mkoch@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Apr 2004 15:33:53 +0000 (15:33 +0000)
committermkoch <mkoch@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 21 Apr 2004 15:33:53 +0000 (15:33 +0000)
* java/nio/DirectByteBufferImpl.java
(shiftDown): Made static, give address as argument and
provide a convenience method that overwrites shiftDown in
ByteBufferImpl and calls the native shiftDown.
* java/nio/MappedByteBufferImpl.java
(): Use optimized method in DirectByteBufferImpl.
* java/nio/natDirectByteBufferImpl.cc
(shiftDown): Changed method signature. Removed usage of array_offset.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@80967 138bc75d-0d04-0410-961f-82ee72b054a4

libjava/ChangeLog
libjava/java/nio/DirectByteBufferImpl.java
libjava/java/nio/MappedByteBufferImpl.java
libjava/java/nio/natDirectByteBufferImpl.cc

index 04c0876..56bcc32 100644 (file)
@@ -1,5 +1,16 @@
 2004-04-21  Michael Koch  <konqueror@gmx.de>
 
+       * java/nio/DirectByteBufferImpl.java
+       (shiftDown): Made static, give address as argument and
+       provide a convenience method that overwrites shiftDown in
+       ByteBufferImpl and calls the native shiftDown.
+       * java/nio/MappedByteBufferImpl.java
+       (): Use optimized method in DirectByteBufferImpl.
+       * java/nio/natDirectByteBufferImpl.cc
+       (shiftDown): Changed method signature. Removed usage of array_offset.
+
+2004-04-21  Michael Koch  <konqueror@gmx.de>
+
        * gnu/java/net/natPlainSocketImplPosix.cc
        (SocketInputStream::read): Make sure returned data is a byte value.
 
index 7c2b783..be0fc52 100644 (file)
@@ -136,15 +136,20 @@ final class DirectByteBufferImpl extends ByteBuffer
     return this;
   }
   
-  native void shiftDown (int dst_offset, int src_offset, int count);
+  static native void shiftDown(RawData address, int dst_offset, int src_offset, int count);
 
+  void shiftDown(int dst_offset, int src_offset, int count)
+  {
+    shiftDown(address, dst_offset, src_offset, count);
+  }
+  
   public ByteBuffer compact ()
   {
     int pos = position();
     if (pos > 0)
       {
        int count = remaining();
-       shiftDown(0, pos, count);
+       shiftDown(address, 0, pos, count);
        position(count);
        limit(capacity());
       }
index ccd987e..5932c99 100644 (file)
@@ -121,7 +121,8 @@ final class MappedByteBufferImpl extends MappedByteBuffer
     if (pos > 0)
       {
        int count = remaining();
-       shiftDown(0, pos, count);
+       // Call shiftDown method optimized for direct buffers.
+       DirectByteBufferImpl.shiftDown(address, 0, pos, count);
        position(count);
        limit(capacity());
       }
index 94225c3..88f53fc 100644 (file)
@@ -65,9 +65,9 @@ java::nio::DirectByteBufferImpl::adjustAddress (RawData* address, jint offset)
 
 void
 java::nio::DirectByteBufferImpl::shiftDown
-(jint dst_offset, jint src_offset, jint count)
+(RawData* address, jint dst_offset, jint src_offset, jint count)
 {
-  jbyte* dst = reinterpret_cast<jbyte*> (address) + array_offset + dst_offset;
-  jbyte* src = reinterpret_cast<jbyte*> (address) + array_offset + src_offset;
+  jbyte* dst = reinterpret_cast<jbyte*> (address) + dst_offset;
+  jbyte* src = reinterpret_cast<jbyte*> (address) + src_offset;
   ::memmove(dst, src, count);
 }