Reece
99c5e1fa65
[*] Split up Aurora Async [*] Split Async app into seperate ThreadPool concept [*] Fix various OSThread bugs and tls transfer issues [*] Set default affinity to 0xFFFFFFFF [*] Update Build script [+] Add AuTuplePopFront [+] New Network Interface (unimplemented) [*] Stub out the interfaces required for a better logger [*] Fix Win32 ShellExecute bug; windows 11 struggles without explicit com init per the docs - now deferring to thread pool [*] Update gitignore [*] Follow XDG home standard [*] Refactor some namespaces to use the shorthand aliases [*] Various stability fixes
44 lines
1.5 KiB
C++
44 lines
1.5 KiB
C++
/***
|
|
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
File: Process.hpp
|
|
Date: 2021-6-10
|
|
Author: Reece
|
|
***/
|
|
#pragma once
|
|
|
|
#include "Paths.hpp"
|
|
#include "ProcessMap.hpp"
|
|
|
|
namespace Aurora::Process
|
|
{
|
|
AUKN_SYM AU_NORETURN void Exit(AuUInt32 exitcode);
|
|
|
|
AUE_DEFINE(EModulePath,
|
|
(
|
|
eModulePathCWD,
|
|
eModulePathSystemDir, /// /lib/, windir/system32
|
|
eModulePathUserDir, /// /usr/lib/
|
|
eProcessDirectory, ///
|
|
eOSSpecified, /// LD_LIBRARY_PATH + /etc/ld.so.conf, AddDllDirectory
|
|
eSpecified
|
|
));
|
|
|
|
static AuList<EModulePath> kUserOverloadableSearchPath = {EModulePath::eSpecified, EModulePath::eModulePathCWD, EModulePath::eProcessDirectory, EModulePath::eModulePathUserDir, EModulePath::eModulePathSystemDir};
|
|
static AuList<EModulePath> kAdminOverloadableSearchPath = {EModulePath::eSpecified, EModulePath::eModulePathSystemDir, EModulePath::eProcessDirectory, EModulePath::eModulePathCWD, EModulePath::eModulePathUserDir};
|
|
|
|
struct ModuleLoadRequest
|
|
{
|
|
AuString mod;
|
|
AuString version;
|
|
AuString extension;
|
|
AuList<AuString> const *specifiedSearchPaths {};
|
|
AuList<EModulePath> const *searchPath {};
|
|
bool verify {}; // always effectively true if the executable is signed and enableMitigations is true
|
|
bool unixCheckPlusX {};
|
|
bool enableMitigations {true};
|
|
};
|
|
|
|
AUKN_SYM bool LoadModule(const ModuleLoadRequest &request);
|
|
AUKN_SYM AuMach GetProcAddress(AuString mod, AuString symbol);
|
|
} |