1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
/* COVERAGE: unlink unlinkat */
#define _GNU_SOURCE
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
// To test for glibc support for unlinkat(), symlinkat(), readlinkat():
//
// Since glibc 2.10:
// _XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
// Before glibc 2.10:
// _ATFILE_SOURCE
#define GLIBC_SUPPORT \
(_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L \
|| defined(_ATFILE_SOURCE))
int main()
{
int fd1;
fd1 = creat("foobar1",S_IREAD|S_IWRITE);
close (fd1);
#if GLIBC_SUPPORT
fd1 = creat("foobar2", S_IREAD|S_IWRITE);
close (fd1);
#endif
unlink("foobar1");
//staptest// [[[[unlink ("foobar1"!!!!unlinkat (AT_FDCWD, "foobar1", 0x0]]]]) = 0
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, "foobar2", 0);
//staptest// unlinkat (AT_FDCWD, "foobar2", 0x0) = 0
#endif
unlink("foobar1");
//staptest// [[[[unlink ("foobar1"!!!!unlinkat (AT_FDCWD, "foobar1", 0x0]]]]) = -NNNN (ENOENT)
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, "foobar1", 0);
//staptest// unlinkat (AT_FDCWD, "foobar1", 0x0) = -NNNN (ENOENT)
#endif
unlink("foobar2");
//staptest// [[[[unlink ("foobar2"!!!!unlinkat (AT_FDCWD, "foobar2", 0x0]]]]) = -NNNN (ENOENT)
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, "foobar2", 0);
//staptest// unlinkat (AT_FDCWD, "foobar2", 0x0) = -NNNN (ENOENT)
#endif
unlink(0);
//staptest// [[[[unlink ( *0x0!!!!unlinkat (AT_FDCWD, *0x0, 0x0]]]]) = -NNNN (EFAULT)
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, 0, 0);
//staptest// unlinkat (AT_FDCWD, *0x0, 0x0) = -NNNN (EFAULT)
#endif
unlink("..");
//staptest// [[[[unlink (".."!!!!unlinkat (AT_FDCWD, "..", 0x0]]]]) = -NNNN (EISDIR)
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, "..", 0);
//staptest// unlinkat (AT_FDCWD, "..", 0x0) = -NNNN (EISDIR)
#endif
unlink("");
//staptest// [[[[unlink (""!!!!unlinkat (AT_FDCWD, "", 0x0]]]]) = -NNNN (ENOENT)
#if GLIBC_SUPPORT
unlinkat(AT_FDCWD, "", 0);
//staptest// unlinkat (AT_FDCWD, "", 0x0) = -NNNN (ENOENT)
#endif
/* Limits testing. */
unlink((char *)-1);
#ifdef __s390__
//staptest// [[[[unlink (0x[7]?[f]+!!!!unlinkat (AT_FDCWD, 0x[7]?[f]+, 0x0]]]]) = -NNNN
#else
//staptest// [[[[unlink (0x[f]+!!!!unlinkat (AT_FDCWD, 0x[f]+, 0x0]]]]) = -NNNN
#endif
#if GLIBC_SUPPORT
unlinkat(-1, "foobar2", 0);
//staptest// unlinkat (-1, "foobar2", 0x0) = -NNNN
unlinkat(AT_FDCWD, (char *)-1, 0);
#ifdef __s390__
//staptest// unlinkat (AT_FDCWD, 0x[7]?[f]+, 0x0) = -NNNN
#else
//staptest// unlinkat (AT_FDCWD, 0x[f]+, 0x0) = -NNNN
#endif
unlinkat(AT_FDCWD, "foobar2", -1);
//staptest// unlinkat (AT_FDCWD, "foobar2", AT_[^ ]+|XXXX) = -NNNN
unlinkat(AT_FDCWD, "foobar2", AT_REMOVEDIR);
//staptest// unlinkat (AT_FDCWD, "foobar2", AT_REMOVEDIR) = -NNNN
#endif
return 0;
}
|