8234103: DatagramSocketImpl::socket is not needed

DatagramSocketImpl has a socket field that links back to the DatagramSocket. This is only used to figure out whether multicasting is supported or not. This fix replaces it with a boolean isMulticast.

Reviewed-by: alanb, chegar, dfuchs
This commit is contained in:
Patrick Concannon 2019-11-20 10:13:10 +00:00
parent a0b8244416
commit e636c69e61
8 changed files with 25 additions and 23 deletions

View File

@ -54,6 +54,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
private int trafficClass = 0; private int trafficClass = 0;
protected InetAddress connectedAddress = null; protected InetAddress connectedAddress = null;
private int connectedPort = -1; private int connectedPort = -1;
private final boolean isMulticast;
private static final String os = private static final String os =
GetPropertyAction.privilegedGetProperty("os.name"); GetPropertyAction.privilegedGetProperty("os.name");
@ -84,6 +85,10 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
return isReusePortAvailable; return isReusePortAvailable;
} }
AbstractPlainDatagramSocketImpl(boolean isMulticast) {
this.isMulticast = isMulticast;
}
/** /**
* Creates a datagram socket * Creates a datagram socket
*/ */
@ -406,6 +411,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
options.add(StandardSocketOptions.SO_SNDBUF); options.add(StandardSocketOptions.SO_SNDBUF);
options.add(StandardSocketOptions.SO_RCVBUF); options.add(StandardSocketOptions.SO_RCVBUF);
options.add(StandardSocketOptions.SO_REUSEADDR); options.add(StandardSocketOptions.SO_REUSEADDR);
options.add(StandardSocketOptions.SO_BROADCAST);
options.add(StandardSocketOptions.IP_TOS); options.add(StandardSocketOptions.IP_TOS);
if (isReusePortAvailable()) if (isReusePortAvailable())
options.add(StandardSocketOptions.SO_REUSEPORT); options.add(StandardSocketOptions.SO_REUSEPORT);
@ -418,6 +424,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
options.add(StandardSocketOptions.SO_SNDBUF); options.add(StandardSocketOptions.SO_SNDBUF);
options.add(StandardSocketOptions.SO_RCVBUF); options.add(StandardSocketOptions.SO_RCVBUF);
options.add(StandardSocketOptions.SO_REUSEADDR); options.add(StandardSocketOptions.SO_REUSEADDR);
options.add(StandardSocketOptions.SO_BROADCAST);
options.add(StandardSocketOptions.IP_TOS); options.add(StandardSocketOptions.IP_TOS);
options.add(StandardSocketOptions.IP_MULTICAST_IF); options.add(StandardSocketOptions.IP_MULTICAST_IF);
options.add(StandardSocketOptions.IP_MULTICAST_TTL); options.add(StandardSocketOptions.IP_MULTICAST_TTL);
@ -430,7 +437,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
@Override @Override
protected Set<SocketOption<?>> supportedOptions() { protected Set<SocketOption<?>> supportedOptions() {
if (getDatagramSocket() instanceof MulticastSocket) if (isMulticast)
return multicastSocketOptions; return multicastSocketOptions;
else else
return datagramSocketOptions; return datagramSocketOptions;
@ -460,6 +467,8 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
setOption(SocketOptions.SO_REUSEADDR, value); setOption(SocketOptions.SO_REUSEADDR, value);
} else if (name == StandardSocketOptions.SO_REUSEPORT) { } else if (name == StandardSocketOptions.SO_REUSEPORT) {
setOption(SocketOptions.SO_REUSEPORT, value); setOption(SocketOptions.SO_REUSEPORT, value);
} else if (name == StandardSocketOptions.SO_BROADCAST) {
setOption(SocketOptions.SO_BROADCAST, value);
} else if (name == StandardSocketOptions.IP_TOS) { } else if (name == StandardSocketOptions.IP_TOS) {
int i = ((Integer)value).intValue(); int i = ((Integer)value).intValue();
if (i < 0 || i > 255) if (i < 0 || i > 255)
@ -499,6 +508,8 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl
return (T) getOption(SocketOptions.SO_REUSEADDR); return (T) getOption(SocketOptions.SO_REUSEADDR);
} else if (name == StandardSocketOptions.SO_REUSEPORT) { } else if (name == StandardSocketOptions.SO_REUSEPORT) {
return (T) getOption(SocketOptions.SO_REUSEPORT); return (T) getOption(SocketOptions.SO_REUSEPORT);
} else if (name == StandardSocketOptions.SO_BROADCAST) {
return (T) getOption(SocketOptions.SO_BROADCAST);
} else if (name == StandardSocketOptions.IP_TOS) { } else if (name == StandardSocketOptions.IP_TOS) {
return (T) getOption(SocketOptions.IP_TOS); return (T) getOption(SocketOptions.IP_TOS);
} else if (name == StandardSocketOptions.IP_MULTICAST_IF) { } else if (name == StandardSocketOptions.IP_MULTICAST_IF) {

View File

@ -338,7 +338,6 @@ class DatagramSocket implements java.io.Closeable {
} }
// creates a udp socket // creates a udp socket
impl.create(); impl.create();
impl.setDatagramSocket(this);
created = true; created = true;
} }

