mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-08 21:47:57 +00:00
kern: fix constant evaluation correctness, codegen tweak
This commit is contained in:
parent
8010290472
commit
0a11d341b7
2 changed files with 35 additions and 5 deletions
|
@ -312,7 +312,7 @@ namespace ams::kern {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr ALWAYS_INLINE KAutoObject *GetObjectImpl(ams::svc::Handle handle) const {
|
constexpr NOINLINE KAutoObject *GetObjectImpl(ams::svc::Handle handle) const {
|
||||||
MESOSPHERE_ASSERT_THIS();
|
MESOSPHERE_ASSERT_THIS();
|
||||||
|
|
||||||
/* Handles must not have reserved bits set. */
|
/* Handles must not have reserved bits set. */
|
||||||
|
|
|
@ -66,11 +66,41 @@ namespace ams::kern {
|
||||||
consteval operator KMemoryRegionType() const { return static_cast<KMemoryRegionType>(m_value); }
|
consteval operator KMemoryRegionType() const { return static_cast<KMemoryRegionType>(m_value); }
|
||||||
consteval ValueType GetValue() const { return m_value; }
|
consteval ValueType GetValue() const { return m_value; }
|
||||||
|
|
||||||
consteval const KMemoryRegionTypeValue &Finalize() { m_finalized = true; return *this; }
|
consteval const KMemoryRegionTypeValue Finalize() {
|
||||||
consteval const KMemoryRegionTypeValue &SetSparseOnly() { m_sparse_only = true; return *this; }
|
AMS_ASSUME(!m_finalized);
|
||||||
consteval const KMemoryRegionTypeValue &SetDenseOnly() { m_dense_only = true; return *this; }
|
|
||||||
|
|
||||||
consteval KMemoryRegionTypeValue &SetAttribute(KMemoryRegionAttr attr) { AMS_ASSUME(!m_finalized); m_value |= attr; return *this; }
|
KMemoryRegionTypeValue new_type = *this;
|
||||||
|
new_type.m_finalized = true;
|
||||||
|
return new_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
consteval const KMemoryRegionTypeValue SetSparseOnly() {
|
||||||
|
AMS_ASSUME(!m_finalized);
|
||||||
|
AMS_ASSUME(!m_sparse_only);
|
||||||
|
AMS_ASSUME(!m_dense_only);
|
||||||
|
|
||||||
|
KMemoryRegionTypeValue new_type = *this;
|
||||||
|
new_type.m_sparse_only = true;
|
||||||
|
return new_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
consteval const KMemoryRegionTypeValue SetDenseOnly() {
|
||||||
|
AMS_ASSUME(!m_finalized);
|
||||||
|
AMS_ASSUME(!m_sparse_only);
|
||||||
|
AMS_ASSUME(!m_dense_only);
|
||||||
|
|
||||||
|
KMemoryRegionTypeValue new_type = *this;
|
||||||
|
new_type.m_dense_only = true;
|
||||||
|
return new_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
consteval KMemoryRegionTypeValue SetAttribute(KMemoryRegionAttr attr) {
|
||||||
|
AMS_ASSUME(!m_finalized);
|
||||||
|
|
||||||
|
KMemoryRegionTypeValue new_type = *this;
|
||||||
|
new_type.m_value |= attr;
|
||||||
|
return new_type;
|
||||||
|
}
|
||||||
|
|
||||||
consteval KMemoryRegionTypeValue DeriveInitial(size_t i, size_t next = BITSIZEOF(ValueType)) const {
|
consteval KMemoryRegionTypeValue DeriveInitial(size_t i, size_t next = BITSIZEOF(ValueType)) const {
|
||||||
AMS_ASSUME(!m_finalized);
|
AMS_ASSUME(!m_finalized);
|
||||||
|
|
Loading…
Reference in a new issue