ams: revamp assertion system

This commit is contained in:
Michael Scire 2020-02-22 23:05:14 -08:00
parent 9572fb2ce3
commit 40400aee1f
168 changed files with 1014 additions and 696 deletions

View file

@ -22,11 +22,11 @@ namespace ams::kern {
} }
#if 1 #if 1 || defined(AMS_BUILD_FOR_AUDITING)
#define MESOSPHERE_BUILD_FOR_AUDITING #define MESOSPHERE_BUILD_FOR_AUDITING
#endif #endif
#ifdef MESOSPHERE_BUILD_FOR_AUDITING #if defined(MESOSPHERE_BUILD_FOR_AUDITING) || defined(AMS_BUILD_FOR_DEBUGGING)
#define MESOSPHERE_BUILD_FOR_DEBUGGING #define MESOSPHERE_BUILD_FOR_DEBUGGING
#endif #endif

View file

@ -40,7 +40,7 @@ namespace ams {
const u32 build_version = exosphere::GetVersion(ATMOSPHERE_RELEASE_VERSION); const u32 build_version = exosphere::GetVersion(ATMOSPHERE_RELEASE_VERSION);
if (runtime_version < build_version) { if (runtime_version < build_version) {
R_ASSERT(exosphere::ResultVersionMismatch()); R_ABORT_UNLESS(exosphere::ResultVersionMismatch());
} }
} }

View file

