#include <3ds.h> #include "manager.h" #include "reslimit.h" #include "launch.h" #include "firmlaunch.h" #include "exheader_info_heap.h" #include "task_runner.h" #include "process_monitor.h" #include "pmapp.h" #include "pmdbg.h" #include "util.h" #include "my_thread.h" #include "service_manager.h" static MyThread processMonitorThread, taskRunnerThread; static u8 ALIGN(8) processDataBuffer[0x40 * sizeof(ProcessData)] = {0}; static u8 ALIGN(8) exheaderInfoBuffer[6 * sizeof(ExHeader_Info)] = {0}; static u8 ALIGN(8) threadStacks[2][THREAD_STACK_SIZE] = {0}; // this is called after main exits void __wrap_exit(int rc) { (void)rc; // Not supposed to terminate... kernel will clean up the handles if it does happen anyway svcExitProcess(); } Result __sync_init(void); //void __libc_init_array(void); // Called before main void initSystem() { __sync_init(); //__libc_init_array(); // Wait for sm for(Result res = 0xD88007FA; res == (Result)0xD88007FA; svcSleepThread(500 * 1000LL)) { res = srvPmInit(); if(R_FAILED(res) && res != (Result)0xD88007FA) panic(res); } loaderInit(); fsRegInit(); // Init objects Manager_Init(processDataBuffer, 0x40); ExHeaderInfoHeap_Init(exheaderInfoBuffer, 6); TaskRunner_Init(); } static const ServiceManagerServiceEntry services[] = { { "pm:app", 4, pmAppHandleCommands, false }, { "pm:dbg", 2, pmDbgHandleCommands, false }, { NULL }, }; static const ServiceManagerNotificationEntry notifications[] = { { 0x000, NULL }, }; void __ctru_exit(int rc) { (void)rc; } // needed to avoid linking error int main(void) { Result res = 0; // Init the reslimits, register the KIPs and map the firmlaunch parameters initializeReslimits(); Manager_RegisterKips(); mapFirmlaunchParameters(); // Create the threads assertSuccess(MyThread_Create(&processMonitorThread, processMonitor, NULL, threadStacks[0], THREAD_STACK_SIZE, 0x17, -2)); assertSuccess(MyThread_Create(&taskRunnerThread, TaskRunner_HandleTasks, NULL, threadStacks[1], THREAD_STACK_SIZE, 0x17, -2)); // Launch NS, etc. autolaunchSysmodules(); if (R_FAILED(res = ServiceManager_Run(services, notifications, NULL))) { panic(res); } return 0; }