

# Using Portable Stimulus to Verify an ARMv8 Sub-System SoC Integration

### Mike Baird, Willamette HDL

Aileen Honess, Breker Verification Systems







# Agenda

- Brief Introduction to PSS Aileen & Mike
- PSS modeling concepts Mike
- Overview of key PSS constructs Mike
- ARMv8 integration verification Aileen





## Why Waste Your Life Writing and Debugging Tests?

### UVM

Laborious concurrent sequence, scoreboard and coverage authoring, limited reuse

### SoC

Time-consuming, manual C tests targeting multicore platforms with many corner-cases

### Silicon

Complex diagnostic patterns with no link to verification, limited visibility







## Accellera Portable Stimulus Standard



Accellera Sponsored Portable Stimulus Working Group

Proposed Portable Stimulus Specification (Courtesy: Accellera Systems Initiative)

- Abstract, specification-driven testing
- Designed to be portable across:
  - Verification process phases
  - Verification platforms
  - Engineering groups
- The real win:
  - Eliminate UVM painful coding
  - Create intricate SDV corner cases
  - Automate silicon diagnostics
- PSS 1.0 powerful... but the tools make the difference!





## **PSS Concept: Flight Booking Example**

### **Traditional**



Contact lots of airlines for lots of flights

#### Is a bit like





### Modern



Morning (5:00am - 11:59am)

Afternoon (12:00pm - 5:59pm)



Details & baggage fees 👻



# **PSS Language Flavors**

- Two "flavors" or different syntax for PSS
  - Domain Specific Language (DSL) syntax
    - SystemVerilog like syntax
  - C++ using a C++ class library that is semantically equivalent to the DSL
- Today
  - PSS language explained using DSL
  - ARMv8 verification using C++





## Test Scenarios and the Scenario Space

- Test scenario (or scenario)
  - High-level documentation of a use case
    - "Tells" a story
      - "Capture an image, manipulate it with a photo processor and save it to memory"
      - "Capture audio and transmit it out the modem"
  - Performed to ensure end-to-end functionality
    - Looks at the system as a whole not just individual parts
- Test scenarios are derived from "user stories"
- The *scenario space* encompasses the possible test scenarios or use cases for a particular system







## **PSS Scenario Model**

- PSS language is used to model the the scenario space of a system
  - AKA a PSS scenario model
- Tools can "process" the PSS language scenario model and represent it in a graph-based scenario model
  - Tool solves for one or multiple test scenarios from this model
    - Test case(s) are generated for a target test environment
- It can be useful to think of a PSS scenario model as an "abstract" layer or model or on top of an underlying test layer or model
  - Underlying layer:
    - UVM tests/model
    - "C" based tests/model







# What then is a PSS Scenario Model?

- PSS models the scenario space in terms of
  - Resources
    - What is available to accomplish scenarios
    - CPU, DMA, Encrypt/decrypt, Graphics processor, camera etc.
  - Actions
    - Behaviors of a scenario
    - Encrypt/decrypt, transmit/receive, image capture, dma transfer etc.
  - Data and control flows
    - Information flow in the scenario
    - Buffers, streams, states etc.





accellera

SYSTEMS INITIATIVE

# Paradigm Shift

- Coming from a UVM or Software Driven Verification (SDV) environment to PSS requires a paradigm shift (a must have "aha!" moment)
  - You will struggle mightily until you make this shift
- Must move from a "testbench viewpoint" to a "test intent viewpoint"





## "Testbench Viewpoint"

- Think in terms of what the testbench must do to cause a desired behavior in the system (DUT)
  - Look at the pieces of the system as boxes with some kinds of interfaces that are exercised to cause DUT behaviors
  - Write code that executes on VIP/Processor that uses the DUT interface to exercise and observe DUT behaviors
    - UVM sequences, C functions
      - Initialize IPs
      - Cause DMAs, encrypt/decrypt, ethernet transfers etc
      - Do all the interfaces operations
      - Get results
      - "Scoreboard" DUT behaviors







## Testbench Example

- Focusing just on the DMA IP in the wb\_subsys example...
- Write sequences/functions
  - DMA initialization
    - Write/read memory mapped registers to initialize the DMA
  - DMA transfer
    - Initialize buffer(s)
    - Start transfer
    - Verify transfer