@ -29,7 +29,7 @@ namespace ams::dd {
inline uintptr_t GetIoMapping(uintptr_t phys_addr, size_t size) { inline uintptr_t GetIoMapping(uintptr_t phys_addr, size_t size) {
const uintptr_t io_mapping = QueryIoMapping(phys_addr, size); const uintptr_t io_mapping = QueryIoMapping(phys_addr, size);
AMS_ASSERT(io_mapping); AMS_ABORT_UNLESS(io_mapping);
return io_mapping; return io_mapping;
} }

View file

@ -83,7 +83,7 @@ namespace ams::fssystem {
/* Iteration API */ /* Iteration API */
template<typename OnEnterDir, typename OnExitDir, typename OnFile> template<typename OnEnterDir, typename OnExitDir, typename OnFile>
Result IterateDirectoryRecursively(fs::fsa::IFileSystem *fs, const char *root_path, char *work_path, size_t work_path_size, fs::DirectoryEntry *dir_ent_buf, OnEnterDir on_enter_dir, OnExitDir on_exit_dir, OnFile on_file) { Result IterateDirectoryRecursively(fs::fsa::IFileSystem *fs, const char *root_path, char *work_path, size_t work_path_size, fs::DirectoryEntry *dir_ent_buf, OnEnterDir on_enter_dir, OnExitDir on_exit_dir, OnFile on_file) {
AMS_ASSERT(work_path_size >= fs::EntryNameLengthMax + 1); AMS_ABORT_UNLESS(work_path_size >= fs::EntryNameLengthMax + 1);
/* Get size of the root path. */ /* Get size of the root path. */
size_t root_path_len = strnlen(root_path, fs::EntryNameLengthMax + 1); size_t root_path_len = strnlen(root_path, fs::EntryNameLengthMax + 1);

View file

@ -66,7 +66,7 @@ namespace ams::kvdb {
Result Initialize(size_t size) { Result Initialize(size_t size) {
/* Check that we're not already initialized. */ /* Check that we're not already initialized. */
AMS_ASSERT(this->buffer == nullptr); AMS_ABORT_UNLESS(this->buffer == nullptr);
/* Allocate a buffer. */ /* Allocate a buffer. */
this->buffer = static_cast<u8 *>(std::malloc(size)); this->buffer = static_cast<u8 *>(std::malloc(size));

View file

@ -28,7 +28,7 @@ namespace ams::kvdb {
private: private:
/* Utility. */ /* Utility. */
static inline void CheckLength(size_t len) { static inline void CheckLength(size_t len) {
AMS_ASSERT(len < N); AMS_ABORT_UNLESS(len < N);
} }
public: public:
/* Constructors. */ /* Constructors. */
@ -109,8 +109,8 @@ namespace ams::kvdb {
/* Substring utilities. */ /* Substring utilities. */
void GetSubstring(char *dst, size_t dst_size, size_t offset, size_t length) const { void GetSubstring(char *dst, size_t dst_size, size_t offset, size_t length) const {
/* Make sure output buffer can hold the substring. */ /* Make sure output buffer can hold the substring. */
AMS_ASSERT(offset + length <= GetLength()); AMS_ABORT_UNLESS(offset + length <= GetLength());
AMS_ASSERT(dst_size > length); AMS_ABORT_UNLESS(dst_size > length);
/* Copy substring to dst. */ /* Copy substring to dst. */
std::strncpy(dst, this->buffer + offset, length); std::strncpy(dst, this->buffer + offset, length);
dst[length] = 0; dst[length] = 0;

View file

@ -54,7 +54,7 @@ namespace ams::kvdb {
} }
private: private:
void RemoveIndex(size_t i) { void RemoveIndex(size_t i) {
AMS_ASSERT(i < this->GetCount()); AMS_ABORT_UNLESS(i < this->GetCount());
std::memmove(this->keys + i, this->keys + i + 1, sizeof(*this->keys) * (this->GetCount() - (i + 1))); std::memmove(this->keys + i, this->keys + i + 1, sizeof(*this->keys) * (this->GetCount() - (i + 1)));
this->DecrementCount(); this->DecrementCount();
} }
@ -71,8 +71,8 @@ namespace ams::kvdb {
Result Initialize(const char *path, void *buf, size_t size) { Result Initialize(const char *path, void *buf, size_t size) {
/* Only initialize once, and ensure we have sufficient memory. */ /* Only initialize once, and ensure we have sufficient memory. */
AMS_ASSERT(this->keys == nullptr); AMS_ABORT_UNLESS(this->keys == nullptr);
AMS_ASSERT(size >= BufferSize); AMS_ABORT_UNLESS(size >= BufferSize);
/* Setup member variables. */ /* Setup member variables. */
this->keys = static_cast<Key *>(buf); this->keys = static_cast<Key *>(buf);
@ -127,23 +127,23 @@ namespace ams::kvdb {
} }
Key Get(size_t i) const { Key Get(size_t i) const {
AMS_ASSERT(i < this->GetCount()); AMS_ABORT_UNLESS(i < this->GetCount());
return this->keys[i]; return this->keys[i];
} }
Key Peek() const { Key Peek() const {
AMS_ASSERT(!this->IsEmpty()); AMS_ABORT_UNLESS(!this->IsEmpty());
return this->Get(0); return this->Get(0);
} }
void Push(const Key &key) { void Push(const Key &key) {
AMS_ASSERT(!this->IsFull()); AMS_ABORT_UNLESS(!this->IsFull());
this->keys[this->GetCount()] = key; this->keys[this->GetCount()] = key;
this->IncrementCount(); this->IncrementCount();
} }
Key Pop() { Key Pop() {
AMS_ASSERT(!this->IsEmpty()); AMS_ABORT_UNLESS(!this->IsEmpty());
this->RemoveIndex(0); this->RemoveIndex(0);
} }

View file

@ -92,7 +92,7 @@ namespace ams::kvdb {
static_assert(std::is_pod<Value>::value && !std::is_pointer<Value>::value, "Invalid FileKeyValueStore Value!"); static_assert(std::is_pod<Value>::value && !std::is_pointer<Value>::value, "Invalid FileKeyValueStore Value!");
size_t size = 0; size_t size = 0;
R_TRY(this->Get(&size, out_value, sizeof(Value), key)); R_TRY(this->Get(&size, out_value, sizeof(Value), key));
AMS_ASSERT(size >= sizeof(Value)); AMS_ABORT_UNLESS(size >= sizeof(Value));
return ResultSuccess(); return ResultSuccess();
} }

View file

@ -45,7 +45,7 @@ namespace ams::kvdb {
Value *GetValuePointer() { Value *GetValuePointer() {
/* Size check. Note: Nintendo does not size check. */ /* Size check. Note: Nintendo does not size check. */
if constexpr (!std::is_same<Value, void>::value) { if constexpr (!std::is_same<Value, void>::value) {
AMS_ASSERT(sizeof(Value) <= this->value_size); AMS_ABORT_UNLESS(sizeof(Value) <= this->value_size);
/* Ensure we only get pod. */ /* Ensure we only get pod. */
static_assert(std::is_pod<Value>::value, "KeyValueStore Values must be pod"); static_assert(std::is_pod<Value>::value, "KeyValueStore Values must be pod");
} }
@ -56,7 +56,7 @@ namespace ams::kvdb {
const Value *GetValuePointer() const { const Value *GetValuePointer() const {
/* Size check. Note: Nintendo does not size check. */ /* Size check. Note: Nintendo does not size check. */
if constexpr (!std::is_same<Value, void>::value) { if constexpr (!std::is_same<Value, void>::value) {
AMS_ASSERT(sizeof(Value) <= this->value_size); AMS_ABORT_UNLESS(sizeof(Value) <= this->value_size);
/* Ensure we only get pod. */ /* Ensure we only get pod. */
static_assert(std::is_pod<Value>::value, "KeyValueStore Values must be pod"); static_assert(std::is_pod<Value>::value, "KeyValueStore Values must be pod");
} }

View file

@ -53,7 +53,7 @@ namespace ams::map {
~AutoCloseMap() { ~AutoCloseMap() {
if (this->process_handle != INVALID_HANDLE && R_SUCCEEDED(this->result)) { if (this->process_handle != INVALID_HANDLE && R_SUCCEEDED(this->result)) {
R_ASSERT(svcUnmapProcessMemory(this->mapped_address, this->process_handle, this->base_address, this->size)); R_ABORT_UNLESS(svcUnmapProcessMemory(this->mapped_address, this->process_handle, this->base_address, this->size));
} }
} }
@ -88,7 +88,7 @@ namespace ams::map {
~MappedCodeMemory() { ~MappedCodeMemory() {
if (this->process_handle != INVALID_HANDLE && R_SUCCEEDED(this->result) && this->size > 0) { if (this->process_handle != INVALID_HANDLE && R_SUCCEEDED(this->result) && this->size > 0) {
R_ASSERT(svcUnmapProcessCodeMemory(this->process_handle, this->dst_address, this->src_address, this->size)); R_ABORT_UNLESS(svcUnmapProcessCodeMemory(this->process_handle, this->dst_address, this->src_address, this->size));
} }
} }

View file

@ -50,7 +50,7 @@ namespace ams::os {
NX_INLINE os::ProcessId GetProcessId(::Handle process_handle) { NX_INLINE os::ProcessId GetProcessId(::Handle process_handle) {
os::ProcessId process_id; os::ProcessId process_id;
R_ASSERT(TryGetProcessId(&process_id, process_handle)); R_ABORT_UNLESS(TryGetProcessId(&process_id, process_handle));
return process_id; return process_id;
} }

View file

@ -47,7 +47,7 @@ namespace ams::os {
} }
void Wait(::Mutex *m) { void Wait(::Mutex *m) {
R_ASSERT(condvarWait(&this->cv, m)); R_ABORT_UNLESS(condvarWait(&this->cv, m));
} }
ConditionVariableStatus TimedWait(os::Mutex *m, u64 timeout) { ConditionVariableStatus TimedWait(os::Mutex *m, u64 timeout) {

View file

@ -28,7 +28,7 @@ namespace ams::os {
ManagedHandle(Handle h) : hnd(h) { /* ... */ } ManagedHandle(Handle h) : hnd(h) { /* ... */ }
~ManagedHandle() { ~ManagedHandle() {
if (this->hnd != INVALID_HANDLE) { if (this->hnd != INVALID_HANDLE) {
R_ASSERT(svcCloseHandle(this->hnd)); R_ABORT_UNLESS(svcCloseHandle(this->hnd));
this->hnd = INVALID_HANDLE; this->hnd = INVALID_HANDLE;
} }
} }

View file

@ -71,7 +71,7 @@ namespace ams::os {
constexpr StaticThread() : stack_mem{}, thr{} { /* ... */ } constexpr StaticThread() : stack_mem{}, thr{} { /* ... */ }
constexpr StaticThread(ThreadFunc entry, void *arg, int prio, int cpuid = -2) : StaticThread() { constexpr StaticThread(ThreadFunc entry, void *arg, int prio, int cpuid = -2) : StaticThread() {
R_ASSERT(this->Initialize(entry, arg, prio, cpuid)); R_ABORT_UNLESS(this->Initialize(entry, arg, prio, cpuid));
} }
Result Initialize(ThreadFunc entry, void *arg, int prio, int cpuid = -2) { Result Initialize(ThreadFunc entry, void *arg, int prio, int cpuid = -2) {
@ -103,7 +103,7 @@ namespace ams::os {
NX_INLINE u32 GetCurrentThreadPriority() { NX_INLINE u32 GetCurrentThreadPriority() {
u32 prio; u32 prio;
R_ASSERT(svcGetThreadPriority(&prio, CUR_THREAD_HANDLE)); R_ABORT_UNLESS(svcGetThreadPriority(&prio, CUR_THREAD_HANDLE));
return prio; return prio;
} }

View file

@ -61,7 +61,7 @@ namespace ams::ro {
ModuleType GetType() const { ModuleType GetType() const {
const ModuleType type = static_cast<ModuleType>(this->type); const ModuleType type = static_cast<ModuleType>(this->type);
AMS_ASSERT(type < ModuleType::Count); AMS_ABORT_UNLESS(type < ModuleType::Count);
return type; return type;
} }

View file

@ -87,7 +87,7 @@ namespace ams::sf::cmif {
inline DomainObjectId GetId(Entry *e) { inline DomainObjectId GetId(Entry *e) {
const size_t index = e - this->entries; const size_t index = e - this->entries;
AMS_ASSERT(index < this->num_entries); AMS_ABORT_UNLESS(index < this->num_entries);
return DomainObjectId{ u32(index + 1) }; return DomainObjectId{ u32(index + 1) };
} }

View file

@ -41,8 +41,8 @@ namespace ams::sf::cmif {
ServerMessageRuntimeMetadata impl_metadata; ServerMessageRuntimeMetadata impl_metadata;
public: public:
DomainServiceObjectProcessor(ServerDomainBase *d, DomainObjectId *in_obj_ids, size_t num_in_objs) : domain(d), in_object_ids(in_obj_ids), num_in_objects(num_in_objs) { DomainServiceObjectProcessor(ServerDomainBase *d, DomainObjectId *in_obj_ids, size_t num_in_objs) : domain(d), in_object_ids(in_obj_ids), num_in_objects(num_in_objs) {
AMS_ASSERT(this->domain != nullptr); AMS_ABORT_UNLESS(this->domain != nullptr);
AMS_ASSERT(this->in_object_ids != nullptr); AMS_ABORT_UNLESS(this->in_object_ids != nullptr);
this->impl_processor = nullptr; this->impl_processor = nullptr;
this->out_object_ids = nullptr; this->out_object_ids = nullptr;
this->impl_metadata = {}; this->impl_metadata = {};

View file

@ -83,11 +83,11 @@ namespace ams::sf::hipc {
virtual ~Server() override { virtual ~Server() override {
if (this->service_managed) { if (this->service_managed) {
if constexpr (IsMitmServer) { if constexpr (IsMitmServer) {
R_ASSERT(sm::mitm::UninstallMitm(this->service_name)); R_ABORT_UNLESS(sm::mitm::UninstallMitm(this->service_name));
} else { } else {
R_ASSERT(sm::UnregisterService(this->service_name)); R_ABORT_UNLESS(sm::UnregisterService(this->service_name));
} }
R_ASSERT(svcCloseHandle(this->port_handle)); R_ABORT_UNLESS(svcCloseHandle(this->port_handle));
} }
} }
@ -106,7 +106,7 @@ namespace ams::sf::hipc {
/* Get mitm forward session. */ /* Get mitm forward session. */
sm::MitmProcessInfo client_info; sm::MitmProcessInfo client_info;
R_ASSERT(sm::mitm::AcknowledgeSession(forward_service.get(), &client_info, this->service_name)); R_ABORT_UNLESS(sm::mitm::AcknowledgeSession(forward_service.get(), &client_info, this->service_name));
*out_obj = std::move(cmif::ServiceObjectHolder(std::move(MakeShared(std::shared_ptr<::Service>(forward_service), client_info)))); *out_obj = std::move(cmif::ServiceObjectHolder(std::move(MakeShared(std::shared_ptr<::Service>(forward_service), client_info))));
*out_fsrv = std::move(forward_service); *out_fsrv = std::move(forward_service);
@ -149,7 +149,7 @@ namespace ams::sf::hipc {
void RegisterServerImpl(Handle port_handle, sm::ServiceName service_name, bool managed, cmif::ServiceObjectHolder &&static_holder) { void RegisterServerImpl(Handle port_handle, sm::ServiceName service_name, bool managed, cmif::ServiceObjectHolder &&static_holder) {
/* Allocate server memory. */ /* Allocate server memory. */
auto *server = this->AllocateServer(); auto *server = this->AllocateServer();
AMS_ASSERT(server != nullptr); AMS_ABORT_UNLESS(server != nullptr);
new (server) Server<ServiceImpl, MakeShared>(port_handle, service_name, managed, std::forward<cmif::ServiceObjectHolder>(static_holder)); new (server) Server<ServiceImpl, MakeShared>(port_handle, service_name, managed, std::forward<cmif::ServiceObjectHolder>(static_holder));
if constexpr (!ServiceObjectTraits<ServiceImpl>::IsMitmServiceObject) { if constexpr (!ServiceObjectTraits<ServiceImpl>::IsMitmServiceObject) {
@ -273,13 +273,13 @@ namespace ams::sf::hipc {
private: private:
constexpr inline size_t GetServerIndex(const ServerBase *server) const { constexpr inline size_t GetServerIndex(const ServerBase *server) const {
const size_t i = server - GetPointer(this->server_storages[0]); const size_t i = server - GetPointer(this->server_storages[0]);
AMS_ASSERT(i < MaxServers); AMS_ABORT_UNLESS(i < MaxServers);
return i; return i;
} }
constexpr inline size_t GetSessionIndex(const ServerSession *session) const { constexpr inline size_t GetSessionIndex(const ServerSession *session) const {
const size_t i = session - GetPointer(this->session_storages[0]); const size_t i = session - GetPointer(this->session_storages[0]);
AMS_ASSERT(i < MaxSessions); AMS_ABORT_UNLESS(i < MaxSessions);
return i; return i;
} }
@ -301,7 +301,7 @@ namespace ams::sf::hipc {
virtual void FreeSession(ServerSession *session) override final { virtual void FreeSession(ServerSession *session) override final {
std::scoped_lock lk(this->resource_mutex); std::scoped_lock lk(this->resource_mutex);
const size_t index = this->GetSessionIndex(session); const size_t index = this->GetSessionIndex(session);
AMS_ASSERT(this->session_allocated[index]); AMS_ABORT_UNLESS(this->session_allocated[index]);
this->session_allocated[index] = false; this->session_allocated[index] = false;
} }
@ -319,7 +319,7 @@ namespace ams::sf::hipc {
virtual void DestroyServer(ServerBase *server) override final { virtual void DestroyServer(ServerBase *server) override final {
std::scoped_lock lk(this->resource_mutex); std::scoped_lock lk(this->resource_mutex);
const size_t index = this->GetServerIndex(server); const size_t index = this->GetServerIndex(server);
AMS_ASSERT(this->server_allocated[index]); AMS_ABORT_UNLESS(this->server_allocated[index]);
server->~ServerBase(); server->~ServerBase();
this->server_allocated[index] = false; this->server_allocated[index] = false;
} }
@ -339,8 +339,8 @@ namespace ams::sf::hipc {
std::scoped_lock lk(this->resource_mutex); std::scoped_lock lk(this->resource_mutex);
DomainStorage *ptr = static_cast<DomainStorage *>(domain); DomainStorage *ptr = static_cast<DomainStorage *>(domain);
const size_t index = ptr - this->domain_storages; const size_t index = ptr - this->domain_storages;
AMS_ASSERT(index < ManagerOptions::MaxDomains); AMS_ABORT_UNLESS(index < ManagerOptions::MaxDomains);
AMS_ASSERT(this->domain_allocated[index]); AMS_ABORT_UNLESS(this->domain_allocated[index]);
this->domain_allocated[index] = false; this->domain_allocated[index] = false;
} }

View file

@ -58,14 +58,14 @@ namespace ams::sf::hipc {
this->is_closed = false; this->is_closed = false;
this->has_received = false; this->has_received = false;
this->forward_service = nullptr; this->forward_service = nullptr;
AMS_ASSERT(!this->IsMitmSession()); AMS_ABORT_UNLESS(!this->IsMitmSession());
} }
ServerSession(Handle h, cmif::ServiceObjectHolder &&obj, std::shared_ptr<::Service> &&fsrv) : WaitableHolder(h), srv_obj_holder(std::move(obj)), session_handle(h) { ServerSession(Handle h, cmif::ServiceObjectHolder &&obj, std::shared_ptr<::Service> &&fsrv) : WaitableHolder(h), srv_obj_holder(std::move(obj)), session_handle(h) {
this->is_closed = false; this->is_closed = false;
this->has_received = false; this->has_received = false;
this->forward_service = std::move(fsrv); this->forward_service = std::move(fsrv);
AMS_ASSERT(this->IsMitmSession()); AMS_ABORT_UNLESS(this->IsMitmSession());
} }
bool IsMitmSession() const { bool IsMitmSession() const {

View file

@ -797,8 +797,8 @@ namespace ams::sf::impl {
return; return;
} }
Handle server_handle, client_handle; Handle server_handle, client_handle;
R_ASSERT(sf::hipc::CreateSession(&server_handle, &client_handle)); R_ABORT_UNLESS(sf::hipc::CreateSession(&server_handle, &client_handle));
R_ASSERT(manager->RegisterSession(server_handle, std::move(object))); R_ABORT_UNLESS(manager->RegisterSession(server_handle, std::move(object)));
response.move_handles[Index] = client_handle; response.move_handles[Index] = client_handle;
} }
@ -1013,7 +1013,7 @@ namespace ams::sf::impl {
/* Fake buffer. This is either InData or OutData, but serializing over buffers. */ /* Fake buffer. This is either InData or OutData, but serializing over buffers. */
constexpr auto Attributes = CommandMeta::BufferAttributes[Info.buffer_index]; constexpr auto Attributes = CommandMeta::BufferAttributes[Info.buffer_index];
if constexpr (Attributes & SfBufferAttr_In) { if constexpr (Attributes & SfBufferAttr_In) {
/* TODO: AMS_ASSERT()? N does not bother. */ /* TODO: AMS_ABORT_UNLESS()? N does not bother. */
return *reinterpret_cast<const T *>(buffers[Info.buffer_index].GetAddress()); return *reinterpret_cast<const T *>(buffers[Info.buffer_index].GetAddress());
} else if constexpr (Attributes & SfBufferAttr_Out) { } else if constexpr (Attributes & SfBufferAttr_Out) {
return T(buffers[Info.buffer_index]); return T(buffers[Info.buffer_index]);

View file

@ -44,7 +44,7 @@ namespace ams::sf {
public: public:
constexpr Out(uintptr_t p) : ptr(reinterpret_cast<T *>(p)) { /* ... */ } constexpr Out(uintptr_t p) : ptr(reinterpret_cast<T *>(p)) { /* ... */ }
constexpr Out(T *p) : ptr(p) { /* ... */ } constexpr Out(T *p) : ptr(p) { /* ... */ }
constexpr Out(const cmif::PointerAndSize &pas) : ptr(reinterpret_cast<T *>(pas.GetAddress())) { /* TODO: Is AMS_ASSERT(pas.GetSize() >= sizeof(T)); necessary? */ } constexpr Out(const cmif::PointerAndSize &pas) : ptr(reinterpret_cast<T *>(pas.GetAddress())) { /* TODO: Is AMS_ABORT_UNLESS(pas.GetSize() >= sizeof(T)); necessary? */ }
void SetValue(const T& value) const { void SetValue(const T& value) const {
*this->ptr = value; *this->ptr = value;

View file

@ -62,7 +62,7 @@ namespace ams::sm {
} }
Result Initialize() { Result Initialize() {
AMS_ASSERT(!this->has_initialized); AMS_ABORT_UNLESS(!this->has_initialized);
sm::DoWithSession([&]() { sm::DoWithSession([&]() {
this->result = Initializer(); this->result = Initializer();
@ -73,7 +73,7 @@ namespace ams::sm {
} }
void Finalize() { void Finalize() {
AMS_ASSERT(this->has_initialized); AMS_ABORT_UNLESS(this->has_initialized);
Finalizer(); Finalizer();
this->has_initialized = false; this->has_initialized = false;
} }

View file

@ -82,7 +82,7 @@ namespace ams::emummc {
} *paths = reinterpret_cast<decltype(paths)>(&path_storage); } *paths = reinterpret_cast<decltype(paths)>(&path_storage);
/* Retrieve paths from secure monitor. */ /* Retrieve paths from secure monitor. */
AMS_ASSERT(spl::smc::AtmosphereGetEmummcConfig(&g_exo_config, paths, 0) == spl::smc::Result::Success); AMS_ABORT_UNLESS(spl::smc::AtmosphereGetEmummcConfig(&g_exo_config, paths, 0) == spl::smc::Result::Success);
const Storage storage = static_cast<Storage>(g_exo_config.base_cfg.type); const Storage storage = static_cast<Storage>(g_exo_config.base_cfg.type);
g_is_emummc = g_exo_config.base_cfg.magic == StorageMagic && storage != Storage_Emmc; g_is_emummc = g_exo_config.base_cfg.magic == StorageMagic && storage != Storage_Emmc;

View file

@ -37,8 +37,8 @@ namespace ams {
extern ncm::ProgramId CurrentProgramId; extern ncm::ProgramId CurrentProgramId;
void WEAK_SYMBOL ExceptionHandler(FatalErrorContext *ctx) { void WEAK_SYMBOL ExceptionHandler(FatalErrorContext *ctx) {
R_ASSERT(amsBpcInitialize()); R_ABORT_UNLESS(amsBpcInitialize());
R_ASSERT(amsBpcRebootToFatalError(ctx)); R_ABORT_UNLESS(amsBpcRebootToFatalError(ctx));
while (1) { /* ... */ } while (1) { /* ... */ }
} }

View file

@ -23,22 +23,22 @@ namespace ams::exosphere {
ApiInfo GetApiInfo() { ApiInfo GetApiInfo() {
u64 exosphere_cfg; u64 exosphere_cfg;
if (spl::smc::GetConfig(&exosphere_cfg, 1, SplConfigItem_ExosphereApiVersion) != spl::smc::Result::Success) { if (spl::smc::GetConfig(&exosphere_cfg, 1, SplConfigItem_ExosphereApiVersion) != spl::smc::Result::Success) {
R_ASSERT(ResultNotPresent()); R_ABORT_UNLESS(ResultNotPresent());
} }
return ApiInfo{ util::BitPack64(exosphere_cfg) }; return ApiInfo{ util::BitPack64(exosphere_cfg) };
} }
void ForceRebootToRcm() { void ForceRebootToRcm() {
R_ASSERT(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsReboot, 1))); R_ABORT_UNLESS(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsReboot, 1)));
} }
void ForceRebootToIramPayload() { void ForceRebootToIramPayload() {
R_ASSERT(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsReboot, 2))); R_ABORT_UNLESS(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsReboot, 2)));
} }
void ForceShutdown() { void ForceShutdown() {
R_ASSERT(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsShutdown, 1))); R_ABORT_UNLESS(spl::smc::ConvertResult(spl::smc::SetConfig(SplConfigItem_ExosphereNeedsShutdown, 1)));
} }
void CopyToIram(uintptr_t iram_dst, const void *dram_src, size_t size) { void CopyToIram(uintptr_t iram_dst, const void *dram_src, size_t size) {
@ -62,7 +62,7 @@ namespace ams::exosphere {
bool IsRcmBugPatched() { bool IsRcmBugPatched() {
bool rcm_bug_patched; bool rcm_bug_patched;
R_ASSERT(GetRcmBugPatched(&rcm_bug_patched)); R_ABORT_UNLESS(GetRcmBugPatched(&rcm_bug_patched));
return rcm_bug_patched; return rcm_bug_patched;
} }

View file

@ -140,9 +140,9 @@ namespace ams::boot2 {
/* Launch, lightly validate result. */ /* Launch, lightly validate result. */
{ {
const auto launch_result = pm::shell::LaunchProgram(&process_id, loc, launch_flags); const auto launch_result = pm::shell::LaunchProgram(&process_id, loc, launch_flags);
AMS_ASSERT(!(svc::ResultOutOfResource::Includes(launch_result))); AMS_ABORT_UNLESS(!(svc::ResultOutOfResource::Includes(launch_result)));
AMS_ASSERT(!(svc::ResultOutOfMemory::Includes(launch_result))); AMS_ABORT_UNLESS(!(svc::ResultOutOfMemory::Includes(launch_result)));
AMS_ASSERT(!(svc::ResultLimitReached::Includes(launch_result))); AMS_ABORT_UNLESS(!(svc::ResultLimitReached::Includes(launch_result)));
} }
if (out_process_id) { if (out_process_id) {
@ -265,10 +265,10 @@ namespace ams::boot2 {
} }
/* Don't allow invalid lines. */ /* Don't allow invalid lines. */
AMS_ASSERT(name_len <= sizeof(sm::ServiceName)); AMS_ABORT_UNLESS(name_len <= sizeof(sm::ServiceName));
/* Declare the service. */ /* Declare the service. */
R_ASSERT(sm::mitm::DeclareFutureMitm(sm::ServiceName::Encode(mitm_list + offset, name_len))); R_ABORT_UNLESS(sm::mitm::DeclareFutureMitm(sm::ServiceName::Encode(mitm_list + offset, name_len)));
/* Advance to the next line. */ /* Advance to the next line. */
offset += name_len; offset += name_len;
@ -296,7 +296,7 @@ namespace ams::boot2 {
/* This code is normally run by PM. */ /* This code is normally run by PM. */
/* Wait until fs.mitm has installed itself. We want this to happen as early as possible. */ /* Wait until fs.mitm has installed itself. We want this to happen as early as possible. */
R_ASSERT(sm::mitm::WaitMitm(sm::ServiceName::Encode("fsp-srv"))); R_ABORT_UNLESS(sm::mitm::WaitMitm(sm::ServiceName::Encode("fsp-srv")));
/* Launch programs required to mount the SD card. */ /* Launch programs required to mount the SD card. */
LaunchList(PreSdCardLaunchPrograms, NumPreSdCardLaunchPrograms); LaunchList(PreSdCardLaunchPrograms, NumPreSdCardLaunchPrograms);
@ -305,11 +305,11 @@ namespace ams::boot2 {
cfg::WaitSdCardRequiredServicesReady(); cfg::WaitSdCardRequiredServicesReady();
/* Wait for other atmosphere mitm modules to initialize. */ /* Wait for other atmosphere mitm modules to initialize. */
R_ASSERT(sm::mitm::WaitMitm(sm::ServiceName::Encode("set:sys"))); R_ABORT_UNLESS(sm::mitm::WaitMitm(sm::ServiceName::Encode("set:sys")));
if (hos::GetVersion() >= hos::Version_200) { if (hos::GetVersion() >= hos::Version_200) {
R_ASSERT(sm::mitm::WaitMitm(sm::ServiceName::Encode("bpc"))); R_ABORT_UNLESS(sm::mitm::WaitMitm(sm::ServiceName::Encode("bpc")));
} else { } else {
R_ASSERT(sm::mitm::WaitMitm(sm::ServiceName::Encode("bpc:c"))); R_ABORT_UNLESS(sm::mitm::WaitMitm(sm::ServiceName::Encode("bpc:c")));
} }
/* Launch Atmosphere boot2, using NcmStorageId_None to force SD card boot. */ /* Launch Atmosphere boot2, using NcmStorageId_None to force SD card boot. */

View file

@ -84,8 +84,6 @@ namespace ams::cfg {
.override_any_app = true, .override_any_app = true,
}; };
bool g_loaded_override_config = false;
char g_hbl_sd_path[0x100] = "/atmosphere/hbl.nsp"; char g_hbl_sd_path[0x100] = "/atmosphere/hbl.nsp";
/* Helpers. */ /* Helpers. */

View file

@ -35,12 +35,12 @@ namespace ams::cfg {
os::ProcessId min = os::InvalidProcessId, max = os::InvalidProcessId; os::ProcessId min = os::InvalidProcessId, max = os::InvalidProcessId;
if (hos::GetVersion() >= hos::Version_500) { if (hos::GetVersion() >= hos::Version_500) {
/* On 5.0.0+, we can get precise limits from svcGetSystemInfo. */ /* On 5.0.0+, we can get precise limits from svcGetSystemInfo. */
R_ASSERT(svcGetSystemInfo(reinterpret_cast<u64 *>(&min), SystemInfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Minimum)); R_ABORT_UNLESS(svcGetSystemInfo(reinterpret_cast<u64 *>(&min), SystemInfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Minimum));
R_ASSERT(svcGetSystemInfo(reinterpret_cast<u64 *>(&max), SystemInfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Maximum)); R_ABORT_UNLESS(svcGetSystemInfo(reinterpret_cast<u64 *>(&max), SystemInfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Maximum));
} else if (hos::GetVersion() >= hos::Version_400) { } else if (hos::GetVersion() >= hos::Version_400) {
/* On 4.0.0-4.1.0, we can get the precise limits from normal svcGetInfo. */ /* On 4.0.0-4.1.0, we can get the precise limits from normal svcGetInfo. */
R_ASSERT(svcGetInfo(reinterpret_cast<u64 *>(&min), InfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Minimum)); R_ABORT_UNLESS(svcGetInfo(reinterpret_cast<u64 *>(&min), InfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Minimum));
R_ASSERT(svcGetInfo(reinterpret_cast<u64 *>(&max), InfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Maximum)); R_ABORT_UNLESS(svcGetInfo(reinterpret_cast<u64 *>(&max), InfoType_InitialProcessIdRange, INVALID_HANDLE, InitialProcessIdRangeInfo_Maximum));
} else { } else {
/* On < 4.0.0, we just use hardcoded extents. */ /* On < 4.0.0, we just use hardcoded extents. */
min = InitialProcessIdMinDeprecated; min = InitialProcessIdMinDeprecated;

View file

@ -49,20 +49,20 @@ namespace ams::cfg {
void WaitSdCardServicesReadyImpl() { void WaitSdCardServicesReadyImpl() {
for (size_t i = 0; i < NumRequiredServicesForSdCardAccess; i++) { for (size_t i = 0; i < NumRequiredServicesForSdCardAccess; i++) {
R_ASSERT(sm::WaitService(RequiredServicesForSdCardAccess[i])); R_ABORT_UNLESS(sm::WaitService(RequiredServicesForSdCardAccess[i]));
} }
} }
Result TryInitializeSdCard() { Result TryInitializeSdCard() {
R_TRY(CheckSdCardServicesReady()); R_TRY(CheckSdCardServicesReady());
R_ASSERT(fsOpenSdCardFileSystem(&g_sd_card_filesystem)); R_ABORT_UNLESS(fsOpenSdCardFileSystem(&g_sd_card_filesystem));
g_sd_card_initialized = true; g_sd_card_initialized = true;
return ResultSuccess(); return ResultSuccess();
} }
void InitializeSdCard() { void InitializeSdCard() {
WaitSdCardServicesReadyImpl(); WaitSdCardServicesReadyImpl();
R_ASSERT(fsOpenSdCardFileSystem(&g_sd_card_filesystem)); R_ABORT_UNLESS(fsOpenSdCardFileSystem(&g_sd_card_filesystem));
g_sd_card_initialized = true; g_sd_card_initialized = true;
} }

View file

@ -34,7 +34,7 @@ namespace ams::dd {
inline u32 ReadWriteRegisterImpl(uintptr_t phys_addr, u32 value, u32 mask) { inline u32 ReadWriteRegisterImpl(uintptr_t phys_addr, u32 value, u32 mask) {
u32 out_value; u32 out_value;
R_ASSERT(svcReadWriteRegister(&out_value, phys_addr, mask, value)); R_ABORT_UNLESS(svcReadWriteRegister(&out_value, phys_addr, mask, value));
return out_value; return out_value;
} }

View file

@ -0,0 +1,135 @@
/*
* Copyright (c) 2018-2020 Atmosphère-NX
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <stratosphere.hpp>
namespace ams {
extern ncm::ProgramId CurrentProgramId;
}
namespace ams::diag {
namespace {
inline NORETURN void AbortWithValue(u64 debug) {
/* Just perform a data abort. */
register u64 addr __asm__("x27") = FatalErrorContext::StdAbortMagicAddress;
register u64 val __asm__("x28") = FatalErrorContext::StdAbortMagicValue;
while (true) {
__asm__ __volatile__ (
"mov x0, %[debug]\n"
"str %[val], [%[addr]]\n"
:
: [debug]"r"(debug), [val]"r"(val), [addr]"r"(addr)
: "x0"
);
}
__builtin_unreachable();
}
ALWAYS_INLINE void DebugLog(const char *format, ...) __attribute__((format(printf, 1, 2)));
#ifdef AMS_ENABLE_DEBUG_PRINT
os::Mutex g_debug_log_lock;
char g_debug_buffer[0x400];
void DebugLogImpl(const char *format, ::std::va_list vl) {
std::scoped_lock lk(g_debug_log_lock);
std::vsnprintf(g_debug_buffer, sizeof(g_debug_buffer), format, vl);
svc::OutputDebugString(g_debug_buffer, strlen(g_debug_buffer));
}
void DebugLog(const char *format, ...) __attribute__((format(printf, 1, 2))) {
::std::va_list vl;
va_start(vl, format);
DebugLogImpl(format, vl);
va_end(vl);
}
#else
void DebugLog(const char *format, ...) { /* ... */ }
#endif
}
NORETURN WEAK_SYMBOL void AssertionFailureImpl(const char *file, int line, const char *func, const char *expr, u64 value, const char *format, ...) {
DebugLog("%016lx: Assertion Failure\n", static_cast<u64>(ams::CurrentProgramId));
DebugLog(" Location: %s:%d\n", file, line);
DebugLog(" Function: %s\n", func);
DebugLog(" Expression: %s\n", expr);
DebugLog(" Value: %016lx\n", value);
DebugLog("\n");
#ifdef AMS_ENABLE_DEBUG_PRINT
{
::std::va_list vl;
va_start(vl, format);
DebugLogImpl(format, vl);
va_end(vl);
}
#endif
DebugLog("\n");
AbortWithValue(value);
}
NORETURN WEAK_SYMBOL void AssertionFailureImpl(const char *file, int line, const char *func, const char *expr, u64 value) {
DebugLog("%016lx: Assertion Failure\n", static_cast<u64>(ams::CurrentProgramId));
DebugLog(" Location: %s:%d\n", file, line);
DebugLog(" Function: %s\n", func);
DebugLog(" Expression: %s\n", expr);
DebugLog(" Value: %016lx\n", value);
DebugLog("\n");
DebugLog("\n");
AbortWithValue(value);
}
NORETURN WEAK_SYMBOL void AbortImpl(const char *file, int line, const char *func, const char *expr, u64 value, const char *format, ...) {
DebugLog("%016lx: Abort Called\n", static_cast<u64>(ams::CurrentProgramId));
DebugLog(" Location: %s:%d\n", file, line);
DebugLog(" Function: %s\n", func);
DebugLog(" Expression: %s\n", expr);
DebugLog(" Value: %016lx\n", value);
DebugLog("\n");
#ifdef AMS_ENABLE_DEBUG_PRINT
{
::std::va_list vl;
va_start(vl, format);
DebugLogImpl(format, vl);
va_end(vl);
}
#endif
DebugLog("\n");
AbortWithValue(value);
}
NORETURN WEAK_SYMBOL void AbortImpl(const char *file, int line, const char *func, const char *expr, u64 value) {
DebugLog("%016lx: Abort Called\n", static_cast<u64>(ams::CurrentProgramId));
DebugLog(" Location: %s:%d\n", file, line);
DebugLog(" Function: %s\n", func);
DebugLog(" Expression: %s\n", expr);
DebugLog(" Value: %016lx\n", value);
DebugLog("\n");
DebugLog("\n");
AbortWithValue(value);
}
}

View file

@ -71,8 +71,8 @@ namespace ams::fs {
if (IsCurrentDirectory(&src[i])) { if (IsCurrentDirectory(&src[i])) {
skip_next_sep = true; skip_next_sep = true;
} else if (IsParentDirectory(&src[i])) { } else if (IsParentDirectory(&src[i])) {
AMS_ASSERT(IsSeparator(out[0])); AMS_ABORT_UNLESS(IsSeparator(out[0]));
AMS_ASSERT(IsSeparator(out[len - 1])); AMS_ABORT_UNLESS(IsSeparator(out[len - 1]));
R_UNLESS(len != 1, fs::ResultDirectoryUnobtainable()); R_UNLESS(len != 1, fs::ResultDirectoryUnobtainable());
/* Walk up a directory. */ /* Walk up a directory. */
@ -120,7 +120,7 @@ namespace ams::fs {
/* Assert normalized. */ /* Assert normalized. */
bool normalized = false; bool normalized = false;
AMS_ASSERT(unc_preserved || (R_SUCCEEDED(IsNormalized(&normalized, out)) && normalized)); AMS_ABORT_UNLESS(unc_preserved || (R_SUCCEEDED(IsNormalized(&normalized, out)) && normalized));
return ResultSuccess(); return ResultSuccess();
} }
@ -216,8 +216,8 @@ namespace ams::fs {
} }
bool PathTool::IsSubPath(const char *lhs, const char *rhs) { bool PathTool::IsSubPath(const char *lhs, const char *rhs) {
AMS_ASSERT(lhs != nullptr); AMS_ABORT_UNLESS(lhs != nullptr);
AMS_ASSERT(rhs != nullptr); AMS_ABORT_UNLESS(rhs != nullptr);
/* Special case certain paths. */ /* Special case certain paths. */
if (IsSeparator(lhs[0]) && !IsSeparator(lhs[1]) && IsSeparator(rhs[0]) && IsSeparator(rhs[1])) { if (IsSeparator(lhs[0]) && !IsSeparator(lhs[1]) && IsSeparator(rhs[0]) && IsSeparator(rhs[1])) {

View file

@ -29,7 +29,7 @@ namespace ams::fssrv::impl {
} }
void FileInterfaceAdapter::InvalidateCache() { void FileInterfaceAdapter::InvalidateCache() {
AMS_ASSERT(this->parent_filesystem->IsDeepRetryEnabled()); AMS_ABORT_UNLESS(this->parent_filesystem->IsDeepRetryEnabled());
std::scoped_lock<os::ReadWriteLock> scoped_write_lock(this->parent_filesystem->GetReadWriteLockForCacheInvalidation()); std::scoped_lock<os::ReadWriteLock> scoped_write_lock(this->parent_filesystem->GetReadWriteLockForCacheInvalidation());
this->base_file->OperateRange(nullptr, 0, fs::OperationId::InvalidateCache, 0, std::numeric_limits<s64>::max(), nullptr, 0); this->base_file->OperateRange(nullptr, 0, fs::OperationId::InvalidateCache, 0, std::numeric_limits<s64>::max(), nullptr, 0);
} }
@ -129,7 +129,7 @@ namespace ams::fssrv::impl {
bool FileSystemInterfaceAdapter::IsAccessFailureDetectionObserved() const { bool FileSystemInterfaceAdapter::IsAccessFailureDetectionObserved() const {
/* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */ /* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */
AMS_ASSERT(false); AMS_ABORT_UNLESS(false);
} }
std::optional<std::shared_lock<os::ReadWriteLock>> FileSystemInterfaceAdapter::AcquireCacheInvalidationReadLock() { std::optional<std::shared_lock<os::ReadWriteLock>> FileSystemInterfaceAdapter::AcquireCacheInvalidationReadLock() {
@ -238,7 +238,7 @@ namespace ams::fssrv::impl {
std::unique_lock<fssystem::SemaphoreAdapter> open_count_semaphore; std::unique_lock<fssystem::SemaphoreAdapter> open_count_semaphore;
if (this->open_count_limited) { if (this->open_count_limited) {
/* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */ /* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */
AMS_ASSERT(false); AMS_ABORT_UNLESS(false);
} }
PathNormalizer normalizer(path.str); PathNormalizer normalizer(path.str);
@ -267,7 +267,7 @@ namespace ams::fssrv::impl {
std::unique_lock<fssystem::SemaphoreAdapter> open_count_semaphore; std::unique_lock<fssystem::SemaphoreAdapter> open_count_semaphore;
if (this->open_count_limited) { if (this->open_count_limited) {
/* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */ /* TODO: This calls into fssrv::FileSystemProxyImpl, which we don't have yet. */
AMS_ASSERT(false); AMS_ABORT_UNLESS(false);
} }
PathNormalizer normalizer(path.str); PathNormalizer normalizer(path.str);

View file

@ -22,7 +22,7 @@ namespace ams::fssystem {
{ {
this->before_dir = nullptr; this->before_dir = nullptr;
this->after_dir = nullptr; this->after_dir = nullptr;
R_ASSERT(this->Initialize(before, after)); R_ABORT_UNLESS(this->Initialize(before, after));
} }
DirectoryRedirectionFileSystem::DirectoryRedirectionFileSystem(std::unique_ptr<fs::fsa::IFileSystem> fs, const char *before, const char *after, bool unc) DirectoryRedirectionFileSystem::DirectoryRedirectionFileSystem(std::unique_ptr<fs::fsa::IFileSystem> fs, const char *before, const char *after, bool unc)
@ -30,7 +30,7 @@ namespace ams::fssystem {
{ {
this->before_dir = nullptr; this->before_dir = nullptr;
this->after_dir = nullptr; this->after_dir = nullptr;
R_ASSERT(this->Initialize(before, after)); R_ABORT_UNLESS(this->Initialize(before, after));
} }
DirectoryRedirectionFileSystem::~DirectoryRedirectionFileSystem() { DirectoryRedirectionFileSystem::~DirectoryRedirectionFileSystem() {
@ -57,7 +57,7 @@ namespace ams::fssystem {
/* Ensure terminating '/' */ /* Ensure terminating '/' */
if (!PathTool::IsSeparator(normalized_path[normalized_path_len - 1])) { if (!PathTool::IsSeparator(normalized_path[normalized_path_len - 1])) {
AMS_ASSERT(normalized_path_len + 2 <= sizeof(normalized_path)); AMS_ABORT_UNLESS(normalized_path_len + 2 <= sizeof(normalized_path));
normalized_path[normalized_path_len] = StringTraits::DirectorySeparator; normalized_path[normalized_path_len] = StringTraits::DirectorySeparator;
normalized_path[normalized_path_len + 1] = StringTraits::NullTerminator; normalized_path[normalized_path_len + 1] = StringTraits::NullTerminator;
@ -67,7 +67,7 @@ namespace ams::fssystem {
/* Allocate new path. */ /* Allocate new path. */
const size_t size = normalized_path_len + 1; const size_t size = normalized_path_len + 1;
char *new_dir = static_cast<char *>(std::malloc(size)); char *new_dir = static_cast<char *>(std::malloc(size));
AMS_ASSERT(new_dir != nullptr); AMS_ABORT_UNLESS(new_dir != nullptr);
/* TODO: custom ResultAllocationFailure? */ /* TODO: custom ResultAllocationFailure? */
/* Copy path in. */ /* Copy path in. */

View file

@ -134,7 +134,7 @@ namespace ams::fssystem {
/* TODO: Return a result here? Nintendo does not, but they have other allocation failed results. */ /* TODO: Return a result here? Nintendo does not, but they have other allocation failed results. */
/* Consider returning ResultFsAllocationFailureInDirectorySaveDataFileSystem? */ /* Consider returning ResultFsAllocationFailureInDirectorySaveDataFileSystem? */
AMS_ASSERT(false); AMS_ABORT_UNLESS(false);
} }
Result DirectorySaveDataFileSystem::SynchronizeDirectory(const char *dst, const char *src) { Result DirectorySaveDataFileSystem::SynchronizeDirectory(const char *dst, const char *src) {
@ -173,7 +173,7 @@ namespace ams::fssystem {
this->open_writable_files--; this->open_writable_files--;
/* Nintendo does not check this, but I think it's sensible to do so. */ /* Nintendo does not check this, but I think it's sensible to do so. */
AMS_ASSERT(this->open_writable_files >= 0); AMS_ABORT_UNLESS(this->open_writable_files >= 0);
} }
Result DirectorySaveDataFileSystem::CopySaveFromFileSystem(fs::fsa::IFileSystem *save_fs) { Result DirectorySaveDataFileSystem::CopySaveFromFileSystem(fs::fsa::IFileSystem *save_fs) {

View file

@ -21,14 +21,14 @@ namespace ams::fssystem {
: PathResolutionFileSystem(fs, unc) : PathResolutionFileSystem(fs, unc)
{ {
this->base_path = nullptr; this->base_path = nullptr;
R_ASSERT(this->Initialize(bp)); R_ABORT_UNLESS(this->Initialize(bp));
} }
SubDirectoryFileSystem::SubDirectoryFileSystem(std::unique_ptr<fs::fsa::IFileSystem> fs, const char *bp, bool unc) SubDirectoryFileSystem::SubDirectoryFileSystem(std::unique_ptr<fs::fsa::IFileSystem> fs, const char *bp, bool unc)
: PathResolutionFileSystem(std::move(fs), unc) : PathResolutionFileSystem(std::move(fs), unc)
{ {
this->base_path = nullptr; this->base_path = nullptr;
R_ASSERT(this->Initialize(bp)); R_ABORT_UNLESS(this->Initialize(bp));
} }
SubDirectoryFileSystem::~SubDirectoryFileSystem() { SubDirectoryFileSystem::~SubDirectoryFileSystem() {
@ -48,7 +48,7 @@ namespace ams::fssystem {
/* Ensure terminating '/' */ /* Ensure terminating '/' */
if (!PathTool::IsSeparator(normalized_path[normalized_path_len - 1])) { if (!PathTool::IsSeparator(normalized_path[normalized_path_len - 1])) {
AMS_ASSERT(normalized_path_len + 2 <= sizeof(normalized_path)); AMS_ABORT_UNLESS(normalized_path_len + 2 <= sizeof(normalized_path));
normalized_path[normalized_path_len] = StringTraits::DirectorySeparator; normalized_path[normalized_path_len] = StringTraits::DirectorySeparator;
normalized_path[normalized_path_len + 1] = StringTraits::NullTerminator; normalized_path[normalized_path_len + 1] = StringTraits::NullTerminator;

View file

@ -40,7 +40,7 @@ namespace ams::fssystem {
char dst_path[fs::EntryNameLengthMax + 1]; char dst_path[fs::EntryNameLengthMax + 1];
const size_t original_size = static_cast<size_t>(std::snprintf(dst_path, sizeof(dst_path), "%s%s", dst_parent_path, entry->name)); const size_t original_size = static_cast<size_t>(std::snprintf(dst_path, sizeof(dst_path), "%s%s", dst_parent_path, entry->name));
/* TODO: Error code? N aborts here. */ /* TODO: Error code? N aborts here. */
AMS_ASSERT(original_size < sizeof(dst_path)); AMS_ABORT_UNLESS(original_size < sizeof(dst_path));
R_TRY(dst_fs->CreateFile(dst_path, entry->file_size)); R_TRY(dst_fs->CreateFile(dst_path, entry->file_size));
R_TRY(dst_fs->OpenFile(&dst_file, dst_path, fs::OpenMode_Write)); R_TRY(dst_fs->OpenFile(&dst_file, dst_path, fs::OpenMode_Write));
@ -64,7 +64,7 @@ namespace ams::fssystem {
Result CopyDirectoryRecursively(fs::fsa::IFileSystem *dst_fs, fs::fsa::IFileSystem *src_fs, const char *dst_path, const char *src_path, void *work_buf, size_t work_buf_size) { Result CopyDirectoryRecursively(fs::fsa::IFileSystem *dst_fs, fs::fsa::IFileSystem *src_fs, const char *dst_path, const char *src_path, void *work_buf, size_t work_buf_size) {
char dst_path_buf[fs::EntryNameLengthMax + 1]; char dst_path_buf[fs::EntryNameLengthMax + 1];
const size_t original_size = static_cast<size_t>(std::snprintf(dst_path_buf, sizeof(dst_path_buf), "%s", dst_path)); const size_t original_size = static_cast<size_t>(std::snprintf(dst_path_buf, sizeof(dst_path_buf), "%s", dst_path));
AMS_ASSERT(original_size < sizeof(dst_path_buf)); AMS_ABORT_UNLESS(original_size < sizeof(dst_path_buf));
return IterateDirectoryRecursively(src_fs, src_path, return IterateDirectoryRecursively(src_fs, src_path,
[&](const char *path, const fs::DirectoryEntry &entry) -> Result { /* On Enter Directory */ [&](const char *path, const fs::DirectoryEntry &entry) -> Result { /* On Enter Directory */

View file

@ -25,10 +25,10 @@ namespace ams::hid {
/* Helper. */ /* Helper. */
void InitializeHid() { void InitializeHid() {
R_ASSERT(smInitialize()); R_ABORT_UNLESS(smInitialize());
ON_SCOPE_EXIT { smExit(); }; ON_SCOPE_EXIT { smExit(); };
{ {
R_ASSERT(hidInitialize()); R_ABORT_UNLESS(hidInitialize());
} }
} }

View file

@ -84,7 +84,7 @@ namespace ams::kvdb {
Result ArchiveReader::ReadEntryCount(size_t *out) { Result ArchiveReader::ReadEntryCount(size_t *out) {
/* This should only be called at the start of reading stream. */ /* This should only be called at the start of reading stream. */
AMS_ASSERT(this->offset == 0); AMS_ABORT_UNLESS(this->offset == 0);
/* Read and validate header. */ /* Read and validate header. */
ArchiveHeader header; ArchiveHeader header;
@ -97,7 +97,7 @@ namespace ams::kvdb {
Result ArchiveReader::GetEntrySize(size_t *out_key_size, size_t *out_value_size) { Result ArchiveReader::GetEntrySize(size_t *out_key_size, size_t *out_value_size) {
/* This should only be called after ReadEntryCount. */ /* This should only be called after ReadEntryCount. */
AMS_ASSERT(this->offset != 0); AMS_ABORT_UNLESS(this->offset != 0);
/* Peek the next entry header. */ /* Peek the next entry header. */
ArchiveEntryHeader header; ArchiveEntryHeader header;
@ -111,7 +111,7 @@ namespace ams::kvdb {
Result ArchiveReader::ReadEntry(void *out_key, size_t key_size, void *out_value, size_t value_size) { Result ArchiveReader::ReadEntry(void *out_key, size_t key_size, void *out_value, size_t value_size) {
/* This should only be called after ReadEntryCount. */ /* This should only be called after ReadEntryCount. */
AMS_ASSERT(this->offset != 0); AMS_ABORT_UNLESS(this->offset != 0);
/* Read the next entry header. */ /* Read the next entry header. */
ArchiveEntryHeader header; ArchiveEntryHeader header;
@ -119,11 +119,11 @@ namespace ams::kvdb {
R_TRY(header.Validate()); R_TRY(header.Validate());
/* Key size and Value size must be correct. */ /* Key size and Value size must be correct. */
AMS_ASSERT(key_size == header.key_size); AMS_ABORT_UNLESS(key_size == header.key_size);
AMS_ASSERT(value_size == header.value_size); AMS_ABORT_UNLESS(value_size == header.value_size);
R_ASSERT(this->Read(out_key, key_size)); R_ABORT_UNLESS(this->Read(out_key, key_size));
R_ASSERT(this->Read(out_value, value_size)); R_ABORT_UNLESS(this->Read(out_value, value_size));
return ResultSuccess(); return ResultSuccess();
} }
@ -140,20 +140,20 @@ namespace ams::kvdb {
void ArchiveWriter::WriteHeader(size_t entry_count) { void ArchiveWriter::WriteHeader(size_t entry_count) {
/* This should only be called at start of write. */ /* This should only be called at start of write. */
AMS_ASSERT(this->offset == 0); AMS_ABORT_UNLESS(this->offset == 0);
ArchiveHeader header = ArchiveHeader::Make(entry_count); ArchiveHeader header = ArchiveHeader::Make(entry_count);
R_ASSERT(this->Write(&header, sizeof(header))); R_ABORT_UNLESS(this->Write(&header, sizeof(header)));
} }
void ArchiveWriter::WriteEntry(const void *key, size_t key_size, const void *value, size_t value_size) { void ArchiveWriter::WriteEntry(const void *key, size_t key_size, const void *value, size_t value_size) {
/* This should only be called after writing header. */ /* This should only be called after writing header. */
AMS_ASSERT(this->offset != 0); AMS_ABORT_UNLESS(this->offset != 0);
ArchiveEntryHeader header = ArchiveEntryHeader::Make(key_size, value_size); ArchiveEntryHeader header = ArchiveEntryHeader::Make(key_size, value_size);
R_ASSERT(this->Write(&header, sizeof(header))); R_ABORT_UNLESS(this->Write(&header, sizeof(header)));
R_ASSERT(this->Write(key, key_size)); R_ABORT_UNLESS(this->Write(key, key_size));
R_ASSERT(this->Write(value, value_size)); R_ABORT_UNLESS(this->Write(value, value_size));
} }
/* Size helper functionality. */ /* Size helper functionality. */

View file

@ -53,7 +53,7 @@ namespace ams::kvdb {
this->backing_buffer_free_offset = 0; this->backing_buffer_free_offset = 0;
this->count = 0; this->count = 0;
this->entries = static_cast<decltype(this->entries)>(this->Allocate(sizeof(*this->entries) * this->capacity)); this->entries = static_cast<decltype(this->entries)>(this->Allocate(sizeof(*this->entries) * this->capacity));
AMS_ASSERT(this->entries != nullptr); AMS_ABORT_UNLESS(this->entries != nullptr);
} }
std::optional<size_t> FileKeyValueStore::Cache::TryGet(void *out_value, size_t max_out_size, const void *key, size_t key_size) { std::optional<size_t> FileKeyValueStore::Cache::TryGet(void *out_value, size_t max_out_size, const void *key, size_t key_size) {
@ -100,7 +100,7 @@ namespace ams::kvdb {
} }
/* Ensure key size is small enough. */ /* Ensure key size is small enough. */
AMS_ASSERT(key_size <= MaxKeySize); AMS_ABORT_UNLESS(key_size <= MaxKeySize);
/* If we're at capacity, invalidate the cache. */ /* If we're at capacity, invalidate the cache. */
if (this->count == this->capacity) { if (this->count == this->capacity) {

View file

@ -73,7 +73,7 @@ namespace ams::map {
R_UNLESS(cur_base != address_space.alias_end, svc::ResultOutOfMemory()); R_UNLESS(cur_base != address_space.alias_end, svc::ResultOutOfMemory());
cur_base = address_space.alias_end; cur_base = address_space.alias_end;
} else { } else {
R_ASSERT(svcQueryMemory(&mem_info, &page_info, cur_base)); R_ABORT_UNLESS(svcQueryMemory(&mem_info, &page_info, cur_base));
if (mem_info.type == 0 && mem_info.addr - cur_base + mem_info.size >= size) { if (mem_info.type == 0 && mem_info.addr - cur_base + mem_info.size >= size) {
*out_address = cur_base; *out_address = cur_base;
return ResultSuccess(); return ResultSuccess();
@ -205,9 +205,9 @@ namespace ams::map {
/* Nintendo doesn't validate SVC return values at all. */ /* Nintendo doesn't validate SVC return values at all. */
/* TODO: Should we allow these to fail? */ /* TODO: Should we allow these to fail? */
R_ASSERT(svcQueryProcessMemory(&mem_info, &page_info, process_handle, address - 1)); R_ABORT_UNLESS(svcQueryProcessMemory(&mem_info, &page_info, process_handle, address - 1));
if (mem_info.type == MemType_Unmapped && address - GuardRegionSize >= mem_info.addr) { if (mem_info.type == MemType_Unmapped && address - GuardRegionSize >= mem_info.addr) {
R_ASSERT(svcQueryProcessMemory(&mem_info, &page_info, process_handle, address + size)); R_ABORT_UNLESS(svcQueryProcessMemory(&mem_info, &page_info, process_handle, address + size));
return mem_info.type == MemType_Unmapped && address + size + GuardRegionSize <= mem_info.addr + mem_info.size; return mem_info.type == MemType_Unmapped && address + size + GuardRegionSize <= mem_info.addr + mem_info.size;
} }

View file

@ -31,7 +31,7 @@ namespace ams::os::impl {
} }
InterProcessEvent::InterProcessEvent(bool autoclear) : is_initialized(false) { InterProcessEvent::InterProcessEvent(bool autoclear) : is_initialized(false) {
R_ASSERT(this->Initialize(autoclear)); R_ABORT_UNLESS(this->Initialize(autoclear));
} }
InterProcessEvent::~InterProcessEvent() { InterProcessEvent::~InterProcessEvent() {
@ -39,7 +39,7 @@ namespace ams::os::impl {
} }
Result InterProcessEvent::Initialize(bool autoclear) { Result InterProcessEvent::Initialize(bool autoclear) {
AMS_ASSERT(!this->is_initialized); AMS_ABORT_UNLESS(!this->is_initialized);
Handle rh, wh; Handle rh, wh;
R_TRY(CreateEventHandles(&rh, &wh)); R_TRY(CreateEventHandles(&rh, &wh));
this->Initialize(rh, true, wh, true, autoclear); this->Initialize(rh, true, wh, true, autoclear);
@ -47,8 +47,8 @@ namespace ams::os::impl {
} }
void InterProcessEvent::Initialize(Handle read_handle, bool manage_read_handle, Handle write_handle, bool manage_write_handle, bool autoclear) { void InterProcessEvent::Initialize(Handle read_handle, bool manage_read_handle, Handle write_handle, bool manage_write_handle, bool autoclear) {
AMS_ASSERT(!this->is_initialized); AMS_ABORT_UNLESS(!this->is_initialized);
AMS_ASSERT(read_handle != INVALID_HANDLE || write_handle != INVALID_HANDLE); AMS_ABORT_UNLESS(read_handle != INVALID_HANDLE || write_handle != INVALID_HANDLE);
this->read_handle = read_handle; this->read_handle = read_handle;
this->manage_read_handle = manage_read_handle; this->manage_read_handle = manage_read_handle;
this->write_handle = write_handle; this->write_handle = write_handle;
@ -58,40 +58,40 @@ namespace ams::os::impl {
} }
Handle InterProcessEvent::DetachReadableHandle() { Handle InterProcessEvent::DetachReadableHandle() {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
const Handle handle = this->read_handle; const Handle handle = this->read_handle;
AMS_ASSERT(handle != INVALID_HANDLE); AMS_ABORT_UNLESS(handle != INVALID_HANDLE);
this->read_handle = INVALID_HANDLE; this->read_handle = INVALID_HANDLE;
this->manage_read_handle = false; this->manage_read_handle = false;
return handle; return handle;
} }
Handle InterProcessEvent::DetachWritableHandle() { Handle InterProcessEvent::DetachWritableHandle() {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
const Handle handle = this->write_handle; const Handle handle = this->write_handle;
AMS_ASSERT(handle != INVALID_HANDLE); AMS_ABORT_UNLESS(handle != INVALID_HANDLE);
this->write_handle = INVALID_HANDLE; this->write_handle = INVALID_HANDLE;
this->manage_write_handle = false; this->manage_write_handle = false;
return handle; return handle;
} }
Handle InterProcessEvent::GetReadableHandle() const { Handle InterProcessEvent::GetReadableHandle() const {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
return this->read_handle; return this->read_handle;
} }
Handle InterProcessEvent::GetWritableHandle() const { Handle InterProcessEvent::GetWritableHandle() const {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
return this->write_handle; return this->write_handle;
} }
void InterProcessEvent::Finalize() { void InterProcessEvent::Finalize() {
if (this->is_initialized) { if (this->is_initialized) {
if (this->manage_read_handle && this->read_handle != INVALID_HANDLE) { if (this->manage_read_handle && this->read_handle != INVALID_HANDLE) {
R_ASSERT(svcCloseHandle(this->read_handle)); R_ABORT_UNLESS(svcCloseHandle(this->read_handle));
} }
if (this->manage_write_handle && this->write_handle != INVALID_HANDLE) { if (this->manage_write_handle && this->write_handle != INVALID_HANDLE) {
R_ASSERT(svcCloseHandle(this->write_handle)); R_ABORT_UNLESS(svcCloseHandle(this->write_handle));
} }
} }
this->read_handle = INVALID_HANDLE; this->read_handle = INVALID_HANDLE;
@ -102,7 +102,7 @@ namespace ams::os::impl {
} }
void InterProcessEvent::Signal() { void InterProcessEvent::Signal() {
R_ASSERT(svcSignalEvent(this->GetWritableHandle())); R_ABORT_UNLESS(svcSignalEvent(this->GetWritableHandle()));
} }
void InterProcessEvent::Reset() { void InterProcessEvent::Reset() {
@ -110,7 +110,7 @@ namespace ams::os::impl {
if (handle == INVALID_HANDLE) { if (handle == INVALID_HANDLE) {
handle = this->GetWritableHandle(); handle = this->GetWritableHandle();
} }
R_ASSERT(svcClearEvent(handle)); R_ABORT_UNLESS(svcClearEvent(handle));
} }
void InterProcessEvent::Wait() { void InterProcessEvent::Wait() {

View file

@ -25,8 +25,8 @@ namespace ams::os::impl {
/* Nintendo does not check the result of these invocations, but we will for safety. */ /* Nintendo does not check the result of these invocations, but we will for safety. */
/* Nintendo uses entropy values 0, 1 to seed the public TinyMT random, and values */ /* Nintendo uses entropy values 0, 1 to seed the public TinyMT random, and values */
/* 2, 3 to seed os::detail::RngManager's private TinyMT random. */ /* 2, 3 to seed os::detail::RngManager's private TinyMT random. */
R_ASSERT(svcGetInfo(reinterpret_cast<u64 *>(&seed[0]), InfoType_RandomEntropy, INVALID_HANDLE, 0)); R_ABORT_UNLESS(svcGetInfo(reinterpret_cast<u64 *>(&seed[0]), InfoType_RandomEntropy, INVALID_HANDLE, 0));
R_ASSERT(svcGetInfo(reinterpret_cast<u64 *>(&seed[2]), InfoType_RandomEntropy, INVALID_HANDLE, 1)); R_ABORT_UNLESS(svcGetInfo(reinterpret_cast<u64 *>(&seed[2]), InfoType_RandomEntropy, INVALID_HANDLE, 1));
mt->Initialize(seed, util::size(seed)); mt->Initialize(seed, util::size(seed));
} }

View file

@ -31,7 +31,7 @@ namespace ams::os::impl {
} }
virtual Handle GetHandle() const override { virtual Handle GetHandle() const override {
AMS_ASSERT(this->event->is_initialized); AMS_ABORT_UNLESS(this->event->is_initialized);
return this->event->GetReadableHandle(); return this->event->GetReadableHandle();
} }
}; };

View file

@ -30,7 +30,7 @@ namespace ams::os::impl {
} }
virtual Handle GetHandle() const override { virtual Handle GetHandle() const override {
AMS_ASSERT(this->event->is_initialized); AMS_ABORT_UNLESS(this->event->is_initialized);
return this->event->handle.Get(); return this->event->handle.Get();
} }
}; };

View file

@ -64,7 +64,7 @@ namespace ams::os::impl{
index = WaitTimedOut; index = WaitTimedOut;
} else { } else {
index = this->WaitSynchronization(object_handles, count, min_timeout); index = this->WaitSynchronization(object_handles, count, min_timeout);
AMS_ASSERT(index != WaitInvalid); AMS_ABORT_UNLESS(index != WaitInvalid);
} }
switch (index) { switch (index) {
@ -115,7 +115,7 @@ namespace ams::os::impl{
for (WaitableHolderBase &holder_base : this->waitable_list) { for (WaitableHolderBase &holder_base : this->waitable_list) {
if (Handle handle = holder_base.GetHandle(); handle != INVALID_HANDLE) { if (Handle handle = holder_base.GetHandle(); handle != INVALID_HANDLE) {
AMS_ASSERT(count < MaximumHandleCount); AMS_ABORT_UNLESS(count < MaximumHandleCount);
out_handles[count] = handle; out_handles[count] = handle;
out_objects[count] = &holder_base; out_objects[count] = &holder_base;
@ -170,7 +170,7 @@ namespace ams::os::impl{
if (this->signaled_holder == nullptr) { if (this->signaled_holder == nullptr) {
this->signaled_holder = holder_base; this->signaled_holder = holder_base;
R_ASSERT(svcCancelSynchronization(this->waiting_thread_handle)); R_ABORT_UNLESS(svcCancelSynchronization(this->waiting_thread_handle));
} }
} }

View file

@ -18,7 +18,7 @@
namespace ams::os { namespace ams::os {
Result InterruptEvent::Initialize(u32 interrupt_id, bool autoclear) { Result InterruptEvent::Initialize(u32 interrupt_id, bool autoclear) {
AMS_ASSERT(!this->is_initialized); AMS_ABORT_UNLESS(!this->is_initialized);
this->auto_clear = autoclear; this->auto_clear = autoclear;
const auto type = this->auto_clear ? svc::InterruptType_Edge : svc::InterruptType_Level; const auto type = this->auto_clear ? svc::InterruptType_Edge : svc::InterruptType_Level;
@ -29,23 +29,23 @@ namespace ams::os {
} }
void InterruptEvent::Finalize() { void InterruptEvent::Finalize() {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
R_ASSERT(svcCloseHandle(this->handle.Move())); R_ABORT_UNLESS(svcCloseHandle(this->handle.Move()));
this->auto_clear = true; this->auto_clear = true;
this->is_initialized = false; this->is_initialized = false;
} }
InterruptEvent::InterruptEvent(u32 interrupt_id, bool autoclear) { InterruptEvent::InterruptEvent(u32 interrupt_id, bool autoclear) {
this->is_initialized = false; this->is_initialized = false;
R_ASSERT(this->Initialize(interrupt_id, autoclear)); R_ABORT_UNLESS(this->Initialize(interrupt_id, autoclear));
} }
void InterruptEvent::Reset() { void InterruptEvent::Reset() {
R_ASSERT(svcClearEvent(this->handle.Get())); R_ABORT_UNLESS(svcClearEvent(this->handle.Get()));
} }
void InterruptEvent::Wait() { void InterruptEvent::Wait() {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
while (true) { while (true) {
/* Continuously wait, until success. */ /* Continuously wait, until success. */
@ -65,7 +65,7 @@ namespace ams::os {
} }
bool InterruptEvent::TryWait() { bool InterruptEvent::TryWait() {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
if (this->auto_clear) { if (this->auto_clear) {
/* Auto-clear. Just try to reset. */ /* Auto-clear. Just try to reset. */
@ -86,7 +86,7 @@ namespace ams::os {
} }
bool InterruptEvent::TimedWait(u64 ns) { bool InterruptEvent::TimedWait(u64 ns) {
AMS_ASSERT(this->is_initialized); AMS_ABORT_UNLESS(this->is_initialized);
TimeoutHelper timeout_helper(ns); TimeoutHelper timeout_helper(ns);
while (true) { while (true) {

View file

@ -29,7 +29,7 @@ namespace ams::os {
void MessageQueue::SendInternal(uintptr_t data) { void MessageQueue::SendInternal(uintptr_t data) {
/* Ensure we don't corrupt the queue, but this should never happen. */ /* Ensure we don't corrupt the queue, but this should never happen. */
AMS_ASSERT(this->count < this->capacity); AMS_ABORT_UNLESS(this->count < this->capacity);
/* Write data to tail of queue. */ /* Write data to tail of queue. */
this->buffer[(this->count++ + this->offset) % this->capacity] = data; this->buffer[(this->count++ + this->offset) % this->capacity] = data;
@ -37,7 +37,7 @@ namespace ams::os {
void MessageQueue::SendNextInternal(uintptr_t data) { void MessageQueue::SendNextInternal(uintptr_t data) {
/* Ensure we don't corrupt the queue, but this should never happen. */ /* Ensure we don't corrupt the queue, but this should never happen. */
AMS_ASSERT(this->count < this->capacity); AMS_ABORT_UNLESS(this->count < this->capacity);
/* Write data to head of queue. */ /* Write data to head of queue. */
this->offset = (this->offset + this->capacity - 1) % this->capacity; this->offset = (this->offset + this->capacity - 1) % this->capacity;
@ -47,7 +47,7 @@ namespace ams::os {
uintptr_t MessageQueue::ReceiveInternal() { uintptr_t MessageQueue::ReceiveInternal() {
/* Ensure we don't corrupt the queue, but this should never happen. */ /* Ensure we don't corrupt the queue, but this should never happen. */
AMS_ASSERT(this->count > 0); AMS_ABORT_UNLESS(this->count > 0);
uintptr_t data = this->buffer[this->offset]; uintptr_t data = this->buffer[this->offset];
this->offset = (this->offset + 1) % this->capacity; this->offset = (this->offset + 1) % this->capacity;
@ -57,7 +57,7 @@ namespace ams::os {
inline uintptr_t MessageQueue::PeekInternal() { inline uintptr_t MessageQueue::PeekInternal() {
/* Ensure we don't corrupt the queue, but this should never happen. */ /* Ensure we don't corrupt the queue, but this should never happen. */
AMS_ASSERT(this->count > 0); AMS_ABORT_UNLESS(this->count > 0);
return this->buffer[this->offset]; return this->buffer[this->offset];
} }

View file

@ -65,7 +65,7 @@ namespace ams::os {
void Semaphore::Release() { void Semaphore::Release() {
std::scoped_lock lk(this->mutex); std::scoped_lock lk(this->mutex);
AMS_ASSERT(this->count + 1 <= this->max_count); AMS_ABORT_UNLESS(this->count + 1 <= this->max_count);
this->count++; this->count++;
this->condvar.Signal(); this->condvar.Signal();
@ -75,7 +75,7 @@ namespace ams::os {
void Semaphore::Release(int count) { void Semaphore::Release(int count) {
std::scoped_lock lk(this->mutex); std::scoped_lock lk(this->mutex);
AMS_ASSERT(this->count + count <= this->max_count); AMS_ABORT_UNLESS(this->count + count <= this->max_count);
this->count += count; this->count += count;
this->condvar.Broadcast(); this->condvar.Broadcast();

View file

@ -20,9 +20,9 @@ namespace ams::os {
SystemEvent::SystemEvent(bool inter_process, bool autoclear) : state(SystemEventState::Uninitialized) { SystemEvent::SystemEvent(bool inter_process, bool autoclear) : state(SystemEventState::Uninitialized) {
if (inter_process) { if (inter_process) {
R_ASSERT(this->InitializeAsInterProcessEvent(autoclear)); R_ABORT_UNLESS(this->InitializeAsInterProcessEvent(autoclear));
} else { } else {
R_ASSERT(this->InitializeAsEvent(autoclear)); R_ABORT_UNLESS(this->InitializeAsEvent(autoclear));
} }
} }
@ -35,34 +35,34 @@ namespace ams::os {
} }
Event &SystemEvent::GetEvent() { Event &SystemEvent::GetEvent() {
AMS_ASSERT(this->state == SystemEventState::Event); AMS_ABORT_UNLESS(this->state == SystemEventState::Event);
return GetReference(this->storage_for_event); return GetReference(this->storage_for_event);
} }
const Event &SystemEvent::GetEvent() const { const Event &SystemEvent::GetEvent() const {
AMS_ASSERT(this->state == SystemEventState::Event); AMS_ABORT_UNLESS(this->state == SystemEventState::Event);
return GetReference(this->storage_for_event); return GetReference(this->storage_for_event);
} }
impl::InterProcessEvent &SystemEvent::GetInterProcessEvent() { impl::InterProcessEvent &SystemEvent::GetInterProcessEvent() {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return GetReference(this->storage_for_inter_process_event); return GetReference(this->storage_for_inter_process_event);
} }
const impl::InterProcessEvent &SystemEvent::GetInterProcessEvent() const { const impl::InterProcessEvent &SystemEvent::GetInterProcessEvent() const {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return GetReference(this->storage_for_inter_process_event); return GetReference(this->storage_for_inter_process_event);
} }
Result SystemEvent::InitializeAsEvent(bool autoclear) { Result SystemEvent::InitializeAsEvent(bool autoclear) {
AMS_ASSERT(this->state == SystemEventState::Uninitialized); AMS_ABORT_UNLESS(this->state == SystemEventState::Uninitialized);
new (GetPointer(this->storage_for_event)) Event(autoclear); new (GetPointer(this->storage_for_event)) Event(autoclear);
this->state = SystemEventState::Event; this->state = SystemEventState::Event;
return ResultSuccess(); return ResultSuccess();
} }
Result SystemEvent::InitializeAsInterProcessEvent(bool autoclear) { Result SystemEvent::InitializeAsInterProcessEvent(bool autoclear) {
AMS_ASSERT(this->state == SystemEventState::Uninitialized); AMS_ABORT_UNLESS(this->state == SystemEventState::Uninitialized);
new (GetPointer(this->storage_for_inter_process_event)) impl::InterProcessEvent(); new (GetPointer(this->storage_for_inter_process_event)) impl::InterProcessEvent();
this->state = SystemEventState::InterProcessEvent; this->state = SystemEventState::InterProcessEvent;
@ -77,7 +77,7 @@ namespace ams::os {
} }
void SystemEvent::AttachHandles(Handle read_handle, bool manage_read_handle, Handle write_handle, bool manage_write_handle, bool autoclear) { void SystemEvent::AttachHandles(Handle read_handle, bool manage_read_handle, Handle write_handle, bool manage_write_handle, bool autoclear) {
AMS_ASSERT(this->state == SystemEventState::Uninitialized); AMS_ABORT_UNLESS(this->state == SystemEventState::Uninitialized);
new (GetPointer(this->storage_for_inter_process_event)) impl::InterProcessEvent(); new (GetPointer(this->storage_for_inter_process_event)) impl::InterProcessEvent();
this->state = SystemEventState::InterProcessEvent; this->state = SystemEventState::InterProcessEvent;
this->GetInterProcessEvent().Initialize(read_handle, manage_read_handle, write_handle, manage_write_handle, autoclear); this->GetInterProcessEvent().Initialize(read_handle, manage_read_handle, write_handle, manage_write_handle, autoclear);
@ -92,22 +92,22 @@ namespace ams::os {
} }
Handle SystemEvent::DetachReadableHandle() { Handle SystemEvent::DetachReadableHandle() {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return this->GetInterProcessEvent().DetachReadableHandle(); return this->GetInterProcessEvent().DetachReadableHandle();
} }
Handle SystemEvent::DetachWritableHandle() { Handle SystemEvent::DetachWritableHandle() {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return this->GetInterProcessEvent().DetachWritableHandle(); return this->GetInterProcessEvent().DetachWritableHandle();
} }
Handle SystemEvent::GetReadableHandle() const { Handle SystemEvent::GetReadableHandle() const {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return this->GetInterProcessEvent().GetReadableHandle(); return this->GetInterProcessEvent().GetReadableHandle();
} }
Handle SystemEvent::GetWritableHandle() const { Handle SystemEvent::GetWritableHandle() const {
AMS_ASSERT(this->state == SystemEventState::InterProcessEvent); AMS_ABORT_UNLESS(this->state == SystemEventState::InterProcessEvent);
return this->GetInterProcessEvent().GetWritableHandle(); return this->GetInterProcessEvent().GetWritableHandle();
} }

View file

@ -20,7 +20,7 @@ namespace ams::os {
WaitableHolder::WaitableHolder(Handle handle) { WaitableHolder::WaitableHolder(Handle handle) {
/* Don't allow invalid handles. */ /* Don't allow invalid handles. */
AMS_ASSERT(handle != INVALID_HANDLE); AMS_ABORT_UNLESS(handle != INVALID_HANDLE);
/* Initialize appropriate holder. */ /* Initialize appropriate holder. */
new (GetPointer(this->impl_storage)) impl::WaitableHolderOfHandle(handle); new (GetPointer(this->impl_storage)) impl::WaitableHolderOfHandle(handle);
@ -98,7 +98,7 @@ namespace ams::os {
auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(this->impl_storage)); auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(this->impl_storage));
/* Don't allow destruction of a linked waitable holder. */ /* Don't allow destruction of a linked waitable holder. */
AMS_ASSERT(!holder_base->IsLinkedToManager()); AMS_ABORT_UNLESS(!holder_base->IsLinkedToManager());
holder_base->~WaitableHolderBase(); holder_base->~WaitableHolderBase();
} }
@ -107,7 +107,7 @@ namespace ams::os {
auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(this->impl_storage)); auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(this->impl_storage));
/* Don't allow unlinking of an unlinked holder. */ /* Don't allow unlinking of an unlinked holder. */
AMS_ASSERT(holder_base->IsLinkedToManager()); AMS_ABORT_UNLESS(holder_base->IsLinkedToManager());
holder_base->GetManager()->UnlinkWaitableHolder(*holder_base); holder_base->GetManager()->UnlinkWaitableHolder(*holder_base);
holder_base->SetManager(nullptr); holder_base->SetManager(nullptr);

View file

@ -27,7 +27,7 @@ namespace ams::os {
auto &impl = GetReference(this->impl_storage); auto &impl = GetReference(this->impl_storage);
/* Don't allow destruction of a non-empty waitable holder. */ /* Don't allow destruction of a non-empty waitable holder. */
AMS_ASSERT(impl.IsEmpty()); AMS_ABORT_UNLESS(impl.IsEmpty());
impl.~WaitableManagerImpl(); impl.~WaitableManagerImpl();
} }
@ -38,7 +38,7 @@ namespace ams::os {
auto &impl = GetReference(this->impl_storage); auto &impl = GetReference(this->impl_storage);
/* Don't allow waiting on empty list. */ /* Don't allow waiting on empty list. */
AMS_ASSERT(!impl.IsEmpty()); AMS_ABORT_UNLESS(!impl.IsEmpty());
return reinterpret_cast<WaitableHolder *>(impl.WaitAny()); return reinterpret_cast<WaitableHolder *>(impl.WaitAny());
} }
@ -47,7 +47,7 @@ namespace ams::os {
auto &impl = GetReference(this->impl_storage); auto &impl = GetReference(this->impl_storage);
/* Don't allow waiting on empty list. */ /* Don't allow waiting on empty list. */
AMS_ASSERT(!impl.IsEmpty()); AMS_ABORT_UNLESS(!impl.IsEmpty());
return reinterpret_cast<WaitableHolder *>(impl.TryWaitAny()); return reinterpret_cast<WaitableHolder *>(impl.TryWaitAny());
} }
@ -56,7 +56,7 @@ namespace ams::os {
auto &impl = GetReference(this->impl_storage); auto &impl = GetReference(this->impl_storage);
/* Don't allow waiting on empty list. */ /* Don't allow waiting on empty list. */
AMS_ASSERT(!impl.IsEmpty()); AMS_ABORT_UNLESS(!impl.IsEmpty());
return reinterpret_cast<WaitableHolder *>(impl.TimedWaitAny(timeout)); return reinterpret_cast<WaitableHolder *>(impl.TimedWaitAny(timeout));
} }
@ -67,7 +67,7 @@ namespace ams::os {
auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(holder->impl_storage)); auto holder_base = reinterpret_cast<impl::WaitableHolderBase *>(GetPointer(holder->impl_storage));
/* Don't allow double-linking a holder. */ /* Don't allow double-linking a holder. */
AMS_ASSERT(!holder_base->IsLinkedToManager()); AMS_ABORT_UNLESS(!holder_base->IsLinkedToManager());
impl.LinkWaitableHolder(*holder_base); impl.LinkWaitableHolder(*holder_base);
holder_base->SetManager(&impl); holder_base->SetManager(&impl);

View file

@ -92,11 +92,11 @@ namespace ams::patcher {
void ApplyIpsPatch(u8 *mapped_module, size_t mapped_size, size_t protected_size, size_t offset, bool is_ips32, FILE *f_ips) { void ApplyIpsPatch(u8 *mapped_module, size_t mapped_size, size_t protected_size, size_t offset, bool is_ips32, FILE *f_ips) {
/* Validate offset/protected size. */ /* Validate offset/protected size. */
AMS_ASSERT(offset <= protected_size); AMS_ABORT_UNLESS(offset <= protected_size);
u8 buffer[sizeof(Ips32TailMagic)]; u8 buffer[sizeof(Ips32TailMagic)];
while (true) { while (true) {
AMS_ASSERT(fread(buffer, is_ips32 ? sizeof(Ips32TailMagic) : sizeof(IpsTailMagic), 1, f_ips) == 1); AMS_ABORT_UNLESS(fread(buffer, is_ips32 ? sizeof(Ips32TailMagic) : sizeof(IpsTailMagic), 1, f_ips) == 1);
if (IsIpsTail(is_ips32, buffer)) { if (IsIpsTail(is_ips32, buffer)) {
break; break;
@ -106,18 +106,18 @@ namespace ams::patcher {
u32 patch_offset = GetIpsPatchOffset(is_ips32, buffer); u32 patch_offset = GetIpsPatchOffset(is_ips32, buffer);
/* Size of patch. */ /* Size of patch. */
AMS_ASSERT(fread(buffer, 2, 1, f_ips) == 1); AMS_ABORT_UNLESS(fread(buffer, 2, 1, f_ips) == 1);
u32 patch_size = GetIpsPatchSize(is_ips32, buffer); u32 patch_size = GetIpsPatchSize(is_ips32, buffer);
/* Check for RLE encoding. */ /* Check for RLE encoding. */
if (patch_size == 0) { if (patch_size == 0) {
/* Size of RLE. */ /* Size of RLE. */
AMS_ASSERT(fread(buffer, 2, 1, f_ips) == 1); AMS_ABORT_UNLESS(fread(buffer, 2, 1, f_ips) == 1);
u32 rle_size = (buffer[0] << 8) | (buffer[1]); u32 rle_size = (buffer[0] << 8) | (buffer[1]);
/* Value for RLE. */ /* Value for RLE. */
AMS_ASSERT(fread(buffer, 1, 1, f_ips) == 1); AMS_ABORT_UNLESS(fread(buffer, 1, 1, f_ips) == 1);
/* Ensure we don't write to protected region. */ /* Ensure we don't write to protected region. */
if (patch_offset < protected_size) { if (patch_offset < protected_size) {
@ -160,7 +160,7 @@ namespace ams::patcher {
if (patch_offset + read_size > mapped_size) { if (patch_offset + read_size > mapped_size) {
read_size = mapped_size - patch_offset; read_size = mapped_size - patch_offset;
} }
AMS_ASSERT(fread(mapped_module + patch_offset, read_size, 1, f_ips) == 1); AMS_ABORT_UNLESS(fread(mapped_module + patch_offset, read_size, 1, f_ips) == 1);
if (patch_size > read_size) { if (patch_size > read_size) {
fseek(f_ips, patch_size - read_size, SEEK_CUR); fseek(f_ips, patch_size - read_size, SEEK_CUR);
} }

View file

@ -21,12 +21,12 @@ namespace ams::pm::bm {
/* Both functions should be weakly linked, so that they can be overridden by ams::boot2 as needed. */ /* Both functions should be weakly linked, so that they can be overridden by ams::boot2 as needed. */
BootMode WEAK_SYMBOL GetBootMode() { BootMode WEAK_SYMBOL GetBootMode() {
PmBootMode boot_mode = PmBootMode_Normal; PmBootMode boot_mode = PmBootMode_Normal;
R_ASSERT(pmbmGetBootMode(&boot_mode)); R_ABORT_UNLESS(pmbmGetBootMode(&boot_mode));
return static_cast<BootMode>(boot_mode); return static_cast<BootMode>(boot_mode);
} }
void WEAK_SYMBOL SetMaintenanceBoot() { void WEAK_SYMBOL SetMaintenanceBoot() {
R_ASSERT(pmbmSetMaintenanceBoot()); R_ABORT_UNLESS(pmbmSetMaintenanceBoot());
} }
} }

View file

@ -69,7 +69,7 @@ namespace ams::pm::info {
bool HasLaunchedProgram(ncm::ProgramId program_id) { bool HasLaunchedProgram(ncm::ProgramId program_id) {
bool has_launched = false; bool has_launched = false;
R_ASSERT(HasLaunchedProgram(&has_launched, program_id)); R_ABORT_UNLESS(HasLaunchedProgram(&has_launched, program_id));
return has_launched; return has_launched;
} }

View file

@ -23,15 +23,38 @@ namespace ams::result {
namespace ams::result::impl { namespace ams::result::impl {
NORETURN WEAK_SYMBOL void OnResultAssertion(Result result) { NORETURN WEAK_SYMBOL void OnResultAbort(const char *file, int line, const char *func, const char *expr, Result result) {
/* Assert that we should call fatal on result assertion. */ /* Assert that we should call fatal on result assertion. */
/* If we shouldn't fatal, this will std::abort(); */ /* If we shouldn't fatal, this will abort(); */
/* If we should, we'll continue onwards. */ /* If we should, we'll continue onwards. */
AMS_ASSERT((ams::result::CallFatalOnResultAssertion)); if (!ams::result::CallFatalOnResultAssertion) {
::ams::diag::AbortImpl(file, line, func, expr, result.GetValue(), "Result Abort: %203d-%04d", result.GetModule(), result.GetDescription());
}
/* TODO: ams::fatal:: */ /* TODO: ams::fatal:: */
fatalThrow(result.GetValue()); fatalThrow(result.GetValue());
while (true) { /* ... */ } while (true) { /* ... */ }
} }
NORETURN WEAK_SYMBOL void OnResultAbort(Result result) {
OnResultAbort("", 0, "", "", result);
}
NORETURN WEAK_SYMBOL void OnResultAssertion(const char *file, int line, const char *func, const char *expr, Result result) {
/* Assert that we should call fatal on result assertion. */
/* If we shouldn't fatal, this will assert(); */
/* If we should, we'll continue onwards. */
if (!ams::result::CallFatalOnResultAssertion) {
::ams::diag::AssertionFailureImpl(file, line, func, expr, result.GetValue(), "Result Assertion: %203d-%04d", result.GetModule(), result.GetDescription());
}
/* TODO: ams::fatal:: */
fatalThrow(result.GetValue());
while (true) { /* ... */ }
}
NORETURN WEAK_SYMBOL void OnResultAssertion(Result result) {
OnResultAssertion("", 0, "", "", result);
}
} }

View file

@ -22,13 +22,13 @@ namespace ams::settings::fwdbg {
size_t WEAK_SYMBOL GetSettingsItemValueSize(const char *name, const char *key) { size_t WEAK_SYMBOL GetSettingsItemValueSize(const char *name, const char *key) {
u64 size = 0; u64 size = 0;
R_ASSERT(setsysGetSettingsItemValueSize(name, key, &size)); R_ABORT_UNLESS(setsysGetSettingsItemValueSize(name, key, &size));
return size; return size;
} }
size_t WEAK_SYMBOL GetSettingsItemValue(void *dst, size_t dst_size, const char *name, const char *key) { size_t WEAK_SYMBOL GetSettingsItemValue(void *dst, size_t dst_size, const char *name, const char *key) {
u64 size = 0; u64 size = 0;
R_ASSERT(setsysGetSettingsItemValue(name, key, dst, dst_size, &size)); R_ABORT_UNLESS(setsysGetSettingsItemValue(name, key, dst, dst_size, &size));
return size; return size;
} }

View file

@ -22,7 +22,7 @@ namespace ams::sf::cmif {
Entry *entry = &this->entries.front(); Entry *entry = &this->entries.front();
{ {
std::scoped_lock lk(this->manager->entry_owner_lock); std::scoped_lock lk(this->manager->entry_owner_lock);
AMS_ASSERT(entry->owner == this); AMS_ABORT_UNLESS(entry->owner == this);
entry->owner = nullptr; entry->owner = nullptr;
} }
entry->object.Reset(); entry->object.Reset();
@ -41,7 +41,7 @@ namespace ams::sf::cmif {
for (size_t i = 0; i < count; i++) { for (size_t i = 0; i < count; i++) {
Entry *entry = this->manager->entry_manager.AllocateEntry(); Entry *entry = this->manager->entry_manager.AllocateEntry();
R_UNLESS(entry != nullptr, sf::cmif::ResultOutOfDomainEntries()); R_UNLESS(entry != nullptr, sf::cmif::ResultOutOfDomainEntries());
AMS_ASSERT(entry->owner == nullptr); AMS_ABORT_UNLESS(entry->owner == nullptr);
out_ids[i] = this->manager->entry_manager.GetId(entry); out_ids[i] = this->manager->entry_manager.GetId(entry);
} }
return ResultSuccess(); return ResultSuccess();
@ -54,18 +54,18 @@ namespace ams::sf::cmif {
void ServerDomainManager::Domain::UnreserveIds(const DomainObjectId *ids, size_t count) { void ServerDomainManager::Domain::UnreserveIds(const DomainObjectId *ids, size_t count) {
for (size_t i = 0; i < count; i++) { for (size_t i = 0; i < count; i++) {
Entry *entry = this->manager->entry_manager.GetEntry(ids[i]); Entry *entry = this->manager->entry_manager.GetEntry(ids[i]);
AMS_ASSERT(entry != nullptr); AMS_ABORT_UNLESS(entry != nullptr);
AMS_ASSERT(entry->owner == nullptr); AMS_ABORT_UNLESS(entry->owner == nullptr);
this->manager->entry_manager.FreeEntry(entry); this->manager->entry_manager.FreeEntry(entry);
} }
} }
void ServerDomainManager::Domain::RegisterObject(DomainObjectId id, ServiceObjectHolder &&obj) { void ServerDomainManager::Domain::RegisterObject(DomainObjectId id, ServiceObjectHolder &&obj) {
Entry *entry = this->manager->entry_manager.GetEntry(id); Entry *entry = this->manager->entry_manager.GetEntry(id);
AMS_ASSERT(entry != nullptr); AMS_ABORT_UNLESS(entry != nullptr);
{ {
std::scoped_lock lk(this->manager->entry_owner_lock); std::scoped_lock lk(this->manager->entry_owner_lock);
AMS_ASSERT(entry->owner == nullptr); AMS_ABORT_UNLESS(entry->owner == nullptr);
entry->owner = this; entry->owner = this;
this->entries.push_back(*entry); this->entries.push_back(*entry);
} }
@ -135,8 +135,8 @@ namespace ams::sf::cmif {
void ServerDomainManager::EntryManager::FreeEntry(Entry *entry) { void ServerDomainManager::EntryManager::FreeEntry(Entry *entry) {
std::scoped_lock lk(this->lock); std::scoped_lock lk(this->lock);
AMS_ASSERT(entry->owner == nullptr); AMS_ABORT_UNLESS(entry->owner == nullptr);
AMS_ASSERT(!entry->object); AMS_ABORT_UNLESS(!entry->object);
this->free_list.push_front(*entry); this->free_list.push_front(*entry);
} }
@ -148,8 +148,8 @@ namespace ams::sf::cmif {
const auto id = ids[i]; const auto id = ids[i];
Entry *entry = this->GetEntry(id); Entry *entry = this->GetEntry(id);
if (id != InvalidDomainObjectId) { if (id != InvalidDomainObjectId) {
AMS_ASSERT(entry != nullptr); AMS_ABORT_UNLESS(entry != nullptr);
AMS_ASSERT(entry->owner == nullptr); AMS_ABORT_UNLESS(entry->owner == nullptr);
this->free_list.erase(this->free_list.iterator_to(*entry)); this->free_list.erase(this->free_list.iterator_to(*entry));
} }
} }

View file

@ -132,7 +132,7 @@ namespace ams::sf::cmif {
/* Write out header. */ /* Write out header. */
constexpr size_t out_header_size = sizeof(CmifDomainOutHeader); constexpr size_t out_header_size = sizeof(CmifDomainOutHeader);
const size_t impl_out_data_total_size = this->GetImplOutDataTotalSize(); const size_t impl_out_data_total_size = this->GetImplOutDataTotalSize();
AMS_ASSERT(out_header_size + impl_out_data_total_size + sizeof(DomainObjectId) * this->GetOutObjectCount() <= raw_data.GetSize()); AMS_ABORT_UNLESS(out_header_size + impl_out_data_total_size + sizeof(DomainObjectId) * this->GetOutObjectCount() <= raw_data.GetSize());
*reinterpret_cast<CmifDomainOutHeader *>(raw_data.GetPointer()) = CmifDomainOutHeader{ .num_out_objects = static_cast<u32>(this->GetOutObjectCount()), }; *reinterpret_cast<CmifDomainOutHeader *>(raw_data.GetPointer()) = CmifDomainOutHeader{ .num_out_objects = static_cast<u32>(this->GetOutObjectCount()), };
/* Set output raw data. */ /* Set output raw data. */
@ -150,7 +150,7 @@ namespace ams::sf::cmif {
/* Write out header. */ /* Write out header. */
constexpr size_t out_header_size = sizeof(CmifDomainOutHeader); constexpr size_t out_header_size = sizeof(CmifDomainOutHeader);
const size_t impl_out_headers_size = this->GetImplOutHeadersSize(); const size_t impl_out_headers_size = this->GetImplOutHeadersSize();
AMS_ASSERT(out_header_size + impl_out_headers_size <= raw_data.GetSize()); AMS_ABORT_UNLESS(out_header_size + impl_out_headers_size <= raw_data.GetSize());
*reinterpret_cast<CmifDomainOutHeader *>(raw_data.GetPointer()) = CmifDomainOutHeader{ .num_out_objects = 0, }; *reinterpret_cast<CmifDomainOutHeader *>(raw_data.GetPointer()) = CmifDomainOutHeader{ .num_out_objects = 0, };
/* Set output raw data. */ /* Set output raw data. */
@ -186,7 +186,7 @@ namespace ams::sf::cmif {
} }
} }
/* TODO: Can we make this error non-fatal? It isn't for N, since they can reserve IDs earlier due to not having to worry about mitm. */ /* TODO: Can we make this error non-fatal? It isn't for N, since they can reserve IDs earlier due to not having to worry about mitm. */
R_ASSERT(this->domain->ReserveIds(reservations, num_unreserved_ids)); R_ABORT_UNLESS(this->domain->ReserveIds(reservations, num_unreserved_ids));
this->domain->ReserveSpecificIds(specific_ids, num_specific_ids); this->domain->ReserveSpecificIds(specific_ids, num_specific_ids);
} }

View file

@ -46,7 +46,7 @@ namespace ams::sf::cmif {
/* Forward forwardable results, otherwise ensure we can send result to user. */ /* Forward forwardable results, otherwise ensure we can send result to user. */
R_TRY_CATCH(command_result) { R_TRY_CATCH(command_result) {
R_CATCH_RETHROW(sf::impl::ResultRequestContextChanged) R_CATCH_RETHROW(sf::impl::ResultRequestContextChanged)
R_CATCH_ALL() { AMS_ASSERT(out_header != nullptr); } R_CATCH_ALL() { AMS_ABORT_UNLESS(out_header != nullptr); }
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
/* Write output header to raw data. */ /* Write output header to raw data. */
@ -93,7 +93,7 @@ namespace ams::sf::cmif {
return ctx.session->ForwardRequest(ctx); return ctx.session->ForwardRequest(ctx);
} }
R_CATCH_RETHROW(sf::impl::ResultRequestContextChanged) R_CATCH_RETHROW(sf::impl::ResultRequestContextChanged)
R_CATCH_ALL() { AMS_ASSERT(out_header != nullptr); } R_CATCH_ALL() { AMS_ABORT_UNLESS(out_header != nullptr); }
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
/* Write output header to raw data. */ /* Write output header to raw data. */

View file

@ -22,7 +22,7 @@ namespace ams::sf::hipc {
NX_INLINE Result ReceiveImpl(Handle session_handle, void *message_buf, size_t message_buf_size) { NX_INLINE Result ReceiveImpl(Handle session_handle, void *message_buf, size_t message_buf_size) {
s32 unused_index; s32 unused_index;
if (message_buf == armGetTls()) { if (message_buf == armGetTls()) {
/* Consider: AMS_ASSERT(message_buf_size == TlsMessageBufferSize); */ /* Consider: AMS_ABORT_UNLESS(message_buf_size == TlsMessageBufferSize); */
return svcReplyAndReceive(&unused_index, &session_handle, 1, INVALID_HANDLE, U64_MAX); return svcReplyAndReceive(&unused_index, &session_handle, 1, INVALID_HANDLE, U64_MAX);
} else { } else {
return svcReplyAndReceiveWithUserBuffer(&unused_index, message_buf, message_buf_size, &session_handle, 1, INVALID_HANDLE, U64_MAX); return svcReplyAndReceiveWithUserBuffer(&unused_index, message_buf, message_buf_size, &session_handle, 1, INVALID_HANDLE, U64_MAX);
@ -32,7 +32,7 @@ namespace ams::sf::hipc {
NX_INLINE Result ReplyImpl(Handle session_handle, void *message_buf, size_t message_buf_size) { NX_INLINE Result ReplyImpl(Handle session_handle, void *message_buf, size_t message_buf_size) {
s32 unused_index; s32 unused_index;
if (message_buf == armGetTls()) { if (message_buf == armGetTls()) {
/* Consider: AMS_ASSERT(message_buf_size == TlsMessageBufferSize); */ /* Consider: AMS_ABORT_UNLESS(message_buf_size == TlsMessageBufferSize); */
return svcReplyAndReceive(&unused_index, &session_handle, 0, session_handle, 0); return svcReplyAndReceive(&unused_index, &session_handle, 0, session_handle, 0);
} else { } else {
return svcReplyAndReceiveWithUserBuffer(&unused_index, message_buf, message_buf_size, &session_handle, 0, session_handle, 0); return svcReplyAndReceiveWithUserBuffer(&unused_index, message_buf, message_buf_size, &session_handle, 0, session_handle, 0);
@ -73,7 +73,7 @@ namespace ams::sf::hipc {
R_CONVERT(svc::ResultSessionClosed, ResultSuccess()) R_CONVERT(svc::ResultSessionClosed, ResultSuccess())
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
/* ReplyImpl should *always* return an error. */ /* ReplyImpl should *always* return an error. */
AMS_ASSERT(false); AMS_ABORT_UNLESS(false);
} }
Result CreateSession(Handle *out_server_handle, Handle *out_client_handle) { Result CreateSession(Handle *out_server_handle, Handle *out_client_handle) {

View file

@ -66,11 +66,11 @@ namespace ams::sf::hipc::impl {
g_constructed_server = true; g_constructed_server = true;
} }
R_ASSERT(GetPointer(g_query_server_storage)->RegisterSession(query_handle, cmif::ServiceObjectHolder(std::make_shared<MitmQueryService>(query_func)))); R_ABORT_UNLESS(GetPointer(g_query_server_storage)->RegisterSession(query_handle, cmif::ServiceObjectHolder(std::make_shared<MitmQueryService>(query_func))));
if (!g_registered_any) { if (!g_registered_any) {
R_ASSERT(g_query_server_process_thread.Initialize(&QueryServerProcessThreadMain, GetPointer(g_query_server_storage), QueryServerProcessThreadPriority)); R_ABORT_UNLESS(g_query_server_process_thread.Initialize(&QueryServerProcessThreadMain, GetPointer(g_query_server_storage), QueryServerProcessThreadPriority));
R_ASSERT(g_query_server_process_thread.Start()); R_ABORT_UNLESS(g_query_server_process_thread.Start());
g_registered_any = true; g_registered_any = true;
} }
} }

View file

@ -40,16 +40,16 @@ namespace ams::sf::hipc {
/* Create new session handles. */ /* Create new session handles. */
Handle server_handle; Handle server_handle;
R_ASSERT(hipc::CreateSession(&server_handle, out_client_handle)); R_ABORT_UNLESS(hipc::CreateSession(&server_handle, out_client_handle));
/* Register with manager. */ /* Register with manager. */
if (!is_mitm_session) { if (!is_mitm_session) {
R_ASSERT(tagged_manager->RegisterSession(server_handle, std::move(clone))); R_ABORT_UNLESS(tagged_manager->RegisterSession(server_handle, std::move(clone)));
} else { } else {
/* Clone the forward service. */ /* Clone the forward service. */
std::shared_ptr<::Service> new_forward_service = std::move(ServerSession::CreateForwardService()); std::shared_ptr<::Service> new_forward_service = std::move(ServerSession::CreateForwardService());
R_ASSERT(serviceClone(this->session->forward_service.get(), new_forward_service.get())); R_ABORT_UNLESS(serviceClone(this->session->forward_service.get(), new_forward_service.get()));
R_ASSERT(tagged_manager->RegisterMitmSession(server_handle, std::move(clone), std::move(new_forward_service))); R_ABORT_UNLESS(tagged_manager->RegisterMitmSession(server_handle, std::move(clone), std::move(new_forward_service)));
} }
return ResultSuccess(); return ResultSuccess();
@ -71,7 +71,7 @@ namespace ams::sf::hipc {
if (this->is_mitm_session) { if (this->is_mitm_session) {
/* If we're a mitm session, we need to convert the remote session to domain. */ /* If we're a mitm session, we need to convert the remote session to domain. */
AMS_ASSERT(session->forward_service->own_handle); AMS_ABORT_UNLESS(session->forward_service->own_handle);
R_TRY(serviceConvertToDomain(session->forward_service.get())); R_TRY(serviceConvertToDomain(session->forward_service.get()));
/* The object ID reservation cannot fail here, as that would cause desynchronization from target domain. */ /* The object ID reservation cannot fail here, as that would cause desynchronization from target domain. */
@ -90,8 +90,8 @@ namespace ams::sf::hipc {
new_holder = cmif::ServiceObjectHolder(std::move(std::shared_ptr<cmif::DomainServiceObject>(domain_ptr, cmif::ServerDomainManager::DestroyDomainServiceObject))); new_holder = cmif::ServiceObjectHolder(std::move(std::shared_ptr<cmif::DomainServiceObject>(domain_ptr, cmif::ServerDomainManager::DestroyDomainServiceObject)));
} }
AMS_ASSERT(object_id != cmif::InvalidDomainObjectId); AMS_ABORT_UNLESS(object_id != cmif::InvalidDomainObjectId);
AMS_ASSERT(static_cast<bool>(new_holder)); AMS_ABORT_UNLESS(static_cast<bool>(new_holder));
/* We succeeded! */ /* We succeeded! */
domain_guard.Cancel(); domain_guard.Cancel();
@ -117,10 +117,10 @@ namespace ams::sf::hipc {
if (!this->is_mitm_session || object_id.value != serviceGetObjectId(this->session->forward_service.get())) { if (!this->is_mitm_session || object_id.value != serviceGetObjectId(this->session->forward_service.get())) {
/* Create new session handles. */ /* Create new session handles. */
Handle server_handle; Handle server_handle;
R_ASSERT(hipc::CreateSession(&server_handle, out.GetHandlePointer())); R_ABORT_UNLESS(hipc::CreateSession(&server_handle, out.GetHandlePointer()));
/* Register. */ /* Register. */
R_ASSERT(this->manager->RegisterSession(server_handle, std::move(object))); R_ABORT_UNLESS(this->manager->RegisterSession(server_handle, std::move(object)));
} else { } else {
/* Copy from the target domain. */ /* Copy from the target domain. */
Handle new_forward_target; Handle new_forward_target;
@ -128,12 +128,12 @@ namespace ams::sf::hipc {
/* Create new session handles. */ /* Create new session handles. */
Handle server_handle; Handle server_handle;
R_ASSERT(hipc::CreateSession(&server_handle, out.GetHandlePointer())); R_ABORT_UNLESS(hipc::CreateSession(&server_handle, out.GetHandlePointer()));
/* Register. */ /* Register. */
std::shared_ptr<::Service> new_forward_service = std::move(ServerSession::CreateForwardService()); std::shared_ptr<::Service> new_forward_service = std::move(ServerSession::CreateForwardService());
serviceCreate(new_forward_service.get(), new_forward_target); serviceCreate(new_forward_service.get(), new_forward_target);
R_ASSERT(this->manager->RegisterMitmSession(server_handle, std::move(object), std::move(new_forward_service))); R_ABORT_UNLESS(this->manager->RegisterMitmSession(server_handle, std::move(object), std::move(new_forward_service)));
} }
return ResultSuccess(); return ResultSuccess();

View file

@ -76,14 +76,14 @@ namespace ams::sf::hipc {
void ServerManagerBase::AddUserWaitableHolder(os::WaitableHolder *waitable) { void ServerManagerBase::AddUserWaitableHolder(os::WaitableHolder *waitable) {
const auto user_data_tag = static_cast<UserDataTag>(waitable->GetUserData()); const auto user_data_tag = static_cast<UserDataTag>(waitable->GetUserData());
AMS_ASSERT(user_data_tag != UserDataTag::Server); AMS_ABORT_UNLESS(user_data_tag != UserDataTag::Server);
AMS_ASSERT(user_data_tag != UserDataTag::MitmServer); AMS_ABORT_UNLESS(user_data_tag != UserDataTag::MitmServer);
AMS_ASSERT(user_data_tag != UserDataTag::Session); AMS_ABORT_UNLESS(user_data_tag != UserDataTag::Session);
this->RegisterToWaitList(waitable); this->RegisterToWaitList(waitable);
} }
Result ServerManagerBase::ProcessForServer(os::WaitableHolder *holder) { Result ServerManagerBase::ProcessForServer(os::WaitableHolder *holder) {
AMS_ASSERT(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::Server); AMS_ABORT_UNLESS(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::Server);
ServerBase *server = static_cast<ServerBase *>(holder); ServerBase *server = static_cast<ServerBase *>(holder);
ON_SCOPE_EXIT { this->RegisterToWaitList(server); }; ON_SCOPE_EXIT { this->RegisterToWaitList(server); };
@ -94,14 +94,14 @@ namespace ams::sf::hipc {
server->CreateSessionObjectHolder(&obj, &fsrv); server->CreateSessionObjectHolder(&obj, &fsrv);
/* Not a mitm server, so we must have no forward service. */ /* Not a mitm server, so we must have no forward service. */
AMS_ASSERT(fsrv == nullptr); AMS_ABORT_UNLESS(fsrv == nullptr);
/* Try to accept. */ /* Try to accept. */
return this->AcceptSession(server->port_handle, std::move(obj)); return this->AcceptSession(server->port_handle, std::move(obj));
} }
Result ServerManagerBase::ProcessForMitmServer(os::WaitableHolder *holder) { Result ServerManagerBase::ProcessForMitmServer(os::WaitableHolder *holder) {
AMS_ASSERT(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::MitmServer); AMS_ABORT_UNLESS(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::MitmServer);
ServerBase *server = static_cast<ServerBase *>(holder); ServerBase *server = static_cast<ServerBase *>(holder);
ON_SCOPE_EXIT { this->RegisterToWaitList(server); }; ON_SCOPE_EXIT { this->RegisterToWaitList(server); };
@ -112,20 +112,20 @@ namespace ams::sf::hipc {
server->CreateSessionObjectHolder(&obj, &fsrv); server->CreateSessionObjectHolder(&obj, &fsrv);
/* Mitm server, so we must have forward service. */ /* Mitm server, so we must have forward service. */
AMS_ASSERT(fsrv != nullptr); AMS_ABORT_UNLESS(fsrv != nullptr);
/* Try to accept. */ /* Try to accept. */
return this->AcceptMitmSession(server->port_handle, std::move(obj), std::move(fsrv)); return this->AcceptMitmSession(server->port_handle, std::move(obj), std::move(fsrv));
} }
Result ServerManagerBase::ProcessForSession(os::WaitableHolder *holder) { Result ServerManagerBase::ProcessForSession(os::WaitableHolder *holder) {
AMS_ASSERT(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::Session); AMS_ABORT_UNLESS(static_cast<UserDataTag>(holder->GetUserData()) == UserDataTag::Session);
ServerSession *session = static_cast<ServerSession *>(holder); ServerSession *session = static_cast<ServerSession *>(holder);
cmif::PointerAndSize tls_message(armGetTls(), hipc::TlsMessageBufferSize); cmif::PointerAndSize tls_message(armGetTls(), hipc::TlsMessageBufferSize);
const cmif::PointerAndSize &saved_message = session->saved_message; const cmif::PointerAndSize &saved_message = session->saved_message;
AMS_ASSERT(tls_message.GetSize() == saved_message.GetSize()); AMS_ABORT_UNLESS(tls_message.GetSize() == saved_message.GetSize());
if (!session->has_received) { if (!session->has_received) {
R_TRY(this->ReceiveRequest(session, tls_message)); R_TRY(this->ReceiveRequest(session, tls_message));
session->has_received = true; session->has_received = true;
@ -208,7 +208,7 @@ namespace ams::sf::hipc {
if (!waitable) { if (!waitable) {
return false; return false;
} }
R_ASSERT(this->Process(waitable)); R_ABORT_UNLESS(this->Process(waitable));
return true; return true;
} }

View file

@ -40,10 +40,10 @@ namespace ams::sf::hipc {
} }
Result ServerSession::ForwardRequest(const cmif::ServiceDispatchContext &ctx) const { Result ServerSession::ForwardRequest(const cmif::ServiceDispatchContext &ctx) const {
AMS_ASSERT(this->IsMitmSession()); AMS_ABORT_UNLESS(this->IsMitmSession());
/* TODO: Support non-TLS messages? */ /* TODO: Support non-TLS messages? */
AMS_ASSERT(this->saved_message.GetPointer() != nullptr); AMS_ABORT_UNLESS(this->saved_message.GetPointer() != nullptr);
AMS_ASSERT(this->saved_message.GetSize() == TlsMessageBufferSize); AMS_ABORT_UNLESS(this->saved_message.GetSize() == TlsMessageBufferSize);
/* Copy saved TLS in. */ /* Copy saved TLS in. */
std::memcpy(armGetTls(), this->saved_message.GetPointer(), this->saved_message.GetSize()); std::memcpy(armGetTls(), this->saved_message.GetPointer(), this->saved_message.GetSize());
@ -78,7 +78,7 @@ namespace ams::sf::hipc {
void ServerSessionManager::CloseSessionImpl(ServerSession *session) { void ServerSessionManager::CloseSessionImpl(ServerSession *session) {
const Handle session_handle = session->session_handle; const Handle session_handle = session->session_handle;
this->DestroySession(session); this->DestroySession(session);
R_ASSERT(svcCloseHandle(session_handle)); R_ABORT_UNLESS(svcCloseHandle(session_handle));
} }
Result ServerSessionManager::RegisterSessionImpl(ServerSession *session_memory, Handle session_handle, cmif::ServiceObjectHolder &&obj) { Result ServerSessionManager::RegisterSessionImpl(ServerSession *session_memory, Handle session_handle, cmif::ServiceObjectHolder &&obj) {
@ -99,7 +99,7 @@ namespace ams::sf::hipc {
bool succeeded = false; bool succeeded = false;
ON_SCOPE_EXIT { ON_SCOPE_EXIT {
if (!succeeded) { if (!succeeded) {
R_ASSERT(svcCloseHandle(session_handle)); R_ABORT_UNLESS(svcCloseHandle(session_handle));
} }
}; };
/* Register session. */ /* Register session. */
@ -115,7 +115,7 @@ namespace ams::sf::hipc {
session_memory->pointer_buffer = this->GetSessionPointerBuffer(session_memory); session_memory->pointer_buffer = this->GetSessionPointerBuffer(session_memory);
session_memory->saved_message = this->GetSessionSavedMessageBuffer(session_memory); session_memory->saved_message = this->GetSessionSavedMessageBuffer(session_memory);
/* Validate session pointer buffer. */ /* Validate session pointer buffer. */
AMS_ASSERT(session_memory->pointer_buffer.GetSize() >= session_memory->forward_service->pointer_buffer_size); AMS_ABORT_UNLESS(session_memory->pointer_buffer.GetSize() >= session_memory->forward_service->pointer_buffer_size);
session_memory->pointer_buffer = cmif::PointerAndSize(session_memory->pointer_buffer.GetAddress(), session_memory->forward_service->pointer_buffer_size); session_memory->pointer_buffer = cmif::PointerAndSize(session_memory->pointer_buffer.GetAddress(), session_memory->forward_service->pointer_buffer_size);
/* Register to wait list. */ /* Register to wait list. */
this->RegisterSessionToWaitList(session_memory); this->RegisterSessionToWaitList(session_memory);
@ -129,7 +129,7 @@ namespace ams::sf::hipc {
bool succeeded = false; bool succeeded = false;
ON_SCOPE_EXIT { ON_SCOPE_EXIT {
if (!succeeded) { if (!succeeded) {
R_ASSERT(svcCloseHandle(mitm_session_handle)); R_ABORT_UNLESS(svcCloseHandle(mitm_session_handle));
} }
}; };
/* Register session. */ /* Register session. */
@ -291,7 +291,7 @@ namespace ams::sf::hipc {
{ {
ON_SCOPE_EXIT { ON_SCOPE_EXIT {
for (size_t i = 0; i < handles_to_close.num_handles; i++) { for (size_t i = 0; i < handles_to_close.num_handles; i++) {
R_ASSERT(svcCloseHandle(handles_to_close.handles[i])); R_ABORT_UNLESS(svcCloseHandle(handles_to_close.handles[i]));
} }
}; };
R_TRY(hipc::Reply(session->session_handle, out_message)); R_TRY(hipc::Reply(session->session_handle, out_message));

View file

@ -29,7 +29,7 @@ namespace ams::sm::impl {
Result DoWithUserSession(F f) { Result DoWithUserSession(F f) {
std::scoped_lock<os::RecursiveMutex &> lk(GetUserSessionMutex()); std::scoped_lock<os::RecursiveMutex &> lk(GetUserSessionMutex());
{ {
R_ASSERT(smInitialize()); R_ABORT_UNLESS(smInitialize());
ON_SCOPE_EXIT { smExit(); }; ON_SCOPE_EXIT { smExit(); };
return f(); return f();
@ -40,7 +40,7 @@ namespace ams::sm::impl {
Result DoWithMitmAcknowledgementSession(F f) { Result DoWithMitmAcknowledgementSession(F f) {
std::scoped_lock<os::RecursiveMutex &> lk(GetMitmAcknowledgementSessionMutex()); std::scoped_lock<os::RecursiveMutex &> lk(GetMitmAcknowledgementSessionMutex());
{ {
R_ASSERT(smAtmosphereMitmInitialize()); R_ABORT_UNLESS(smAtmosphereMitmInitialize());
ON_SCOPE_EXIT { smAtmosphereMitmExit(); }; ON_SCOPE_EXIT { smAtmosphereMitmExit(); };
return f(); return f();
@ -52,7 +52,7 @@ namespace ams::sm::impl {
Service srv; Service srv;
{ {
std::scoped_lock<os::RecursiveMutex &> lk(GetPerThreadSessionMutex()); std::scoped_lock<os::RecursiveMutex &> lk(GetPerThreadSessionMutex());
R_ASSERT(smAtmosphereOpenSession(&srv)); R_ABORT_UNLESS(smAtmosphereOpenSession(&srv));
} }
{ {
ON_SCOPE_EXIT { smAtmosphereCloseSession(&srv); }; ON_SCOPE_EXIT { smAtmosphereCloseSession(&srv); };

View file

@ -349,7 +349,7 @@ namespace ams::spl::smc {
} }
Result AtmosphereWriteAddress(void *dst, const void *src, size_t size) { Result AtmosphereWriteAddress(void *dst, const void *src, size_t size) {
AMS_ASSERT(size <= sizeof(u64)); AMS_ABORT_UNLESS(size <= sizeof(u64));
SecmonArgs args; SecmonArgs args;
args.X[0] = static_cast<u64>(FunctionId::AtmosphereWriteAddress); args.X[0] = static_cast<u64>(FunctionId::AtmosphereWriteAddress);
@ -363,7 +363,7 @@ namespace ams::spl::smc {
Result AtmosphereGetEmummcConfig(void *out_config, void *out_paths, u32 storage_id) { Result AtmosphereGetEmummcConfig(void *out_config, void *out_paths, u32 storage_id) {
const u64 paths = reinterpret_cast<u64>(out_paths); const u64 paths = reinterpret_cast<u64>(out_paths);
AMS_ASSERT(util::IsAligned(paths, os::MemoryPageSize)); AMS_ABORT_UNLESS(util::IsAligned(paths, os::MemoryPageSize));
SecmonArgs args = {}; SecmonArgs args = {};
args.X[0] = static_cast<u64>(FunctionId::AtmosphereGetEmummcConfig); args.X[0] = static_cast<u64>(FunctionId::AtmosphereGetEmummcConfig);

View file

@ -19,13 +19,13 @@ namespace ams::spl {
HardwareType GetHardwareType() { HardwareType GetHardwareType() {
u64 out_val = 0; u64 out_val = 0;
R_ASSERT(splGetConfig(SplConfigItem_HardwareType, &out_val)); R_ABORT_UNLESS(splGetConfig(SplConfigItem_HardwareType, &out_val));
return static_cast<HardwareType>(out_val); return static_cast<HardwareType>(out_val);
} }
MemoryArrangement GetMemoryArrangement() { MemoryArrangement GetMemoryArrangement() {
u64 arrange = 0; u64 arrange = 0;
R_ASSERT(splGetConfig(SplConfigItem_MemoryArrange, &arrange)); R_ABORT_UNLESS(splGetConfig(SplConfigItem_MemoryArrange, &arrange));
arrange &= 0x3F; arrange &= 0x3F;
switch (arrange) { switch (arrange) {
case 2: case 2:
@ -43,19 +43,19 @@ namespace ams::spl {
bool IsDevelopmentHardware() { bool IsDevelopmentHardware() {
bool is_dev_hardware; bool is_dev_hardware;
R_ASSERT(splIsDevelopment(&is_dev_hardware)); R_ABORT_UNLESS(splIsDevelopment(&is_dev_hardware));
return is_dev_hardware; return is_dev_hardware;
} }
bool IsDevelopmentFunctionEnabled() { bool IsDevelopmentFunctionEnabled() {
u64 val = 0; u64 val = 0;
R_ASSERT(splGetConfig(SplConfigItem_IsDebugMode, &val)); R_ABORT_UNLESS(splGetConfig(SplConfigItem_IsDebugMode, &val));
return val != 0; return val != 0;
} }
bool IsRecoveryBoot() { bool IsRecoveryBoot() {
u64 val = 0; u64 val = 0;
R_ASSERT(splGetConfig(SplConfigItem_IsRecoveryBoot, &val)); R_ABORT_UNLESS(splGetConfig(SplConfigItem_IsRecoveryBoot, &val));
return val != 0; return val != 0;
} }

View file

@ -133,7 +133,7 @@ namespace ams::updater {
Result GetBootImagePackageDataId(u64 *out_data_id, BootModeType mode, void *work_buffer, size_t work_buffer_size) { Result GetBootImagePackageDataId(u64 *out_data_id, BootModeType mode, void *work_buffer, size_t work_buffer_size) {
/* Ensure we can read content metas. */ /* Ensure we can read content metas. */
constexpr size_t MaxContentMetas = 0x40; constexpr size_t MaxContentMetas = 0x40;
AMS_ASSERT(work_buffer_size >= sizeof(NcmContentMetaKey) * MaxContentMetas); AMS_ABORT_UNLESS(work_buffer_size >= sizeof(NcmContentMetaKey) * MaxContentMetas);
/* Open NAND System meta database, list contents. */ /* Open NAND System meta database, list contents. */
NcmContentMetaDatabase meta_db; NcmContentMetaDatabase meta_db;
@ -150,7 +150,7 @@ namespace ams::updater {
return ResultBootImagePackageNotFound(); return ResultBootImagePackageNotFound();
} }
AMS_ASSERT(total_entries == written_entries); AMS_ABORT_UNLESS(total_entries == written_entries);
/* Output is sorted, return the lowest valid exfat entry. */ /* Output is sorted, return the lowest valid exfat entry. */
if (total_entries > 1) { if (total_entries > 1) {
@ -187,7 +187,7 @@ namespace ams::updater {
R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) { R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) {
R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound()) R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound())
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
ON_SCOPE_EXIT { R_ASSERT(romfsUnmount(GetBootImagePackageMountPath())); }; ON_SCOPE_EXIT { R_ABORT_UNLESS(romfsUnmount(GetBootImagePackageMountPath())); };
/* Read and validate hashes of boot images. */ /* Read and validate hashes of boot images. */
{ {
@ -240,7 +240,7 @@ namespace ams::updater {
R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) { R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) {
R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound()) R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound())
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
ON_SCOPE_EXIT { R_ASSERT(romfsUnmount(GetBootImagePackageMountPath())); }; ON_SCOPE_EXIT { R_ABORT_UNLESS(romfsUnmount(GetBootImagePackageMountPath())); };
/* Read and validate hashes of boot images. */ /* Read and validate hashes of boot images. */
{ {
@ -308,7 +308,7 @@ namespace ams::updater {
R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) { R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) {
R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound()) R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound())
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
ON_SCOPE_EXIT { R_ASSERT(romfsUnmount(GetBootImagePackageMountPath())); }; ON_SCOPE_EXIT { R_ABORT_UNLESS(romfsUnmount(GetBootImagePackageMountPath())); };
{ {
Boot0Accessor boot0_accessor; Boot0Accessor boot0_accessor;
@ -363,7 +363,7 @@ namespace ams::updater {
R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) { R_TRY_CATCH(romfsMountFromDataArchive(data_id, NcmStorageId_BuiltInSystem, GetBootImagePackageMountPath())) {
R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound()) R_CONVERT(fs::ResultTargetNotFound, ResultBootImagePackageNotFound())
} R_END_TRY_CATCH; } R_END_TRY_CATCH;
ON_SCOPE_EXIT { R_ASSERT(romfsUnmount(GetBootImagePackageMountPath())); }; ON_SCOPE_EXIT { R_ABORT_UNLESS(romfsUnmount(GetBootImagePackageMountPath())); };
{ {
Boot0Accessor boot0_accessor; Boot0Accessor boot0_accessor;
@ -509,7 +509,7 @@ namespace ams::updater {
/* Get a session to ncm. */ /* Get a session to ncm. */
sm::ScopedServiceHolder<ncmInitialize, ncmExit> ncm_holder; sm::ScopedServiceHolder<ncmInitialize, ncmExit> ncm_holder;
R_ASSERT(ncm_holder.GetResult()); R_ABORT_UNLESS(ncm_holder.GetResult());
/* Verify normal, verify safe as needed. */ /* Verify normal, verify safe as needed. */
if (verification_state.needs_verify_normal) { if (verification_state.needs_verify_normal) {

View file

@ -31,18 +31,18 @@ namespace ams::updater {
} }
Result BisAccessor::Read(void *dst, size_t size, u64 offset) { Result BisAccessor::Read(void *dst, size_t size, u64 offset) {
AMS_ASSERT((offset % SectorAlignment) == 0); AMS_ABORT_UNLESS((offset % SectorAlignment) == 0);
return fsStorageRead(&this->storage, offset, dst, size); return fsStorageRead(&this->storage, offset, dst, size);
} }
Result BisAccessor::Write(u64 offset, const void *src, size_t size) { Result BisAccessor::Write(u64 offset, const void *src, size_t size) {
AMS_ASSERT((offset % SectorAlignment) == 0); AMS_ABORT_UNLESS((offset % SectorAlignment) == 0);
return fsStorageWrite(&this->storage, offset, src, size); return fsStorageWrite(&this->storage, offset, src, size);
} }
Result BisAccessor::Write(u64 offset, size_t size, const char *bip_path, void *work_buffer, size_t work_buffer_size) { Result BisAccessor::Write(u64 offset, size_t size, const char *bip_path, void *work_buffer, size_t work_buffer_size) {
AMS_ASSERT((offset % SectorAlignment) == 0); AMS_ABORT_UNLESS((offset % SectorAlignment) == 0);
AMS_ASSERT((work_buffer_size % SectorAlignment) == 0); AMS_ABORT_UNLESS((work_buffer_size % SectorAlignment) == 0);
FILE *bip_fp = fopen(bip_path, "rb"); FILE *bip_fp = fopen(bip_path, "rb");
if (bip_fp == NULL) { if (bip_fp == NULL) {
@ -59,7 +59,7 @@ namespace ams::updater {
return fsdevGetLastResult(); return fsdevGetLastResult();
} }
} }
AMS_ASSERT(written + read_size <= size); AMS_ABORT_UNLESS(written + read_size <= size);
size_t aligned_size = ((read_size + SectorAlignment - 1) / SectorAlignment) * SectorAlignment; size_t aligned_size = ((read_size + SectorAlignment - 1) / SectorAlignment) * SectorAlignment;
R_TRY(this->Write(offset + written, work_buffer, aligned_size)); R_TRY(this->Write(offset + written, work_buffer, aligned_size));
@ -73,8 +73,8 @@ namespace ams::updater {
} }
Result BisAccessor::Clear(u64 offset, u64 size, void *work_buffer, size_t work_buffer_size) { Result BisAccessor::Clear(u64 offset, u64 size, void *work_buffer, size_t work_buffer_size) {
AMS_ASSERT((offset % SectorAlignment) == 0); AMS_ABORT_UNLESS((offset % SectorAlignment) == 0);
AMS_ASSERT((work_buffer_size % SectorAlignment) == 0); AMS_ABORT_UNLESS((work_buffer_size % SectorAlignment) == 0);
std::memset(work_buffer, 0, work_buffer_size); std::memset(work_buffer, 0, work_buffer_size);
@ -88,8 +88,8 @@ namespace ams::updater {
} }
Result BisAccessor::GetHash(void *dst, u64 offset, u64 size, u64 hash_size, void *work_buffer, size_t work_buffer_size) { Result BisAccessor::GetHash(void *dst, u64 offset, u64 size, u64 hash_size, void *work_buffer, size_t work_buffer_size) {
AMS_ASSERT((offset % SectorAlignment) == 0); AMS_ABORT_UNLESS((offset % SectorAlignment) == 0);
AMS_ASSERT((work_buffer_size % SectorAlignment) == 0); AMS_ABORT_UNLESS((work_buffer_size % SectorAlignment) == 0);
Sha256Context sha_ctx; Sha256Context sha_ctx;
sha256ContextCreate(&sha_ctx); sha256ContextCreate(&sha_ctx);
@ -109,12 +109,12 @@ namespace ams::updater {
size_t Boot0Accessor::GetBootloaderVersion(void *bct) { size_t Boot0Accessor::GetBootloaderVersion(void *bct) {
u32 version = *reinterpret_cast<u32 *>(reinterpret_cast<uintptr_t>(bct) + BctVersionOffset); u32 version = *reinterpret_cast<u32 *>(reinterpret_cast<uintptr_t>(bct) + BctVersionOffset);
AMS_ASSERT(version <= BctVersionMax); AMS_ABORT_UNLESS(version <= BctVersionMax);
return static_cast<size_t>(version); return static_cast<size_t>(version);
} }
size_t Boot0Accessor::GetEksIndex(size_t bootloader_version) { size_t Boot0Accessor::GetEksIndex(size_t bootloader_version) {
AMS_ASSERT(bootloader_version <= BctVersionMax); AMS_ABORT_UNLESS(bootloader_version <= BctVersionMax);
return (bootloader_version > 0) ? bootloader_version - 1 : 0; return (bootloader_version > 0) ? bootloader_version - 1 : 0;
} }

View file

@ -136,13 +136,13 @@ namespace ams::updater {
} }
} }
AMS_ASSERT(entry != nullptr); AMS_ABORT_UNLESS(entry != nullptr);
return entry; return entry;
} }
public: public:
Result Read(size_t *out_size, void *dst, size_t size, EnumType which) { Result Read(size_t *out_size, void *dst, size_t size, EnumType which) {
const auto entry = FindEntry(which); const auto entry = FindEntry(which);
AMS_ASSERT(size >= entry->size); AMS_ABORT_UNLESS(size >= entry->size);
R_TRY(BisAccessor::Read(dst, entry->size, entry->offset)); R_TRY(BisAccessor::Read(dst, entry->size, entry->offset));
@ -152,8 +152,8 @@ namespace ams::updater {
Result Write(const void *src, size_t size, EnumType which) { Result Write(const void *src, size_t size, EnumType which) {
const auto entry = FindEntry(which); const auto entry = FindEntry(which);
AMS_ASSERT(size <= entry->size); AMS_ABORT_UNLESS(size <= entry->size);
AMS_ASSERT((size % BisAccessor::SectorAlignment) == 0); AMS_ABORT_UNLESS((size % BisAccessor::SectorAlignment) == 0);
return BisAccessor::Write(entry->offset, src, size); return BisAccessor::Write(entry->offset, src, size);
} }

View file

@ -29,9 +29,9 @@ namespace ams::updater {
} }
Result BisSave::Initialize(void *work_buffer, size_t work_buffer_size) { Result BisSave::Initialize(void *work_buffer, size_t work_buffer_size) {
AMS_ASSERT(work_buffer_size >= SaveSize); AMS_ABORT_UNLESS(work_buffer_size >= SaveSize);
AMS_ASSERT(util::IsAligned(reinterpret_cast<uintptr_t>(work_buffer), os::MemoryPageSize)); AMS_ABORT_UNLESS(util::IsAligned(reinterpret_cast<uintptr_t>(work_buffer), os::MemoryPageSize));
AMS_ASSERT(util::IsAligned(work_buffer_size, 0x200)); AMS_ABORT_UNLESS(util::IsAligned(work_buffer_size, 0x200));
R_TRY(this->accessor.Initialize()); R_TRY(this->accessor.Initialize());
this->save_buffer = work_buffer; this->save_buffer = work_buffer;

View file

@ -30,7 +30,7 @@ namespace ams::updater {
constexpr const char *Package2PathA = "bip:/a/package2"; constexpr const char *Package2PathA = "bip:/a/package2";
const char *ChooseCandidatePath(const char * const *candidates, size_t num_candidates) { const char *ChooseCandidatePath(const char * const *candidates, size_t num_candidates) {
AMS_ASSERT(num_candidates > 0); AMS_ABORT_UNLESS(num_candidates > 0);
for (size_t i = 0; i < num_candidates; i++) { for (size_t i = 0; i < num_candidates; i++) {
struct stat buf; struct stat buf;

View file

@ -21,8 +21,8 @@ namespace ams::util {
/* Compression utilities. */ /* Compression utilities. */
int CompressLZ4(void *dst, size_t dst_size, const void *src, size_t src_size) { int CompressLZ4(void *dst, size_t dst_size, const void *src, size_t src_size) {
/* Size checks. */ /* Size checks. */
AMS_ASSERT(dst_size <= std::numeric_limits<int>::max()); AMS_ABORT_UNLESS(dst_size <= std::numeric_limits<int>::max());
AMS_ASSERT(src_size <= std::numeric_limits<int>::max()); AMS_ABORT_UNLESS(src_size <= std::numeric_limits<int>::max());
/* This is just a thin wrapper around LZ4. */ /* This is just a thin wrapper around LZ4. */
return LZ4_compress_default(reinterpret_cast<const char *>(src), reinterpret_cast<char *>(dst), static_cast<int>(src_size), static_cast<int>(dst_size)); return LZ4_compress_default(reinterpret_cast<const char *>(src), reinterpret_cast<char *>(dst), static_cast<int>(src_size), static_cast<int>(dst_size));
@ -31,8 +31,8 @@ namespace ams::util {
/* Decompression utilities. */ /* Decompression utilities. */
int DecompressLZ4(void *dst, size_t dst_size, const void *src, size_t src_size) { int DecompressLZ4(void *dst, size_t dst_size, const void *src, size_t src_size) {
/* Size checks. */ /* Size checks. */
AMS_ASSERT(dst_size <= std::numeric_limits<int>::max()); AMS_ABORT_UNLESS(dst_size <= std::numeric_limits<int>::max());
AMS_ASSERT(src_size <= std::numeric_limits<int>::max()); AMS_ABORT_UNLESS(src_size <= std::numeric_limits<int>::max());
/* This is just a thin wrapper around LZ4. */ /* This is just a thin wrapper around LZ4. */
return LZ4_decompress_safe(reinterpret_cast<const char *>(src), reinterpret_cast<char *>(dst), static_cast<int>(src_size), static_cast<int>(dst_size)); return LZ4_decompress_safe(reinterpret_cast<const char *>(src), reinterpret_cast<char *>(dst), static_cast<int>(src_size), static_cast<int>(dst_size));

View file

@ -31,7 +31,7 @@ namespace ams::util::ini {
explicit FsFileContext(FsFile *f) : f(f), offset(0) { explicit FsFileContext(FsFile *f) : f(f), offset(0) {
s64 size; s64 size;
R_ASSERT(fsFileGetSize(this->f, &size)); R_ABORT_UNLESS(fsFileGetSize(this->f, &size));
this->num_left = size_t(size); this->num_left = size_t(size);
} }
}; };
@ -46,8 +46,8 @@ namespace ams::util::ini {
/* Read as many bytes as we can. */ /* Read as many bytes as we can. */
size_t try_read = std::min(size_t(num - 1), ctx->num_left); size_t try_read = std::min(size_t(num - 1), ctx->num_left);
size_t actually_read; size_t actually_read;
R_ASSERT(fsFileRead(ctx->f, ctx->offset, str, try_read, FsReadOption_None, &actually_read)); R_ABORT_UNLESS(fsFileRead(ctx->f, ctx->offset, str, try_read, FsReadOption_None, &actually_read));
AMS_ASSERT(actually_read == try_read); AMS_ABORT_UNLESS(actually_read == try_read);
/* Only "read" up to the first \n. */ /* Only "read" up to the first \n. */
size_t offset = actually_read; size_t offset = actually_read;

View file

@ -15,8 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/includes.hpp> #include <vapours/common.hpp>
#include <vapours/defines.hpp> #include <vapours/assert.hpp>
#include <vapours/literals.hpp> #include <vapours/literals.hpp>
#include <vapours/timespan.hpp> #include <vapours/timespan.hpp>

View file

@ -0,0 +1,76 @@
/*
* Copyright (c) 2018-2020 Atmosphère-NX
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <vapours/common.hpp>
namespace ams::impl {
template<typename... ArgTypes>
ALWAYS_INLINE void UnusedImpl(ArgTypes... args) {
(static_cast<void>(args), ...);
}
}
namespace ams::diag {
NORETURN NOINLINE void AssertionFailureImpl(const char *file, int line, const char *func, const char *expr, u64 value, const char *format, ...) __attribute__((format(printf, 6, 7)));
NORETURN NOINLINE void AssertionFailureImpl(const char *file, int line, const char *func, const char *expr, u64 value);
NORETURN NOINLINE void AbortImpl(const char *file, int line, const char *func, const char *expr, u64 value, const char *format, ...) __attribute__((format(printf, 6, 7)));
NORETURN NOINLINE void AbortImpl(const char *file, int line, const char *func, const char *expr, u64 value);
}
#define AMS_UNUSED(...) ::ams::impl::UnusedImpl(__VA_ARGS__)
#ifdef AMS_ENABLE_DEBUG_PRINT
#define AMS_CALL_ASSERT_FAIL_IMPL(cond, ...) ::ams::diag::AssertionFailureImpl(__FILE__, __LINE__, __PRETTY_FUNCTION__, cond, 0, ## __VA_ARGS__)
#define AMS_CALL_ABORT_IMPL(cond, ...) ::ams::diag::AbortImpl(__FILE__, __LINE__, __PRETTY_FUNCTION__, cond, 0, ## __VA_ARGS__)
#else
#define AMS_CALL_ASSERT_FAIL_IMPL(cond, ...) ::ams::diag::AssertionFailureImpl("", 0, "", "", 0)
#define AMS_CALL_ABORT_IMPL(cond, ...) ::ams::diag::AbortImpl("", 0, "", "", 0)
#endif
#ifdef AMS_ENABLE_ASSERTIONS
#define AMS_ASSERT_IMPL(expr, ...) \
({ \
if (const bool __tmp_ams_assert_val = (expr); AMS_UNLIKELY(!__tmp_ams_assert_val)) { \
AMS_CALL_ASSERT_FAIL_IMPL(#expr, ## __VA_ARGS__); \
} \
})
#else
#define AMS_ASSERT_IMPL(expr, ...) AMS_UNUSED(expr, ## __VA_ARGS__)
#endif
#define AMS_ASSERT(expr, ...) AMS_ASSERT_IMPL(expr, ## __VA_ARGS__)
#define AMS_UNREACHABLE_DEFAULT_CASE() default: AMS_CALL_ABORT_IMPL("Unreachable default case entered")
#ifdef AMS_BUILD_FOR_AUDITING
#define AMS_AUDIT(expr, ...) AMS_ASSERT(expr, ## __VA_ARGS__)
#else
#define AMS_AUDIT(expr, ...) AMS_UNUSED(expr, ## __VA_ARGS__)
#endif
#define AMS_ABORT(...) AMS_CALL_ABORT_IMPL("", ## __VA_ARGS__)
#define AMS_ABORT_UNLESS(expr, ...) \
({ \
if (const bool __tmp_ams_assert_val = (expr); AMS_UNLIKELY(!__tmp_ams_assert_val)) { \
AMS_CALL_ABORT_IMPL(#expr, ##__VA_ARGS__); \
} \
})

View file

@ -0,0 +1,31 @@
/*
* Copyright (c) 2018-2020 Atmosphère-NX
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <vapours/includes.hpp>
#include <vapours/defines.hpp>
#if 0
#define AMS_BUILD_FOR_AUDITING
#endif
#ifdef AMS_BUILD_FOR_AUDITING
#define AMS_BUILD_FOR_DEBUGGING
#endif
#ifdef AMS_BUILD_FOR_DEBUGGING
#define AMS_ENABLE_ASSERTIONS
#define AMS_ENABLE_DEBUG_PRINT
#endif

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/util.hpp> #include <vapours/util.hpp>
#ifdef ATMOSPHERE_ARCH_ARM64 #ifdef ATMOSPHERE_ARCH_ARM64
@ -30,7 +31,7 @@
namespace ams::crypto { namespace ams::crypto {
bool IsSameBytes(const void *lhs, const void *rhs, size_t size) { inline bool IsSameBytes(const void *lhs, const void *rhs, size_t size) {
return impl::IsSameBytes(lhs, rhs, size); return impl::IsSameBytes(lhs, rhs, size);
} }

View file

@ -20,7 +20,7 @@
namespace ams::crypto::impl { namespace ams::crypto::impl {
bool IsSameBytes(const void *lhs, const void *rhs, size_t size) { inline bool IsSameBytes(const void *lhs, const void *rhs, size_t size) {
bool result; bool result;
u8 xor_acc, ltmp, rtmp; u8 xor_acc, ltmp, rtmp;
size_t index; size_t index;

View file

@ -18,10 +18,6 @@
/* Any broadly useful language defines should go here. */ /* Any broadly useful language defines should go here. */
#define AMS_ASSERT(expr) do { if (!(expr)) { std::abort(); } } while (0)
#define AMS_UNREACHABLE_DEFAULT_CASE() default: std::abort()
#define NON_COPYABLE(cls) \ #define NON_COPYABLE(cls) \
cls(const cls&) = delete; \ cls(const cls&) = delete; \
cls& operator=(const cls&) = delete cls& operator=(const cls&) = delete

View file

@ -14,7 +14,8 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams { inline namespace literals { namespace ams { inline namespace literals {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/util.hpp> #include <vapours/util.hpp>
/* Utilities. */ /* Utilities. */

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams { namespace ams {
@ -31,7 +32,7 @@ namespace ams {
static constexpr BaseType ReservedBits = 10; static constexpr BaseType ReservedBits = 10;
static_assert(ModuleBits + DescriptionBits + ReservedBits == sizeof(BaseType) * CHAR_BIT, "ModuleBits + DescriptionBits + ReservedBits == sizeof(BaseType) * CHAR_BIT"); static_assert(ModuleBits + DescriptionBits + ReservedBits == sizeof(BaseType) * CHAR_BIT, "ModuleBits + DescriptionBits + ReservedBits == sizeof(BaseType) * CHAR_BIT");
public: public:
NX_CONSTEXPR BaseType MakeValue(BaseType module, BaseType description) { static constexpr ALWAYS_INLINE BaseType MakeValue(BaseType module, BaseType description) {
return (module) | (description << ModuleBits); return (module) | (description << ModuleBits);
} }
@ -41,11 +42,11 @@ namespace ams {
static_assert(description < (1 << DescriptionBits), "Invalid Description"); static_assert(description < (1 << DescriptionBits), "Invalid Description");
}; };
NX_CONSTEXPR BaseType GetModuleFromValue(BaseType value) { static constexpr ALWAYS_INLINE BaseType GetModuleFromValue(BaseType value) {
return value & ~(~BaseType() << ModuleBits); return value & ~(~BaseType() << ModuleBits);
} }
NX_CONSTEXPR BaseType GetDescriptionFromValue(BaseType value) { static constexpr ALWAYS_INLINE BaseType GetDescriptionFromValue(BaseType value) {
return ((value >> ModuleBits) & ~(~BaseType() << DescriptionBits)); return ((value >> ModuleBits) & ~(~BaseType() << DescriptionBits));
} }
}; };
@ -126,13 +127,16 @@ namespace ams {
namespace result::impl { namespace result::impl {
NORETURN void OnResultAssertion(Result result); NORETURN NOINLINE void OnResultAssertion(const char *file, int line, const char *func, const char *expr, Result result);
NORETURN NOINLINE void OnResultAssertion(Result result);
NORETURN NOINLINE void OnResultAbort(const char *file, int line, const char *func, const char *expr, Result result);
NORETURN NOINLINE void OnResultAbort(Result result);
} }
constexpr ALWAYS_INLINE Result::operator ResultSuccess() const { constexpr ALWAYS_INLINE Result::operator ResultSuccess() const {
if (!ResultSuccess::CanAccept(*this)) { if (!ResultSuccess::CanAccept(*this)) {
result::impl::OnResultAssertion(*this); result::impl::OnResultAbort(*this);
} }
return ResultSuccess(); return ResultSuccess();
} }
@ -149,7 +153,7 @@ namespace ams {
static_assert(Value != Base::SuccessValue, "Value != Base::SuccessValue"); static_assert(Value != Base::SuccessValue, "Value != Base::SuccessValue");
public: public:
constexpr operator Result() const { return MakeResult(Value); } constexpr operator Result() const { return MakeResult(Value); }
constexpr operator ResultSuccess() const { OnResultAssertion(Value); } constexpr operator ResultSuccess() const { OnResultAbort(Value); }
constexpr ALWAYS_INLINE bool IsSuccess() const { return false; } constexpr ALWAYS_INLINE bool IsSuccess() const { return false; }
constexpr ALWAYS_INLINE bool IsFailure() const { return !this->IsSuccess(); } constexpr ALWAYS_INLINE bool IsFailure() const { return !this->IsSuccess(); }
@ -216,18 +220,39 @@ namespace ams {
/// Evaluates an expression that returns a result, and returns the result if it would fail. /// Evaluates an expression that returns a result, and returns the result if it would fail.
#define R_TRY(res_expr) \ #define R_TRY(res_expr) \
({ \ ({ \
const auto _tmp_r_try_rc = res_expr; \ const auto _tmp_r_try_rc = (res_expr); \
if (R_FAILED(_tmp_r_try_rc)) { \ if (R_FAILED(_tmp_r_try_rc)) { \
return _tmp_r_try_rc; \ return _tmp_r_try_rc; \
} \ } \
}) })
/// Evaluates an expression that returns a result, and fatals the result if it would fail. #ifdef AMS_ENABLE_DEBUG_PRINT
#define AMS_CALL_ON_RESULT_ASSERTION_IMPL(cond, val) ::ams::result::impl::OnResultAssertion(__FILE__, __LINE__, __PRETTY_FUNCTION__, cond, val)
#define AMS_CALL_ON_RESULT_ABORT_IMPL(cond, val) ::ams::result::impl::OnResultAbort(__FILE__, __LINE__, __PRETTY_FUNCTION__, cond, val)
#else
#define AMS_CALL_ON_RESULT_ASSERTION_IMPL(cond, val) ::ams::result::impl::OnResultAssertion("", 0, "", "", val)
#define AMS_CALL_ON_RESULT_ABORT_IMPL(cond, val) ::ams::result::impl::OnResultAbort("", 0, "", "", val)
#endif
/// Evaluates an expression that returns a result, and asserts the result if it would fail.
#ifdef AMS_ENABLE_ASSERTIONS
#define R_ASSERT(res_expr) \ #define R_ASSERT(res_expr) \
({ \ ({ \
const auto _tmp_r_assert_rc = res_expr; \ const auto _tmp_r_assert_rc = (res_expr); \
if (R_FAILED(_tmp_r_assert_rc)) { \ if (AMS_UNLIKELY(R_FAILED(_tmp_r_assert_rc))) { \
::ams::result::impl::OnResultAssertion(_tmp_r_assert_rc); \ AMS_CALL_ON_RESULT_ASSERTION_IMPL(#res_expr, _tmp_r_assert_rc); \
} \
})
#else
#define R_ASSERT(res_expr) AMS_UNUSED((res_expr));
#endif
/// Evaluates an expression that returns a result, and aborts if the result would fail.
#define R_ABORT_UNLESS(res_expr) \
({ \
const auto _tmp_r_abort_rc = (res_expr); \
if (AMS_UNLIKELY(R_FAILED(_tmp_r_abort_rc))) { \
AMS_CALL_ON_RESULT_ABORT_IMPL(#res_expr, _tmp_r_abort_rc); \
} \ } \
}) })
@ -244,14 +269,14 @@ namespace ams {
#define R_TRY_CATCH(res_expr) \ #define R_TRY_CATCH(res_expr) \
({ \ ({ \
const auto R_CURRENT_RESULT = res_expr; \ const auto R_CURRENT_RESULT = (res_expr); \
if (R_FAILED(R_CURRENT_RESULT)) { \ if (R_FAILED(R_CURRENT_RESULT)) { \
if (false) if (false)
namespace ams::result::impl { namespace ams::result::impl {
template<typename... Rs> template<typename... Rs>
NX_CONSTEXPR bool AnyIncludes(Result result) { constexpr ALWAYS_INLINE bool AnyIncludes(Result result) {
return (Rs::Includes(result) || ...); return (Rs::Includes(result) || ...);
} }
@ -287,3 +312,11 @@ namespace ams::result::impl {
} \ } \
} \ } \
}) })
#define R_END_TRY_CATCH_WITH_ABORT_UNLESS \
else { \
R_ABORT_UNLESS(R_CURRENT_RESULT); \
} \
} \
})

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/results.hpp> #include <vapours/results.hpp>
#include <vapours/svc/svc_types.hpp> #include <vapours/svc/svc_types.hpp>

View file

@ -14,6 +14,9 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#pragma once #pragma once
#include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/svc/svc_types.hpp>
namespace ams::svc::codegen::impl { namespace ams::svc::codegen::impl {

View file

@ -15,6 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/results.hpp> #include <vapours/results.hpp>
namespace ams::svc { namespace ams::svc {

View file

@ -15,8 +15,8 @@
*/ */
#pragma once #pragma once
#include "svc_common.hpp" #include <vapours/svc/svc_common.hpp>
#include "svc_select_hardware_constants.hpp" #include <vapours/svc/svc_select_hardware_constants.hpp>
namespace ams::svc { namespace ams::svc {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <chrono> #include <chrono>
namespace ams { namespace ams {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include <vapours/defines.hpp> #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/util/util_alignment.hpp> #include <vapours/util/util_alignment.hpp>
#include <vapours/util/util_size.hpp> #include <vapours/util/util_size.hpp>

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,9 @@
*/ */
#pragma once #pragma once
#include "util_parent_of_member.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/util/util_parent_of_member.hpp>
namespace ams::util { namespace ams::util {

View file

@ -16,7 +16,9 @@
#pragma once #pragma once
#include <freebsd/sys/tree.h> #include <freebsd/sys/tree.h>
#include "util_parent_of_member.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
#include <vapours/util/util_parent_of_member.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,8 +15,9 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include "util_typed_storage.hpp" #include <vapours/assert.hpp>
#include <vapours/util/util_typed_storage.hpp>
namespace ams::util { namespace ams::util {

View file

@ -16,7 +16,8 @@
/* Scope guard logic lovingly taken from Andrei Alexandrescu's "Systemic Error Handling in C++" */ /* Scope guard logic lovingly taken from Andrei Alexandrescu's "Systemic Error Handling in C++" */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

View file

@ -15,7 +15,8 @@
*/ */
#pragma once #pragma once
#include "../defines.hpp" #include <vapours/common.hpp>
#include <vapours/assert.hpp>
namespace ams::util { namespace ams::util {

Some files were not shown because too many files have changed in this diff Show more