mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-05 09:38:07 +02:00
nv50/ir: adjust overlapping logic to take fileIndex-relative offsets
If the fileIndex is different, that means they are in logically different spaces. However if there's also a relative offset, then they could end up pointing at the same spot again. Also add a note about potential for multiple buffers to overlap even if they're at different file indexes. However that's potentially lowered away by the point that this logic hits. Not known to fix any specific application or test. Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu> Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
This commit is contained in:
parent
55a8c11705
commit
7d56ae5eb2
1 changed files with 5 additions and 1 deletions
|
|
@ -2779,11 +2779,15 @@ MemoryOpt::Record::overlaps(const Instruction *ldst) const
|
|||
Record that;
|
||||
that.set(ldst);
|
||||
|
||||
if (this->fileIndex != that.fileIndex)
|
||||
// This assumes that images/buffers can't overlap. They can.
|
||||
// TODO: Plumb the restrict logic through, and only skip when it's a
|
||||
// restrict situation, or there can implicitly be no writes.
|
||||
if (this->fileIndex != that.fileIndex && this->rel[1] == that.rel[1])
|
||||
return false;
|
||||
|
||||
if (this->rel[0] || that.rel[0])
|
||||
return this->base == that.base;
|
||||
|
||||
return
|
||||
(this->offset < that.offset + that.size) &&
|
||||
(this->offset + this->size > that.offset);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue