mirror of
https://github.com/Zenithsiz/ftmemsim-valgrind.git
synced 2026-02-04 10:21:20 +00:00
The test succeeds on amd64, but fails on x86, with the following diff: +Syscall param semctl(arg) points to uninitialised byte(s) + at 0x........: semctl@@GLIBC_2.2 (semctl.c:109) + by 0x........: main (sem.c:36) + Address 0x........ is on thread 1's stack + +Syscall param semctl(arg) points to uninitialised byte(s) + at 0x........: semctl@@GLIBC_2.2 (semctl.c:109) + by 0x........: main (sem.c:43) + Address 0x........ is on thread 1's stack + git-svn-id: svn://svn.valgrind.org/valgrind/trunk@13073
104 lines
1.9 KiB
C
104 lines
1.9 KiB
C
#define _GNU_SOURCE
|
|
|
|
#include <config.h>
|
|
#include <errno.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <sys/ipc.h>
|
|
#include <sys/sem.h>
|
|
#include <time.h>
|
|
#include <unistd.h>
|
|
int main(int argc, char **argv)
|
|
{
|
|
int semid;
|
|
struct sembuf sop;
|
|
#ifdef HAVE_SEMTIMEDOP
|
|
struct timespec ts;
|
|
#endif
|
|
|
|
if ((semid = semget(IPC_PRIVATE, 1, 0600)) < 0)
|
|
{
|
|
perror("semget");
|
|
exit(1);
|
|
}
|
|
|
|
sop.sem_num = 0;
|
|
sop.sem_op = 1;
|
|
sop.sem_flg = 0;
|
|
|
|
if (semop(semid, &sop, 1) < 0)
|
|
{
|
|
perror("semop");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
|
|
if (semctl(semid, 0, GETVAL) != 1)
|
|
{
|
|
perror("semctl GETVAL");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
|
|
if (semctl(semid, 0, GETPID) != getpid())
|
|
{
|
|
perror("semctl GETPID");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
|
|
/* The next call to semtimedop causes the program to hang on
|
|
ppc32-linux (Yellow Dog 4.0). I don't know why. Hence the
|
|
extended ifdef. */
|
|
#if defined(HAVE_SEMTIMEDOP) && !defined(__powerpc__)
|
|
sop.sem_num = 0;
|
|
sop.sem_op = 0;
|
|
sop.sem_flg = 0;
|
|
|
|
ts.tv_sec = 0;
|
|
ts.tv_nsec = 1000000;
|
|
|
|
if (semtimedop(semid, &sop, 1, &ts) < 0 && errno != EAGAIN)
|
|
{
|
|
perror("semtimedop");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
#endif
|
|
|
|
sop.sem_num = 0;
|
|
sop.sem_op = -1;
|
|
sop.sem_flg = 0;
|
|
|
|
if (semop(semid, &sop, 1) < 0)
|
|
{
|
|
perror("semop");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
|
|
#ifdef HAVE_SEMTIMEDOP
|
|
sop.sem_num = 0;
|
|
sop.sem_op = 0;
|
|
sop.sem_flg = 0;
|
|
|
|
ts.tv_sec = 0;
|
|
ts.tv_nsec = 1000;
|
|
|
|
if (semtimedop(semid, &sop, 1, &ts) < 0)
|
|
{
|
|
perror("semtimedop");
|
|
semctl(semid, 0, IPC_RMID);
|
|
exit(1);
|
|
}
|
|
#endif
|
|
|
|
if (semctl(semid, 0, IPC_RMID) < 0)
|
|
{
|
|
perror("semctl(IPC_RMID)");
|
|
exit(1);
|
|
}
|
|
|
|
exit(0);
|
|
}
|