source: mainline/uspace/srv/taskmon/taskmon.c@ 444a54e

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 444a54e was 444a54e, checked in by Jiri Svoboda <jiri@…>, 15 years ago

Fix missing percent sign in format string.

  • Property mode set to 100644
File size: 3.0 KB
RevLine 
[a074b4f]1/*
2 * Copyright (c) 2010 Jiri Svoboda
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup taskmon
30 * @brief
31 * @{
32 */
33/**
34 * @file
35 */
36
37#include <stdio.h>
38#include <ipc/ipc.h>
39#include <async.h>
40#include <ipc/services.h>
[1ccafee]41#include <sys/typefmt.h>
[a074b4f]42#include <task.h>
43#include <event.h>
44#include <macros.h>
45#include <errno.h>
46
47#define NAME "taskmon"
48
49static void fault_event(ipc_callid_t callid, ipc_call_t *call)
50{
[dafa2d04]51 char *argv[6];
[a074b4f]52 char *fname;
[03333bc]53 char *dump_fname;
[a074b4f]54 char *s_taskid;
[03333bc]55 char **s;
[a074b4f]56
57 task_id_t taskid;
58 uintptr_t thread;
59
60 taskid = MERGE_LOUP32(IPC_GET_ARG1(*call), IPC_GET_ARG2(*call));
61 thread = IPC_GET_ARG3(*call);
62
[1ccafee]63 if (asprintf(&s_taskid, "%" PRIuTASKID, taskid) < 0) {
[a074b4f]64 printf("Memory allocation failed.\n");
65 return;
66 }
67
[444a54e]68 if (asprintf(&dump_fname, "/data/core%" PRIuTASKID, taskid) < 0) {
[03333bc]69 printf("Memory allocation failed.\n");
70 return;
71 }
72
[1ccafee]73 printf(NAME ": Task %" PRIuTASKID " fault in thread %p.\n", taskid, thread);
[a074b4f]74
[dafa2d04]75#ifdef CONFIG_WRITE_CORE_FILES
76 argv[0] = "/app/taskdump";
77 argv[1] = "-c";
78 argv[2] = dump_fname;
79 argv[3] = "-t";
80 argv[4] = s_taskid;
81 argv[5] = NULL;
[a074b4f]82#else
[f0bdfb7]83 argv[0] = "/app/taskdump";
84 argv[1] = "-t";
85 argv[2] = s_taskid;
86 argv[3] = NULL;
[a074b4f]87#endif
[f0bdfb7]88 fname = argv[0];
89
[03333bc]90 printf(NAME ": Executing");
91 s = argv;
92 while (*s != NULL) {
93 printf(" %s", *s);
94 ++s;
95 }
96 putchar('\n');
[a074b4f]97
98 if (!task_spawn(fname, argv))
99 printf(NAME ": Error spawning taskdump.\n", fname);
100}
101
102int main(int argc, char *argv[])
103{
104 printf(NAME ": Task Monitoring Service\n");
105
106 if (event_subscribe(EVENT_FAULT, 0) != EOK) {
107 printf(NAME ": Error registering fault notifications.\n");
108 return -1;
109 }
110
111 async_set_interrupt_received(fault_event);
112 async_manager();
113
114 return 0;
115}
116
117/** @}
118 */
Note: See TracBrowser for help on using the repository browser.