8223532: Don't try creating IPv4 sockets in NetworkInterface.c if IPv4 is not supported

Reviewed-by: dfuchs, chegar
This commit is contained in:
Arthur Eubanks 2019-05-07 16:18:21 -07:00 committed by Arthur Eubanks
parent 47a39418fa
commit 4e1d7a6caa

View File

@ -807,17 +807,19 @@ static netif *enumInterfaces(JNIEnv *env) {
int sock; int sock;
sock = openSocket(env, AF_INET); sock = openSocket(env, AF_INET);
if (sock < 0) { if (sock < 0 && (*env)->ExceptionOccurred(env)) {
return NULL; return NULL;
} }
// enumerate IPv4 addresses // enumerate IPv4 addresses
ifs = enumIPv4Interfaces(env, sock, NULL); if (sock >= 0) {
close(sock); ifs = enumIPv4Interfaces(env, sock, ifs);
close(sock);
// return partial list if an exception occurs in the middle of process ??? if ((*env)->ExceptionOccurred(env)) {
if (ifs == NULL && (*env)->ExceptionOccurred(env)) { freeif(ifs);
return NULL; return NULL;
}
} }
// If IPv6 is available then enumerate IPv6 addresses. // If IPv6 is available then enumerate IPv6 addresses.
@ -1076,9 +1078,9 @@ static int openSocket(JNIEnv *env, int proto) {
int sock; int sock;
if ((sock = socket(proto, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(proto, SOCK_DGRAM, 0)) < 0) {
// If EPROTONOSUPPORT is returned it means we don't have // If we lack support for this address family or protocol,
// support for this proto so don't throw an exception. // don't throw an exception.
if (errno != EPROTONOSUPPORT) { if (errno != EPROTONOSUPPORT && errno != EAFNOSUPPORT) {
JNU_ThrowByNameWithMessageAndLastError JNU_ThrowByNameWithMessageAndLastError
(env, JNU_JAVANETPKG "SocketException", "Socket creation failed"); (env, JNU_JAVANETPKG "SocketException", "Socket creation failed");
} }
@ -1099,7 +1101,7 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) {
int sock; int sock;
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {
if (errno == EPROTONOSUPPORT) { if (errno == EPROTONOSUPPORT || errno == EAFNOSUPPORT) {
if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) {
JNU_ThrowByNameWithMessageAndLastError JNU_ThrowByNameWithMessageAndLastError
(env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed");
@ -1336,7 +1338,7 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) {
int sock; int sock;
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {
if (errno == EPROTONOSUPPORT) { if (errno == EPROTONOSUPPORT || errno == EAFNOSUPPORT) {
if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) {
JNU_ThrowByNameWithMessageAndLastError JNU_ThrowByNameWithMessageAndLastError
(env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed");
@ -1614,7 +1616,7 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) {
struct lifreq if2; struct lifreq if2;
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {
if (errno == EPROTONOSUPPORT) { if (errno == EPROTONOSUPPORT || errno == EAFNOSUPPORT) {
if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) {
JNU_ThrowByNameWithMessageAndLastError JNU_ThrowByNameWithMessageAndLastError
(env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed");
@ -1965,7 +1967,7 @@ static int openSocketWithFallback(JNIEnv *env, const char *ifname) {
int sock; int sock;
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {
if (errno == EPROTONOSUPPORT) { if (errno == EPROTONOSUPPORT || errno == EAFNOSUPPORT) {
if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) { if ((sock = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) {
JNU_ThrowByNameWithMessageAndLastError JNU_ThrowByNameWithMessageAndLastError
(env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed"); (env, JNU_JAVANETPKG "SocketException", "IPV6 Socket creation failed");