Changeset 153c7a29 in mainline for uspace/lib/c/generic/rtld


Ignore:
Timestamp:
2016-05-22T17:46:10Z (9 years ago)
Author:
Jiri Svoboda <jiri@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
0dc2fec
Parents:
2112a79
Message:

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.

Location:
uspace/lib/c/generic/rtld
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/c/generic/rtld/module.c

    r2112a79 r153c7a29  
    4949#include <rtld/rtld_arch.h>
    5050#include <rtld/module.h>
     51
     52/** Create module for static executable.
     53 *
     54 * @param rtld Run-time dynamic linker
     55 * @param rmodule Place to store pointer to new module or @c NULL
     56 * @return EOK on success, ENOMEM if out of memory
     57 */
     58int module_create_static_exec(rtld_t *rtld, module_t **rmodule)
     59{
     60        module_t *module;
     61
     62        module = calloc(1, sizeof(module_t));
     63        if (module == NULL)
     64                return ENOMEM;
     65
     66        module->id = rtld_get_next_id(rtld);
     67        module->dyn.soname = "[program]";
     68
     69        module->rtld = rtld;
     70        module->exec = true;
     71        module->local = true;
     72
     73        module->tdata = &_tdata_start;
     74        module->tdata_size = &_tdata_end - &_tdata_start;
     75        module->tbss_size = &_tbss_end - &_tbss_start;
     76        module->tls_align = (uintptr_t)&_tls_alignment;
     77
     78        list_append(&module->modules_link, &rtld->modules);
     79
     80        if (rmodule != NULL)
     81                *rmodule = module;
     82        return EOK;
     83}
    5184
    5285/** (Eagerly) process all relocation tables in a module.
     
    191224        m->tls_align = info.tls.tls_align;
    192225
    193         printf("tdata at %p size %zu, tbss size %zu\n",
     226        DPRINTF("tdata at %p size %zu, tbss size %zu\n",
    194227            m->tdata, m->tdata_size, m->tbss_size);
    195228
  • uspace/lib/c/generic/rtld/rtld.c

    r2112a79 r153c7a29  
    4545
    4646/** Initialize the runtime linker for use in a statically-linked executable. */
    47 void rtld_init_static(void)
    48 {
     47int rtld_init_static(void)
     48{
     49        int rc;
     50
    4951        runtime_env = &rt_env_static;
    5052        list_initialize(&runtime_env->modules);
     
    5254        runtime_env->next_bias = 0x2000000;
    5355        runtime_env->program = NULL;
     56        runtime_env->next_id = 1;
     57
     58        rc = module_create_static_exec(runtime_env, NULL);
     59        if (rc != EOK)
     60                return rc;
     61
     62        modules_process_tls(runtime_env);
     63
     64        return EOK;
    5465}
    5566
     
    98109        prog->tls_align = p_info->tls.tls_align;
    99110
    100         printf("prog tdata at %p size %zu, tbss size %zu\n",
     111        DPRINTF("prog tdata at %p size %zu, tbss size %zu\n",
    101112            prog->tdata, prog->tdata_size, prog->tbss_size);
    102113
Note: See TracChangeset for help on using the changeset viewer.