Implement LTTng-UST perf counters support on x86
[lttng-ust.git] / tests / hello / hello.c
CommitLineData
81614639
MD
1/*
2 * Copyright (C) 2009 Pierre-Marc Fournier
3 * Copyright (C) 2011 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
a09dac63
PMF
4 *
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
8d8a24c8
MD
7 * License as published by the Free Software Foundation; version 2.1 of
8 * the License.
a09dac63
PMF
9 *
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18 */
19
68c1021b
PMF
20#include <stdio.h>
21#include <unistd.h>
b6bf28ec 22#include <sys/mman.h>
9c67dc50
PMF
23#include <stdarg.h>
24#include <sys/types.h>
25#include <sys/stat.h>
26#include <fcntl.h>
4486e566 27#include <signal.h>
5dba5937 28#include <string.h>
9a396c3c 29#include <arpa/inet.h>
40b2b5a4 30#include <stdlib.h>
f121009f 31#include <stdbool.h>
68c1021b 32
deb6e540 33#define TRACEPOINT_DEFINE
41aaf8a5 34#include "ust_tests_hello.h"
59b161cd 35
8d938dbd
PMF
36void inthandler(int sig)
37{
8d8a24c8 38 printf("in SIGUSR1 handler\n");
7083f0fe 39 tracepoint(ust_tests_hello, tptest_sighandler);
8d938dbd
PMF
40}
41
42int init_int_handler(void)
43{
44 int result;
45 struct sigaction act;
46
1ea11eab 47 memset(&act, 0, sizeof(act));
8d938dbd 48 result = sigemptyset(&act.sa_mask);
81614639 49 if (result == -1) {
41aaf8a5 50 perror("sigemptyset");
8d938dbd
PMF
51 return -1;
52 }
53
54 act.sa_handler = inthandler;
55 act.sa_flags = SA_RESTART;
56
57 /* Only defer ourselves. Also, try to restart interrupted
58 * syscalls to disturb the traced program as little as possible.
59 */
8d8a24c8 60 result = sigaction(SIGUSR1, &act, NULL);
81614639 61 if (result == -1) {
41aaf8a5 62 perror("sigaction");
8d938dbd
PMF
63 return -1;
64 }
65
66 return 0;
67}
68
8d8a24c8 69int main(int argc, char **argv)
b6bf28ec 70{
9a396c3c 71 int i, netint;
775e7fd8 72 long values[] = { 1, 2, 3 };
5dba5937 73 char text[10] = "test";
513fc97e
MD
74 double dbl = 2.0;
75 float flt = 2222.0;
ff927bae 76 int delay = 0;
f121009f 77 bool mybool = 123; /* should print "1" */
5f54827b 78
8d938dbd
PMF
79 init_int_handler();
80
ff927bae
MD
81 if (argc == 2)
82 delay = atoi(argv[1]);
59b161cd 83
ff927bae 84 fprintf(stderr, "Hello, World!\n");
8d8a24c8 85
ff927bae
MD
86 sleep(delay);
87
88 fprintf(stderr, "Tracing... ");
c95f3a3a 89 for (i = 0; i < 1000000; i++) {
9a396c3c 90 netint = htonl(i);
7083f0fe 91 tracepoint(ust_tests_hello, tptest, i, netint, values,
f121009f 92 text, strlen(text), dbl, flt, mybool);
c95f3a3a 93 //usleep(100000);
8d938dbd 94 }
ff927bae 95 fprintf(stderr, " done.\n");
68c1021b
PMF
96 return 0;
97}
This page took 0.034697 seconds and 4 git commands to generate.