mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
soc_core/add_memory_region: fix memory overlap detection
This commit is contained in:
parent
650df0ebc2
commit
4014fbffe1
1 changed files with 7 additions and 3 deletions
|
@ -374,11 +374,15 @@ class SoCCore(Module):
|
||||||
def add_memory_region(self, name, origin, length, io_region=False):
|
def add_memory_region(self, name, origin, length, io_region=False):
|
||||||
if io_region:
|
if io_region:
|
||||||
self.check_io_region(name, origin, length)
|
self.check_io_region(name, origin, length)
|
||||||
def in_this_region(addr):
|
def memory_overlap(o0, l0, o1, l1):
|
||||||
return addr >= origin and addr < origin + length
|
if o0 >= (o1 + l1):
|
||||||
|
return False
|
||||||
|
if o1 >= (o0 + l0):
|
||||||
|
return False
|
||||||
|
return True
|
||||||
for n, r in self.mem_regions.items():
|
for n, r in self.mem_regions.items():
|
||||||
r.length = 2**log2_int(r.length, False)
|
r.length = 2**log2_int(r.length, False)
|
||||||
if n == name or in_this_region(r.origin) or in_this_region(r.origin + r.length - 1):
|
if n == name or memory_overlap(o0=r.origin, l0=r.length, o1=origin, l1=length):
|
||||||
raise ValueError("Memory region conflict between {} and {}".format(n, name))
|
raise ValueError("Memory region conflict between {} and {}".format(n, name))
|
||||||
self.mem_regions[name] = SoCMemRegion(origin, length)
|
self.mem_regions[name] = SoCMemRegion(origin, length)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue