2019-12-13 09:21:43 +00:00
|
|
|
/*
|
2021-10-04 19:59:10 +00:00
|
|
|
* Copyright (c) Atmosphère-NX
|
2019-12-13 09:21:43 +00:00
|
|
|
*
|
|
|
|
* 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
|
2020-01-30 23:29:51 +00:00
|
|
|
#include <mesosphere/kern_common.hpp>
|
2020-02-05 22:07:51 +00:00
|
|
|
#include <mesosphere/kern_select_interrupt_name.hpp>
|
2019-12-13 09:21:43 +00:00
|
|
|
|
2020-01-29 22:26:24 +00:00
|
|
|
#if defined(ATMOSPHERE_ARCH_ARM64)
|
|
|
|
|
|
|
|
#include <mesosphere/arch/arm64/kern_k_interrupt_manager.hpp>
|
|
|
|
namespace ams::kern {
|
2020-02-15 02:22:55 +00:00
|
|
|
using ams::kern::arch::arm64::KInterruptManager;
|
2020-01-29 22:26:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#error "Unknown architecture for KInterruptManager"
|
2019-12-13 09:21:43 +00:00
|
|
|
|
2020-01-29 22:26:24 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
namespace ams::kern {
|
2019-12-13 09:21:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* Enable or disable interrupts for the lifetime of an object. */
|
|
|
|
class KScopedInterruptDisable {
|
|
|
|
NON_COPYABLE(KScopedInterruptDisable);
|
|
|
|
NON_MOVEABLE(KScopedInterruptDisable);
|
2020-01-29 22:26:24 +00:00
|
|
|
private:
|
2020-12-18 01:18:47 +00:00
|
|
|
u32 m_prev_intr_state;
|
2019-12-13 09:21:43 +00:00
|
|
|
public:
|
2021-10-27 22:00:07 +00:00
|
|
|
ALWAYS_INLINE KScopedInterruptDisable() : m_prev_intr_state(KInterruptManager::GetInterruptsEnabledStateAndDisableInterrupts()) { /* ... */ }
|
2020-12-18 01:18:47 +00:00
|
|
|
ALWAYS_INLINE ~KScopedInterruptDisable() { KInterruptManager::RestoreInterrupts(m_prev_intr_state); }
|
2019-12-13 09:21:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class KScopedInterruptEnable {
|
|
|
|
NON_COPYABLE(KScopedInterruptEnable);
|
|
|
|
NON_MOVEABLE(KScopedInterruptEnable);
|
2020-01-29 22:26:24 +00:00
|
|
|
private:
|
2020-12-18 01:18:47 +00:00
|
|
|
u32 m_prev_intr_state;
|
2019-12-13 09:21:43 +00:00
|
|
|
public:
|
2021-10-27 22:00:07 +00:00
|
|
|
ALWAYS_INLINE KScopedInterruptEnable() : m_prev_intr_state(KInterruptManager::GetInterruptsEnabledStateAndEnableInterrupts()) { /* ... */ }
|
2020-12-18 01:18:47 +00:00
|
|
|
ALWAYS_INLINE ~KScopedInterruptEnable() { KInterruptManager::RestoreInterrupts(m_prev_intr_state); }
|
2019-12-13 09:21:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|