Commit a4536c7a by Michael Koch Committed by Michael Koch

2002-11-29 Michael Koch <konqueror@gmx.de>

	* gnu/java/nio/DatagramChannelImpl:
	(fd): New member variable to store file descriptor of socket.
	* gnu/java/nio/SelectionKeyImpl.java:
	(ops): Removed.
	(readyOps): New member variable.
	(interestOps): New member variable.
	(readyOps): Implemented.
	(readyOps): New method to set member variable readyOps.
	(interestOps): Replaced ops by interestOps.
	* gnu/java/nio/SelectorImpl.java:
	(SelectorImpl): Initialize key sets.
	(select): Call select with -1 instead of Long.MAX_VALUE).
	(java_do_select): Make it a native method.
	(getFDsAsArray): New helper method.
	(select): Remove canceled keys, give only interested file discriptors
	to java_do_select, set ready ops.
	(add): No need to initialize keys set here.
	(add_selected): No need to initialize selected set here.
	(deregisterCanceledKeys): New helper method.
	(register): Set interest ops, set attachments, added handling of datagram
	channels.
	* gnu/java/nio/ServerSocketChannelImpl:
	(SocketAccept): Renamed from NioSocketAccept.
	(implConfigureBlocking): Implemented.
	(accept): Use SocketAccept instead of NioSocketAccept.
	* gnu/java/nio/SocketChannelImpl:
	Reactivate native methods.

