source: mainline/uspace/lib/c/generic/libc.c@ 899342e

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 899342e was 49a796f1, checked in by Jiří Zárevúcky <jiri.zarevucky@…>, 7 years ago

Split the async framework into several parts.

This segregates existing code into three separate files,
to make the async framework easier to navigate and understand.

  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2005 Martin Decky
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 lc Libc
30 * @brief HelenOS C library
31 * @{
32 * @}
33 */
34
35/** @addtogroup libc generic
36 * @ingroup lc
37 * @{
38 */
39
40/** @file
41 */
42
43#include <errno.h>
44#include <libc.h>
45#include <stdbool.h>
46#include <stdlib.h>
47#include <tls.h>
48#include <fibril.h>
49#include <task.h>
50#include <loader/pcb.h>
51#include <vfs/vfs.h>
52#include <vfs/inbox.h>
53#include "private/libc.h"
54#include "private/async.h"
55#include "private/malloc.h"
56#include "private/io.h"
57
58#ifdef FUTEX_UPGRADABLE
59#include <rcu.h>
60#endif
61
62#ifdef CONFIG_RTLD
63#include <rtld/rtld.h>
64#endif
65
66
67static bool env_setup = false;
68
69void __libc_main(void *pcb_ptr)
70{
71 /* Initialize user task run-time environment */
72 __malloc_init();
73
74 /* Save the PCB pointer */
75 __pcb = (pcb_t *) pcb_ptr;
76
77#ifdef CONFIG_RTLD
78 if (__pcb != NULL && __pcb->rtld_runtime != NULL) {
79 runtime_env = (rtld_t *) __pcb->rtld_runtime;
80 } else {
81 if (rtld_init_static() != EOK)
82 abort();
83 }
84#endif
85
86 fibril_t *fibril = fibril_setup();
87 if (fibril == NULL)
88 abort();
89
90 __tcb_set(fibril->tcb);
91
92
93#ifdef FUTEX_UPGRADABLE
94 rcu_register_fibril();
95#endif
96
97 __async_server_init();
98 __async_client_init();
99 __async_ports_init();
100
101 /* The basic run-time environment is setup */
102 env_setup = true;
103
104 int argc;
105 char **argv;
106
107 /*
108 * Get command line arguments and initialize
109 * standard input and output
110 */
111 if (__pcb == NULL) {
112 argc = 0;
113 argv = NULL;
114 __stdio_init();
115 } else {
116 argc = __pcb->argc;
117 argv = __pcb->argv;
118 __inbox_init(__pcb->inbox, __pcb->inbox_entries);
119 __stdio_init();
120 vfs_root_set(inbox_get("root"));
121 (void) vfs_cwd_set(__pcb->cwd);
122 }
123
124 /*
125 * Run main() and set task return value
126 * according the result
127 */
128 int retval = main(argc, argv);
129 exit(retval);
130}
131
132void exit(int status)
133{
134 if (env_setup) {
135 __stdio_done();
136 task_retval(status);
137 fibril_teardown(__tcb_get()->fibril_data, false);
138 }
139
140 __SYSCALL1(SYS_TASK_EXIT, false);
141
142 /* Unreachable */
143 while (true)
144 ;
145}
146
147void abort(void)
148{
149 __SYSCALL1(SYS_TASK_EXIT, true);
150
151 /* Unreachable */
152 while (true)
153 ;
154}
155
156/** @}
157 */
Note: See TracBrowser for help on using the repository browser.