Fix: Java agent: handle partial payload read
[lttng-ust.git] / tests / hello / hello.c
... / ...
CommitLineData
1/*
2 * Copyright (C) 2009 Pierre-Marc Fournier
3 * Copyright (C) 2011 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
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
7 * License as published by the Free Software Foundation; version 2.1 of
8 * the License.
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
20#include <stdio.h>
21#include <unistd.h>
22#include <sys/mman.h>
23#include <stdarg.h>
24#include <sys/types.h>
25#include <sys/stat.h>
26#include <fcntl.h>
27#include <signal.h>
28#include <string.h>
29/*
30 * Work-around inet.h missing struct mmsghdr forward declaration, with
31 * triggers a warning when system files warnings are enabled.
32 */
33struct mmsghdr;
34#include <arpa/inet.h>
35#include <stdlib.h>
36#include <stdbool.h>
37
38#define TRACEPOINT_DEFINE
39#include "ust_tests_hello.h"
40
41void inthandler(int sig)
42{
43 printf("in SIGUSR1 handler\n");
44 tracepoint(ust_tests_hello, tptest_sighandler);
45}
46
47int init_int_handler(void)
48{
49 int result;
50 struct sigaction act;
51
52 memset(&act, 0, sizeof(act));
53 result = sigemptyset(&act.sa_mask);
54 if (result == -1) {
55 perror("sigemptyset");
56 return -1;
57 }
58
59 act.sa_handler = inthandler;
60 act.sa_flags = SA_RESTART;
61
62 /* Only defer ourselves. Also, try to restart interrupted
63 * syscalls to disturb the traced program as little as possible.
64 */
65 result = sigaction(SIGUSR1, &act, NULL);
66 if (result == -1) {
67 perror("sigaction");
68 return -1;
69 }
70
71 return 0;
72}
73
74void test_inc_count(void);
75
76int main(int argc, char **argv)
77{
78 int i, netint;
79 long values[] = { 1, 2, 3 };
80 char text[10] = "test";
81 double dbl = 2.0;
82 float flt = 2222.0;
83 int delay = 0;
84 bool mybool = 123; /* should print "1" */
85
86 init_int_handler();
87
88 if (argc == 2)
89 delay = atoi(argv[1]);
90
91 fprintf(stderr, "Hello, World!\n");
92
93 sleep(delay);
94
95 fprintf(stderr, "Tracing... ");
96 for (i = 0; i < 1000000; i++) {
97 netint = htonl(i);
98 tracepoint(ust_tests_hello, tptest, i, netint, values,
99 text, strlen(text), dbl, flt, mybool);
100 //usleep(100000);
101 }
102 fprintf(stderr, " done.\n");
103 return 0;
104}
This page took 0.022168 seconds and 4 git commands to generate.