summaryrefslogtreecommitdiff
path: root/src/vhdl/sem_inst.ads
diff options
context:
space:
mode:
Diffstat (limited to 'src/vhdl/sem_inst.ads')
-rw-r--r--src/vhdl/sem_inst.ads26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/vhdl/sem_inst.ads b/src/vhdl/sem_inst.ads
new file mode 100644
index 0000000..da8cd5d
--- /dev/null
+++ b/src/vhdl/sem_inst.ads
@@ -0,0 +1,26 @@
+-- Package (and subprograms) instantiations
+
+-- When a package is instantiated, we need to 'duplicate' its declaration.
+-- This looks useless for analysis but it isn't: a type from a package
+-- instantiated twice declares two different types. Without duplication, we
+-- need to attach to each declaration its instance, which looks more expansive
+-- that duplicating the declaration.
+--
+-- Furthermore, for generic type interface, it looks a good idea to duplicate
+-- the body (macro expansion).
+--
+-- Duplicating is not trivial: internal links must be kept and external
+-- links preserved. A table is used to map nodes from the uninstantiated
+-- package to its duplicated node. Links from instantiated declaration to
+-- the original declaration are also stored in that table.
+
+with Iirs; use Iirs;
+
+package Sem_Inst is
+ -- Return the origin of node N, the node from which N was instantiated.
+ -- If N is not an instance, this function returns Null_Iir.
+ function Get_Origin (N : Iir) return Iir;
+
+ -- Create declaration chain and generic declarations for INST from PKG.
+ procedure Instantiate_Package_Declaration (Inst : Iir; Pkg : Iir);
+end Sem_Inst;