soc_core/add_memory_region: fix memory overlap detection

This commit is contained in:
Florent Kermarrec 2019-10-28 17:07:37 +01:00
parent 650df0ebc2
commit 4014fbffe1

View file

@ -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)