From e636c69e61996f55e8bd869ed41ae43fe93ead73 Mon Sep 17 00:00:00 2001 From: Patrick Concannon Date: Wed, 20 Nov 2019 10:13:10 +0000 Subject: [PATCH] 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 --- .../java/net/AbstractPlainDatagramSocketImpl.java | 13 ++++++++++++- .../share/classes/java/net/DatagramSocket.java | 1 - .../share/classes/java/net/DatagramSocketImpl.java | 14 -------------- .../java/net/DefaultDatagramSocketImplFactory.java | 4 ++-- .../classes/java/net/PlainDatagramSocketImpl.java | 4 ++++ .../java/net/DefaultDatagramSocketImplFactory.java | 4 ++-- .../java/net/DualStackPlainDatagramSocketImpl.java | 3 ++- .../java/net/TwoStacksPlainDatagramSocketImpl.java | 5 +++-- 8 files changed, 25 insertions(+), 23 deletions(-) diff --git a/src/java.base/share/classes/java/net/AbstractPlainDatagramSocketImpl.java b/src/java.base/share/classes/java/net/AbstractPlainDatagramSocketImpl.java index c3764ab45d3..5191675b444 100644 --- a/src/java.base/share/classes/java/net/AbstractPlainDatagramSocketImpl.java +++ b/src/java.base/share/classes/java/net/AbstractPlainDatagramSocketImpl.java @@ -54,6 +54,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl private int trafficClass = 0; protected InetAddress connectedAddress = null; private int connectedPort = -1; + private final boolean isMulticast; private static final String os = GetPropertyAction.privilegedGetProperty("os.name"); @@ -84,6 +85,10 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl return isReusePortAvailable; } + AbstractPlainDatagramSocketImpl(boolean isMulticast) { + this.isMulticast = isMulticast; + } + /** * Creates a datagram socket */ @@ -406,6 +411,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl options.add(StandardSocketOptions.SO_SNDBUF); options.add(StandardSocketOptions.SO_RCVBUF); options.add(StandardSocketOptions.SO_REUSEADDR); + options.add(StandardSocketOptions.SO_BROADCAST); options.add(StandardSocketOptions.IP_TOS); if (isReusePortAvailable()) options.add(StandardSocketOptions.SO_REUSEPORT); @@ -418,6 +424,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl options.add(StandardSocketOptions.SO_SNDBUF); options.add(StandardSocketOptions.SO_RCVBUF); options.add(StandardSocketOptions.SO_REUSEADDR); + options.add(StandardSocketOptions.SO_BROADCAST); options.add(StandardSocketOptions.IP_TOS); options.add(StandardSocketOptions.IP_MULTICAST_IF); options.add(StandardSocketOptions.IP_MULTICAST_TTL); @@ -430,7 +437,7 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl @Override protected Set> supportedOptions() { - if (getDatagramSocket() instanceof MulticastSocket) + if (isMulticast) return multicastSocketOptions; else return datagramSocketOptions; @@ -460,6 +467,8 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl setOption(SocketOptions.SO_REUSEADDR, value); } else if (name == StandardSocketOptions.SO_REUSEPORT) { setOption(SocketOptions.SO_REUSEPORT, value); + } else if (name == StandardSocketOptions.SO_BROADCAST) { + setOption(SocketOptions.SO_BROADCAST, value); } else if (name == StandardSocketOptions.IP_TOS) { int i = ((Integer)value).intValue(); if (i < 0 || i > 255) @@ -499,6 +508,8 @@ abstract class AbstractPlainDatagramSocketImpl extends DatagramSocketImpl return (T) getOption(SocketOptions.SO_REUSEADDR); } else if (name == StandardSocketOptions.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) { return (T) getOption(SocketOptions.IP_TOS); } else if (name == StandardSocketOptions.IP_MULTICAST_IF) { diff --git a/src/java.base/share/classes/java/net/DatagramSocket.java b/src/java.base/share/classes/java/net/DatagramSocket.java index c176718edfb..e538221ae21 100644 --- a/src/java.base/share/classes/java/net/DatagramSocket.java +++ b/src/java.base/share/classes/java/net/DatagramSocket.java @@ -338,7 +338,6 @@ class DatagramSocket implements java.io.Closeable { } // creates a udp socket impl.create(); - impl.setDatagramSocket(this); created = true; } diff --git a/src/java.base/share/classes/java/net/DatagramSocketImpl.java b/src/java.base/share/classes/java/net/DatagramSocketImpl.java index 94144322b88..5e396b2cf66 100644 --- a/src/java.base/share/classes/java/net/DatagramSocketImpl.java +++ b/src/java.base/share/classes/java/net/DatagramSocketImpl.java @@ -48,20 +48,6 @@ public abstract class DatagramSocketImpl implements SocketOptions { */ 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() { // default impl returns zero, which disables the calling // functionality diff --git a/src/java.base/unix/classes/java/net/DefaultDatagramSocketImplFactory.java b/src/java.base/unix/classes/java/net/DefaultDatagramSocketImplFactory.java index c6d20b08985..1c459864912 100644 --- a/src/java.base/unix/classes/java/net/DefaultDatagramSocketImplFactory.java +++ b/src/java.base/unix/classes/java/net/DefaultDatagramSocketImplFactory.java @@ -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. * * 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"); } } else { - return new java.net.PlainDatagramSocketImpl(); + return new java.net.PlainDatagramSocketImpl(isMulticast); } } } diff --git a/src/java.base/unix/classes/java/net/PlainDatagramSocketImpl.java b/src/java.base/unix/classes/java/net/PlainDatagramSocketImpl.java index 0ce98dd4cbe..73fc4376106 100644 --- a/src/java.base/unix/classes/java/net/PlainDatagramSocketImpl.java +++ b/src/java.base/unix/classes/java/net/PlainDatagramSocketImpl.java @@ -37,6 +37,10 @@ import sun.net.ext.ExtendedSocketOptions; class PlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl { + PlainDatagramSocketImpl(boolean isMulticast) { + super(isMulticast); + } + static { init(); } diff --git a/src/java.base/windows/classes/java/net/DefaultDatagramSocketImplFactory.java b/src/java.base/windows/classes/java/net/DefaultDatagramSocketImplFactory.java index a85e701efc2..62a93995b8d 100644 --- a/src/java.base/windows/classes/java/net/DefaultDatagramSocketImplFactory.java +++ b/src/java.base/windows/classes/java/net/DefaultDatagramSocketImplFactory.java @@ -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. * * This code is free software; you can redistribute it and/or modify it @@ -100,7 +100,7 @@ class DefaultDatagramSocketImplFactory if (!preferIPv4Stack && !isMulticast) return new DualStackPlainDatagramSocketImpl(exclusiveBind); else - return new TwoStacksPlainDatagramSocketImpl(exclusiveBind && !isMulticast); + return new TwoStacksPlainDatagramSocketImpl(exclusiveBind && !isMulticast, isMulticast); } } } diff --git a/src/java.base/windows/classes/java/net/DualStackPlainDatagramSocketImpl.java b/src/java.base/windows/classes/java/net/DualStackPlainDatagramSocketImpl.java index 3490f832b9a..02a3f3f4000 100644 --- a/src/java.base/windows/classes/java/net/DualStackPlainDatagramSocketImpl.java +++ b/src/java.base/windows/classes/java/net/DualStackPlainDatagramSocketImpl.java @@ -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. * * This code is free software; you can redistribute it and/or modify it @@ -62,6 +62,7 @@ class DualStackPlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl private boolean isReuseAddress; DualStackPlainDatagramSocketImpl(boolean exclBind) { + super(false); exclusiveBind = exclBind; } diff --git a/src/java.base/windows/classes/java/net/TwoStacksPlainDatagramSocketImpl.java b/src/java.base/windows/classes/java/net/TwoStacksPlainDatagramSocketImpl.java index dd75ccef5be..3fe987464e8 100644 --- a/src/java.base/windows/classes/java/net/TwoStacksPlainDatagramSocketImpl.java +++ b/src/java.base/windows/classes/java/net/TwoStacksPlainDatagramSocketImpl.java @@ -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. * * 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 private boolean isReuseAddress; - TwoStacksPlainDatagramSocketImpl(boolean exclBind) { + TwoStacksPlainDatagramSocketImpl(boolean exclBind, boolean isMulticast) { + super(isMulticast); exclusiveBind = exclBind; }