2 AcessOS 1 - Dynamic Loader
\r
9 // === PROTOTYPES ===
\r
10 void *DoRelocate(void *base, char **envp, const char *Filename);
\r
11 int CallUser(void *Entry, void *SP);
\r
14 extern char gLinkedBase[];
\r
15 extern tLoadedLib gLoadedLibraries[];
\r
19 \fn int SoMain(Uint base, int argc, char *argv[], char **envp)
\r
20 \brief Library entry point
\r
21 \note This is the entrypoint for the library
\r
23 void *SoMain(void *base)
\r
27 // - Assume that the file pointer will be less than 4096
\r
28 if((intptr_t)base < 0x1000) {
\r
29 SysDebug("ld-acess - SoMain: Passed file pointer %i\n", base);
\r
33 // Check if we are being called directly
\r
34 if(base == &gLinkedBase) {
\r
35 SysDebug("ld-acess should not be directly called\n");
\r
40 gLoadedLibraries[0].Base = &gLinkedBase;
\r
41 // 'libld-acess.so' because that is what applications link against
\r
42 gLoadedLibraries[0].Name = "/Acess/Libs/libld-acess.so";
\r
44 // Otherwise do relocations
\r
45 //ret = DoRelocate( base, envp, "Executable" );
\r
46 ret = DoRelocate( base, NULL, "Executable" );
\r
48 SysDebug("ld-acess - SoMain: Relocate failed, base=0x%x\n", base);
\r
53 SysDebug("ld-acess - SoMain: ret = %p", ret);
\r
58 \fn int DoRelocate(void *base, char **envp)
\r
59 \brief Relocates an in-memory image
\r
61 void *DoRelocate(void *base, char **envp, const char *Filename)
\r
63 uint8_t *hdr = base;
\r
65 if(memcmp(base, "\x7F""ELF", 4) == 0)
\r
66 return ElfRelocate(base, envp, Filename);
\r
67 if(hdr[0] == 0x7F && hdr[1] == 'E' && hdr[2] == 'L' && hdr[3] == 'F')
\r
68 return ElfRelocate(base, envp, Filename);
\r
70 if(hdr[0] == 'M' && hdr[1] == 'Z')
\r
71 return PE_Relocate(base, envp, Filename);
\r
73 SysDebug("ld-acess - DoRelocate: Unkown file format '0x%x 0x%x 0x%x 0x%x'\n",
\r
74 hdr[0], hdr[1], hdr[2], hdr[3] );
\r
75 SysDebug("ld-acess - DoRelocate: File '%s'\n", Filename);
\r
81 \fn int CallUser(Uint entry, Uint sp)
\r
83 int CallUser(void *entry, void *sp)
\r
85 #if ARCHDIR_IS_x86_64
\r
86 ((void **)sp)[-1] = 0; // Clear return address
\r
87 __asm__ __volatile__ (
\r
88 "mov %%rax, %%rsp;\n\t"
\r
90 : : "a"(sp), "c"(entry));
\r
91 #elif ARCHDIR_IS_x86
\r
92 ((void **)sp)[-1] = 0; // Clear return address
\r
93 __asm__ __volatile__ (
\r
94 "mov %%eax, %%esp;\n\t"
\r
96 : : "a"(sp), "c"(entry));
\r