View File

@ -48,20 +48,6 @@ public abstract class DatagramSocketImpl implements SocketOptions {
*/ */
protected FileDescriptor fd; protected FileDescriptor fd;
/**
* The DatagramSocket or MulticastSocket
* that owns this impl
*/
DatagramSocket socket;
void setDatagramSocket(DatagramSocket socket) {
this.socket = socket;
}
DatagramSocket getDatagramSocket() {
return socket;
}
int dataAvailable() { int dataAvailable() {
// default impl returns zero, which disables the calling // default impl returns zero, which disables the calling
// functionality // functionality

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -69,7 +69,7 @@ class DefaultDatagramSocketImplFactory {
throw new SocketException("can't instantiate DatagramSocketImpl"); throw new SocketException("can't instantiate DatagramSocketImpl");
} }
} else { } else {
return new java.net.PlainDatagramSocketImpl(); return new java.net.PlainDatagramSocketImpl(isMulticast);
} }
} }
} }

View File

@ -37,6 +37,10 @@ import sun.net.ext.ExtendedSocketOptions;
class PlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl class PlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl
{ {
PlainDatagramSocketImpl(boolean isMulticast) {
super(isMulticast);
}
static { static {
init(); init();
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -100,7 +100,7 @@ class DefaultDatagramSocketImplFactory
if (!preferIPv4Stack && !isMulticast) if (!preferIPv4Stack && !isMulticast)
return new DualStackPlainDatagramSocketImpl(exclusiveBind); return new DualStackPlainDatagramSocketImpl(exclusiveBind);
else else
return new TwoStacksPlainDatagramSocketImpl(exclusiveBind && !isMulticast); return new TwoStacksPlainDatagramSocketImpl(exclusiveBind && !isMulticast, isMulticast);
} }
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2018, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -62,6 +62,7 @@ class DualStackPlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl
private boolean isReuseAddress; private boolean isReuseAddress;
DualStackPlainDatagramSocketImpl(boolean exclBind) { DualStackPlainDatagramSocketImpl(boolean exclBind) {
super(false);
exclusiveBind = exclBind; exclusiveBind = exclBind;
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2018, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -78,7 +78,8 @@ final class TwoStacksPlainDatagramSocketImpl extends AbstractPlainDatagramSocket
// emulates SO_REUSEADDR when exclusiveBind is true and socket is bound // emulates SO_REUSEADDR when exclusiveBind is true and socket is bound
private boolean isReuseAddress; private boolean isReuseAddress;
TwoStacksPlainDatagramSocketImpl(boolean exclBind) { TwoStacksPlainDatagramSocketImpl(boolean exclBind, boolean isMulticast) {
super(isMulticast);
exclusiveBind = exclBind; exclusiveBind = exclBind;
} }