java.lang.Object
java.net.Socket
org.newsclub.net.unix.AFSocket<org.newsclub.net.unix.AFVSOCKSocketAddress>
org.newsclub.net.unix.vsock.AFVSOCKSocket
- All Implemented Interfaces:
Closeable,AutoCloseable,org.newsclub.net.unix.AFSocketExtensions,org.newsclub.net.unix.AFSomeSocket,org.newsclub.net.unix.AFSomeSocketThing,org.newsclub.net.unix.FileDescriptorAccess,AFVSOCKSocketExtensions
public final class AFVSOCKSocket
extends org.newsclub.net.unix.AFSocket<org.newsclub.net.unix.AFVSOCKSocketAddress>
implements AFVSOCKSocketExtensions
Implementation of an
AF_VSOCK socket.- Author:
- Christian Kohlschütter
-
Nested Class Summary
Nested classes/interfaces inherited from class org.newsclub.net.unix.AFSocket
org.newsclub.net.unix.AFSocket.Constructor<A extends org.newsclub.net.unix.AFSocketAddress> -
Method Summary
Modifier and TypeMethodDescriptionstatic AFVSOCKSocketconnectTo(org.newsclub.net.unix.AFVSOCKSocketAddress addr) Creates a newAFSocketand connects it to the givenAFVSOCKSocketAddress.static intReturns the local CID.static booleanReturnstrueiffAFVSOCKSockets (sockets of type "AF_VSOCK") are supported by the current Java VM and the kernel.static voidVery basic self-test function.protected AFVSOCKSocketChannelstatic AFVSOCKSocketCreates a new, unboundAFSocket.static AFVSOCKSocketCreates a new, unbound, "strict"AFSocket.Methods inherited from class org.newsclub.net.unix.AFSocket
addCloseable, bind, checkConnectionClosed, close, connect, connect, connectHook, connectTo, connectTo, ensureAncillaryReceiveBufferSize, ensureSupported, ensureUnsafeSupported, forceConnectAddress, getAncillaryReceiveBufferSize, getFileDescriptor, getImplExtensions, getInputStream, getLoadedLibrary, getLocalSocketAddress, getOutputStream, getRemoteSocketAddress, getVersion, isBound, isClosed, isConnected, isRunningOnAndroid, newInstance, removeCloseable, setAncillaryReceiveBufferSize, setShutdownOnClose, socketAddressClass, supports, supports, toStringMethods inherited from class java.net.Socket
getInetAddress, getKeepAlive, getLocalAddress, getLocalPort, getOOBInline, getOption, getPort, getReceiveBufferSize, getReuseAddress, getSendBufferSize, getSoLinger, getSoTimeout, getTcpNoDelay, getTrafficClass, isInputShutdown, isOutputShutdown, sendUrgentData, setKeepAlive, setOOBInline, setOption, setPerformancePreferences, setReceiveBufferSize, setReuseAddress, setSendBufferSize, setSocketImplFactory, setSoLinger, setSoTimeout, setTcpNoDelay, setTrafficClass, shutdownInput, shutdownOutput, supportedOptionsMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.newsclub.net.unix.AFSocketExtensions
ensureAncillaryReceiveBufferSize, getAncillaryReceiveBufferSize, setAncillaryReceiveBufferSize
-
Method Details
-
isSupported
public static boolean isSupported()ReturnstrueiffAFVSOCKSockets (sockets of type "AF_VSOCK") are supported by the current Java VM and the kernel. To supportAFVSOCKSockets, a custom JNI library must be loaded that is supplied with junixsocket, and the system must support AF_VSOCK sockets. This call is equivalent to checkingAFSocket.isSupported()andAFSocket.supports(AFSocketCapability)withAFSocketCapability.CAPABILITY_VSOCK.- Returns:
trueiff supported.
-
newChannel
- Specified by:
newChannelin classorg.newsclub.net.unix.AFSocket<org.newsclub.net.unix.AFVSOCKSocketAddress>
-
newInstance
Creates a new, unboundAFSocket. This "default" implementation is a bit "lenient" with respect to the specification. In particular, we ignore calls toSocket.getTcpNoDelay()andSocket.setTcpNoDelay(boolean).- Returns:
- A new, unbound socket.
- Throws:
IOException- if the operation fails.
-
newStrictInstance
Creates a new, unbound, "strict"AFSocket. This call uses an implementation that tries to be closer to the specification thannewInstance(), at least for some cases.- Returns:
- A new, unbound socket.
- Throws:
IOException- if the operation fails.
-
connectTo
public static AFVSOCKSocket connectTo(org.newsclub.net.unix.AFVSOCKSocketAddress addr) throws IOException Creates a newAFSocketand connects it to the givenAFVSOCKSocketAddress.- Parameters:
addr- The address to connect to.- Returns:
- A new, connected socket.
- Throws:
IOException- if the operation fails.
-
getChannel
- Overrides:
getChannelin classorg.newsclub.net.unix.AFSocket<org.newsclub.net.unix.AFVSOCKSocketAddress>
-
getLocalCID
Returns the local CID. If the system does not support vsock, or status about support cannot be retrieved, -1 (AFVSOCKSocketAddress.VMADDR_CID_ANY) is returned. The value may be cached upon initialization of the library.- Returns:
- The CID, or -1.
- Throws:
IOException- on error.
-
main
Very basic self-test function. Prints "supported" and "capabilities" status to System.out.- Parameters:
args- ignored.
-