- Write a test (and another and another...)
  - Code is written with a specific execution platform in mind
    - Sequences for a UVM VIP interface agent
    - C code for a processor
  - Explicit calls to sequences/functions that execute on the VIP agent/processor
  - Written from the point of view "What do I need to do to the DMA IP?"







# Test Intent Viewpoint

- Think in terms of what the system does
  - What does it do?
  - What are its behaviors?
  - What inputs does it require?
- Write a PSS model that captures the test *intent* 
  - Not the test implementation we are not writing tests in PSS
- Model (scenario model) of the test intent
  - Describes what the system must do to prove it has been verified
    - Is as abstract as possible to make tests re-targetable
  - Describes the system in terms of resources, requirements and behaviors
  - Partial description
    - E.g. what the requirements are, not how they are met
      - Let the PSS tool infer the "how they are met"







# Test Intent Example - Capture

- Focusing just on the DMA IP in the wb\_subsys example...
- Capture the behaviors, resources and requirements
  - DMA initialization
    - Perform the DMA configuration
  - DMA transfer
    - Perform DMA
    - Require a DMA channel as a resource
    - Require source and destination memory blocks
  - PSS written from the point of view: "What does this DMA IP do?







Test generation for target testbench environment







# Test Intent Example - Inference

Tool inference

and Visualization

- Tool infers a source for required resources
  - DMA initialization
    - VIP/Processor that executes the DMA configuration
  - DMA transfer
    - What DMA channel is used
    - What provides the source block
      - Other IP in the system Ethernet MAC, AES etc.
      - VIP/processor
    - What infers the DMA transfer to happen

Capture

**PSS Model** 

- Other IP in the system - Ethernet MAC, AES etc.

Compose

scenario

- VIP/processor









## **PSS Overview - Constructs**

- component
- Flow objects: buffer, stream, state
- action
- resource
- Pools of flow objects and resources











## Components

- Abstract representation of the functional units of a system
  - HW IPs
  - HW Cores
  - Testbench VIP
  - The DMA, AES, GPX etc. in the SoC diagram would be components in a PSS model
- Components are containers
  - Instances of other components
  - Actions
  - Resources

| <pre>component component_name{}</pre>   | component |
|-----------------------------------------|-----------|
| <pre>Example: component dma_c{ };</pre> |           |







## **Component Instances**

- Components may contain instances of other components
  - Creates a hierarchical structure
  - The top or root component
    - pss\_top

```
component_type instance_name;
Example:
pss_top {
...
dma_c dma{};
}
```









# **Modeling Behaviors - Actions**

- Actions
  - Defined in a component
  - Abstract representation of component behavior
    - Transmit a packet, DMA transfer, capture video etc.
- Compound actions
  - "Call" other actions
    - May be scheduled in any order but are sequentially by default
      - Various operators covered later for more complex scheduling of actions
- Atomic actions
  - "Call" test code that is one of
    - C code that would run on a target processor
    - SV code that runs on SV or UVM VIP
    - Other target languages

| component |  |  |  |
|-----------|--|--|--|
| action    |  |  |  |
|           |  |  |  |





# **Defining Atomic Actions**

- Atomic actions contain test code in a block referred to as an exec block
  - body exec block contains either of
    - Literal C or SV code (we will use this type for now)
    - Imported or exported function calls (we will illustrate later)
  - There are other exec block types available but not covered here





# Action Inputs and Outputs

- An action is an *abstract representation* of component behavior
- Actions may require inputs
  - A DMA transfer requires data to move
  - An encrypt requires data and a key to encrypt
- Actions may generate outputs
  - A DMA transfer generates data that was moved
  - An encrypt generates encrypted data
- The input of an action could be the output of another action
  - This is a key abstraction of PSS (matching inputs and outputs)
  - The properties of the inputs must be agreed upon by all involved actions
    - Size, format or direction of data
    - Location in memory of data





# **Flow Objects**

- Flow objects are the abstract representation of the input and output information of an action
- PSS has 3 flow object types
  - Buffer
    - Represents persistent data
  - Stream
    - Represents transient data
  - State
    - Represents state information







**Buffers** 

buffer

- Data once generated is always available
- Typically represent data or control buffers in memories
- Schedule dependency
  - A buffer must be written (generated) before it is read

```
buffer name { body_item, ... }
Example:
buffer mem_buff {
   rand bit[31:0] addr;
   rand bit[15:0] size;
}
```





# Action Inputs and Outputs

• Actions may define the inputs they require











