aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMicael Karlberg <[email protected]>2018-11-27 12:04:36 +0100
committerMicael Karlberg <[email protected]>2018-11-27 12:04:36 +0100
commita76dbf18074b33774d4c8a58280b690c6f462962 (patch)
tree50fde8509a5e5e8ee6adc7f17771afeb6dc5f6a2
parent75f584009677b67d8cead653244bf55a799207b1 (diff)
parentcdc39e8040e5817bb15c2d035c48cec812047035 (diff)
downloadotp-a76dbf18074b33774d4c8a58280b690c6f462962.tar.gz
otp-a76dbf18074b33774d4c8a58280b690c6f462962.tar.bz2
otp-a76dbf18074b33774d4c8a58280b690c6f462962.zip
Merge branch 'bmk/20181127/nififying_inet_sles10/OTP-14831' into bmk/20180918/nififying_inet/OTP-14831
-rw-r--r--erts/configure.in1
-rw-r--r--erts/emulator/nifs/common/socket_nif.c12
2 files changed, 13 insertions, 0 deletions
diff --git a/erts/configure.in b/erts/configure.in
index 79a1944a03..e6e734728c 100644
--- a/erts/configure.in
+++ b/erts/configure.in
@@ -1595,6 +1595,7 @@ if test x"$ac_cv_header_netinet_sctp_h" = x"yes"; then
struct sctp_paddrparams.spp_flags,
struct sctp_remote_error.sre_data,
struct sctp_send_failed.ssf_data,
+ struct sctp_event_subscribe.sctp_authentication_event,
struct sctp_event_subscribe.sctp_sender_dry_event], [], [],
[#if HAVE_SYS_SOCKET_H
#include <sys/socket.h>
diff --git a/erts/emulator/nifs/common/socket_nif.c b/erts/emulator/nifs/common/socket_nif.c
index cc58918f43..cdd9f0fb15 100644
--- a/erts/emulator/nifs/common/socket_nif.c
+++ b/erts/emulator/nifs/common/socket_nif.c
@@ -9273,8 +9273,10 @@ ERL_NIF_TERM nsetopt_lvl_sctp_events(ErlNifEnv* env,
if (!GET_MAP_VAL(env, eVal, atom_adaptation_layer, &eAdaptLayer))
return esock_make_error(env, esock_atom_einval);
+#if defined(HAVE_STRUCT_SCTP_EVENT_SUBSCRIBE_SCTP_AUTHENTICATION_EVENT)
if (!GET_MAP_VAL(env, eVal, atom_authentication, &eAuth))
return esock_make_error(env, esock_atom_einval);
+#endif
#if defined(HAVE_STRUCT_SCTP_EVENT_SUBSCRIBE_SCTP_SENDER_DRY_EVENT)
if (!GET_MAP_VAL(env, eVal, atom_sender_dry, &eSndDry))
@@ -9292,7 +9294,9 @@ ERL_NIF_TERM nsetopt_lvl_sctp_events(ErlNifEnv* env,
events.sctp_shutdown_event = esock_decode_bool(eShutdown);
events.sctp_partial_delivery_event = esock_decode_bool(ePartialDelivery);
events.sctp_adaptation_layer_event = esock_decode_bool(eAdaptLayer);
+#if defined(HAVE_STRUCT_SCTP_EVENT_SUBSCRIBE_SCTP_AUTHENTICATION_EVENT)
events.sctp_authentication_event = esock_decode_bool(eAuth);
+#endif
#if defined(HAVE_STRUCT_SCTP_EVENT_SUBSCRIBE_SCTP_SENDER_DRY_EVENT)
events.sctp_sender_dry_event = esock_decode_bool(eSndDry);
#endif
@@ -15418,8 +15422,10 @@ char* decode_ip_pmtudisc(ErlNifEnv* env, ERL_NIF_TERM eVal, int* val)
*val = IP_PMTUDISC_DONT;
} else if (COMPARE(eVal, atom_do) == 0) {
*val = IP_PMTUDISC_DO;
+#if defined(IP_PMTUDISC_PROBE)
} else if (COMPARE(eVal, atom_probe) == 0) {
*val = IP_PMTUDISC_PROBE;
+#endif
} else {
*val = -1;
res = ESOCK_STR_EINVAL;
@@ -15469,8 +15475,10 @@ char* decode_ipv6_pmtudisc(ErlNifEnv* env, ERL_NIF_TERM eVal, int* val)
*val = IPV6_PMTUDISC_DONT;
} else if (COMPARE(eVal, atom_do) == 0) {
*val = IPV6_PMTUDISC_DO;
+#if defined(IPV6_PMTUDISC_PROBE)
} else if (COMPARE(eVal, atom_probe) == 0) {
*val = IPV6_PMTUDISC_PROBE;
+#endif
} else {
*val = -1;
res = ESOCK_STR_EINVAL;
@@ -15523,9 +15531,11 @@ void encode_ip_pmtudisc(ErlNifEnv* env, int val, ERL_NIF_TERM* eVal)
*eVal = atom_do;
break;
+#if defined(IP_PMTUDISC_PROBE)
case IP_PMTUDISC_PROBE:
*eVal = atom_probe;
break;
+#endif
default:
*eVal = MKI(env, val);
@@ -15565,9 +15575,11 @@ void encode_ipv6_pmtudisc(ErlNifEnv* env, int val, ERL_NIF_TERM* eVal)
*eVal = atom_do;
break;
+#if defined(IPV6_PMTUDISC_PROBE)
case IPV6_PMTUDISC_PROBE:
*eVal = atom_probe;
break;
+#endif
default:
*eVal = MKI(env, val);