forked from ShuriZma/suyu
hle: kernel: KPriorityQueue: Various style fixes based on code review feedback.
This commit is contained in:
parent
4d3be1816c
commit
8fd921557f
|
@ -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 {
|
||||||
|
|
Loading…
Reference in New Issue