X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=AcessNative%2Flibacess-native.so_src%2Fexports.c;h=0f71f2121b76de0fc2871a0998f2eb653165ae04;hb=ca9a575116285753b48fd8e0ae6dcdbf8a4af5b1;hp=f22fe46d7e7048d9f6cbfa2df015d49eabd99d1b;hpb=4ab2ee475505478c2e1fa6547e94b480ef1308ec;p=tpg%2Facess2.git diff --git a/AcessNative/libacess-native.so_src/exports.c b/AcessNative/libacess-native.so_src/exports.c index f22fe46d..0f71f212 100644 --- a/AcessNative/libacess-native.so_src/exports.c +++ b/AcessNative/libacess-native.so_src/exports.c @@ -1,3 +1,4 @@ +#include "common.h" #define acess__SysSpawn _disabled_acess__SysSpawn #include "../ld-acess_src/exports.c" @@ -9,29 +10,49 @@ int *libc_geterrno(void) return &acess__errno; } +void _ZN4_sys5debugEPKcz(const char *fmt, ...) __attribute__((alias("acess__SysDebug"))); + #undef acess__SysSpawn int acess__SysSpawn(const char *binary, const char **argv, const char **envp, int nfd, int fds[], struct s_sys_spawninfo *info) { int argc = 0; - while( argv[argc++] ); + while( argv[argc++] ) + ; Debug("_SysSpawn('%s', %p (%i), %p, %i, %p, %p)", binary, argv, argc, envp, nfd, fds, info); - int kernel_tid; - int newID; - newID = _Syscall(SYS_AN_SPAWN, "d >d", sizeof(int), &kernel_tid, + char realpath[256]; + realpath[255] = 0; + + if( _Syscall(SYS_AN_GETPATH, "s", sizeof(realpath)-1, realpath, binary) <= 0 ) { + Warning("No translation for path '%s'", binary); + acess__errno = -11; + return -1; + } + + Warning("TODO: Spawn '%s' = '%s'", binary, realpath); + + int emulated_tid; + int newID = _Syscall(SYS_AN_SPAWN, "d >d", + sizeof(emulated_tid), &emulated_tid, nfd*sizeof(int), fds, - info ? sizeof(*info) : 0, info); - + (info ? sizeof(*info) : 0), info + ); - // TODO: Translate internal path to actual path + if( newID <= 0 ) { + return -1; + } - // TODO: set environment variables for libacess-native - // > ACESSNATIVE_KEY=`newID` - native_spawn(binary, argv, envp); + if( acessnative_spawn(realpath, newID, argv, envp) ) { + } - return 0; + return emulated_tid; +} + +void ldacess_DumpLoadedLibraries(void) +{ + Debug("ldacess_DumpLoadedLibraries"); }