diff options
Diffstat (limited to 'src/lib/libcrypto/bio')
-rw-r--r-- | src/lib/libcrypto/bio/bss_dgram.c | 91 | ||||
-rw-r--r-- | src/lib/libcrypto/bio/bss_log.c | 2 |
2 files changed, 63 insertions, 30 deletions
diff --git a/src/lib/libcrypto/bio/bss_dgram.c b/src/lib/libcrypto/bio/bss_dgram.c index 1b1e4bec81..54c012c47d 100644 --- a/src/lib/libcrypto/bio/bss_dgram.c +++ b/src/lib/libcrypto/bio/bss_dgram.c | |||
@@ -77,10 +77,20 @@ | |||
77 | #define OPENSSL_SCTP_FORWARD_CUM_TSN_CHUNK_TYPE 0xc0 | 77 | #define OPENSSL_SCTP_FORWARD_CUM_TSN_CHUNK_TYPE 0xc0 |
78 | #endif | 78 | #endif |
79 | 79 | ||
80 | #ifdef OPENSSL_SYS_LINUX | 80 | #if defined(OPENSSL_SYS_LINUX) && !defined(IP_MTU) |
81 | #define IP_MTU 14 /* linux is lame */ | 81 | #define IP_MTU 14 /* linux is lame */ |
82 | #endif | 82 | #endif |
83 | 83 | ||
84 | #if defined(__FreeBSD__) && defined(IN6_IS_ADDR_V4MAPPED) | ||
85 | /* Standard definition causes type-punning problems. */ | ||
86 | #undef IN6_IS_ADDR_V4MAPPED | ||
87 | #define s6_addr32 __u6_addr.__u6_addr32 | ||
88 | #define IN6_IS_ADDR_V4MAPPED(a) \ | ||
89 | (((a)->s6_addr32[0] == 0) && \ | ||
90 | ((a)->s6_addr32[1] == 0) && \ | ||
91 | ((a)->s6_addr32[2] == htonl(0x0000ffff))) | ||
92 | #endif | ||
93 | |||
84 | #ifdef WATT32 | 94 | #ifdef WATT32 |
85 | #define sock_write SockWrite /* Watt-32 uses same names */ | 95 | #define sock_write SockWrite /* Watt-32 uses same names */ |
86 | #define sock_read SockRead | 96 | #define sock_read SockRead |
@@ -255,7 +265,7 @@ static void dgram_adjust_rcv_timeout(BIO *b) | |||
255 | { | 265 | { |
256 | #if defined(SO_RCVTIMEO) | 266 | #if defined(SO_RCVTIMEO) |
257 | bio_dgram_data *data = (bio_dgram_data *)b->ptr; | 267 | bio_dgram_data *data = (bio_dgram_data *)b->ptr; |
258 | int sz = sizeof(int); | 268 | union { size_t s; int i; } sz = {0}; |
259 | 269 | ||
260 | /* Is a timer active? */ | 270 | /* Is a timer active? */ |
261 | if (data->next_timeout.tv_sec > 0 || data->next_timeout.tv_usec > 0) | 271 | if (data->next_timeout.tv_sec > 0 || data->next_timeout.tv_usec > 0) |
@@ -265,8 +275,10 @@ static void dgram_adjust_rcv_timeout(BIO *b) | |||
265 | /* Read current socket timeout */ | 275 | /* Read current socket timeout */ |
266 | #ifdef OPENSSL_SYS_WINDOWS | 276 | #ifdef OPENSSL_SYS_WINDOWS |
267 | int timeout; | 277 | int timeout; |
278 | |||
279 | sz.i = sizeof(timeout); | ||
268 | if (getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, | 280 | if (getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, |
269 | (void*)&timeout, &sz) < 0) | 281 | (void*)&timeout, &sz.i) < 0) |
270 | { perror("getsockopt"); } | 282 | { perror("getsockopt"); } |
271 | else | 283 | else |
272 | { | 284 | { |
@@ -274,9 +286,12 @@ static void dgram_adjust_rcv_timeout(BIO *b) | |||
274 | data->socket_timeout.tv_usec = (timeout % 1000) * 1000; | 286 | data->socket_timeout.tv_usec = (timeout % 1000) * 1000; |
275 | } | 287 | } |
276 | #else | 288 | #else |
289 | sz.i = sizeof(data->socket_timeout); | ||
277 | if ( getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, | 290 | if ( getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, |
278 | &(data->socket_timeout), (void *)&sz) < 0) | 291 | &(data->socket_timeout), (void *)&sz) < 0) |
279 | { perror("getsockopt"); } | 292 | { perror("getsockopt"); } |
293 | else if (sizeof(sz.s)!=sizeof(sz.i) && sz.i==0) | ||
294 | OPENSSL_assert(sz.s<=sizeof(data->socket_timeout)); | ||
280 | #endif | 295 | #endif |
281 | 296 | ||
282 | /* Get current time */ | 297 | /* Get current time */ |
@@ -445,11 +460,10 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
445 | int *ip; | 460 | int *ip; |
446 | struct sockaddr *to = NULL; | 461 | struct sockaddr *to = NULL; |
447 | bio_dgram_data *data = NULL; | 462 | bio_dgram_data *data = NULL; |
448 | #if defined(IP_MTU_DISCOVER) || defined(IP_MTU) | 463 | #if defined(OPENSSL_SYS_LINUX) && (defined(IP_MTU_DISCOVER) || defined(IP_MTU)) |
449 | long sockopt_val = 0; | 464 | int sockopt_val = 0; |
450 | unsigned int sockopt_len = 0; | 465 | socklen_t sockopt_len; /* assume that system supporting IP_MTU is |
451 | #endif | 466 | * modern enough to define socklen_t */ |
452 | #ifdef OPENSSL_SYS_LINUX | ||
453 | socklen_t addr_len; | 467 | socklen_t addr_len; |
454 | union { | 468 | union { |
455 | struct sockaddr sa; | 469 | struct sockaddr sa; |
@@ -531,7 +545,7 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
531 | break; | 545 | break; |
532 | /* (Linux)kernel sets DF bit on outgoing IP packets */ | 546 | /* (Linux)kernel sets DF bit on outgoing IP packets */ |
533 | case BIO_CTRL_DGRAM_MTU_DISCOVER: | 547 | case BIO_CTRL_DGRAM_MTU_DISCOVER: |
534 | #ifdef OPENSSL_SYS_LINUX | 548 | #if defined(OPENSSL_SYS_LINUX) && defined(IP_MTU_DISCOVER) && defined(IP_PMTUDISC_DO) |
535 | addr_len = (socklen_t)sizeof(addr); | 549 | addr_len = (socklen_t)sizeof(addr); |
536 | memset((void *)&addr, 0, sizeof(addr)); | 550 | memset((void *)&addr, 0, sizeof(addr)); |
537 | if (getsockname(b->num, &addr.sa, &addr_len) < 0) | 551 | if (getsockname(b->num, &addr.sa, &addr_len) < 0) |
@@ -539,7 +553,6 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
539 | ret = 0; | 553 | ret = 0; |
540 | break; | 554 | break; |
541 | } | 555 | } |
542 | sockopt_len = sizeof(sockopt_val); | ||
543 | switch (addr.sa.sa_family) | 556 | switch (addr.sa.sa_family) |
544 | { | 557 | { |
545 | case AF_INET: | 558 | case AF_INET: |
@@ -548,7 +561,7 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
548 | &sockopt_val, sizeof(sockopt_val))) < 0) | 561 | &sockopt_val, sizeof(sockopt_val))) < 0) |
549 | perror("setsockopt"); | 562 | perror("setsockopt"); |
550 | break; | 563 | break; |
551 | #if OPENSSL_USE_IPV6 && defined(IPV6_MTU_DISCOVER) | 564 | #if OPENSSL_USE_IPV6 && defined(IPV6_MTU_DISCOVER) && defined(IPV6_PMTUDISC_DO) |
552 | case AF_INET6: | 565 | case AF_INET6: |
553 | sockopt_val = IPV6_PMTUDISC_DO; | 566 | sockopt_val = IPV6_PMTUDISC_DO; |
554 | if ((ret = setsockopt(b->num, IPPROTO_IPV6, IPV6_MTU_DISCOVER, | 567 | if ((ret = setsockopt(b->num, IPPROTO_IPV6, IPV6_MTU_DISCOVER, |
@@ -565,7 +578,7 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
565 | break; | 578 | break; |
566 | #endif | 579 | #endif |
567 | case BIO_CTRL_DGRAM_QUERY_MTU: | 580 | case BIO_CTRL_DGRAM_QUERY_MTU: |
568 | #ifdef OPENSSL_SYS_LINUX | 581 | #if defined(OPENSSL_SYS_LINUX) && defined(IP_MTU) |
569 | addr_len = (socklen_t)sizeof(addr); | 582 | addr_len = (socklen_t)sizeof(addr); |
570 | memset((void *)&addr, 0, sizeof(addr)); | 583 | memset((void *)&addr, 0, sizeof(addr)); |
571 | if (getsockname(b->num, &addr.sa, &addr_len) < 0) | 584 | if (getsockname(b->num, &addr.sa, &addr_len) < 0) |
@@ -727,12 +740,15 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
727 | #endif | 740 | #endif |
728 | break; | 741 | break; |
729 | case BIO_CTRL_DGRAM_GET_RECV_TIMEOUT: | 742 | case BIO_CTRL_DGRAM_GET_RECV_TIMEOUT: |
730 | #ifdef OPENSSL_SYS_WINDOWS | ||
731 | { | 743 | { |
732 | int timeout, sz = sizeof(timeout); | 744 | union { size_t s; int i; } sz = {0}; |
745 | #ifdef OPENSSL_SYS_WINDOWS | ||
746 | int timeout; | ||
733 | struct timeval *tv = (struct timeval *)ptr; | 747 | struct timeval *tv = (struct timeval *)ptr; |
748 | |||
749 | sz.i = sizeof(timeout); | ||
734 | if (getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, | 750 | if (getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, |
735 | (void*)&timeout, &sz) < 0) | 751 | (void*)&timeout, &sz.i) < 0) |
736 | { perror("getsockopt"); ret = -1; } | 752 | { perror("getsockopt"); ret = -1; } |
737 | else | 753 | else |
738 | { | 754 | { |
@@ -740,12 +756,20 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
740 | tv->tv_usec = (timeout % 1000) * 1000; | 756 | tv->tv_usec = (timeout % 1000) * 1000; |
741 | ret = sizeof(*tv); | 757 | ret = sizeof(*tv); |
742 | } | 758 | } |
743 | } | ||
744 | #else | 759 | #else |
760 | sz.i = sizeof(struct timeval); | ||
745 | if ( getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, | 761 | if ( getsockopt(b->num, SOL_SOCKET, SO_RCVTIMEO, |
746 | ptr, (void *)&ret) < 0) | 762 | ptr, (void *)&sz) < 0) |
747 | { perror("getsockopt"); ret = -1; } | 763 | { perror("getsockopt"); ret = -1; } |
764 | else if (sizeof(sz.s)!=sizeof(sz.i) && sz.i==0) | ||
765 | { | ||
766 | OPENSSL_assert(sz.s<=sizeof(struct timeval)); | ||
767 | ret = (int)sz.s; | ||
768 | } | ||
769 | else | ||
770 | ret = sz.i; | ||
748 | #endif | 771 | #endif |
772 | } | ||
749 | break; | 773 | break; |
750 | #endif | 774 | #endif |
751 | #if defined(SO_SNDTIMEO) | 775 | #if defined(SO_SNDTIMEO) |
@@ -765,12 +789,15 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
765 | #endif | 789 | #endif |
766 | break; | 790 | break; |
767 | case BIO_CTRL_DGRAM_GET_SEND_TIMEOUT: | 791 | case BIO_CTRL_DGRAM_GET_SEND_TIMEOUT: |
768 | #ifdef OPENSSL_SYS_WINDOWS | ||
769 | { | 792 | { |
770 | int timeout, sz = sizeof(timeout); | 793 | union { size_t s; int i; } sz = {0}; |
794 | #ifdef OPENSSL_SYS_WINDOWS | ||
795 | int timeout; | ||
771 | struct timeval *tv = (struct timeval *)ptr; | 796 | struct timeval *tv = (struct timeval *)ptr; |
797 | |||
798 | sz.i = sizeof(timeout); | ||
772 | if (getsockopt(b->num, SOL_SOCKET, SO_SNDTIMEO, | 799 | if (getsockopt(b->num, SOL_SOCKET, SO_SNDTIMEO, |
773 | (void*)&timeout, &sz) < 0) | 800 | (void*)&timeout, &sz.i) < 0) |
774 | { perror("getsockopt"); ret = -1; } | 801 | { perror("getsockopt"); ret = -1; } |
775 | else | 802 | else |
776 | { | 803 | { |
@@ -778,12 +805,20 @@ static long dgram_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
778 | tv->tv_usec = (timeout % 1000) * 1000; | 805 | tv->tv_usec = (timeout % 1000) * 1000; |
779 | ret = sizeof(*tv); | 806 | ret = sizeof(*tv); |
780 | } | 807 | } |
781 | } | ||
782 | #else | 808 | #else |
809 | sz.i = sizeof(struct timeval); | ||
783 | if ( getsockopt(b->num, SOL_SOCKET, SO_SNDTIMEO, | 810 | if ( getsockopt(b->num, SOL_SOCKET, SO_SNDTIMEO, |
784 | ptr, (void *)&ret) < 0) | 811 | ptr, (void *)&sz) < 0) |
785 | { perror("getsockopt"); ret = -1; } | 812 | { perror("getsockopt"); ret = -1; } |
813 | else if (sizeof(sz.s)!=sizeof(sz.i) && sz.i==0) | ||
814 | { | ||
815 | OPENSSL_assert(sz.s<=sizeof(struct timeval)); | ||
816 | ret = (int)sz.s; | ||
817 | } | ||
818 | else | ||
819 | ret = sz.i; | ||
786 | #endif | 820 | #endif |
821 | } | ||
787 | break; | 822 | break; |
788 | #endif | 823 | #endif |
789 | case BIO_CTRL_DGRAM_GET_SEND_TIMER_EXP: | 824 | case BIO_CTRL_DGRAM_GET_SEND_TIMER_EXP: |
@@ -871,8 +906,8 @@ BIO *BIO_new_dgram_sctp(int fd, int close_flag) | |||
871 | memset(authchunks, 0, sizeof(sockopt_len)); | 906 | memset(authchunks, 0, sizeof(sockopt_len)); |
872 | ret = getsockopt(fd, IPPROTO_SCTP, SCTP_LOCAL_AUTH_CHUNKS, authchunks, &sockopt_len); | 907 | ret = getsockopt(fd, IPPROTO_SCTP, SCTP_LOCAL_AUTH_CHUNKS, authchunks, &sockopt_len); |
873 | OPENSSL_assert(ret >= 0); | 908 | OPENSSL_assert(ret >= 0); |
874 | 909 | ||
875 | for (p = (unsigned char*) authchunks + sizeof(sctp_assoc_t); | 910 | for (p = (unsigned char*) authchunks->gauth_chunks; |
876 | p < (unsigned char*) authchunks + sockopt_len; | 911 | p < (unsigned char*) authchunks + sockopt_len; |
877 | p += sizeof(uint8_t)) | 912 | p += sizeof(uint8_t)) |
878 | { | 913 | { |
@@ -955,7 +990,6 @@ static int dgram_sctp_free(BIO *a) | |||
955 | #ifdef SCTP_AUTHENTICATION_EVENT | 990 | #ifdef SCTP_AUTHENTICATION_EVENT |
956 | void dgram_sctp_handle_auth_free_key_event(BIO *b, union sctp_notification *snp) | 991 | void dgram_sctp_handle_auth_free_key_event(BIO *b, union sctp_notification *snp) |
957 | { | 992 | { |
958 | unsigned int sockopt_len = 0; | ||
959 | int ret; | 993 | int ret; |
960 | struct sctp_authkey_event* authkeyevent = &snp->sn_auth_event; | 994 | struct sctp_authkey_event* authkeyevent = &snp->sn_auth_event; |
961 | 995 | ||
@@ -965,9 +999,8 @@ void dgram_sctp_handle_auth_free_key_event(BIO *b, union sctp_notification *snp) | |||
965 | 999 | ||
966 | /* delete key */ | 1000 | /* delete key */ |
967 | authkeyid.scact_keynumber = authkeyevent->auth_keynumber; | 1001 | authkeyid.scact_keynumber = authkeyevent->auth_keynumber; |
968 | sockopt_len = sizeof(struct sctp_authkeyid); | ||
969 | ret = setsockopt(b->num, IPPROTO_SCTP, SCTP_AUTH_DELETE_KEY, | 1002 | ret = setsockopt(b->num, IPPROTO_SCTP, SCTP_AUTH_DELETE_KEY, |
970 | &authkeyid, sockopt_len); | 1003 | &authkeyid, sizeof(struct sctp_authkeyid)); |
971 | } | 1004 | } |
972 | } | 1005 | } |
973 | #endif | 1006 | #endif |
@@ -1164,7 +1197,7 @@ static int dgram_sctp_read(BIO *b, char *out, int outl) | |||
1164 | ii = getsockopt(b->num, IPPROTO_SCTP, SCTP_PEER_AUTH_CHUNKS, authchunks, &optlen); | 1197 | ii = getsockopt(b->num, IPPROTO_SCTP, SCTP_PEER_AUTH_CHUNKS, authchunks, &optlen); |
1165 | OPENSSL_assert(ii >= 0); | 1198 | OPENSSL_assert(ii >= 0); |
1166 | 1199 | ||
1167 | for (p = (unsigned char*) authchunks + sizeof(sctp_assoc_t); | 1200 | for (p = (unsigned char*) authchunks->gauth_chunks; |
1168 | p < (unsigned char*) authchunks + optlen; | 1201 | p < (unsigned char*) authchunks + optlen; |
1169 | p += sizeof(uint8_t)) | 1202 | p += sizeof(uint8_t)) |
1170 | { | 1203 | { |
@@ -1298,7 +1331,7 @@ static long dgram_sctp_ctrl(BIO *b, int cmd, long num, void *ptr) | |||
1298 | { | 1331 | { |
1299 | long ret=1; | 1332 | long ret=1; |
1300 | bio_dgram_sctp_data *data = NULL; | 1333 | bio_dgram_sctp_data *data = NULL; |
1301 | unsigned int sockopt_len = 0; | 1334 | socklen_t sockopt_len = 0; |
1302 | struct sctp_authkeyid authkeyid; | 1335 | struct sctp_authkeyid authkeyid; |
1303 | struct sctp_authkey *authkey; | 1336 | struct sctp_authkey *authkey; |
1304 | 1337 | ||
diff --git a/src/lib/libcrypto/bio/bss_log.c b/src/lib/libcrypto/bio/bss_log.c index b7dce5c1a2..2227b2b52d 100644 --- a/src/lib/libcrypto/bio/bss_log.c +++ b/src/lib/libcrypto/bio/bss_log.c | |||
@@ -245,7 +245,7 @@ static int MS_CALLBACK slg_puts(BIO *bp, const char *str) | |||
245 | 245 | ||
246 | static void xopenlog(BIO* bp, char* name, int level) | 246 | static void xopenlog(BIO* bp, char* name, int level) |
247 | { | 247 | { |
248 | if (GetVersion() < 0x80000000) | 248 | if (check_winnt()) |
249 | bp->ptr = RegisterEventSourceA(NULL,name); | 249 | bp->ptr = RegisterEventSourceA(NULL,name); |
250 | else | 250 | else |
251 | bp->ptr = NULL; | 251 | bp->ptr = NULL; |