blob: 58508570a25be90f3b640b27e3057dd1de7ec3d2 [file] [log] [blame]
/* { dg-require-effective-target sockets } */
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#include <errno.h>
#include "analyzer-decls.h"
void test_leak_socket (void)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "datagram socket created here" } */
} /* { dg-warning "leak of file descriptor 'fd'" } */
void test_leak_socket_no_lhs (void)
{
socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-warning "leak of file descriptor" } */
}
void test_close_unchecked_socket (void)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0);
close (fd);
}
void test_close_checked_socket (void)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0);
if (fd == -1)
return;
__analyzer_dump_state ("file-descriptor", fd); /* { dg-warning "state: 'fd-new-datagram-socket'" } */
close (fd);
}
void test_leak_checked_socket (void)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "datagram socket created here" } */
if (fd == -1) /* { dg-warning "leak of file descriptor 'fd'" } */
return;
// TODO: strange location for leak message
}
void test_bind (const char *sockname)
{
struct sockaddr_un addr;
int fd = socket (AF_UNIX, SOCK_DGRAM, 0);
if (fd == -1)
return;
__analyzer_dump_state ("file-descriptor", fd); /* { dg-warning "state: 'fd-new-datagram-socket'" } */
memset (&addr, 0, sizeof (addr));
addr.sun_family = AF_UNIX;
strncpy (addr.sun_path, sockname, sizeof(addr.sun_path) - 1);
bind (fd, (struct sockaddr *)&addr, sizeof (addr));
close (fd);
}
void test_bind_on_unchecked_socket (const char *sockname)
{
struct sockaddr_un addr;
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "when 'socket' fails" } */
memset (&addr, 0, sizeof (addr));
addr.sun_family = AF_UNIX;
strncpy (addr.sun_path, sockname, sizeof(addr.sun_path) - 1);
bind (fd, (struct sockaddr *)&addr, sizeof (addr)); /* { dg-warning "'bind' on possibly invalid file descriptor 'fd'" } */
close (fd);
}
void test_leak_of_bound_socket (const char *sockname)
{
struct sockaddr_un addr;
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "datagram socket created here" } */
if (fd == -1)
return;
memset (&addr, 0, sizeof (addr));
addr.sun_family = AF_UNIX;
strncpy (addr.sun_path, sockname, sizeof(addr.sun_path) - 1);
bind (fd, (struct sockaddr *)&addr, sizeof (addr)); /* { dg-warning "leak of file descriptor 'fd'" } */
}
void test_listen_on_datagram_socket_without_bind (void)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "datagram socket created here" } */
if (fd == -1)
return;
__analyzer_dump_state ("file-descriptor", fd); /* { dg-warning "state: 'fd-new-datagram-socket'" } */
listen (fd, 5); /* { dg-warning "'listen' on datagram socket file descriptor 'fd' \\\[-Wanalyzer-fd-type-mismatch\\\]" "warning" } */
/* { dg-message "'listen' expects a stream socket file descriptor but 'fd' is a datagram socket" "final event" { target *-*-* } .-1 } */
close (fd);
}
void test_listen_on_datagram_socket_with_bind (const char *sockname)
{
int fd = socket (AF_UNIX, SOCK_DGRAM, 0); /* { dg-message "datagram socket created here" } */
if (fd == -1)
return;
__analyzer_dump_state ("file-descriptor", fd); /* { dg-warning "state: 'fd-new-datagram-socket'" } */
struct sockaddr_un addr;
memset (&addr, 0, sizeof (addr));
addr.sun_family = AF_UNIX;
strncpy (addr.sun_path, sockname, sizeof(addr.sun_path) - 1);
if (bind (fd, (struct sockaddr *)&addr, sizeof (addr)) == -1) /* { dg message "datagram socket bound here" } */
{
close (fd);
return;
}
listen (fd, 5); /* { dg-warning "'listen' on datagram socket file descriptor 'fd' \\\[-Wanalyzer-fd-type-mismatch\\\]" "warning" } */
/* { dg-message "'listen' expects a stream socket file descriptor but 'fd' is a datagram socket" "final event" { target *-*-* } .-1 } */
close (fd);
}