diff options
| -rw-r--r-- | src/core/hle/kernel/address_arbiter.cpp | 53 | ||||
| -rw-r--r-- | src/core/hle/kernel/address_arbiter.h | 2 | ||||
| -rw-r--r-- | src/core/hle/kernel/thread.cpp | 4 | ||||
| -rw-r--r-- | src/core/hle/service/bcat/backend/backend.cpp | 4 | ||||
| -rw-r--r-- | src/video_core/engines/maxwell_3d.h | 7 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_rasterizer.cpp | 1 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_state.cpp | 1 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_state.h | 1 | 
8 files changed, 39 insertions, 34 deletions
| diff --git a/src/core/hle/kernel/address_arbiter.cpp b/src/core/hle/kernel/address_arbiter.cpp index 2ea3dcb61..8475b698c 100644 --- a/src/core/hle/kernel/address_arbiter.cpp +++ b/src/core/hle/kernel/address_arbiter.cpp @@ -201,42 +201,39 @@ void AddressArbiter::HandleWakeupThread(std::shared_ptr<Thread> thread) {  void AddressArbiter::InsertThread(std::shared_ptr<Thread> thread) {      const VAddr arb_addr = thread->GetArbiterWaitAddress();      std::list<std::shared_ptr<Thread>>& thread_list = arb_threads[arb_addr]; -    auto it = thread_list.begin(); -    while (it != thread_list.end()) { -        const std::shared_ptr<Thread>& current_thread = *it; -        if (current_thread->GetPriority() >= thread->GetPriority()) { -            thread_list.insert(it, thread); -            return; -        } -        ++it; + +    const auto iter = +        std::find_if(thread_list.cbegin(), thread_list.cend(), [&thread](const auto& entry) { +            return entry->GetPriority() >= thread->GetPriority(); +        }); + +    if (iter == thread_list.cend()) { +        thread_list.push_back(std::move(thread)); +    } else { +        thread_list.insert(iter, std::move(thread));      } -    thread_list.push_back(std::move(thread));  }  void AddressArbiter::RemoveThread(std::shared_ptr<Thread> thread) {      const VAddr arb_addr = thread->GetArbiterWaitAddress();      std::list<std::shared_ptr<Thread>>& thread_list = arb_threads[arb_addr]; -    auto it = thread_list.begin(); -    while (it != thread_list.end()) { -        const std::shared_ptr<Thread>& current_thread = *it; -        if (current_thread.get() == thread.get()) { -            thread_list.erase(it); -            return; -        } -        ++it; -    } -    UNREACHABLE(); + +    const auto iter = std::find_if(thread_list.cbegin(), thread_list.cend(), +                                   [&thread](const auto& entry) { return thread == entry; }); + +    ASSERT(iter != thread_list.cend()); + +    thread_list.erase(iter);  } -std::vector<std::shared_ptr<Thread>> AddressArbiter::GetThreadsWaitingOnAddress(VAddr address) { -    std::vector<std::shared_ptr<Thread>> result; -    std::list<std::shared_ptr<Thread>>& thread_list = arb_threads[address]; -    auto it = thread_list.begin(); -    while (it != thread_list.end()) { -        std::shared_ptr<Thread> current_thread = *it; -        result.push_back(std::move(current_thread)); -        ++it; +std::vector<std::shared_ptr<Thread>> AddressArbiter::GetThreadsWaitingOnAddress( +    VAddr address) const { +    const auto iter = arb_threads.find(address); +    if (iter == arb_threads.cend()) { +        return {};      } -    return result; + +    const std::list<std::shared_ptr<Thread>>& thread_list = iter->second; +    return {thread_list.cbegin(), thread_list.cend()};  }  } // namespace Kernel diff --git a/src/core/hle/kernel/address_arbiter.h b/src/core/hle/kernel/address_arbiter.h index 386983e54..f958eee5a 100644 --- a/src/core/hle/kernel/address_arbiter.h +++ b/src/core/hle/kernel/address_arbiter.h @@ -86,7 +86,7 @@ private:      void RemoveThread(std::shared_ptr<Thread> thread);      // Gets the threads waiting on an address. -    std::vector<std::shared_ptr<Thread>> GetThreadsWaitingOnAddress(VAddr address); +    std::vector<std::shared_ptr<Thread>> GetThreadsWaitingOnAddress(VAddr address) const;      /// List of threads waiting for a address arbiter      std::unordered_map<VAddr, std::list<std::shared_ptr<Thread>>> arb_threads; diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp index e965b5b04..ad464e03b 100644 --- a/src/core/hle/kernel/thread.cpp +++ b/src/core/hle/kernel/thread.cpp @@ -474,7 +474,7 @@ void Thread::AdjustSchedulingOnPriority(u32 old_priority) {      if (GetSchedulingStatus() != ThreadSchedStatus::Runnable) {          return;      } -    auto& scheduler = Core::System::GetInstance().GlobalScheduler(); +    auto& scheduler = kernel.GlobalScheduler();      if (processor_id >= 0) {          scheduler.Unschedule(old_priority, static_cast<u32>(processor_id), this);      } @@ -506,7 +506,7 @@ void Thread::AdjustSchedulingOnPriority(u32 old_priority) {  }  void Thread::AdjustSchedulingOnAffinity(u64 old_affinity_mask, s32 old_core) { -    auto& scheduler = Core::System::GetInstance().GlobalScheduler(); +    auto& scheduler = kernel.GlobalScheduler();      if (GetSchedulingStatus() != ThreadSchedStatus::Runnable ||          current_priority >= THREADPRIO_COUNT) {          return; diff --git a/src/core/hle/service/bcat/backend/backend.cpp b/src/core/hle/service/bcat/backend/backend.cpp index 6f5ea095a..def3410cc 100644 --- a/src/core/hle/service/bcat/backend/backend.cpp +++ b/src/core/hle/service/bcat/backend/backend.cpp @@ -117,13 +117,13 @@ bool NullBackend::SynchronizeDirectory(TitleIDVersion title, std::string name,  }  bool NullBackend::Clear(u64 title_id) { -    LOG_DEBUG(Service_BCAT, "called, title_id={:016X}"); +    LOG_DEBUG(Service_BCAT, "called, title_id={:016X}", title_id);      return true;  }  void NullBackend::SetPassphrase(u64 title_id, const Passphrase& passphrase) { -    LOG_DEBUG(Service_BCAT, "called, title_id={:016X}, passphrase = {}", title_id, +    LOG_DEBUG(Service_BCAT, "called, title_id={:016X}, passphrase={}", title_id,                Common::HexToString(passphrase));  } diff --git a/src/video_core/engines/maxwell_3d.h b/src/video_core/engines/maxwell_3d.h index 78e055765..0a2af54e5 100644 --- a/src/video_core/engines/maxwell_3d.h +++ b/src/video_core/engines/maxwell_3d.h @@ -861,7 +861,11 @@ public:                  float point_size; -                INSERT_UNION_PADDING_WORDS(0x7); +                INSERT_UNION_PADDING_WORDS(0x1); + +                u32 point_sprite_enable; + +                INSERT_UNION_PADDING_WORDS(0x5);                  u32 zeta_enable; @@ -1496,6 +1500,7 @@ ASSERT_REG_POSITION(vb_element_base, 0x50D);  ASSERT_REG_POSITION(vb_base_instance, 0x50E);  ASSERT_REG_POSITION(clip_distance_enabled, 0x544);  ASSERT_REG_POSITION(point_size, 0x546); +ASSERT_REG_POSITION(point_sprite_enable, 0x548);  ASSERT_REG_POSITION(zeta_enable, 0x54E);  ASSERT_REG_POSITION(multisample_control, 0x54F);  ASSERT_REG_POSITION(condition, 0x554); diff --git a/src/video_core/renderer_opengl/gl_rasterizer.cpp b/src/video_core/renderer_opengl/gl_rasterizer.cpp index 46a7433ea..b0eb14c8b 100644 --- a/src/video_core/renderer_opengl/gl_rasterizer.cpp +++ b/src/video_core/renderer_opengl/gl_rasterizer.cpp @@ -1220,6 +1220,7 @@ void RasterizerOpenGL::SyncPointState() {      // Limit the point size to 1 since nouveau sometimes sets a point size of 0 (and that's invalid      // in OpenGL).      state.point.program_control = regs.vp_point_size.enable != 0; +    state.point.sprite = regs.point_sprite_enable != 0;      state.point.size = std::max(1.0f, regs.point_size);  } diff --git a/src/video_core/renderer_opengl/gl_state.cpp b/src/video_core/renderer_opengl/gl_state.cpp index cc185e9e1..ab1f7983c 100644 --- a/src/video_core/renderer_opengl/gl_state.cpp +++ b/src/video_core/renderer_opengl/gl_state.cpp @@ -128,6 +128,7 @@ void OpenGLState::ApplyClipDistances() {  void OpenGLState::ApplyPointSize() {      Enable(GL_PROGRAM_POINT_SIZE, cur_state.point.program_control, point.program_control); +    Enable(GL_POINT_SPRITE, cur_state.point.sprite, point.sprite);      if (UpdateValue(cur_state.point.size, point.size)) {          glPointSize(point.size);      } diff --git a/src/video_core/renderer_opengl/gl_state.h b/src/video_core/renderer_opengl/gl_state.h index 678e5cd89..4953eeda2 100644 --- a/src/video_core/renderer_opengl/gl_state.h +++ b/src/video_core/renderer_opengl/gl_state.h @@ -132,6 +132,7 @@ public:      struct {          bool program_control = false; // GL_PROGRAM_POINT_SIZE +        bool sprite = false;          // GL_POINT_SPRITE          GLfloat size = 1.0f;          // GL_POINT_SIZE      } point; | 
