#endif
#include <unistd.h>
#include <string.h>
+#include <stdbool.h>
+#include "../../KernelLand/Kernel/include/logdebug.h"
+
+#define VALGRIND_CLIENT 0
// === IMPORTS ===
extern int UI_Initialise(int Width, int Height);
extern void UI_MainLoop(void);
extern int VFS_Init(void);
+extern int PTY_Install(char **Arguments);
extern int Video_Install(char **Arguments);
extern int NativeKeyboard_Install(char **Arguments);
extern int NativeFS_Install(char **Arguments);
extern void Debug_SetKTerminal(char *Path);
extern int VT_Install(char **Arguments);
+extern int Mouse_Install(char **Arguments);
+extern int IPCPipe_Install(char **Arguments);
+extern int Net_Install(char **Arguments);
extern int VFS_Mount(const char *Device, const char *MountPoint, const char *Filesystem, const char *Options);
extern int VFS_MkDir(const char *Path);
extern int SyscallServer(void);
+extern int Server_Shutdown(void);
extern const char gsKernelVersion[];
extern const char gsGitHash[];
extern int giBuildNumber;
// === GLOBALS ===
-const char *gsAcessDir = "../Usermode/Output/x86_64";
+const char *gsAcessDir = "../Usermode/Output/native";
// === CODE ===
+#ifndef __WIN32__
+#define P_NOWAIT 0
+int spawnv(int flags, const char *execuable, char * const argv[])
+{
+ int pid = fork();
+ if( pid != 0 ) return pid;
+
+ execv(execuable, argv);
+ perror("spawnv - execve");
+ for(;;);
+}
+#endif
+
int main(int argc, char *argv[])
{
char **rootapp = NULL;
UI_Initialise(800, 480);
// - Ignore SIGUSR1 (used to wake threads)
+ #ifdef SIGUSR1
signal(SIGUSR1, SIG_IGN);
+ #endif
// Initialise VFS
VFS_Init();
Log_Error("Init", "Unable to load NativeKeyboard");
}
NativeFS_Install(NULL);
+ Mouse_Install(NULL);
+ IPCPipe_Install(NULL);
+ PTY_Install(NULL);
+ Net_Install(NULL);
// - Start VTerm
{
char *args[] = {
VFS_MkDir("/Acess");
VFS_Mount(gsAcessDir, "/Acess", "nativefs", "");
- Debug_SetKTerminal("/Devices/VTerm/8");
+ Debug_SetKTerminal("/Devices/pts/vt7");
// Start syscall server
SyscallServer();
if( rootapp )
{
int pid;
- char *args[7+rootapp_argc+1];
-
- args[0] = "ld-acess";
- args[1] = "--open"; args[2] = "/Devices/VTerm/0";
- args[3] = "--open"; args[4] = "/Devices/VTerm/0";
- args[5] = "--open"; args[6] = "/Devices/VTerm/0";
+ int argcount = 0;
+ const char *args[7+rootapp_argc+1+1];
+
+ #if VALGRIND_CLIENT
+ args[argcount++] = "valgrind";
+ #endif
+ args[argcount++] = "./ld-acess";
+ args[argcount++] = "--open"; args[argcount++] = "/Devices/pts/vt0";
+ args[argcount++] = "--open"; args[argcount++] = "/Devices/pts/vt0";
+ args[argcount++] = "--open"; args[argcount++] = "/Devices/pts/vt0";
for( i = 0; i < rootapp_argc; i ++ )
- args[7+i] = rootapp[i];
- args[7+rootapp_argc] = NULL;
-
- pid = fork();
+ args[argcount+i] = rootapp[i];
+ args[argcount+rootapp_argc] = NULL;
+ pid = spawnv(P_NOWAIT, "./ld-acess", (char *const*)args);
if(pid < 0) {
perror("Starting root application [fork(2)]");
return 1;
}
- if(pid == 0)
- {
- #ifdef __LINUX__
- prctl(PR_SET_PDEATHSIG, SIGHUP); // LINUX ONLY!
- #endif
- execv("./ld-acess", args);
- }
printf("Root application running as PID %i\n", pid);
}
void AcessNative_Exit(void)
{
// TODO: Close client applications too
+ Server_Shutdown();
exit(0);
}
return 0;
}
+void Proc_PrintBacktrace(void)
+{
+
+}
+