Comments (3)
from systemrdl-compiler.
@PRWald is correct. The example shown in the spec is a little misleading since they do not properly instantiate the regfile declared as example
. Declaring the regfile definition only makes the type available in the local namespace. Since the example does not create an instance of the component, it does not exist, and ends up violating one of the semantic checks (components cannot be empty)
A corrected example would create an instance of example
as shown here:
addrmap top {
regfile example {
reg some_reg { field {} a; };
some_reg a @0x0;
some_reg b @0x4;
some_reg c;
some_reg d @0x10;
};
example example_inst @ 0x0;
};
I already have a running list of typos/oversights the RDL spec authors missed here: https://github.com/SystemRDL/systemrdl-compiler/blob/master/docs/implementation_notes/systemrdl_spec_issues.md
I'll add this one to the list.
from systemrdl-compiler.
Many thanks for the help and appreciate it. The code now works beautifully. Amykyta3, thanks for the errata link.
from systemrdl-compiler.
Related Issues (20)
- regfile inside addrmap does not compile HOT 1
- Cannot alias registers with we = true HOT 2
- Add ability to inject define macros into preprocessor
- Empty addrmap causes compiler to crash HOT 4
- Software-writable field spanning multiple words should cause error message (accesswidth/regwidth problem) HOT 1
- User defined property default for array type causes exception HOT 2
- [BUG] Parameter internal cleanup after first elaboration HOT 1
- Add support for assigning references in importer API
- Unintended `external` applied to `addrmap` instance HOT 3
- missing parameterization in the component hierarchy HOT 13
- Add method to generate a globally scoped type name to Node API HOT 1
- if struct is not fully defined, compiler crashes, it should point the line with to the error in the SystemRDL file HOT 2
- detecting name collisions during path serialization HOT 1
- Allow Elaboration without addrmap HOT 1
- Set abbreviated Node.type_name for long parameterized types HOT 1
- [FEATURE] property_src_ref needed for UserEnum and UserEnumMember
- Describe how addressing is impacted by ispresent in docs HOT 2
- `define for value replacement does not work HOT 2
- Compatibility between UDP `default` property and `UDPDefinition.default_assignment` HOT 4
- [BUG] [QUESTION] - Importer API support for signals HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from systemrdl-compiler.