- Streams represent *transient* information
  - Typically represents data flow, message or control exchange
    - Typically models the transmission of data or control
- Schedule dependency
  - Streams are exchanged between actions that are *concurrent*
- Examples
  - "Transmit" of an ethernet packet from an Ethernet MAC to Ethernet VIP
  - "Receive" of a packet by a modem from VIP







accellera

SYSTEMS INITIATIV

# Stream Action inputs/outputs Example

- Transmit packet action of MAC has a stream output
- **Receive packet action of MII Operations has a** stream input •





# **Flow Object Pools**

- Flow object pools are collections of flow objects (buffer, stream, state)
- Actions use a pool to exchange flow objects
  - An action's inputs and outputs are references to a flow object pool

pool flow\_object\_type\_name pool\_name;

Example: pool mem\_buff mem\_buff\_p; // pool of mem\_buff pool eth\_packet eth\_pkt\_p; // pool of ethernet packets eth\_pkt\_p





# Flow Object Pool Binding

- Every flow object resides in some pool
- Every action of an instance of a component
  - Outputs objects to or inputs objects from a specific pool
- Pool bind directives determine which pool is accessible to each action in each component instance
- Two forms of binding
  - Default binding associate a pool by object type
    - bind pool to any action's input or output of the object type
  - Explicit binding associate a pool with a specific action's input or output of the object type (not discussed here)

// bind pool to any action's input or output of pool\_name type
bind pool\_name {\*};





output

# Flow Object Pool Binding Example

• Pool binding: mem\_buff pool to any action with a mem\_buff input or







# Resource Objects (Resources)

- Resource objects represent available computational resources that may be associated with actions
  - I.e. resources describe what is available in the execution environment to accomplish a scenario
- Resources relate to the underlying model IPs, buses etc.
  - In the diagram below we might list DMA channels, CPU, GPX, Ethernet MAC, USB device, Encrypt/decrypt engine and the camera as resources









SYSTEMS INITIATIVE

## **Resource Pools**

- Resource object pools are collections of objects of a resource type
- Pool size (total number of resources)
  - Default size is 1, may be set to any size
- Resources may be claimed by actions
  - lock
    - An action claims an available resource
    - This action has exclusive use of the resource throughout its execution





SYSTEMS INITIATIVE

# **Resource Pool Binding**

- Every resource object resides in some pool
- Every action of an instance of a component can be assigned a resource of a certain pool
- Like flow object pools, bind directives determine which pool is accessible to each action in each component instance
- Same types of binding (default and explicit)

```
bind pool_name {*};
bind pool_name *; // equivalent syntax
Example:
component dma_c {
  resource dma_chan_r {} // DMA channel resource
  pool[4] dma_chan_r dma_chan_p; // pool of DMA channels, size 4
  bind dma_chan_p {*}; // bind pool to anything that uses a dma_chan_r
...
}
```



accellera

SYSTEMS INITIATIVE

## Constraints

- Actions and flow objects may have constraints applied
  - Defines legal combinations of data and control resources
  - Key abstraction in PSS, limits the possible scenario solution space
    - A valid PSS scenario is one that satisfies ALL constraints

```
constraint constraint_expression;
constraint constraint_name { constraint_expression; ... }
Example:
component dma_c {
...
dma_xfr_a {
    input mem_buff buff_in; // source of DMA
    output mem_buff buff_out; // dest of DMA
    lock dma_chan_r dma_chan; // lock a DMA channel
    constraint buff_in.size < 4096; *// constrain size of DMA xfer
    // constrain output buffer to same size as input buffer
    constraint buff_out.size == buff_in.size;
    ...
```



## Packages

- PSS package is similar to a package in SV or a namespace in C++
- Package
  - Defines a namespace (or scope)
  - A namespace for declarations
    - Data flow types, resource types, enumerations etc.

package package\_name { body\_item, ... }

```
Example:
package data_flow_pkg {
   stream eth_packet {...}
   buffer mem_buff {...}
}
```



## data\_flow\_pkg



```
package data_flow_pkg {
    enum dir_e {Rx = 0, Tx};
    enum buff_type_e {MEM_BLOCK = 0, ETH_PKT}
```

```
// Ethernet Packet definition
stream eth packet {
  rand dir e dir;
  rand bit[15:0] payload len;
};
// memory buffer definition
buffer mem buff {
  rand buff type e buff type;
  rand bit[31:0] addr;
  rand bit[15:0] size;
// resources
resource wb bus {};
```







