diff options
author | Johan Alfven <johan.alfven@arm.com> | 2023-02-07 13:01:03 +0100 |
---|---|---|
committer | Johan Alfven <johan.alfven@arm.com> | 2023-02-14 13:29:26 +0100 |
commit | 9070f0f1d9ee0fbf2cc3ee62a60f9b600bd62055 (patch) | |
tree | 01ad61e2a33c9b976de53656743a24369ccc8119 /ethosu/vela/nn_graph.py | |
parent | 33c01e68984bf455d3a1f00c7f43ab2a6bb75cbe (diff) | |
download | ethos-u-vela-9070f0f1d9ee0fbf2cc3ee62a60f9b600bd62055.tar.gz |
MLBEDSW-7316: Fix crash for networks with resource variables
- The problem was that networks with resource variables have
not been thought of. The major problem was the graph traversal
where these ops were not visited resulting in an empty subgraph
that resulted in the crash.
- Fixed the problem by attaching virtual tensors to the ops simulating
subgraph output. These tensors are only used to get the graph
traversal to work.
- Fixed serializing of attribute container and shared_name
- Fixed subgraph index for operator CallOnce
- All resource variable ops are pushed to the CPU
Change-Id: I815f9c81baf7a3fbb686e895980b462f58208b6e
Signed-off-by: Johan Alfven <johan.alfven@arm.com>
Diffstat (limited to 'ethosu/vela/nn_graph.py')
-rw-r--r-- | ethosu/vela/nn_graph.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/ethosu/vela/nn_graph.py b/ethosu/vela/nn_graph.py index 846632df..a43aac2a 100644 --- a/ethosu/vela/nn_graph.py +++ b/ethosu/vela/nn_graph.py @@ -149,7 +149,11 @@ class Subgraph: def __init__(self, name="<unnamed>", placement=PassPlacement.Cpu): self.output_tensors = [] self.input_tensors = [] - self.original_inputs = [] # Preserve the original input order + # Preserve the original input order + self.original_inputs = [] + # Attach virtual outputs to resource variables op + # in order to be able to traverse the graph correctly + self.virtual_outputs = [] self.passes = [] self.cascaded_passes = [] self.name = name |