Changeset 40abf56 in mainline for uspace/lib/c/generic/rtld/module.c


Ignore:
Timestamp:
2018-07-18T19:42:28Z (6 years ago)
Author:
Jiří Zárevúcky <jiri.zarevucky@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
9bde0d5
Parents:
0b05082
git-author:
Jiří Zárevúcky <jiri.zarevucky@…> (2018-07-18 19:05:08)
git-committer:
Jiří Zárevúcky <jiri.zarevucky@…> (2018-07-18 19:42:28)
Message:

Make sure that a thread with uninitialized TLS does not need to call malloc()
to initialize it.

For threads and tasks created by loader, we create TLS beforehand and pass
it to the child. For tasks spawned directly by the kernel, we require it is
a static executable and allocate the initial TLS using as_area_create() instead
of the libc allocator.

File:
1 edited

Legend:

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

    r0b05082 r40abf56  
    368368         * be correct, "zero" offset (i.e. the total size) must be aligned
    369369         * to the strictest alignment present.
     370         * Note that the padding is actually in front of the TLS data,
     371         * not after it.
    370372         */
    371373        rtld->tls_size = ALIGN_UP(rtld->tls_size, rtld->tls_align);
Note: See TracChangeset for help on using the changeset viewer.