mirror of
https://github.com/skyline-emu/skyline.git
synced 2024-12-24 03:41:52 +01:00
Store delegate attached state within the delegate itself
Avoids a costly map lookup for every AttachBuffer call, this was a serious bottleneck in SMO
This commit is contained in:
parent
0268e1d5a0
commit
70eec5a414
@ -100,6 +100,7 @@ namespace skyline::gpu {
|
|||||||
struct BufferDelegate {
|
struct BufferDelegate {
|
||||||
LockableSharedPtr<Buffer> buffer;
|
LockableSharedPtr<Buffer> buffer;
|
||||||
const Buffer::BufferViewStorage *view;
|
const Buffer::BufferViewStorage *view;
|
||||||
|
bool attached{};
|
||||||
std::function<void(const BufferViewStorage &, const std::shared_ptr<Buffer> &)> usageCallback;
|
std::function<void(const BufferViewStorage &, const std::shared_ptr<Buffer> &)> usageCallback;
|
||||||
std::list<BufferDelegate *>::iterator iterator;
|
std::list<BufferDelegate *>::iterator iterator;
|
||||||
|
|
||||||
|
@ -137,9 +137,11 @@ namespace skyline::gpu::interconnect {
|
|||||||
if (didLock)
|
if (didLock)
|
||||||
attachedBuffers.emplace_back(view->buffer);
|
attachedBuffers.emplace_back(view->buffer);
|
||||||
|
|
||||||
if (!attachedBufferDelegates.contains(view.bufferDelegate))
|
if (view.bufferDelegate->attached)
|
||||||
attachedBufferDelegates.emplace(view.bufferDelegate);
|
return didLock;
|
||||||
|
|
||||||
|
attachedBufferDelegates.emplace_back(view.bufferDelegate);
|
||||||
|
view.bufferDelegate->attached = true;
|
||||||
return didLock;
|
return didLock;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,8 +156,11 @@ namespace skyline::gpu::interconnect {
|
|||||||
lock.Release(); // The executor will handle unlocking the lock so it doesn't need to be handled here
|
lock.Release(); // The executor will handle unlocking the lock so it doesn't need to be handled here
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!attachedBufferDelegates.contains(view.bufferDelegate))
|
if (view.bufferDelegate->attached)
|
||||||
attachedBufferDelegates.emplace(view.bufferDelegate);
|
return;
|
||||||
|
|
||||||
|
attachedBufferDelegates.emplace_back(view.bufferDelegate);
|
||||||
|
view.bufferDelegate->attached = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CommandExecutor::AttachLockedBuffer(std::shared_ptr<Buffer> buffer, ContextLock<Buffer> &&lock) {
|
void CommandExecutor::AttachLockedBuffer(std::shared_ptr<Buffer> buffer, ContextLock<Buffer> &&lock) {
|
||||||
@ -320,6 +325,7 @@ namespace skyline::gpu::interconnect {
|
|||||||
|
|
||||||
for (const auto &delegate : attachedBufferDelegates) {
|
for (const auto &delegate : attachedBufferDelegates) {
|
||||||
delegate->usageCallback = nullptr;
|
delegate->usageCallback = nullptr;
|
||||||
|
delegate->attached = false;
|
||||||
delegate->view->megaBufferAllocation = {};
|
delegate->view->megaBufferAllocation = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ namespace skyline::gpu::interconnect {
|
|||||||
std::vector<LockedBuffer> attachedBuffers; //!< All textures that are attached to the current execution
|
std::vector<LockedBuffer> attachedBuffers; //!< All textures that are attached to the current execution
|
||||||
|
|
||||||
using SharedBufferDelegate = std::shared_ptr<Buffer::BufferDelegate>;
|
using SharedBufferDelegate = std::shared_ptr<Buffer::BufferDelegate>;
|
||||||
std::unordered_set<SharedBufferDelegate> attachedBufferDelegates; //!< All buffers that are attached to the current execution
|
std::vector<SharedBufferDelegate> attachedBufferDelegates; //!< All buffers that are attached to the current execution
|
||||||
|
|
||||||
std::vector<TextureView *> lastSubpassAttachments; //!< The storage backing for attachments used in the last subpass
|
std::vector<TextureView *> lastSubpassAttachments; //!< The storage backing for attachments used in the last subpass
|
||||||
span<TextureView *> lastSubpassInputAttachments; //!< The set of input attachments used in the last subpass
|
span<TextureView *> lastSubpassInputAttachments; //!< The set of input attachments used in the last subpass
|
||||||
|
Loading…
Reference in New Issue
Block a user