wb subsys

Memory

DMA



#### component wb ops c{ import data flow pkg; // import data flow pkg items Ethernet MAC // receive action action wb receive a { Wishbone MIL input mem buff buff in; Operations Operations exec body { pss\_info("wb\_receive\_a", "\*\*\* WB operations send action i \*\*\* \n\n"); Simple printouts for test realization // send action action wb send a { output mem buff buff out; exec body { pss info("wb send a","\n \*\*\* WB operatins send action \*\*\* \n\n");



### mac\_c



```
component mac_c {
```

import data flow pkg::\*; // import data\_flow\_pkg items

```
// action to receive an ethernet packet
action rx_pkt_a {
    input eth packet pkt in: // input eth
```

input eth\_packet pkt\_in; // input eth packet
output mem\_buff buff\_out; // output wb mem buffer
// Lock the Wishbone bus so transmit doesn't starve
lock wb\_bus wb\_bus\_l;

```
wb_subsys

Memory DMA

Ethernet

MAC

Wishbone

Operations MII

Operations
```

```
// Lock the Wishbone bus so transmit doesn't starve
lock wb_bus wb_bus_l;
// constrain eth_packet direction to receive only
constraint pkt_dir_con {pkt_in.dir == Rx; }
// constrain mem_buff type
constraint buff_type_con {buff_out.buff_type == ETH_PKT; }
exec body {
    pss_info("rx_pkt_a","\n *** MAC rx_pkt action *** \n\n");
}
```



### mac\_c (cont.)



```
// action to transmit an ethernet packet
action tx pkt a {
  input mem buff buff in; // input mem buffer
  output eth packet pkt out; // output eth packet
  // Lock the Wishbone bus so transmit doesn't starve
  lock wb bus wb bus l;
  // constrain eth packet direction to send only
  constraint pkt dir con {pkt out.dir == Tx; }
  // constrain mem buff type
  constraint buff dir con {buff in.buff type == ETH PKT; }
  exec body {
   pss info("tx pkt a","\n *** MAC tx pkt action *** \n\n");
  }
// action configure MAC
action config mac a {
 lock wb bus wb bus 1; // lock wishbone bus
 exec body {
   pss_info("config mac a","\n *** MAC config action *** \n\n");
```









#### component pss\_top {

import data\_flow\_pkg::\*; //import data\_flow\_pkg items
// component instantiations
mac\_c mac;
dma\_c dma;
mii\_vip\_c mii\_vip;
wb vip c wb vip;

pss top

#### // pools

pool eth\_packet eth\_pkt\_pool; // pool of ethernet packets
pool mem\_buff mem\_buff\_pool; // pool of ethernet packets
pool [1] wb\_bus wb\_bus\_pool;

#### // binds

bind eth\_pkt\_pool \*; // bind eth\_pkt\_pool to \*
bind mem\_buff\_pool \*; // bind mem\_buff\_pool to \*
bind wb\_bus\_pool \*; // bind wb\_bus\_pool to \*

# SYSTEMS INITIATIVE



#### // entry action

```
action entry_a {
   mac_c::rx_pkt_a rx_pkt;
   mac_c::tx_pkt_a tx_pkt;
   activity {
      schedule {
         rx_pkt;
         tx_pkt;
      }
    }
   "Compound" action: Schedules
    other actions in an activity
    block
```





## **Test Realization**



- We have scenarios that do correct actions
  - However if we asked Trek5 to generate tests from our scenarios the tests would only do print statements as written!
- Need to describe behavior in our action exec blocks that implement tests in the targeted test environment
  - The MAC  $\mathtt{tx\_pkt\_a}$  action needs to "do" the transmit of a packet
- We want to take advantage of existing APIs, sequences etc. in our target test environment
  - Be it C code on a embedded processor or a sequence in a UVM testbench





## **PSS Test Realization**

PSS provides the ability to interact with foreign-language code

- Help compute stimulus or expected values during stimulus generation
- Calls to API or libraries that correspond to behavior in leaf-level actions
- PSS Procedural Interface (PI)
  - Defines mechanisms by which the PSS model can interact with other languages such as C/C++ and/or SystemVerilog
    - Import or export functions
    - Used to reference external foreign-language functions or classes
- However, PSS does not specify beyond "you can can import or export what you want"
  - Result is different "solutions" across different vendors for integration with their tool and "talking" with C or SystemVerilog



