chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
selinux: rework selinux tests a little
[elogind.git]
/
src
/
socket.h
diff --git
a/src/socket.h
b/src/socket.h
index 2067eb425428be24f67a288909534df4bed0db28..230dd200d5e423ebef41f869ec3f6555d5b0c0c1 100644
(file)
--- a/
src/socket.h
+++ b/
src/socket.h
@@
-41,7
+41,7
@@
typedef enum SocketState {
SOCKET_STOP_POST,
SOCKET_FINAL_SIGTERM,
SOCKET_FINAL_SIGKILL,
SOCKET_STOP_POST,
SOCKET_FINAL_SIGTERM,
SOCKET_FINAL_SIGKILL,
- SOCKET_MAINT
AI
NANCE,
+ SOCKET_MAINT
E
NANCE,
_SOCKET_STATE_MAX,
_SOCKET_STATE_INVALID = -1
} SocketState;
_SOCKET_STATE_MAX,
_SOCKET_STATE_INVALID = -1
} SocketState;
@@
-78,34
+78,49
@@
struct Socket {
LIST_HEAD(SocketPort, ports);
LIST_HEAD(SocketPort, ports);
- /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
- SocketAddressBindIPv6Only bind_ipv6_only;
unsigned backlog;
unsigned backlog;
-
usec_t timeout_usec;
ExecCommand* exec_command[_SOCKET_EXEC_COMMAND_MAX];
ExecContext exec_context;
usec_t timeout_usec;
ExecCommand* exec_command[_SOCKET_EXEC_COMMAND_MAX];
ExecContext exec_context;
+ /* For Accept=no sockets refers to the one service we'll
+ activate. For Accept=yes sockets is either NULL, or filled
+ when the next service we spawn. */
Service *service;
SocketState state, deserialized_state;
Service *service;
SocketState state, deserialized_state;
- KillMode kill_mode;
-
ExecCommand* control_command;
SocketExecCommand control_command_id;
pid_t control_pid;
ExecCommand* control_command;
SocketExecCommand control_command_id;
pid_t control_pid;
- char *bind_to_device;
- mode_t directory_mode;
- mode_t socket_mode;
-
bool accept;
unsigned n_accepted;
bool accept;
unsigned n_accepted;
+ unsigned n_connections;
+ unsigned max_connections;
bool failure;
Watch timer_watch;
bool failure;
Watch timer_watch;
+
+ /* Socket options */
+ bool keep_alive;
+ int priority;
+ size_t receive_buffer;
+ size_t send_buffer;
+ int ip_tos;
+ int ip_ttl;
+ size_t pipe_size;
+ int mark;
+ bool free_bind;
+ char *bind_to_device;
+ char *tcp_congestion;
+
+ /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
+ SocketAddressBindIPv6Only bind_ipv6_only;
+
+ mode_t directory_mode;
+ mode_t socket_mode;
};
/* Called from the service code when collecting fds */
};
/* Called from the service code when collecting fds */
@@
-118,6
+133,9
@@
void socket_notify_service_dead(Socket *s);
* any of the sockets of this socket */
int socket_add_one_mount_link(Socket *s, Mount *m);
* any of the sockets of this socket */
int socket_add_one_mount_link(Socket *s, Mount *m);
+/* Called from the service code when a per-connection service ended */
+void socket_connection_unref(Socket *s);
+
extern const UnitVTable socket_vtable;
const char* socket_state_to_string(SocketState i);
extern const UnitVTable socket_vtable;
const char* socket_state_to_string(SocketState i);