/******************************************************************************/
/* */
/* Copyright (c) 2009 FUJITSU LIMITED */
/* */
/* This program is free software; you can redistribute it and/or modify */
/* it under the terms of the GNU General Public License as published by */
/* the Free Software Foundation; either version 2 of the License, or */
/* (at your option) any later version. */
/* */
/* This program is distributed in the hope that it will be useful, */
/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See */
/* the GNU General Public License for more details. */
/* */
/* You should have received a copy of the GNU General Public License */
/* along with this program; if not, write to the Free Software */
/* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */
/* */
/* Author: Miao Xie <miaox@cn.fujitsu.com> */
/* Restructure for LTP: Shi Weihua <shiwh@cn.fujitsu.com> */
/* */
/******************************************************************************/
#include <stdio.h>
#include <math.h>
#include <err.h>
#include <errno.h>
#include <signal.h>
#define __USE_GNU
#include <sched.h>
#define UNUSED __attribute__ ((unused))
unsigned long count;
volatile int start = 0;
volatile double f = 2744545.34456455;
void sighandler(UNUSED int signo)
{
start = !start;
}
int main(void)
{
sigset_t signalset;
struct sigaction sa;
sa.sa_handler = sighandler;
if (sigemptyset(&sa.sa_mask) < 0)
err(1, "sigemptyset()");
sa.sa_flags = 0;
if (sigaction(SIGUSR1, &sa, NULL) < 0)
err(1, "sigaction()");
if (sigemptyset(&signalset) < 0)
err(1, "sigemptyset()");
sigsuspend(&signalset);
if (errno != EINTR)
err(1, "sigsuspend()");
while (start) {
f = sqrt(f * f);
}
return 0;
}