Index: uspace/lib/c/generic/rtld/module.c
===================================================================
--- uspace/lib/c/generic/rtld/module.c	(revision 9c07c3d937d51ff587e1eac05d09ce9b2423f541)
+++ uspace/lib/c/generic/rtld/module.c	(revision b272c67a36699ea68cd8634a6e11d904c307d1bc)
@@ -49,4 +49,37 @@
 #include <rtld/rtld_arch.h>
 #include <rtld/module.h>
+
+/** Create module for static executable.
+ *
+ * @param rtld Run-time dynamic linker
+ * @param rmodule Place to store pointer to new module or @c NULL
+ * @return EOK on success, ENOMEM if out of memory
+ */
+int module_create_static_exec(rtld_t *rtld, module_t **rmodule)
+{
+	module_t *module;
+
+	module = calloc(1, sizeof(module_t));
+	if (module == NULL)
+		return ENOMEM;
+
+	module->id = rtld_get_next_id(rtld);
+	module->dyn.soname = "[program]";
+
+	module->rtld = rtld;
+	module->exec = true;
+	module->local = true;
+
+	module->tdata = &_tdata_start;
+	module->tdata_size = &_tdata_end - &_tdata_start;
+	module->tbss_size = &_tbss_end - &_tbss_start;
+	module->tls_align = (uintptr_t)&_tls_alignment;
+
+	list_append(&module->modules_link, &rtld->modules);
+
+	if (rmodule != NULL)
+		*rmodule = module;
+	return EOK;
+}
 
 /** (Eagerly) process all relocation tables in a module.
@@ -191,5 +224,5 @@
 	m->tls_align = info.tls.tls_align;
 
-	printf("tdata at %p size %zu, tbss size %zu\n",
+	DPRINTF("tdata at %p size %zu, tbss size %zu\n",
 	    m->tdata, m->tdata_size, m->tbss_size);
 
Index: uspace/lib/c/generic/rtld/rtld.c
===================================================================
--- uspace/lib/c/generic/rtld/rtld.c	(revision 9c07c3d937d51ff587e1eac05d09ce9b2423f541)
+++ uspace/lib/c/generic/rtld/rtld.c	(revision b272c67a36699ea68cd8634a6e11d904c307d1bc)
@@ -45,6 +45,8 @@
 
 /** Initialize the runtime linker for use in a statically-linked executable. */
-void rtld_init_static(void)
-{
+int rtld_init_static(void)
+{
+	int rc;
+
 	runtime_env = &rt_env_static;
 	list_initialize(&runtime_env->modules);
@@ -52,4 +54,13 @@
 	runtime_env->next_bias = 0x2000000;
 	runtime_env->program = NULL;
+	runtime_env->next_id = 1;
+
+	rc = module_create_static_exec(runtime_env, NULL);
+	if (rc != EOK)
+		return rc;
+
+	modules_process_tls(runtime_env);
+
+	return EOK;
 }
 
@@ -98,5 +109,5 @@
 	prog->tls_align = p_info->tls.tls_align;
 
-	printf("prog tdata at %p size %zu, tbss size %zu\n",
+	DPRINTF("prog tdata at %p size %zu, tbss size %zu\n",
 	    prog->tdata, prog->tdata_size, prog->tbss_size);
 