## HSI



- Breker has defined a Hardware Software Interface (HSI) for use in exec blocks
  - Provides a standardized way of accessing registers, memories and VIP
  - Provides a translation layer that hides underlying details
- For accessing registers and memories
  - Defines a "register model" very similar to the UVM register model
    - Similar API methods for writing, reading, setting, updating registers and memories
    - Provides a translation layer for register and memory accesses
- For communication with VIP etc.
  - Defines TLM style transactions and ports with TLM methods (get, put etc.)
- HSI code gets realized in target language (C, SV etc.)



### HSI Example – Uart Register Block

```
2019
DESIGN AND VERIFICATION
           class uart block : public hsi::reg block {
   NCE AND EXHIBITION
           public:
JNITED STATES
             uart block(
               const pss::scope& name, hsi::reg addr base, const std::string& tb path)
                : hsi::reg block (this),
                 map("map", base), cfg_port("cfg_port", tb_path + "_cfg"),
                  drv port("drv port", tb path + " drv"), chk port("chk port",
                 tb path + " chk")
                                                  0x00 ); // R
               map.add reg ( UART RX,
                                                                                 adding and
                . . .
                                                                                 mapping
               map.add reg ( UART LSR,
                                                  0x05); // R
                                                                                 registers
                • • •
             reg_uart DATA
                                                  { "UART RX"
                                UART RX
                                                                         };
              . . .
             reg uart LSR UART LSR
                                                  { "UART LSR"
                                                                         };
             hsi::reg map map;
             hsi::put port <uart cfg tlm> cfg port;
                                                                                TLM Ports
             hsi::put port <uart drv tlm> drv port;
             hsi::check port <uart chk tlm>
                                                 chk port;
accelle
           };
```

SYSTEMS INITIATIVE

code in examples/wb subsys v2a

### HSI Example – Uart Configuration Action





## **Executable Specification Test Case Synthesis**

Abstract, scenario test-case synthesis, for all stages of the verification process, from a single, comprehensible, executable intent specification





2019

JNITED STATE



## SDV Portable Stimulus Deployment Example

- Broad, comprehensive test sets synthesized to exercise corner-cases, hard to write by hand
- Memory management, hardware software interface, "trickboxing" for full automation
- Debug visualization of concurrent, synchronized transaction and SW tests with backdoor access









## **ARM Platform Verification Issues**



This infrastructure verification process needs a large number of tests to check, for example:

• Cache coherency, Stress testing of sub-system components, SoC functional testing, etc.





## ARMv8 Application Easy verification of ARM installations



Automated test generation for a broad range of ARMv8 integration issues, including indepth SoC cache coherency.

- Auto-generation of broad, inclusive test sets, otherwise requiring man-months of manual authoring
- Find and wring out complex, SoC corner cases hard to envisage manually
- Complete ARMv8 integration verification for SoC simulation, emulation and post silicon





## Top Level ARMv8 Graph Structure



Tool Traverses Scenario Model graph to generate tests





# **ARMv8 Verification Metrics**

- Cache State Transitions
- Cache Line Sharing Cases
- Snoop / Probe Sources
- Load/Store Operation Size
- Load/Store Sources
- False Sharing Cases

- Crossing Cache Line Boundaries
- Capacity Eviction Cases
- Multiple Memory Regions
- Memory Ordering Tests
- Concurrent Scenarios
- Interrupt/Exception Sources





## **Cache State Transitions**

- There can only be up to five states in global context
- Need to follow a specific sequence of transitions to reach each state







# **Cache State Transitions**

- "One Address, Many Data"
- Start with end state, work backwards to find transition scenario







## Cache State Transition Graph







# Cache Line Sharing Cases

- Need to consider all possible cache line sharing cases across caches
  - How many caches are sharing the cache line
  - Which caches are involved
  - Is the shared line clean or modified



Fig. 2. (a) State space of SI protocol with 3 cores. Each global state is presented with 3 letters, e.g., IIS means core 2, core 1, and core 0 are in states I, I, and S, respectively. (b) Viewed as a composition of 3 isomorphic trees.



Fig. 3. State space of MSI protocol with 3 cores. For the clarity of presentation, the transitions to global modified states (IIM, IMI, MII) are omitted, if the transition in the opposite direction does not exist.

source: Qin et al., http://www.cise.ufl.edu/tr/DOC/REP-2012-537.pdf





## **Cache Line Sharing Cases**







