gem5  v21.0.1.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
socket.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2020 The Regents of the University of California
3  * All rights reserved
4  *
5  * Copyright (c) 2002-2005 The Regents of The University of Michigan
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are
10  * met: redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer;
12  * redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in the
14  * documentation and/or other materials provided with the distribution;
15  * neither the name of the copyright holders nor the names of its
16  * contributors may be used to endorse or promote products derived from
17  * this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #include "base/socket.hh"
33 
34 #include <netinet/in.h>
35 #include <netinet/tcp.h>
36 #include <sys/socket.h>
37 #include <sys/types.h>
38 #include <unistd.h>
39 
40 #include <cerrno>
41 
42 #include "base/logging.hh"
43 #include "base/types.hh"
44 #include "sim/byteswap.hh"
45 
47 bool ListenSocket::anyListening = false;
48 
49 bool ListenSocket::bindToLoopback = false;
50 
51 void
53 {
54  listeningDisabled = false;
55  anyListening = false;
56  bindToLoopback = false;
57 }
58 
59 void
61 {
62  if (anyListening)
63  panic("Too late to disable all listeners, already have a listener");
64  listeningDisabled = true;
65 }
66 
67 bool
69 {
70  return listeningDisabled;
71 }
72 
73 void
75 {
76  if (anyListening)
77  panic("Too late to bind to loopback, already have a listener");
78  bindToLoopback = true;
79 }
80 
82 //
83 //
84 
86  : listening(false), fd(-1)
87 {}
88 
90 {
91  if (fd != -1)
92  close(fd);
93 }
94 
95 // Create a socket and configure it for listening
96 bool
97 ListenSocket::listen(int port, bool reuse)
98 {
99  if (listening)
100  panic("Socket already listening!");
101 
102  // only create socket if not already created by a previous call
103  if (fd == -1) {
104  fd = ::socket(PF_INET, SOCK_STREAM, 0);
105  if (fd < 0)
106  panic("Can't create socket:%s !", strerror(errno));
107  }
108 
109  if (reuse) {
110  int i = 1;
111  if (::setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (char *)&i,
112  sizeof(i)) < 0)
113  panic("ListenSocket(listen): setsockopt() SO_REUSEADDR failed!");
114  }
115 
116  struct sockaddr_in sockaddr;
117  sockaddr.sin_family = PF_INET;
118  sockaddr.sin_addr.s_addr =
119  htobe<in_addr_t>(bindToLoopback ? INADDR_LOOPBACK : INADDR_ANY);
120  sockaddr.sin_port = htons(port);
121  // finally clear sin_zero
122  std::memset(&sockaddr.sin_zero, 0, sizeof(sockaddr.sin_zero));
123  int ret = ::bind(fd, (struct sockaddr *)&sockaddr, sizeof (sockaddr));
124  if (ret != 0) {
125  if (ret == -1 && errno != EADDRINUSE)
126  panic("ListenSocket(listen): bind() failed!");
127  return false;
128  }
129 
130  if (::listen(fd, 1) == -1) {
131  if (errno != EADDRINUSE)
132  panic("ListenSocket(listen): listen() failed!");
133 
134  return false;
135  }
136 
137  listening = true;
138  anyListening = true;
139  return true;
140 }
141 
142 
143 // Open a connection. Accept will block, so if you don't want it to,
144 // make sure a connection is ready before you call accept.
145 int
146 ListenSocket::accept(bool nodelay)
147 {
148  struct sockaddr_in sockaddr;
149  socklen_t slen = sizeof (sockaddr);
150  int sfd = ::accept(fd, (struct sockaddr *)&sockaddr, &slen);
151  if (sfd != -1 && nodelay) {
152  int i = 1;
153  if (::setsockopt(sfd, IPPROTO_TCP, TCP_NODELAY, (char *)&i,
154  sizeof(i)) < 0)
155  warn("ListenSocket(accept): setsockopt() TCP_NODELAY failed!");
156  }
157 
158  return sfd;
159 }
socket.hh
warn
#define warn(...)
Definition: logging.hh:239
ListenSocket::listen
virtual bool listen(int port, bool reuse=true)
Definition: socket.cc:97
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
ArmISA::fd
Bitfield< 14, 12 > fd
Definition: types.hh:159
ListenSocket::accept
virtual int accept(bool nodelay=false)
Definition: socket.cc:146
ListenSocket::~ListenSocket
virtual ~ListenSocket()
Definition: socket.cc:89
ListenSocket::listeningDisabled
static bool listeningDisabled
The following variables are only used by socket unit tests: listeningDisabled, anyListening,...
Definition: socket.hh:39
ListenSocket::bindToLoopback
static bool bindToLoopback
Definition: socket.hh:42
ListenSocket::ListenSocket
ListenSocket()
Definition: socket.cc:85
ListenSocket::fd
int fd
Definition: socket.hh:52
ListenSocket::listening
bool listening
Definition: socket.hh:51
ListenSocket::cleanup
static void cleanup()
Definition: socket.cc:52
ListenSocket::allDisabled
static bool allDisabled()
Definition: socket.cc:68
types.hh
ListenSocket::loopbackOnly
static void loopbackOnly()
Definition: socket.cc:74
logging.hh
ListenSocket::disableAll
static void disableAll()
Definition: socket.cc:60
ListenSocket::anyListening
static bool anyListening
Definition: socket.hh:40
byteswap.hh
panic
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:171

Generated on Tue Jun 22 2021 15:28:25 for gem5 by doxygen 1.8.17