mirror of https://github.com/openssl/openssl.git
bss_dgram.c: fix unaligned access
char (alignment 1) casted to union sctp_notification (alignment > 1). Fixes: #9538 Signed-off-by: Patrick Steuer <patrick.steuer@de.ibm.com> Reviewed-by: Matt Caswell <matt@openssl.org> (Merged from https://github.com/openssl/openssl/pull/10336)
This commit is contained in:
parent
fd4a6e7d1e
commit
287e1a7eac
|
@ -1009,7 +1009,6 @@ static int dgram_sctp_read(BIO *b, char *out, int outl)
|
|||
int ret = 0, n = 0, i, optval;
|
||||
socklen_t optlen;
|
||||
bio_dgram_sctp_data *data = (bio_dgram_sctp_data *) b->ptr;
|
||||
union sctp_notification *snp;
|
||||
struct msghdr msg;
|
||||
struct iovec iov;
|
||||
struct cmsghdr *cmsg;
|
||||
|
@ -1075,8 +1074,10 @@ static int dgram_sctp_read(BIO *b, char *out, int outl)
|
|||
}
|
||||
|
||||
if (msg.msg_flags & MSG_NOTIFICATION) {
|
||||
snp = (union sctp_notification *)out;
|
||||
if (snp->sn_header.sn_type == SCTP_SENDER_DRY_EVENT) {
|
||||
union sctp_notification snp;
|
||||
|
||||
memcpy(&snp, out, sizeof(snp));
|
||||
if (snp.sn_header.sn_type == SCTP_SENDER_DRY_EVENT) {
|
||||
# ifdef SCTP_EVENT
|
||||
struct sctp_event event;
|
||||
# else
|
||||
|
@ -1116,17 +1117,19 @@ static int dgram_sctp_read(BIO *b, char *out, int outl)
|
|||
# endif
|
||||
}
|
||||
# ifdef SCTP_AUTHENTICATION_EVENT
|
||||
if (snp->sn_header.sn_type == SCTP_AUTHENTICATION_EVENT)
|
||||
dgram_sctp_handle_auth_free_key_event(b, snp);
|
||||
if (snp.sn_header.sn_type == SCTP_AUTHENTICATION_EVENT)
|
||||
dgram_sctp_handle_auth_free_key_event(b, &snp);
|
||||
# endif
|
||||
|
||||
if (data->handle_notifications != NULL)
|
||||
data->handle_notifications(b, data->notification_context,
|
||||
(void *)out);
|
||||
|
||||
memset(&snp, 0, sizeof(snp));
|
||||
memset(out, 0, outl);
|
||||
} else
|
||||
} else {
|
||||
ret += n;
|
||||
}
|
||||
}
|
||||
while ((msg.msg_flags & MSG_NOTIFICATION) && (msg.msg_flags & MSG_EOR)
|
||||
&& (ret < outl));
|
||||
|
|
Loading…
Reference in New Issue