diff --git a/libavformat/rtpproto.c b/libavformat/rtpproto.c index a8cbd97708af9625956eb20355360f736dfaf23a..62f77da289ea6a61b1861fc37ed2e2e0d9740ec2 100644 --- a/libavformat/rtpproto.c +++ b/libavformat/rtpproto.c @@ -130,23 +130,26 @@ static int compare_addr(const struct sockaddr_storage *a, static int get_port(const struct sockaddr_storage *ss) { + sockaddr_union ssu = (sockaddr_union){.storage = *ss}; if (ss->ss_family == AF_INET) - return ntohs(((const struct sockaddr_in *)ss)->sin_port); + return ntohs(ssu.in.sin_port); #if HAVE_STRUCT_SOCKADDR_IN6 if (ss->ss_family == AF_INET6) - return ntohs(((const struct sockaddr_in6 *)ss)->sin6_port); + return ntohs(ssu.in6.sin6_port); #endif return 0; } static void set_port(struct sockaddr_storage *ss, int port) { + sockaddr_union ssu = (sockaddr_union){.storage = *ss}; if (ss->ss_family == AF_INET) - ((struct sockaddr_in *)ss)->sin_port = htons(port); + ssu.in.sin_port = htons(port); #if HAVE_STRUCT_SOCKADDR_IN6 else if (ss->ss_family == AF_INET6) - ((struct sockaddr_in6 *)ss)->sin6_port = htons(port); + ssu.in6.sin6_port = htons(port); #endif + *ss = ssu.storage; } static int rtp_check_source_lists(RTPContext *s, struct sockaddr_storage *source_addr_ptr)