mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Merge pull request #1410 from trabucayre/improve_connectors
Improve connectors
This commit is contained in:
commit
ea8ba57eab
1 changed files with 16 additions and 1 deletions
|
@ -132,6 +132,12 @@ def _resource_type(resource):
|
|||
class ConnectorManager:
|
||||
def __init__(self, connectors):
|
||||
self.connector_table = dict()
|
||||
self.add_connector(connectors)
|
||||
|
||||
def add_connector(self, connectors):
|
||||
if isinstance(connectors, tuple):
|
||||
connectors = [connectors]
|
||||
|
||||
for connector in connectors:
|
||||
cit = iter(connector)
|
||||
conn_name = next(cit)
|
||||
|
@ -162,7 +168,10 @@ class ConnectorManager:
|
|||
if pn.isdigit():
|
||||
pn = int(pn)
|
||||
|
||||
r.append(self.connector_table[conn][pn])
|
||||
conn_pn = self.connector_table[conn][pn]
|
||||
if ":" in conn_pn:
|
||||
conn_pn = self.resolve_identifiers([conn_pn])[0]
|
||||
r.append(conn_pn)
|
||||
else:
|
||||
r.append(identifier)
|
||||
|
||||
|
@ -193,6 +202,9 @@ class ConstraintManager:
|
|||
def add_extension(self, io):
|
||||
self.available.extend(io)
|
||||
|
||||
def add_connector(self, connectors):
|
||||
self.connector_manager.add_connector(connectors)
|
||||
|
||||
def request(self, name, number=None, loose=False):
|
||||
resource = _lookup(self.available, name, number, loose)
|
||||
if resource is None:
|
||||
|
@ -356,6 +368,9 @@ class GenericPlatform:
|
|||
def add_extension(self, *args, **kwargs):
|
||||
return self.constraint_manager.add_extension(*args, **kwargs)
|
||||
|
||||
def add_connector(self, *args, **kwargs):
|
||||
self.constraint_manager.add_connector(*args, **kwargs)
|
||||
|
||||
def finalize(self, fragment, *args, **kwargs):
|
||||
if self.finalized:
|
||||
raise ConstraintError("Already finalized")
|
||||
|
|
Loading…
Reference in a new issue