aboutsummaryrefslogtreecommitdiff
path: root/gdb/gdbserver/gdbreplay.c
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2015-03-07 17:30:46 +0000
committerPedro Alves <palves@redhat.com>2015-03-07 17:30:46 +0000
commit366c75fc9183e46fe151aefb40f2d55a17815cb7 (patch)
tree46a0b48ae8dcf84e1317b870e87a66472f2b637d /gdb/gdbserver/gdbreplay.c
parent72df25b28d68fd0b903380ceb06c6b5866eab453 (diff)
downloadgdb-366c75fc9183e46fe151aefb40f2d55a17815cb7.zip
gdb-366c75fc9183e46fe151aefb40f2d55a17815cb7.tar.gz
gdb-366c75fc9183e46fe151aefb40f2d55a17815cb7.tar.bz2
Fix struct sockaddr/sockaddr_in/sockaddr_un strict aliasing violations
Building gdbserver in C++ mode shows: gdb/gdbserver/tracepoint.c: In function ‘void* gdb_agent_helper_thread(void*)’: gdb/gdbserver/tracepoint.c:7190:47: error: cannot convert ‘sockaddr_un*’ to ‘sockaddr*’ for argument ‘2’ to ‘int accept(int, sockaddr*, socklen_t*)’ fd = accept (listen_fd, &sockaddr, &tmp); A few places in the tree already have an explicit cast to struct sockaddr *, but that's a strict aliasing violation. Instead of propagating invalid code, fix this by using a union instead. gdb/ChangeLog: 2015-03-07 Pedro Alves <palves@redhat.com> * common/gdb_socket.h: New file. * ser-tcp.c: Include gdb_socket.h. Don't include netinet/in.h nor sys/socket.h. (net_open): Use union gdb_sockaddr_u. gdb/gdbserver/ChangeLog: 2015-03-07 Pedro Alves <palves@redhat.com> * gdbreplay.c: No longer include <netinet/in.h>, <sys/socket.h>, or <winsock2.h> here. Instead include "gdb_socket.h". (remote_open): Use union gdb_sockaddr_u. * remote-utils.c: No longer include <netinet/in.h>, <sys/socket.h> or <winsock2.h> here. Instead include "gdb_socket.h". (handle_accept_event, remote_prepare): Use union gdb_sockaddr_u. * tracepoint.c: Include "gdb_socket.h" instead of <sys/socket.h> or <sys/un.h>. (init_named_socket, gdb_agent_helper_thread): Use union gdb_sockaddr_u.
Diffstat (limited to 'gdb/gdbserver/gdbreplay.c')
-rw-r--r--gdb/gdbserver/gdbreplay.c24
1 files changed, 8 insertions, 16 deletions
diff --git a/gdb/gdbserver/gdbreplay.c b/gdb/gdbserver/gdbreplay.c
index a02a824..bfd6f19 100644
--- a/gdb/gdbserver/gdbreplay.c
+++ b/gdb/gdbserver/gdbreplay.c
@@ -36,24 +36,16 @@
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
-#ifdef HAVE_NETINET_IN_H
-#include <netinet/in.h>
-#endif
-#ifdef HAVE_SYS_SOCKET_H
-#include <sys/socket.h>
-#endif
#if HAVE_NETDB_H
#include <netdb.h>
#endif
#if HAVE_NETINET_TCP_H
#include <netinet/tcp.h>
#endif
+#include "gdb_socket.h"
#include <alloca.h>
-#if USE_WIN32API
-#include <winsock2.h>
-#endif
#ifndef HAVE_SOCKLEN_T
typedef int socklen_t;
@@ -188,7 +180,7 @@ remote_open (char *name)
#endif
char *port_str;
int port;
- struct sockaddr_in sockaddr;
+ union gdb_sockaddr_u sockaddr;
socklen_t tmp;
int tmp_desc;
@@ -215,16 +207,16 @@ remote_open (char *name)
setsockopt (tmp_desc, SOL_SOCKET, SO_REUSEADDR, (char *) &tmp,
sizeof (tmp));
- sockaddr.sin_family = PF_INET;
- sockaddr.sin_port = htons (port);
- sockaddr.sin_addr.s_addr = INADDR_ANY;
+ sockaddr.sa_in.sin_family = PF_INET;
+ sockaddr.sa_in.sin_port = htons (port);
+ sockaddr.sa_in.sin_addr.s_addr = INADDR_ANY;
- if (bind (tmp_desc, (struct sockaddr *) &sockaddr, sizeof (sockaddr))
+ if (bind (tmp_desc, &sockaddr.sa, sizeof (sockaddr.sa_in))
|| listen (tmp_desc, 1))
perror_with_name ("Can't bind address");
- tmp = sizeof (sockaddr);
- remote_desc = accept (tmp_desc, (struct sockaddr *) &sockaddr, &tmp);
+ tmp = sizeof (sockaddr.sa_in);
+ remote_desc = accept (tmp_desc, &sockaddr.sa, &tmp);
if (remote_desc == -1)
perror_with_name ("Accept failed");