forked from ShuriZma/suyu
1
0
Fork 0

hle: kernel: KPriorityQueue: Various style fixes based on code review feedback.

This commit is contained in:
bunnei 2020-12-04 23:57:18 -08:00
parent 4d3be1816c
commit 8fd921557f
1 changed files with 36 additions and 29 deletions

View File

@ -7,6 +7,8 @@
#pragma once #pragma once
#include <array>
#include "common/assert.h" #include "common/assert.h"
#include "common/bit_set.h" #include "common/bit_set.h"
#include "common/bit_util.h" #include "common/bit_util.h"
@ -17,7 +19,7 @@ namespace Kernel {
class Thread; class Thread;
template <typename T> template <typename T>
concept KPriorityQueueAffinityMask = !std::is_reference<T>::value && requires(T & t) { concept KPriorityQueueAffinityMask = !std::is_reference_v<T> && requires(T & t) {
{ t.GetAffinityMask() } { t.GetAffinityMask() }
->std::convertible_to<u64>; ->std::convertible_to<u64>;
{t.SetAffinityMask(std::declval<u64>())}; {t.SetAffinityMask(std::declval<u64>())};
@ -29,7 +31,7 @@ concept KPriorityQueueAffinityMask = !std::is_reference<T>::value && requires(T
}; };
template <typename T> template <typename T>
concept KPriorityQueueMember = !std::is_reference<T>::value && requires(T & t) { concept KPriorityQueueMember = !std::is_reference_v<T> && requires(T & t) {
{typename T::QueueEntry()}; {typename T::QueueEntry()};
{(typename T::QueueEntry()).Initialize()}; {(typename T::QueueEntry()).Initialize()};
{(typename T::QueueEntry()).SetPrev(std::addressof(t))}; {(typename T::QueueEntry()).SetPrev(std::addressof(t))};
@ -54,8 +56,8 @@ concept KPriorityQueueMember = !std::is_reference<T>::value && requires(T & t) {
template <typename Member, size_t _NumCores, int LowestPriority, int HighestPriority> template <typename Member, size_t _NumCores, int LowestPriority, int HighestPriority>
requires KPriorityQueueMember<Member> class KPriorityQueue { requires KPriorityQueueMember<Member> class KPriorityQueue {
public: public:
using AffinityMaskType = typename std::remove_cv<typename std::remove_reference<decltype( using AffinityMaskType = typename std::remove_cv_t<
std::declval<Member>().GetAffinityMask())>::type>::type; typename std::remove_reference<decltype(std::declval<Member>().GetAffinityMask())>::type>;
static_assert(LowestPriority >= 0); static_assert(LowestPriority >= 0);
static_assert(HighestPriority >= 0); static_assert(HighestPriority >= 0);
@ -77,12 +79,12 @@ private:
public: public:
class KPerCoreQueue { class KPerCoreQueue {
private: private:
Entry root[NumCores]; std::array<Entry, NumCores> root{};
public: public:
constexpr KPerCoreQueue() : root() { constexpr KPerCoreQueue() {
for (size_t i = 0; i < NumCores; i++) { for (auto& per_core_root : root) {
this->root[i].Initialize(); per_core_root.Initialize();
} }
} }
@ -101,7 +103,7 @@ public:
tail_entry.SetNext(member); tail_entry.SetNext(member);
this->root[core].SetPrev(member); this->root[core].SetPrev(member);
return (tail == nullptr); return tail == nullptr;
} }
constexpr bool PushFront(s32 core, Member* member) { constexpr bool PushFront(s32 core, Member* member) {
@ -147,45 +149,47 @@ public:
}; };
class KPriorityQueueImpl { class KPriorityQueueImpl {
private:
KPerCoreQueue queues[NumPriority];
Common::BitSet64<NumPriority> available_priorities[NumCores];
public: public:
constexpr KPriorityQueueImpl() : queues(), available_priorities() {} constexpr KPriorityQueueImpl() = default;
constexpr void PushBack(s32 priority, s32 core, Member* member) { constexpr void PushBack(s32 priority, s32 core, Member* member) {
ASSERT(IsValidCore(core)); ASSERT(IsValidCore(core));
ASSERT(IsValidPriority(priority)); ASSERT(IsValidPriority(priority));
if (priority <= LowestPriority) { if (priority > LowestPriority) {
return;
}
if (this->queues[priority].PushBack(core, member)) { if (this->queues[priority].PushBack(core, member)) {
this->available_priorities[core].SetBit(priority); this->available_priorities[core].SetBit(priority);
} }
} }
}
constexpr void PushFront(s32 priority, s32 core, Member* member) { constexpr void PushFront(s32 priority, s32 core, Member* member) {
ASSERT(IsValidCore(core)); ASSERT(IsValidCore(core));
ASSERT(IsValidPriority(priority)); ASSERT(IsValidPriority(priority));
if (priority <= LowestPriority) { if (priority > LowestPriority) {
return;
}
if (this->queues[priority].PushFront(core, member)) { if (this->queues[priority].PushFront(core, member)) {
this->available_priorities[core].SetBit(priority); this->available_priorities[core].SetBit(priority);
} }
} }
}
constexpr void Remove(s32 priority, s32 core, Member* member) { constexpr void Remove(s32 priority, s32 core, Member* member) {
ASSERT(IsValidCore(core)); ASSERT(IsValidCore(core));
ASSERT(IsValidPriority(priority)); ASSERT(IsValidPriority(priority));
if (priority <= LowestPriority) { if (priority > LowestPriority) {
return;
}
if (this->queues[priority].Remove(core, member)) { if (this->queues[priority].Remove(core, member)) {
this->available_priorities[core].ClearBit(priority); this->available_priorities[core].ClearBit(priority);
} }
} }
}
constexpr Member* GetFront(s32 core) const { constexpr Member* GetFront(s32 core) const {
ASSERT(IsValidCore(core)); ASSERT(IsValidCore(core));
@ -246,6 +250,10 @@ public:
return nullptr; return nullptr;
} }
} }
private:
std::array<KPerCoreQueue, NumPriority> queues{};
std::array<Common::BitSet64<NumPriority>, NumCores> available_priorities{};
}; };
private: private:
@ -254,7 +262,7 @@ private:
private: private:
constexpr void ClearAffinityBit(u64& affinity, s32 core) { constexpr void ClearAffinityBit(u64& affinity, s32 core) {
affinity &= ~(u64(1ul) << core); affinity &= ~(u64(1) << core);
} }
constexpr s32 GetNextCore(u64& affinity) { constexpr s32 GetNextCore(u64& affinity) {
@ -313,8 +321,7 @@ private:
} }
public: public:
constexpr KPriorityQueue() : scheduled_queue(), suggested_queue() { // ... constexpr KPriorityQueue() = default;
}
// Getters. // Getters.
constexpr Member* GetScheduledFront(s32 core) const { constexpr Member* GetScheduledFront(s32 core) const {