source: mainline/uspace/lib/c/generic/libc.c@ b272c67a

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

Since dlopen() sets up runtime_env, we would no longer use the static TLS. Thus set up runtime_env right away and convert static TLS to dynamic TLS.

  • Property mode set to 100644
File size: 3.2 KB
RevLine 
[3eddaff]1/*
[df4ed85]2 * Copyright (c) 2005 Martin Decky
[3eddaff]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.
[b2951e2]27 */
[a46da63]28
29/** @addtogroup lc Libc
[433131d]30 * @brief HelenOS C library
[a46da63]31 * @{
32 * @}
33 */
[433131d]34
[a46da63]35/** @addtogroup libc generic
36 * @ingroup lc
[b2951e2]37 * @{
38 */
[433131d]39
[b2951e2]40/** @file
[433131d]41 */
[3eddaff]42
[153c7a29]43#include <errno.h>
[3eddaff]44#include <libc.h>
[47b7006]45#include <stdlib.h>
[fa23560]46#include <tls.h>
[bc1f1c2]47#include <fibril.h>
[47b7006]48#include <task.h>
[c98e6ee]49#include <loader/pcb.h>
[e26a4633]50#include "private/libc.h"
[fc5f7a8]51#include "private/async.h"
[47b7006]52#include "private/malloc.h"
53#include "private/io.h"
[d54b303]54
55#ifdef FUTEX_UPGRADABLE
56#include <rcu.h>
57#endif
[07d960a]58
[7fb3f1c]59#ifdef CONFIG_RTLD
[8a1fb09]60#include <rtld/rtld.h>
[7fb3f1c]61#endif
[1ea99cc]62
[d54b303]63
[47b7006]64static bool env_setup = false;
[350514c]65
[c98e6ee]66void __main(void *pcb_ptr)
[a46da63]67{
[153c7a29]68 /* Initialize user task run-time environment */
69 __malloc_init();
70
[91e4567]71 /* Save the PCB pointer */
72 __pcb = (pcb_t *) pcb_ptr;
73
74#ifdef CONFIG_RTLD
75 if (__pcb != NULL && __pcb->rtld_runtime != NULL) {
76 runtime_env = (rtld_t *) __pcb->rtld_runtime;
[153c7a29]77 } else {
78 if (rtld_init_static() != EOK)
79 abort();
[91e4567]80 }
81#endif
[47b7006]82
[433131d]83 fibril_t *fibril = fibril_setup();
[47b7006]84 if (fibril == NULL)
85 abort();
86
[433131d]87 __tcb_set(fibril->tcb);
[663c5a6]88
[433131d]89
[d54b303]90#ifdef FUTEX_UPGRADABLE
91 rcu_register_fibril();
92#endif
93
94 __async_init();
[9a3b469]95
[47b7006]96 /* The basic run-time environment is setup */
97 env_setup = true;
98
[433131d]99 int argc;
100 char **argv;
101
[47b7006]102 /*
103 * Get command line arguments and initialize
104 * standard input and output
105 */
[c98e6ee]106 if (__pcb == NULL) {
107 argc = 0;
108 argv = NULL;
[7171760]109 __stdio_init(0);
[c98e6ee]110 } else {
111 argc = __pcb->argc;
112 argv = __pcb->argv;
[7171760]113 __stdio_init(__pcb->filc);
[7591b27d]114 (void) chdir(__pcb->cwd);
[c98e6ee]115 }
[433131d]116
[47b7006]117 /*
118 * Run main() and set task return value
119 * according the result
120 */
121 int retval = main(argc, argv);
122 exit(retval);
123}
[7114d83]124
[47b7006]125void exit(int status)
126{
127 if (env_setup) {
128 __stdio_done();
129 task_retval(status);
[4d11204]130 fibril_teardown(__tcb_get()->fibril_data, false);
[47b7006]131 }
132
133 __SYSCALL1(SYS_TASK_EXIT, false);
134
135 /* Unreachable */
136 while (1);
[3eddaff]137}
138
[47b7006]139void abort(void)
[a46da63]140{
[47b7006]141 __SYSCALL1(SYS_TASK_EXIT, true);
142
143 /* Unreachable */
144 while (1);
[3eddaff]145}
[b2951e2]146
[a46da63]147/** @}
[b2951e2]148 */
Note: See TracBrowser for help on using the repository browser.