#include nx::InteruptEntry::InteruptEntry() : mCap(kCapId), mInterupt{0,0} { } nx::InteruptEntry::InteruptEntry(const KernelCapability & kernel_cap) : mCap(kCapId), mInterupt{ 0,0 } { setKernelCapability(kernel_cap); } nx::InteruptEntry::InteruptEntry(uint32_t interupt0, uint32_t interupt1) : mCap(kCapId), mInterupt{ 0,0 } { setInterupt(0, interupt0); setInterupt(1, interupt1); } void nx::InteruptEntry::operator=(const InteruptEntry& other) { mInterupt[0] = other.mInterupt[0]; mInterupt[1] = other.mInterupt[1]; updateCapField(); } bool nx::InteruptEntry::operator==(const InteruptEntry& other) const { return (mInterupt[0] == other.mInterupt[0]) \ && (mInterupt[1] == other.mInterupt[1]); } bool nx::InteruptEntry::operator!=(const InteruptEntry& other) const { return !(*this == other); } const nx::KernelCapability & nx::InteruptEntry::getKernelCapability() const { return mCap; } void nx::InteruptEntry::setKernelCapability(const KernelCapability & kernel_cap) { if (kernel_cap.getType() != kCapId) { throw fnd::Exception(kModuleName, "KernelCapability is not type 'EnableInterupts'"); } mCap = kernel_cap; processCapField(); } uint32_t nx::InteruptEntry::operator[](size_t index) const { return getInterupt(index); } uint32_t nx::InteruptEntry::getInterupt(size_t index) const { return mInterupt[index % kInteruptNum]; } void nx::InteruptEntry::setInterupt(size_t index, uint32_t interupt) { if (interupt > kInteruptMax) { throw fnd::Exception(kModuleName, "Illegal interupt value."); } mInterupt[index % kInteruptNum] = interupt; updateCapField(); }