1
0
Fork 0
mirror of https://github.com/Atmosphere-NX/Atmosphere.git synced 2025-01-08 10:36:16 +00:00

More main fixes

This commit is contained in:
Adubbz 2019-07-27 19:56:54 +10:00
parent 741d0f8116
commit 0169e3e3d6
2 changed files with 38 additions and 9 deletions

View file

@ -640,7 +640,7 @@ namespace sts::ncm {
this->placeholder_accessor.GetPlaceHolderPathUncached(placeholder_path, placeholder_id); this->placeholder_accessor.GetPlaceHolderPathUncached(placeholder_path, placeholder_id);
if (stat(placeholder_path, &st) == -1) { if (stat(placeholder_path, &st) == -1) {
return fsdevGetLastResult();; return fsdevGetLastResult();
} }
out_size.SetValue(st.st_size); out_size.SetValue(st.st_size);

View file

@ -76,19 +76,48 @@ void __appExit(void) {
fsExit(); fsExit();
} }
struct ServerOptions {
static constexpr size_t PointerBufferSize = 0x400;
static constexpr size_t MaxDomains = 0;
static constexpr size_t MaxDomainObjects = 0;
};
void ContentManagerServerMain(void* arg) {
static auto s_server_manager = WaitableManager<ServerOptions>(1);
/* Create services. */
s_server_manager.AddWaitable(new ServiceServer<sts::ncm::ContentManagerService>("ncm", 0x10));
/* Loop forever, servicing our services. */
s_server_manager.Process();
}
void LocationResolverServerMain(void* arg) {
static auto s_server_manager = WaitableManager<ServerOptions>(1);
/* Create services. */
s_server_manager.AddWaitable(new ServiceServer<sts::lr::LocationResolverManagerService>("lr", 0x10));
/* Loop forever, servicing our services. */
s_server_manager.Process();
}
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
static auto s_server_manager = WaitableManager(2);
/* Initialize content manager implementation. */ /* Initialize content manager implementation. */
R_ASSERT(sts::ncm::impl::InitializeContentManager()); R_ASSERT(sts::ncm::impl::InitializeContentManager());
/* Create services. */ static HosThread s_content_manager_thread;
s_server_manager.AddWaitable(new ServiceServer<sts::ncm::ContentManagerService>("ncm", 0x10)); static HosThread s_location_resolver_thread;
s_server_manager.AddWaitable(new ServiceServer<sts::lr::LocationResolverManagerService>("lr", 0x10));
R_ASSERT(s_content_manager_thread.Initialize(&ContentManagerServerMain, nullptr, 0x4000, 0x15));
/* Loop forever, servicing our services. */ R_ASSERT(s_content_manager_thread.Start());
s_server_manager.Process();
R_ASSERT(s_location_resolver_thread.Initialize(&LocationResolverServerMain, nullptr, 0x4000, 0x15));
R_ASSERT(s_location_resolver_thread.Start());
s_content_manager_thread.Join();
s_location_resolver_thread.Join();
return 0; return 0;
} }