## SystemC Evolution Day Wrap-up and Next Steps





#### **Technical sessions**

- SystemC/TLM and Language Standards (C++11/14)
- TLM Standard for Serial Interfaces
- Multi-Threaded SystemC and External Interfaces
- UVM-SystemC & Config., Control and Inspection





### SystemC/TLM and Language Standards (C++11/14)

- Using Modern C++ in SystemC Modeling
  - Significant producitivity gain seen in modeling domain
- C++ standard in IEEE 1666-20XX
  - Base next version of standard on C++14
  - compatibility not seen too critical, as standard moves slowly anyway
- C++14 SystemC API extensions should focus on enabling designer productivity
  - Detailed feature discussions in extended minutes
  - Incremental addition of new features, without immediate compatibility break on old compilers





### **TLM Standard for Serial Interfaces**

- Summary
  - ~20 attendees
  - Several approaches
    - TLM-2 using OSI layers to define abstraction levels.
      - Having a blueprint that should be followed by each protocol implementation.
      - Minimize GP, use extensions for protocol specific details.
    - Bottom-up implement dedicated protocols without the need for a generic umbrella.
  - Many questions e.g.
    - Router model needed required for all protocols?
    - Which limitations are acceptable?
    - Different abstraction level due to orthogonal use cases.
      - Multiple timing points
- Next Steps
  - Address questions in TLMWG
  - Source code examples to discuss more concrete issues



#### Multi-Threaded SystemC and External Interfaces

- Two Views on Parallelism
  - Fine-grained automatic
    - Not really discussed in the session
  - Coarse-grained manual
    - Controlled by the modeler
- The proposed synch mechanism is a good thing and should be moved on to the standards working group
- Exact rules for how to sync simulator time varies with the use case, no consistent picture emerged in the discussions





#### **Two Views on Parallelism**

- Fine-grained automatic
  - Not really discussed in the session
- Coarse-grained manual
  - Controlled by the modeler

© Accellera Systems Initiative

- The proposed synch mechanism is a good thing and should be moved on to the standards working group
- Exact rules for how to sync simulator time varies with the use case, no consistent picture emerged in the discussions







6

#### **Coarse-Grained Manual**







#### **Coarse-Grained Manual II**

Manually set up threads on top of a kernel, implement thread safety in some way. Implement communication in a thread-safe way.















#### UVM-SystemC & Config., Control and Inspection

- SystemC Configuration Use Models
  - Combine or separate UVM-SC and CCI approach
  - Use model: Tool/model interface and/or tool/testbench interface
- Register interface

© Accellera Systems Initiative

- uvm\_reg versus sci\_reg: combine or separate
- Use model: connect UVM-SC backdoor to a HDL or SystemC objection via the HDL path





## Main Points (Configuration)

- UVM primarily aimed at testbench (e.g. blackbox testing)
  - Type agnostic, simple set & get, global database, DUT-nonintrusive
- CCI primarily aimed at IP model configuration
  - More sophisticated (e.g. broker layer, access controls, ...)
- Are both configuration developments too far to cancel one of them?
  - Can one be based on the other?
  - Both access philosophies needed to fulfil requirements
- Where/how should seed values be configured? (e.g. variation simulation)
  - Some CCI-parameter control from UVM-SC may be necessary





### Main Points (Register interface)

- Register API available from Cadence & ST
  - Layer between model and tool





#### Next Steps

- Access of DUT configuration from the UVM-Testbench (CCI)
- Features/Function Matrix of UVM-SC and CCI config methods/APIs needed to prove if implementation can be based on each other (CCI&VWG)





#### Join A Working Group And Contribute!



SYSTEMS INITIATIVE

Slide 14

MAY 3, 2016 | MUNICH | GERMANY

#### SystemC Community

- Online at <a href="http://accellera.org/community/systemc">http://accellera.org/community/systemc</a> ullet
- Community forums, upload area for contributions, SystemC news

#### Overview

| SystemC       |                                                            |       |
|---------------|------------------------------------------------------------|-------|
| About SystemC | SystemC<br>SystemC addresses the need                      | C     |
| SystemC TLM   |                                                            |       |
| SystemC AMS   |                                                            |       |
| SystemC CCI   | for a system design and verification language that         | • Dov |
| UVM           | spans hardware and software.                               | • For |
|               | It is a language built in                                  | • Upl |
|               | standard C++ by extending the language with a set of class | • Wo  |
|               | libraries created for design and verification. Users       | 0     |
|               | worldwide are applying SystemC to system-level modeling,   | 0     |
|               | abstract analog/mixed-signal modeling, architectural       | 0     |
|               | exploration, performance modeling, software development,   | 0     |
|               | functional verification, and high-level synthesis.         | 0     |
|               |                                                            |       |



Home » Community » SystemC

#### OMMUNITY LINKS

- wnload SystemC
- rums
- oads
- rking Groups
  - Language
  - AMS
  - TLM
  - CCI
  - Synthesis
  - Verification



### Advancing Standards Together

- Share your experiences
  - Visit <u>www.accellera.org</u> and register to post on community forums at <u>forums.accellera.org</u>
- Show your support
  - Record your adoption of standards
- Become an Accellera member
  - Join working groups
- Join face-to-face meetings





### Dinner

- Taj am Campeon <u>http://www.taj-am-campeon.de</u>
- 19:30 21:30
- Building 10 –
  here on campus
- Please announce your participation until 11:00!
- (Food/drinks not included – self-paid)







#### Thank you!



#### SYSTEMS INITIATIVE<sup>™</sup>

**Accellera Global Sponsors** 

# ARM cādence (intel GMBABS Synopsys



© Accellera Systems Initiative

