mirror of
https://github.com/Atmosphere-NX/Atmosphere.git
synced 2025-05-30 22:45:17 -04:00
sf: Change interface definition methodology (#1074)
* sf: Begin experimenting with new interface declaration format * sf: convert fs interfaces to new format * sf: finish conversion of libstrat to new definitions * sf: convert loader to new format * sf: convert spl to new format * sf: update ncm for new format * sf: convert pm to new format * sf: convert ro/sm to new format * sf: update fatal for new format * sf: support building dmnt under new scheme * sf: update ams.mitm for new format * sf: correct invocation def for pointer holder * fs: correct 10.x+ user bindings for Get*SpaceSize
This commit is contained in:
parent
94eb2195d3
commit
9fde97cfdd
190 changed files with 3220 additions and 3172 deletions
|
@ -18,41 +18,42 @@
|
|||
|
||||
namespace ams::psc {
|
||||
|
||||
class RemotePmModule final : public psc::sf::IPmModule {
|
||||
class RemotePmModule final {
|
||||
NON_COPYABLE(RemotePmModule);
|
||||
NON_MOVEABLE(RemotePmModule);
|
||||
private:
|
||||
::PscPmModule module;
|
||||
public:
|
||||
constexpr RemotePmModule(const ::PscPmModule &m) : module(m) { /* ... */ }
|
||||
virtual ~RemotePmModule() override {
|
||||
~RemotePmModule() {
|
||||
::pscPmModuleClose(std::addressof(this->module));
|
||||
}
|
||||
|
||||
virtual Result Initialize(ams::sf::OutCopyHandle out, psc::PmModuleId module_id, const ams::sf::InBuffer &child_list) override final {
|
||||
Result Initialize(ams::sf::OutCopyHandle out, psc::PmModuleId module_id, const ams::sf::InBuffer &child_list) {
|
||||
/* NOTE: This functionality is already implemented by the libnx command we use to instantiate the PscPmModule. */
|
||||
AMS_ABORT();
|
||||
}
|
||||
|
||||
virtual Result GetRequest(ams::sf::Out<PmState> out_state, ams::sf::Out<PmFlagSet> out_flags) override final {
|
||||
Result GetRequest(ams::sf::Out<PmState> out_state, ams::sf::Out<PmFlagSet> out_flags) {
|
||||
static_assert(sizeof(PmState) == sizeof(::PscPmState));
|
||||
static_assert(sizeof(PmFlagSet) == sizeof(u32));
|
||||
return ::pscPmModuleGetRequest(std::addressof(this->module), reinterpret_cast<::PscPmState *>(out_state.GetPointer()), reinterpret_cast<u32 *>(out_flags.GetPointer()));
|
||||
}
|
||||
|
||||
virtual Result Acknowledge() override final {
|
||||
Result Acknowledge() {
|
||||
/* NOTE: libnx does not separate acknowledge/acknowledgeEx. */
|
||||
return ::pscPmModuleAcknowledge(std::addressof(this->module), static_cast<::PscPmState>(0));
|
||||
}
|
||||
|
||||
virtual Result Finalize() override final {
|
||||
Result Finalize() {
|
||||
return ::pscPmModuleFinalize(std::addressof(this->module));
|
||||
}
|
||||
|
||||
virtual Result AcknowledgeEx(PmState state) override final {
|
||||
Result AcknowledgeEx(PmState state) {
|
||||
static_assert(sizeof(state) == sizeof(::PscPmState));
|
||||
return ::pscPmModuleAcknowledge(std::addressof(this->module), static_cast<::PscPmState>(state));
|
||||
}
|
||||
};
|
||||
static_assert(psc::sf::IsIPmModule<RemotePmModule>);
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue