2
0
mirror of https://github.com/checkpoint-restore/criu synced 2025-08-25 03:18:36 +00:00
criu/test/others/unix-callback/unix-client.c
Nicolas Viennot 17c4a8b245 style: Enforce kernel style -Wstrict-prototypes
Include warnings that the kernel uses during compilation:
-Wstrict-prototypes: enforces full declaration of functions.
Previously, when declaring extern void func(), one can call func(123)
and have no compilation error. This is dangerous. The correct declaration
is extern void func(void).

Signed-off-by: Nicolas Viennot <Nicolas.Viennot@twosigma.com>
[Generated a commit message from the pull request]
Signed-off-by: Dmitry Safonov <dima@arista.com>
2020-02-04 12:39:42 -08:00

122 lines
2.0 KiB
C

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
#include <signal.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <linux/un.h>
#include <fcntl.h>
#include <syslog.h>
#define SK_NAME "/tmp/criu.unix.callback.test"
#define SK_NR 2
struct {
int id;
int sk;
int val;
} sks[SK_NR];
static int create_sock(int i)
{
int ret, id, sk, val = time(NULL) + i * 314;
char buf[4096];
struct sockaddr_un addr;
socklen_t addr_len;
id = getpid() * 10 + i;
sk = socket(AF_UNIX, SOCK_DGRAM, 0);
if (sk < 0)
return -1;
addr.sun_family = AF_UNIX;
addr_len = snprintf(addr.sun_path, UNIX_PATH_MAX, "%s%d", SK_NAME, id);
addr_len += sizeof(addr.sun_family);
if (bind(sk, (struct sockaddr *) &addr, addr_len) < 0) {
perror("bind");
return 1;
}
addr.sun_family = AF_UNIX;
addr_len = snprintf(addr.sun_path, UNIX_PATH_MAX, SK_NAME);
addr_len += sizeof(addr.sun_family);
if (connect(sk, (struct sockaddr *) &addr, addr_len) < 0) {
perror("connect");
return 1;
}
printf("init %d\n", val);
ret = sprintf(buf, "t%d", val);
if (send(sk, buf, ret, 0) < 0) {
perror("send");
return -1;
}
sks[i].sk = sk;
sks[i].val = val;
return 0;
}
static int check_sock(int i)
{
int sk = sks[i].sk, val = sks[i].val;
char buf[4096];
if (send(sk, "r", 1, 0) < 0) {
perror("send(\"r\")");
return -1;
}
if (recv(sk, buf, sizeof(buf), 0) <= 0) {
perror("recv");
return -1;
}
printf("%s - %d\n", buf, val);
if (atoi(buf) != val)
return -1;
return 0;
}
int main(void)
{
int i, fd;
sigset_t set;
int sig;
for (i = 0; i < SK_NR; i++)
if (create_sock(i))
return -1;
fd = open("pid", O_WRONLY | O_CREAT, 0666);
if (fd < 0)
return 1;
dprintf(fd, "%d\n", getpid());
close(fd);
openlog("test", LOG_NDELAY, LOG_USER );
sigemptyset(&set);
sigaddset(&set, SIGTERM);
sigprocmask(SIG_BLOCK, &set, NULL);
sigwait(&set, &sig);
syslog(LOG_CRIT, "test message");
for (i = 0; i < SK_NR; i++)
if (check_sock(i))
return -1;
printf("PASS\n");
return 0;
}