# Snoop/Probe Sources

- Snoops/Probes query a cache to see if it contains a cache line
  - Cache may respond by writing back / returning dirty data
- Need to consider multiple Snoop / Probe sources
  - Another core on the same cluster
  - A core from a another cluster
  - A core from another chip
  - A coherency master (e.g. PCIe)





## Snoop/Probe Sources

| TrekSoC: Version 4.2.9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>File C</u> overage Constraints <u>S</u> elect <u>V</u> iew <u>P</u> references <u>W</u> indow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1 See Contraction (Contraction) 2 See Contraction (Contraction) 2 See Contraction (Contraction) 3 See Contract |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| armv8TrekApp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| armv8TrekApp<br>lo_write_external<br>armv8TrekApp.impl<br>armv8TrekApp.impl<br>armv8TrekApp.impl.agents<br>select agent category to use<br>memActions<br>Agents<br>termote_this_cluster<br>remote_this_cluster<br>remote_this_cluster<br>termote_this_cluster<br>address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| I descendant paths                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |





# Load/Store Operation Sizes

- Must consider 1 Byte, 2 Byte, 4 Byte, 8 Byte operations for Loads and Stores to caches
  - Can do many small operations concurrently
  - Opportunities for false sharing (more on this later)
- Must also consider block operations
  - Do a sequential Load or Store operations to a block of addresses (e.g. 3233 bytes)
  - Causes fetch buffers, write buffers, branch prediction etc to fill up
  - Different type of testing than with single, small operations
  - Some operations require blocks that are multiples of cache-line size





## Load/Store Operation Sizes

| 🚸 TrekSoC: Version 4.2.9 _ 🗆                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>File</u> <u>Coverage</u> Constraints <u>Select</u> <u>View</u> <u>Preferences</u> <u>W</u> indow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ] 🐘 🖿 🖷 🔍 🐚 🥙 🟥 📅 🛛 🚳 🔮 🕘 🍐 ⇔ ↓ 🔹 👂 🔺                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| armv8TrekApp<br>armv8TrekApp.impl<br>armv8TrekApp.impl.address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| singe instruction address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| op_type_single op_size_Bbyte<br>op_size_I6byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| op_size_3.6,7byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| random sized address block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| op type block op size_medium<br>(pp_size_long<br>op_type_dczid_bik_size)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| multiple of cacheline size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Address<br>Africa TekApp<br>Twe store to the store of the store |
| 2 descendant paths                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |





# ARMv8 Load/Store Instructions

- All variants of Load/Store operations including
  - Acquire/Release
  - Exclusive
  - Pair Operations (16 byte)
  - All valid sizes of the above





## ARMv8 Load/Store Instructions







# Multiple Memory Regions

- A memory region is a range of addresses at a specific location in the memory map
- Randomize memory addresses across multiple memory regions with different properties
  - Different cache-ability properties
  - Different memory controllers
  - Different physical memory types
- Memory regions configured in configure/platform.trekcfg





# Memory Ordering Tests

- CPU0
  - writes data A
  - (memory barrier)
  - write flag B
- CPU1
  - wait for flag B
  - read data A
- CPU1 *must* get data value A from CPU0





# Memory Ordering Tests

- Every dependency that crosses processors tests memory ordering
  - Producer writes data
  - Producer updates state ( with memory barrier )
  - Consumer waiting for state
  - Consume uses data
- Tested on every producer/consumer dependency
- See Test Map view







# Dekker Algorithm

- Assume initial state A=0 , B=0
- The Dekker Algorithm States
   core 0: ST A, 1; LD B
   core 1: ST B, 1; LD A
   error iff ( A == 0 && B == 0 )
- This is a test for a weakly ordered memory system
  - Such a system must preserve the property that a LD may not reorder ahead of a previous ST from the same agent





## **Dekker Scaled to Multiple Processors**

| Core 0 | Core 1 | Core 2 | Core 3 |
|--------|--------|--------|--------|
| ST A   | ST B   | ST C   | ST D   |
| LD B   | LD C   | LD D   | LD A   |

- Error if all loads see initial value
- Dekker randomized for all memories, operation sizes, load/store sources





## Load/Store Sources







## Summary

- PSS provides a powerful method to raise the abstraction for multiple verification flows
- PSS combined with the right tooling allows for powerful verification solutions with the minimal of user coding effort
- ARMv8 integrations are one area where PSS can discover a range of issues