From-SVN: r59632
parent 45596747
2002-11-29 Michael Koch <konqueror@gmx.de> 2002-11-29 Michael Koch <konqueror@gmx.de>
* gnu/java/nio/DatagramChannelImpl:
(fd): New member variable to store file descriptor of socket.
* gnu/java/nio/SelectionKeyImpl.java:
(ops): Removed.
(readyOps): New member variable.
(interestOps): New member variable.
(readyOps): Implemented.
(readyOps): New method to set member variable readyOps.
(interestOps): Replaced ops by interestOps.
* gnu/java/nio/SelectorImpl.java:
(SelectorImpl): Initialize key sets.
(select): Call select with -1 instead of Long.MAX_VALUE).
(java_do_select): Make it a native method.
(getFDsAsArray): New helper method.
(select): Remove canceled keys, give only interested file discriptors
to java_do_select, set ready ops.
(add): No need to initialize keys set here.
(add_selected): No need to initialize selected set here.
(deregisterCanceledKeys): New helper method.
(register): Set interest ops, set attachments, added handling of datagram
channels.
* gnu/java/nio/ServerSocketChannelImpl:
(SocketAccept): Renamed from NioSocketAccept.
(implConfigureBlocking): Implemented.
(accept): Use SocketAccept instead of NioSocketAccept.
* gnu/java/nio/SocketChannelImpl:
Reactivate native methods.
2002-11-29 Michael Koch <konqueror@gmx.de>
* gnu/java/nio/natByteBufferImpl.cc, * gnu/java/nio/natByteBufferImpl.cc,
gnu/java/nio/natCharBufferImpl.cc, gnu/java/nio/natCharBufferImpl.cc,
gnu/java/nio/natDoubleBufferImpl.cc, gnu/java/nio/natDoubleBufferImpl.cc,
......
...@@ -45,6 +45,8 @@ import java.nio.channels.spi.SelectorProvider; ...@@ -45,6 +45,8 @@ import java.nio.channels.spi.SelectorProvider;
public class DatagramChannelImpl extends DatagramChannel public class DatagramChannelImpl extends DatagramChannel
{ {
int fd;
protected DatagramChannelImpl (SelectorProvider provider) protected DatagramChannelImpl (SelectorProvider provider)
{ {
super (provider); super (provider);
......
...@@ -44,7 +44,9 @@ import java.nio.channels.spi.AbstractSelectionKey; ...@@ -44,7 +44,9 @@ import java.nio.channels.spi.AbstractSelectionKey;
public class SelectionKeyImpl extends AbstractSelectionKey public class SelectionKeyImpl extends AbstractSelectionKey
{ {
int fd, ops; int fd;
int readyOps;
int interestOps;
SelectorImpl impl; SelectorImpl impl;
SelectableChannel ch; SelectableChannel ch;
...@@ -62,17 +64,23 @@ public class SelectionKeyImpl extends AbstractSelectionKey ...@@ -62,17 +64,23 @@ public class SelectionKeyImpl extends AbstractSelectionKey
public int readyOps () public int readyOps ()
{ {
return 0; return readyOps;
}
public SelectionKey readyOps (int ops)
{
readyOps = ops;
return this;
} }
public int interestOps () public int interestOps ()
{ {
return ops; return interestOps;
} }
public SelectionKey interestOps (int ops) public SelectionKey interestOps (int ops)
{ {
this.ops = ops; interestOps = ops;
return this; return this;
} }
......
...@@ -56,6 +56,10 @@ public class SelectorImpl extends AbstractSelector ...@@ -56,6 +56,10 @@ public class SelectorImpl extends AbstractSelector
public SelectorImpl (SelectorProvider provider) public SelectorImpl (SelectorProvider provider)
{ {
super (provider); super (provider);
keys = new HashSet ();
selected = new HashSet ();
canceled = new HashSet ();
} }
public Set keys () public Set keys ()
...@@ -70,16 +74,48 @@ public class SelectorImpl extends AbstractSelector ...@@ -70,16 +74,48 @@ public class SelectorImpl extends AbstractSelector
public int select () public int select ()
{ {
return select (Long.MAX_VALUE); return select (-1);
} }
// private static native int java_do_select(int[] read, int[] write, // A timeout value of -1 means block forever.
// int[] except, long timeout); private static native int java_do_select (int[] read, int[] write,
int[] except, long timeout);
private static int java_do_select(int[] read, int[] write, private int[] getFDsAsArray (int ops)
int[] except, long timeout)
{ {
return 0; int[] result;
int counter = 0;
Iterator it = keys.iterator ();
// Count the number of file descriptors needed
while (it.hasNext ())
{
SelectionKeyImpl key = (SelectionKeyImpl) it.next ();
if ((key.interestOps () & ops) != 0)
{
counter++;
}
}
result = new int[counter];
counter = 0;
it = keys.iterator ();
// Fill the array with the file descriptors
while (it.hasNext ())
{
SelectionKeyImpl key = (SelectionKeyImpl) it.next ();
if ((key.interestOps () & ops) != 0)
{
result[counter] = key.fd;
counter++;
}
}
return result;
} }
public int select (long timeout) public int select (long timeout)
...@@ -94,40 +130,79 @@ public class SelectorImpl extends AbstractSelector ...@@ -94,40 +130,79 @@ public class SelectorImpl extends AbstractSelector
return 0; return 0;
} }
int[] read = new int[keys.size ()]; int ret = 0;
int[] write = new int[keys.size ()];
int[] except = new int[keys.size ()]; deregisterCanceledKeys ();
int i = 0;
// Set only keys with the needed interest ops into the arrays.
int[] read = getFDsAsArray (SelectionKey.OP_READ | SelectionKey.OP_ACCEPT);
int[] write = getFDsAsArray (SelectionKey.OP_WRITE | SelectionKey.OP_CONNECT);
int[] except = new int [0]; // FIXME: We dont need to check this yet
// Call the native select () on all file descriptors.
int anzahl = read.length + write.length + except.length;
ret = java_do_select (read, write, except, timeout);
Iterator it = keys.iterator (); Iterator it = keys.iterator ();
while (it.hasNext ()) while (it.hasNext ())
{ {
SelectionKeyImpl k = (SelectionKeyImpl) it.next (); int ops = 0;
read[i] = k.fd; SelectionKeyImpl key = (SelectionKeyImpl) it.next ();
write[i] = k.fd;
except[i] = k.fd;
i++;
}
int ret = java_do_select (read, write, except, timeout); // If key is already selected retrieve old ready ops.
if (selected.contains (key))
{
ops = key.readyOps ();
}
i = 0; // Set new ready read/accept ops
it = keys.iterator (); for (int i = 0; i < read.length; i++)
{
if (key.fd == read[i])
{
if (key.channel () instanceof ServerSocketChannelImpl)
{
ops = ops | SelectionKey.OP_ACCEPT;
}
else
{
ops = ops | SelectionKey.OP_READ;
}
}
}
while (it.hasNext ()) // Set new ready write ops
{ for (int i = 0; i < write.length; i++)
SelectionKeyImpl k = (SelectionKeyImpl) it.next (); {
if (key.fd == write[i])
{
ops = ops | SelectionKey.OP_WRITE;
// if (key.channel ().isConnected ())
// {
// ops = ops | SelectionKey.OP_WRITE;
// }
// else
// {
// ops = ops | SelectionKey.OP_CONNECT;
// }
}
}
// FIXME: We dont handle exceptional file descriptors yet.
if (read[i] != -1 || // If key is not yet selected add it.
write[i] != -1 || if (!selected.contains (key))
except[i] != -1)
{ {
add_selected (k); add_selected (key);
} }
i++; // Set new ready ops
} key.readyOps (key.interestOps () & ops);
}
deregisterCanceledKeys ();
return ret; return ret;
} }
...@@ -143,25 +218,30 @@ public class SelectorImpl extends AbstractSelector ...@@ -143,25 +218,30 @@ public class SelectorImpl extends AbstractSelector
public void add (SelectionKeyImpl k) public void add (SelectionKeyImpl k)
{ {
if (keys == null)
keys = new HashSet ();
keys.add (k); keys.add (k);
} }
void add_selected (SelectionKeyImpl k) void add_selected (SelectionKeyImpl k)
{ {
if (selected == null) selected.add (k);
selected = new HashSet ();
selected.add(k);
} }
protected void implCloseSelector () protected void implCloseSelector ()
{ {
closed = true; closed = true;
} }
private void deregisterCanceledKeys ()
{
Iterator it = canceled.iterator ();
while (it.hasNext ())
{
keys.remove ((SelectionKeyImpl) it.next ());
it.remove ();
}
}
protected SelectionKey register (SelectableChannel ch, int ops, Object att) protected SelectionKey register (SelectableChannel ch, int ops, Object att)
{ {
return register ((AbstractSelectableChannel) ch, ops, att); return register ((AbstractSelectableChannel) ch, ops, att);
...@@ -176,6 +256,8 @@ public class SelectorImpl extends AbstractSelector ...@@ -176,6 +256,8 @@ public class SelectorImpl extends AbstractSelector
// FileChannelImpl fc = (FileChannelImpl) ch; // FileChannelImpl fc = (FileChannelImpl) ch;
// SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, fc.fd); // SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, fc.fd);
// keys.add (impl); // keys.add (impl);
// impl.interestOps (ops);
// impl.attach (att);
// return impl; // return impl;
// } // }
// else // else
...@@ -185,13 +267,26 @@ public class SelectorImpl extends AbstractSelector ...@@ -185,13 +267,26 @@ public class SelectorImpl extends AbstractSelector
SocketChannelImpl sc = (SocketChannelImpl) ch; SocketChannelImpl sc = (SocketChannelImpl) ch;
SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, sc.fd); SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, sc.fd);
add (impl); add (impl);
impl.interestOps (ops);
impl.attach (att);
return impl; return impl;
} }
else if (ch instanceof DatagramChannelImpl)
{
DatagramChannelImpl dc = (DatagramChannelImpl) ch;
SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, dc.fd);
add (impl);
impl.interestOps (ops);
impl.attach (att);
return impl;
}
else if (ch instanceof ServerSocketChannelImpl) else if (ch instanceof ServerSocketChannelImpl)
{ {
ServerSocketChannelImpl ssc = (ServerSocketChannelImpl) ch; ServerSocketChannelImpl ssc = (ServerSocketChannelImpl) ch;
SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, ssc.fd); SelectionKeyImpl impl = new SelectionKeyImpl (ch, this, ssc.fd);
add (impl); add (impl);
impl.interestOps (ops);
impl.attach (att);
return impl; return impl;
} }
else else
......
...@@ -54,14 +54,8 @@ class ServerSocketChannelImpl extends ServerSocketChannel ...@@ -54,14 +54,8 @@ class ServerSocketChannelImpl extends ServerSocketChannel
boolean connected = false; boolean connected = false;
// InetSocketAddress sa; // InetSocketAddress sa;
// private static native int NioSocketAccept (ServerSocketChannelImpl server, private static native int SocketAccept (ServerSocketChannelImpl server,
// SocketChannelImpl s); SocketChannelImpl s);
private static int NioSocketAccept (ServerSocketChannelImpl server,
SocketChannelImpl s)
{
return 0;
}
protected ServerSocketChannelImpl (SelectorProvider provider) protected ServerSocketChannelImpl (SelectorProvider provider)
{ {
...@@ -101,13 +95,14 @@ class ServerSocketChannelImpl extends ServerSocketChannel ...@@ -101,13 +95,14 @@ class ServerSocketChannelImpl extends ServerSocketChannel
protected void implConfigureBlocking (boolean block) protected void implConfigureBlocking (boolean block)
{ {
blocking = block;
} }
public SocketChannel accept () public SocketChannel accept ()
{ {
SocketChannelImpl result = new SocketChannelImpl (provider ()); SocketChannelImpl result = new SocketChannelImpl (provider ());
result.sa = new InetSocketAddress (0); result.sa = new InetSocketAddress (0);
int res = NioSocketAccept (this, result); int res = SocketAccept (this,result);
return result; return result;
} }
......
...@@ -57,25 +57,14 @@ public class SocketChannelImpl extends SocketChannel ...@@ -57,25 +57,14 @@ public class SocketChannelImpl extends SocketChannel
boolean connected = false; boolean connected = false;
InetSocketAddress sa; InetSocketAddress sa;
/*
static native int SocketCreate(); static native int SocketCreate();
static native int SocketConnect(int fd, InetAddress a, int port); static native int SocketConnect(int fd, InetAddress addr, int port);
static native int SocketBind(int fd, InetAddress host, int port); static native int SocketBind(int fd, InetAddress addr, int port);
static native int SocketListen(int fd, int backlog); static native int SocketListen(int fd, int backlog);
static native int SocketAvailable(int fd); static native int SocketAvailable(int fd);
static native int SocketClose(int fd); static native int SocketClose(int fd);
static native int SocketRead(int fd, byte b[], int off, int len); static native int SocketRead(int fd, byte b[], int off, int len);
static native int SocketWrite(int fd, byte b[], int off, int len); static native int SocketWrite(int fd, byte b[], int off, int len);
*/
static int SocketCreate() { return 0; };
static int SocketConnect(int fd, InetAddress a, int port) { return 0; };
static int SocketBind(int fd, InetAddress host, int port) { return 0; };
static int SocketListen(int fd, int backlog) { return 0; };
static int SocketAvailable(int fd) { return 0; };
static int SocketClose(int fd) { return 0; };
static int SocketRead(int fd, byte b[], int off, int len) { return 0; };
static int SocketWrite(int fd, byte b[], int off, int len) { return 0; };
public SocketChannelImpl(SelectorProvider provider) public SocketChannelImpl(SelectorProvider provider)
{ {
...@@ -87,7 +76,7 @@ public class SocketChannelImpl extends SocketChannel ...@@ -87,7 +76,7 @@ public class SocketChannelImpl extends SocketChannel
System.err.println("failed to create socket:"+fd); System.err.println("failed to create socket:"+fd);
} }
} }
public void finalizer() public void finalizer()
{ {
if (connected) if (connected)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment