Add full documentation for updated metrics (#224)
Co-authored-by: Nick Curtis <nicholas.curtis@amd.com>
Signed-off-by: colramos-amd <colramos@amd.com>
[ROCm/rocprofiler-compute commit: 4b8f519e9b]
@@ -5,7 +5,7 @@
|
||||
:glob:
|
||||
:maxdepth: 4
|
||||
```
|
||||
Omniperf offers several ways to interact with the metrics it generates from profiling. The option you choose will likey be influnced by your familiarity with the profiled application, computing enviroment, and experience with Omniperf.
|
||||
Omniperf offers several ways to interact with the metrics it generates from profiling. The option you choose will likely be influnced by your familiarity with the profiled application, computing enviroment, and experience with Omniperf.
|
||||
|
||||
While analyzing with the CLI offers quick and straightforward access to Omniperf metrics from terminal, the GUI adds an extra layer of styling and interactiveness some users may prefer.
|
||||
|
||||
@@ -16,7 +16,7 @@ See sections below for more information on each.
|
||||
|
||||
### Features
|
||||
|
||||
- All Omniperf built-in metrics.
|
||||
- All of Omniperf's built-in metrics.
|
||||
- Multiple runs base line comparison.
|
||||
- Metrics customization: pick up subset of build-in metrics or build your own profiling configuration.
|
||||
- Kernel, gpu-id, dispatch-id filters.
|
||||
@@ -254,7 +254,7 @@ Analyze
|
||||
```
|
||||
> **Note:** Some cells may be blank indicating a missing/unavailable hardware counter or NULL value
|
||||
|
||||
3. Optimizatize application, iterate, and re-profile to inspect performance changes.
|
||||
3. Optimize application, iterate, and re-profile to inspect performance changes.
|
||||
4. Redo a comprehensive analysis with Omniperf CLI at any milestone or at the end.
|
||||
|
||||
### Demo
|
||||
@@ -281,7 +281,7 @@ Analyze
|
||||
$ omniperf analyze -p workloads/vcopy/mi200/ -b 2 5.1.0
|
||||
```
|
||||
|
||||
> Note: Users can filter single metric or the whole IP block by its id. In this case, 1 is the id for "system speed of light" and 5.1.0 the id for metric "GPU Busy Cycles".
|
||||
> Note: Users can filter single metric or the whole hardware component by its id. In this case, 1 is the id for "system speed of light" and 5.1.0 the id for metric "GPU Busy Cycles".
|
||||
|
||||
- Filter kernels
|
||||
|
||||
@@ -304,7 +304,7 @@ Analyze
|
||||
|
||||
```
|
||||
|
||||
Second, select the index of the kernel you'd like to filter (i.e. __vecCopy(double*, double*, double*, int, int) [clone .kd]__ at index __0__). Then, use this index to apply the filter via `-k/--kernels`.
|
||||
Second, select the index of the kernel you would like to filter (i.e. __vecCopy(double*, double*, double*, int, int) [clone .kd]__ at index __0__). Then, use this index to apply the filter via `-k/--kernels`.
|
||||
|
||||
```shell-session
|
||||
$ omniperf -p workloads/vcopy/mi200/ -k 0
|
||||
@@ -325,7 +325,7 @@ Analyze
|
||||
... ...
|
||||
```
|
||||
|
||||
> Note: You'll see your filtered kernel(s) indicated by a asterisk in the Top Stats table
|
||||
> Note: You will see your filtered kernel(s) indicated by an asterisk in the Top Stats table
|
||||
|
||||
|
||||
- Baseline comparison
|
||||
@@ -333,7 +333,7 @@ Analyze
|
||||
```shell
|
||||
omniperf analyze -p workload1/path/ -p workload2/path/
|
||||
```
|
||||
> Note: You can also apply diffrent filters to each workload.
|
||||
> Note: You can also apply different filters to each workload.
|
||||
|
||||
OR
|
||||
```shell
|
||||
@@ -414,7 +414,7 @@ When no filters are applied, users will see five basic sections derived from the
|
||||
|
||||
To dive deeper, use the top drop down menus to isolate particular
|
||||
kernel(s) or dispatch(s). You will then see the web page update with
|
||||
metrics specific to the filter you've applied.
|
||||
metrics specific to the filter you have applied.
|
||||
|
||||
Once you have applied a filter, you will also see several additional
|
||||
sections become available with detailed metrics specific to that area
|
||||
@@ -427,22 +427,22 @@ interface](https://amdresearch.github.io/omniperf/analysis.html#grafana-based-gu
|
||||
#### Features
|
||||
The Omniperf Grafana GUI Analyzer supports the following features to facilitate MI GPU performance profiling and analysis:
|
||||
|
||||
- System and IP-Block Speed-of-Light (SOL)
|
||||
- System and Hardware Component (IP Block) Speed-of-Light (SOL)
|
||||
- Multiple normalization options, including per-cycle, per-wave, per-kernel and per-second.
|
||||
- Baseline comparisons
|
||||
- Regex based Dispatch ID filtering
|
||||
- Roofline Analysis
|
||||
- Detailed per IP Block performance counters and metrics
|
||||
- CPC/CPF
|
||||
- SPI
|
||||
- SQ
|
||||
- SQC
|
||||
- TA/TD
|
||||
- TCP
|
||||
- TCC (both aggregated and per-channel perf info)
|
||||
- Detailed performance counters and metrics per hardware component, e.g.,
|
||||
- Command Processor - Fetch (CPF) / Command Processor - Controller (CPC)
|
||||
- Workgroup Manager (SPI)
|
||||
- Shader Sequencer (SQ)
|
||||
- Shader Sequencer Controller (SQC)
|
||||
- L1 Address Processing Unit, a.k.a. Texture Addresser (TA) / L1 Backend Data Processing Unit, a.k.a. Texture Data (TD)
|
||||
- L1 Cache (TCP)
|
||||
- L2 Cache (TCC) (both aggregated and per-channel perf info)
|
||||
|
||||
##### Speed-of-Light
|
||||
Speed-of-light panels are provided at both the system and per IP block level to help diagnosis performance bottlenecks. The performance numbers of the workload under testing are compared to the theoretical maximum, (e.g. floating point operations, bandwidth, cache hit rate, etc.), to indicate the available room to further utilize the hardware capability.
|
||||
Speed-of-light panels are provided at both the system and per hardware component level to help diagnosis performance bottlenecks. The performance numbers of the workload under testing are compared to the theoretical maximum, (e.g. floating point operations, bandwidth, cache hit rate, etc.), to indicate the available room to further utilize the hardware capability.
|
||||
|
||||
##### Multi Normalization
|
||||
|
||||
@@ -457,24 +457,24 @@ Omniperf enables baseline comparison to allow checking A/B effect. The current r
|
||||
|
||||
For both the Current Workload and the Baseline Workload, one can independently setup the following filters to allow fine grained comparions:
|
||||
- Workload Name
|
||||
- GPU ID filtering (multi selection)
|
||||
- Kernel Name filtering (multi selection)
|
||||
- GPU ID filtering (multi-selection)
|
||||
- Kernel Name filtering (multi-selection)
|
||||
- Dispatch ID filtering (Regex filtering)
|
||||
- Omniperf Panels (multi selection)
|
||||
- Omniperf Panels (multi-selection)
|
||||
|
||||
##### Regex based Dispatch ID filtering
|
||||
This release enables regex based dispatch ID filtering to flexibly choose the kernel invocations. One may refer to [Regex Numeric Range Generator](https://3widgets.com/), to generate typical number ranges.
|
||||
This release enables Regular Expression (regex), a standard Linux string matching syntax, based dispatch ID filtering to flexibly choose the kernel invocations. One may refer to [Regex Numeric Range Generator](https://3widgets.com/), to generate typical number ranges.
|
||||
|
||||
For example, if one wants to inspect Dispatch Range from 17 to 48, inclusive, the corresponding regex is : **(1[7-9]|[23]\d|4[0-8])**. The generated express can be copied over for filtering.
|
||||
For example, if one wants to inspect Dispatch Range from 17 to 48, inclusive, the corresponding regex is : **(1[7-9]|[23]\d|4[0-8])**. The generated expression can be copied over for filtering.
|
||||
|
||||
##### Incremental Profiling
|
||||
Omniperf supports incremental profiling to significantly speed up performance analysis.
|
||||
|
||||
> Refer to [*IP Block profiling*](https://amdresearch.github.io/omniperf/profiling.html#ip-block-profiling) section for this command.
|
||||
> Refer to [*Hardware Component Filtering*](https://amdresearch.github.io/omniperf/profiling.html#hardware-component-filtering) section for this command.
|
||||
|
||||
By default, the entire application is profiled to collect perfmon counter for all IP blocks, giving a system level view of where the workload stands in terms of performance optimization opportunities and bottlenecks.
|
||||
By default, the entire application is profiled to collect performance counters for all hardware blocks, giving a complete view of where the workload stands in terms of performance optimization opportunities and bottlenecks.
|
||||
|
||||
After that one may focus on only a few IP blocks, (e.g., L1 Cache or LDS) to closely check the effect of software optimizations, without performing application replay for all other IP Blocks. This saves lots of compute time. In addition, the prior profiling results for other IP blocks are not overwritten. Instead, they can be merged during the import to piece together the system view.
|
||||
After that one may focus on only a few hardware components, (e.g., L1 Cache or LDS) to closely check the effect of software optimizations, without performing application replay for all other hardware components. This saves lots of compute time. In addition, the prior profiling results for other hardware components are not overwritten. Instead, they can be merged during the import to piece together the system view.
|
||||
|
||||
##### Color Coding
|
||||
The uniform color coding is applied to most visualizations (bars, table, diagrams etc). Typically, Yellow color means over 50%, while Red color mean over 90% percent, for easy inspection.
|
||||
@@ -539,7 +539,7 @@ Connection Options:
|
||||
-p , --password The user's password. (will be requested later if it's not set)
|
||||
-t , --team Specify Team prefix.
|
||||
-w , --workload Specify name of workload (to remove) or path to workload (to import)
|
||||
-k , --kernel-verbose Specify Kernel Name verbose level 1-5.
|
||||
-k , --kernelVerbose Specify Kernel Name verbose level 1-5.
|
||||
Lower the level, shorter the kernel name. (DEFAULT: 2) (DISABLE: 5)
|
||||
```
|
||||
|
||||
@@ -594,7 +594,7 @@ There are currently 18 main panel categories available for analyzing the compute
|
||||
- Command Processor
|
||||
- Command Processor - Fetch (CPF)
|
||||
- Command Processor - Controller (CPC)
|
||||
- Shader Processing Input (SPI)
|
||||
- Workgroup Manager or Shader Processor Input (SPI)
|
||||
- SPI Stats
|
||||
- SPI Resource Allocations
|
||||
- Wavefront Launch
|
||||
@@ -655,116 +655,357 @@ There are currently 18 main panel categories available for analyzing the compute
|
||||
- Per-channel L2-EA Read stall (I/O, GMI, HBM)
|
||||
- Per-channel L2-EA Write stall (I/O, GMI, HBM, Starve)
|
||||
|
||||
Most panels are designed around a specific IP block to thoroughly understand its behavior. Additional panels, including custom panels, could also be added to aid the performance analysis.
|
||||
Most panels are designed around a specific hardware component block to thoroughly understand its behavior. Additional panels, including custom panels, could also be added to aid the performance analysis.
|
||||
|
||||
##### System Info Panel
|
||||

|
||||
``` {figure} images/system-info_panel.png
|
||||
:alt: System Info
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
System details logged from host machine.
|
||||
```
|
||||
|
||||
##### Kernel Statistics
|
||||
|
||||
###### Kernel Time Histogram
|
||||

|
||||
``` {figure} images/Kernel_time_histogram.png
|
||||
:alt: Kernel Time Histogram
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Mapping application kernel launches to execution duration.
|
||||
```
|
||||
###### Top Bottleneck Kernels
|
||||

|
||||
``` {figure} images/top-stat_panel.png
|
||||
:alt: Top Bottleneck Kernels
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Top N kernels and relevant statistics. Sorted by total duration.
|
||||
```
|
||||
###### Top Bottleneck Dispatches
|
||||

|
||||
``` {figure} images/Top_bottleneck_dispatches.png
|
||||
:alt: Top Bottleneck Dispatches
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Top N kernel dispatches and relevant statistics. Sorted by total duration.
|
||||
```
|
||||
###### Current and Baseline Dispatch IDs (Filtered)
|
||||

|
||||
``` {figure} images/Current_and_baseline_dispatch_ids.png
|
||||
:alt: Current and Baseline Dispatch IDs
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
List of all kernel dispatches.
|
||||
```
|
||||
|
||||
##### System Speed-of-Light
|
||||

|
||||
``` {figure} images/sol_panel.png
|
||||
:alt: System Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Key metrics from various sections of Omniperf’s profiling report.
|
||||
```
|
||||
|
||||
##### Memory Chart Analysis
|
||||
> Note: The Memory Chart Analysis support multiple normalizations. Due to the space limit, all transactions, when normalized to per-sec, default to unit of Billion transactions per second.
|
||||
|
||||

|
||||
``` {figure} images/memory-chart_panel.png
|
||||
:alt: Memory Chart Analysis
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
A graphical representation of performance data for memory blocks on the GPU.
|
||||
```
|
||||
|
||||
##### Empirical Roofline Analysis
|
||||
``` {figure} images/roofline_panel.png
|
||||
:alt: Roofline Analysis
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Visualize achieved performance relative to a benchmarked peak performance.
|
||||
```
|
||||
|
||||
##### Roofline Analysis
|
||||

|
||||
##### Command Processor
|
||||

|
||||
##### Shader Processing Input (SPI)
|
||||

|
||||
##### Wavefront Launch
|
||||

|
||||
###### Command Processor Fetcher
|
||||
``` {figure} images/cpc_panel.png
|
||||
:alt: Command Processor Fetcher
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Fetches commands out of memory to hand them over to the Command Processor Fetcher (CPC) for processing
|
||||
```
|
||||
###### Command Processor Compute
|
||||
``` {figure} images/cpf_panel.png
|
||||
:alt: Command Processor Compute
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The micro-controller running the command processing firmware that decodes the fetched commands, and (for kernels) passes them to the Workgroup Managers (SPIs) for scheduling.
|
||||
```
|
||||
|
||||
##### Shader Processor Input (SPI)
|
||||
###### SPI Stats
|
||||
``` {figure} images/spi-stats_panel.png
|
||||
:alt: SPI Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
TODO: Add caption after merge
|
||||
```
|
||||
###### SPI Resource Allocation
|
||||
``` {figure} images/spi-resource-allocation_panel.png
|
||||
:alt: SPI Resource Allocation
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
TODO: Add caption after merge
|
||||
```
|
||||
|
||||
##### Wavefront
|
||||
###### Wavefront Launch Stats
|
||||
``` {figure} images/wavefront-launch-stats_panel.png
|
||||
:alt: Wavefront Launch Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
General information about the kernel launch.
|
||||
```
|
||||
###### Wavefront Runtime Stats
|
||||
``` {figure} images/wavefront-runtime-stats_panel.png
|
||||
:alt: Wavefront Runtime Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
High-level overview of the execution of wavefronts in a kernel.
|
||||
```
|
||||
|
||||
##### Compute Unit - Instruction Mix
|
||||
###### Instruction Mix
|
||||

|
||||
``` {figure} images/cu-inst-mix_panel.png
|
||||
:alt: Instruction Mix
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Breakdown of the various types of instructions executed by the user’s kernel, and which pipelines on the Compute Unit (CU) they were executed on.
|
||||
```
|
||||
###### VALU Arithmetic Instruction Mix
|
||||

|
||||
``` {figure} images/cu-value-arith-instr-mix_panel.png
|
||||
:alt: VALU Arithmetic Instruction Mix
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The various types of vector instructions that were issued to the vector arithmetic logic unit (VALU).
|
||||
```
|
||||
###### MFMA Arithmetic Instruction Mix
|
||||

|
||||
``` {figure} images/cu-mafma-arith-instr-mix_panel.png
|
||||
:alt: MFMA Arithmetic Instruction Mix
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The types of Matrix Fused Multiply-Add (MFMA) instructions that were issued.
|
||||
```
|
||||
###### VMEM Arithmetic Instruction Mix
|
||||

|
||||
``` {figure} images/cu-vmem-instr-mix_panel.png
|
||||
:alt: VMEM Arithmetic Instruction Mix
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The types of vector memory (VMEM) instructions that were issued.
|
||||
```
|
||||
|
||||
##### Compute Unit - Compute Pipeline
|
||||
###### Speed-of-Light
|
||||

|
||||
###### Compute Pipeline Stats
|
||||

|
||||
``` {figure} images/cu-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The number of floating-point and integer operations executed on the vector arithmetic logic unit (VALU) and Matrix Fused Multiply-Add (MFMA) units in various precisions.
|
||||
```
|
||||
###### Pipeline Stats
|
||||
``` {figure} images/cu-pipeline-stats_panel.png
|
||||
:alt: Pipeline Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detailed metrics to analyze the several independent pipelines found in the Compute Unit (CU).
|
||||
```
|
||||
###### Arithmetic Operations
|
||||

|
||||
###### Memory Latencies
|
||||

|
||||
``` {figure} images/cu-arith-ops_panel.png
|
||||
:alt: Arithmetic Operations
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The total number of floating-point and integer operations executed in various precisions.
|
||||
```
|
||||
|
||||
##### Local Data Share (LDS)
|
||||
###### Speed-of-Light
|
||||

|
||||
``` {figure} images/lds-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Key metrics for the Local Data Share (LDS) as a comparison with the peak achievable values of those metrics.
|
||||
```
|
||||
###### LDS Stats
|
||||

|
||||
``` {figure} images/lds-stats_panel.png
|
||||
:alt: LDS Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detailed view of the Local Data Share (LDS) performance.
|
||||
```
|
||||
|
||||
##### Instruction Cache
|
||||
###### Speed-of-Light
|
||||

|
||||
``` {figure} images/instr-cache-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Key metrics of the L1 Instruction (L1I) cache as a comparison with the peak achievable values of those metrics.
|
||||
```
|
||||
###### Instruction Cache Stats
|
||||

|
||||
``` {figure} images/instr-cache-accesses_panel.png
|
||||
:alt: Instruction Cache Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detail on the hit/miss statistics of the L1 Instruction (L1I) cache.
|
||||
```
|
||||
|
||||
##### Scalar L1D Cache
|
||||
###### Speed-of-Light
|
||||

|
||||
###### Constant Cache Stats
|
||||

|
||||
###### Constant Cache - L2 Interface
|
||||

|
||||
``` {figure} images/sl1d-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Key metrics of the Scalar L1 Data (sL1D) cache as a comparison with the peak achievable values of those metrics.
|
||||
```
|
||||
###### Scalar L1D Cache Accesses
|
||||
``` {figure} images/sl1d-cache-accesses_panel.png
|
||||
:alt: Scalar L1D Cache Accesses
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detail on the types of accesses made to the Scalar L1 Data (sL1D) cache, and the hit/miss statistics.
|
||||
```
|
||||
###### Scalar L1D Cache - L2 Interface
|
||||
``` {figure} images/sl1d-l12-interface_panel.png
|
||||
:alt: Scalar L1D Cache - L2 Interface
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detail on the data requested across the Scalar L1 Data (sL1D) cache <-> L2 interface.
|
||||
```
|
||||
|
||||
##### Texture Address and Texture Data
|
||||
###### Texture Address (TA)
|
||||

|
||||
###### Texture Data (TD)
|
||||

|
||||
###### Texture Addresser
|
||||
``` {figure} images/ta_panel.png
|
||||
:alt: Texture Addresser
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
##### Vector L1D Cache
|
||||
Metric specific to texture addresser (TA) which receives commands (e.g., instructions) and write/atomic data from the Compute Unit (CU), and coalesces them into fewer requests for the cache to process.
|
||||
```
|
||||
###### Texture Data
|
||||
``` {figure} images/td_panel.png
|
||||
:alt: Texture Data
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Metrics specific to texture data (TD) which routes data back to the requesting Compute Unit (CU).
|
||||
```
|
||||
|
||||
##### Vector L1 Data Cache
|
||||
###### Speed-of-Light
|
||||

|
||||
###### Vector L1D Cache Accesses
|
||||

|
||||
###### L1 Cache Stalls
|
||||

|
||||
###### L1 - L2 Transactions
|
||||

|
||||
###### L1 - UTCL1 Interface Stats
|
||||

|
||||
``` {figure} images/vl1d-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Key metrics of the vector L1 data (vL1D) cache as a comparison with the peak achievable values of those metrics.
|
||||
```
|
||||
###### L1D Cache Stalls
|
||||
``` {figure} images/vl1d-cache-stalls_panel.png
|
||||
:alt: L1D Cache Stalls
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detail on where vector L1 data (vL1D) cache is stalled in the pipeline, which may indicate performance limiters of the cache.
|
||||
```
|
||||
###### L1D Cache Accesses
|
||||
``` {figure} images/vl1d-cache-accesses_panel.png
|
||||
:alt: L1D Cache Accesses
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
The type of requests incoming from the cache frontend, the number of requests that were serviced by the vector L1 data (vL1D) cache, and the number & type of outgoing requests to the L2 cache.
|
||||
```
|
||||
###### L1D - L2 Transactions
|
||||
``` {figure} images/vl1d-l2-transactions_panel.png
|
||||
:alt: L1D - L2 Transactions
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
A more granular look at the types of requests made to the L2 cache.
|
||||
```
|
||||
###### L1D Addr Translation
|
||||
``` {figure} images/vl1d-addr-translation_panel.png
|
||||
:alt: L1D Addr Translation
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
After a vector memory instruction has been processed/coalesced by the address processing unit of the vector L1 data (vL1D) cache, it must be translated from a virtual to physical address. These metrics provide more details on the L1 Translation Lookaside Buffer (TLB) which handles this process.
|
||||
```
|
||||
|
||||
##### L2 Cache
|
||||
###### Speed-of-Light
|
||||

|
||||
###### L2 Cache Accesses
|
||||

|
||||
###### L2 - EA Transactions
|
||||

|
||||
###### L2 - EA Stalls
|
||||

|
||||
``` {figure} images/l2-sol_panel.png
|
||||
:alt: Speed-of-Light
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
##### L2 Cache Per Channel Performance
|
||||
###### L1-L2 Transactions
|
||||

|
||||
###### L2-EA Transactions
|
||||

|
||||
###### L2-EA Latencies
|
||||

|
||||
###### L2-EA Stalls
|
||||

|
||||
###### L2-EA Write Stalls
|
||||

|
||||
###### L2-EA Write Starvation
|
||||

|
||||
Key metrics about the performance of the L2 cache, aggregated over all the L2 channels, as a comparison with the peak achievable values of those metrics.
|
||||
```
|
||||
###### L2 Cache Accesses
|
||||
``` {figure} images/l2-accesses_panel.png
|
||||
:alt: L2 Cache Accesses
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
Incoming requests to the L2 cache from the vector L1 data (vL1D) cache and other clients (e.g., the sL1D and L1I caches).
|
||||
```
|
||||
###### L2 - Fabric Transactions
|
||||
``` {figure} images/l2-fabric-transactions_panel.png
|
||||
:alt: L2 - Fabric Transactions
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
More detail on the flow of requests through Infinity Fabric™.
|
||||
```
|
||||
###### L2 - Fabric Interface Stalls
|
||||
``` {figure} images/l2-fabric-interface-stalls_panel.png
|
||||
:alt: L2 - Fabric Interface Stalls
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
A breakdown of what types of requests in a kernel caused a stall (e.g., read vs write), and to which locations (e.g., to the accelerator’s local memory, or to remote accelerators/CPUs).
|
||||
```
|
||||
|
||||
##### L2 Cache Per Channel
|
||||
###### Aggregate Stats
|
||||
``` {figure} images/l2-per-channel-agg-stats_panel.png
|
||||
:alt: Aggregate Stats
|
||||
:figclass: figure
|
||||
:align: center
|
||||
|
||||
L2 Cache per channel performance at a glance. Metrics are aggregated over all available channels.
|
||||
```
|
||||
|
||||
@@ -32,13 +32,13 @@ def install(package):
|
||||
# -- Project information -----------------------------------------------------
|
||||
|
||||
project = "Omniperf"
|
||||
copyright = "2022, Audacious Software Group"
|
||||
copyright = "2023-2024, Audacious Software Group"
|
||||
author = "Audacious Software Group"
|
||||
|
||||
# The short X.Y version
|
||||
version = repo_version
|
||||
# The full version, including alpha/beta/rc tags
|
||||
release = ""
|
||||
release = repo_version
|
||||
|
||||
# -- General configuration ---------------------------------------------------
|
||||
|
||||
@@ -52,9 +52,12 @@ extensions = [
|
||||
"myst_parser",
|
||||
]
|
||||
|
||||
myst_heading_anchors = 2
|
||||
show_authors = True
|
||||
|
||||
myst_heading_anchors = 4
|
||||
# enable replacement of (tm) & friends
|
||||
myst_enable_extensions = ["replacements"]
|
||||
myst_enable_extensions = ["replacements", "dollarmath"]
|
||||
|
||||
|
||||
# Add any paths that contain templates here, relative to this directory.
|
||||
templates_path = ["_templates"]
|
||||
@@ -112,6 +115,10 @@ html_theme = "sphinx_rtd_theme"
|
||||
# so a file named "default.css" will overwrite the builtin "default.css".
|
||||
html_static_path = ["_static"]
|
||||
|
||||
latex_elements = {
|
||||
"sphinxsetup": 'verbatimwrapslines=true, verbatimforcewraps=true',
|
||||
}
|
||||
|
||||
|
||||
# -- Options for HTMLHelp output ---------------------------------------------
|
||||
|
||||
@@ -130,7 +137,7 @@ html_theme_options = {
|
||||
# Toc options
|
||||
"collapse_navigation": True,
|
||||
"sticky_navigation": True,
|
||||
"navigation_depth": 4,
|
||||
"navigation_depth": 5,
|
||||
"includehidden": True,
|
||||
"titles_only": False,
|
||||
}
|
||||
@@ -162,6 +169,7 @@ def setup(app):
|
||||
app.add_transform(AutoStructify)
|
||||
app.add_config_value("docstring_replacements", {}, True)
|
||||
app.connect("source-read", replaceString)
|
||||
app.add_css_file("css/custom.css")
|
||||
|
||||
|
||||
# function to replace version string througout documentation
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
:maxdepth: 4
|
||||
```
|
||||
|
||||
**1. How do I export profiling data I've already generated using Omniperf?**
|
||||
**1. How do I export profiling data I have already generated using Omniperf?**
|
||||
|
||||
In order to interact with the Grafana GUI you must sync data with the MongoDB backend. This interaction is done through ***database*** mode.
|
||||
|
||||
@@ -35,11 +35,23 @@ $ export LANG=C.UTF-8
|
||||
|
||||
1. Open MobaXterm
|
||||
2. In the top ribbon, select `Tunneling`
|
||||

|
||||
``` {image} images/tunnel_demo1.png
|
||||
:alt: MobaXterm Tunnel Button
|
||||
:class: bg-primary
|
||||
:align: center
|
||||
```
|
||||
This pop up will appear
|
||||

|
||||
``` {image} images/tunnel_demo2.png
|
||||
:alt: MobaXterm Pop Up
|
||||
:class: bg-primary
|
||||
:align: center
|
||||
```
|
||||
3. Press `New SSH tunnel`
|
||||

|
||||
``` {image} images/tunnel_demo3.png
|
||||
:alt: MobaXterm Pop Up
|
||||
:class: bg-primary
|
||||
:align: center
|
||||
```
|
||||
4. Configure tunnel accordingly
|
||||
|
||||
Local clients
|
||||
@@ -52,4 +64,4 @@ This pop up will appear
|
||||
SSH Server
|
||||
- SSH server: Name of the server one is connecting to
|
||||
- SSH login: Username to login to the server
|
||||
- SSH port: 22
|
||||
- SSH port: 22
|
||||
|
||||
@@ -10,13 +10,13 @@
|
||||
|
||||
1. **Launch & Profile the target application with the command line profiler**
|
||||
|
||||
The command line profiler launches the target application, calls the rocProfiler API, and collects profile results for the specified kernels, dispatches, and/or IP blocks. If not specified, Omniperf will default to collecting all available counters for all kernels/dispatches launched by the user's executable.
|
||||
The command line profiler launches the target application, calls the rocProfiler API via the rocProf binary, and collects profile results for the specified kernels, dispatches, and/or hardware components. If not specified, Omniperf will default to collecting all available counters for all kernels/dispatches launched by the user's executable.
|
||||
|
||||
To collect the default set of data for all kernels in the target application, launch, e.g.:
|
||||
```shell
|
||||
$ omniperf profile -n vcopy_data -- ./vcopy -n 1048576 -b 256
|
||||
$ omniperf profile -n vcopy_data -- ./vcopy 1048576 256
|
||||
```
|
||||
The app runs, each kernel is launched, and profiling results are generated. By default, results are written to (e.g.,) ./workloads/vcopy_data (configurable via the `-n` argument). To collect all requested profile information, it may be required to replay kernels multiple times.
|
||||
The app runs, each kernel is launched, and profiling results are generated. By default, results are written to e.g., ./workloads/vcopy_data (configurable via the `-n` argument). To collect all requested profile information, it may be required to replay kernels multiple times.
|
||||
|
||||
2. **Customize data collection**
|
||||
|
||||
@@ -25,19 +25,20 @@
|
||||
|
||||
Some common filters include:
|
||||
|
||||
- `-k`/`--kernel` enables filtering kernels by name. `-d`/`--dispatch` enables filtering based on dispatch ID
|
||||
- `-b`/`--ipblocks` enables collects metrics for only the specified (one or more) IP Blocks.
|
||||
- `-k`/`--kernel` enables filtering kernels by name.
|
||||
- `-d`/`--dispatch` enables filtering based on dispatch ID.
|
||||
- `-b`/`--ipblocks` enables collects metrics for only the specified (one or more) hardware component blocks.
|
||||
|
||||
To view available metrics by IP Block you can use the `--list-metrics` argument to view a list of all available metrics organized by IP Block.
|
||||
To view available metrics by IP Block you can use the `--list-metrics` argument:
|
||||
```shell
|
||||
$ omniperf analyze --list-metrics <sys_arch>
|
||||
```
|
||||
|
||||
3. **Analyze at the command line**
|
||||
|
||||
After generating a local output folder (./workloads/\<name>), the command line tool can also be used to quickly interface with profiling results. View different metrics derived from your profiled results and get immediate access all metrics organized by IP block.
|
||||
After generating a local output folder (./workloads/\<name>), the command line tool can also be used to quickly interface with profiling results. View different metrics derived from your profiled results and get immediate access all metrics organized by IP blocks.
|
||||
|
||||
If no kernel, dispatch, or ipblock filters are applied at this stage, analysis will be reflective of the entirety of the profiling data.
|
||||
If no kernel, dispatch, or hardware block filters are applied at this stage, analysis will be reflective of the entirety of the profiling data.
|
||||
|
||||
To interact with profiling results from a different session, users just provide the workload path. `-p`/`--path` enables users to analyze existing profiling data in the Omniperf CLI.
|
||||
|
||||
@@ -55,7 +56,7 @@
|
||||
### Modes
|
||||
Modes change the fundamental behavior of the Omniperf command line tool. Depending on which mode is chosen, different command line options become available.
|
||||
|
||||
- **Profile**: Target application is launched on the local system utilizing AMD’s [ROC Profiler](https://github.com/ROCm-Developer-Tools/rocprofiler). Depending on the profiling options chosen, selected kernels, dispatches, and/or IP Blocks in the application are profiled and results are stored locally in an output folder (./workloads/\<name>).
|
||||
- **Profile**: Target application is launched on the local system using AMD’s [ROC Profiler](https://github.com/ROCm-Developer-Tools/rocprofiler). Depending on the profiling options chosen, selected kernels, dispatches, and/or hardware components in the application are profiled and results are stored locally in an output folder (./workloads/\<name>).
|
||||
|
||||
```shell
|
||||
$ omniperf profile --help
|
||||
@@ -65,7 +66,7 @@ Modes change the fundamental behavior of the Omniperf command line tool. Dependi
|
||||
|
||||
To gererate a lightweight GUI interface users can add the `--gui` flag to their analysis command.
|
||||
|
||||
This mode is designed to be a middle ground to the highly detailed Omniperf Grafana GUI and is great for users who want immediate access to an IP Block they’re already familiar with.
|
||||
This mode is designed to be a middle ground to the highly detailed Omniperf Grafana GUI and is great for users who want immediate access to a hardware component they’re already familiar with.
|
||||
|
||||
```shell
|
||||
$ omniperf analyze --help
|
||||
@@ -90,4 +91,4 @@ Standalone roofline analysis | profile | `--name`, `--roof-only`, `-- <profile_c
|
||||
Import a workload to database | database | `--import`, `--host`, `--username`, `--workload`, `--team`
|
||||
Remove a workload from database | database | `--remove`, `--host`, `--username`, `--workload`, `--team`
|
||||
Launch standalone GUI from CLI | analyze | `--path`, `--gui`
|
||||
Interact with profiling results from CLI | analyze | `--path`
|
||||
Interact with profiling results from CLI | analyze | `--path`
|
||||
|
||||
@@ -8,10 +8,10 @@
|
||||
|
||||
The [Omniperf](https://github.com/AMDResearch/omniperf) Tool is architecturally composed of three major components, as shown in the following figure.
|
||||
|
||||
- **Omniperf Profiling**: Acquire raw performance counters via application replay based on the [rocProfiler](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html). The counters are stored in a comma-seperated value, for further analyis. A set of MI200 specific micro benchmarks are also run to acquire the hierarchical roofline data. The roofline model is not available on earlier accelerators.
|
||||
- **Omniperf Profiling**: Acquire raw performance counters via application replay based on [rocProf](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html). The counters are stored in a comma-seperated value, for further analysis. A set of MI200 specific micro benchmarks are also run to acquire the hierarchical roofline data. The roofline model is not available on earlier accelerators.
|
||||
|
||||
- **Omniperf Grafana Analyzer**:
|
||||
- *Grafana database import*: All raw performance counters are imported into the backend MongoDB database for Grafana GUI analysis and visualization. Compatibility of previously generated data between Omniperf versions is not necessarily guarenteed.
|
||||
- *Grafana database import*: All raw performance counters are imported into the backend MongoDB database for Grafana GUI analysis and visualization. Compatibility of previously generated data between Omniperf versions is not necessarily guaranteed.
|
||||
- *Grafana GUI Analyzer*: A Grafana dashboard is designed to retrieve the raw counters info from the backend database. It also creates the relevant performance metrics and visualization.
|
||||
- **Omniperf Standalone GUI Analyzer**: A standalone GUI is provided to enable performance analysis without importing data into the backend database.
|
||||
|
||||
|
||||
|
До Ширина: | Высота: | Размер: 28 KiB |
|
До Ширина: | Высота: | Размер: 79 KiB |
|
До Ширина: | Высота: | Размер: 16 KiB |
|
До Ширина: | Высота: | Размер: 23 KiB |
|
До Ширина: | Высота: | Размер: 16 KiB |
|
До Ширина: | Высота: | Размер: 48 KiB |
|
До Ширина: | Высота: | Размер: 22 KiB |
|
До Ширина: | Высота: | Размер: 22 KiB |
|
До Ширина: | Высота: | Размер: 59 KiB |
|
До Ширина: | Высота: | Размер: 51 KiB |
|
До Ширина: | Высота: | Размер: 30 KiB |
|
До Ширина: | Высота: | Размер: 11 KiB |
|
До Ширина: | Высота: | Размер: 24 KiB |
|
До Ширина: | Высота: | Размер: 77 KiB |
|
До Ширина: | Высота: | Размер: 30 KiB |
|
До Ширина: | Высота: | Размер: 11 KiB |
|
До Ширина: | Высота: | Размер: 53 KiB |
|
До Ширина: | Высота: | Размер: 55 KiB |
|
До Ширина: | Высота: | Размер: 11 KiB |
|
До Ширина: | Высота: | Размер: 44 KiB |
|
До Ширина: | Высота: | Размер: 11 KiB |
|
До Ширина: | Высота: | Размер: 79 KiB |
|
До Ширина: | Высота: | Размер: 70 KiB |
|
До Ширина: | Высота: | Размер: 50 KiB |
|
До Ширина: | Высота: | Размер: 199 KiB |
|
До Ширина: | Высота: | Размер: 54 KiB |
|
До Ширина: | Высота: | Размер: 26 KiB |
|
До Ширина: | Высота: | Размер: 43 KiB |
|
До Ширина: | Высота: | Размер: 16 KiB |
|
До Ширина: | Высота: | Размер: 72 KiB |
|
До Ширина: | Высота: | Размер: 47 KiB |
|
До Ширина: | Высота: | Размер: 52 KiB |
|
После Ширина: | Высота: | Размер: 42 KiB |
|
После Ширина: | Высота: | Размер: 29 KiB |
|
После Ширина: | Высота: | Размер: 22 KiB |
|
После Ширина: | Высота: | Размер: 21 KiB |
|
После Ширина: | Высота: | Размер: 10 KiB |
|
После Ширина: | Высота: | Размер: 23 KiB |
|
После Ширина: | Высота: | Размер: 20 KiB |
|
После Ширина: | Высота: | Размер: 27 KiB |
|
После Ширина: | Высота: | Размер: 15 KiB |
|
После Ширина: | Высота: | Размер: 30 KiB |
@@ -0,0 +1,899 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="122.17907mm"
|
||||
height="59.61977mm"
|
||||
viewBox="0 0 122.17907 59.61977"
|
||||
version="1.1"
|
||||
id="svg5"
|
||||
sodipodi:docname="fabric.svg"
|
||||
inkscape:version="1.1.2 (0a00cf5339, 2022-02-04)"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/fabric.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg">
|
||||
<sodipodi:namedview
|
||||
id="namedview142"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
inkscape:zoom="2.8284271"
|
||||
inkscape:cx="251.55324"
|
||||
inkscape:cy="153.61895"
|
||||
inkscape:window-width="2490"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="70"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
inkscape:current-layer="layer1"
|
||||
fit-margin-top="0"
|
||||
fit-margin-left="0"
|
||||
fit-margin-right="0"
|
||||
fit-margin-bottom="0" />
|
||||
<defs
|
||||
id="defs2">
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="marker10337"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path10335" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Send"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.2,0,0,-0.2,-1.2,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1319" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313" />
|
||||
</marker>
|
||||
<rect
|
||||
x="83.387405"
|
||||
y="34.737923"
|
||||
width="275.12451"
|
||||
height="59.135487"
|
||||
id="rect97993" />
|
||||
<rect
|
||||
x="428.84567"
|
||||
y="387.25235"
|
||||
width="209.04202"
|
||||
height="89.898453"
|
||||
id="rect64747" />
|
||||
<rect
|
||||
x="396.33554"
|
||||
y="373.98026"
|
||||
width="250.97929"
|
||||
height="100.31375"
|
||||
id="rect58746" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lstart"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(0.8,0,0,0.8,10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20531" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-3" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-3" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend-7"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534-3" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend-7-9"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534-3-2" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend-7-9-7"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534-3-2-6" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-3-0" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend-7-7"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534-3-0" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend-7-7-2"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path20534-3-0-1" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2" />
|
||||
<rect
|
||||
x="83.387405"
|
||||
y="34.737923"
|
||||
width="275.12451"
|
||||
height="59.135487"
|
||||
id="rect97993-7" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-3"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-5" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-3-2"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-5-9" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2" />
|
||||
<rect
|
||||
x="83.387405"
|
||||
y="34.737923"
|
||||
width="275.12451"
|
||||
height="59.135487"
|
||||
id="rect97993-7-7" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-36"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-7" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5" />
|
||||
<rect
|
||||
x="83.387405"
|
||||
y="34.737923"
|
||||
width="275.12451"
|
||||
height="59.135487"
|
||||
id="rect97993-7-7-6" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-36-0"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-7-9" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5-3" />
|
||||
<rect
|
||||
x="83.387405"
|
||||
y="34.737923"
|
||||
width="275.12451"
|
||||
height="59.135487"
|
||||
id="rect97993-7-7-6-6" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-3-2-9"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-5-9-2" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-36-0-3"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-7-9-7" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5-3-3" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5-3-3-6" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-36-0-2"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-7-9-70" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-36-3"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-7-6" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-367"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-53" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-6"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path1313-2" />
|
||||
</marker>
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5-3-6" />
|
||||
<rect
|
||||
x="97.144325"
|
||||
y="226.69614"
|
||||
width="148.65651"
|
||||
height="56.321774"
|
||||
id="rect6328-0-6-8-2-2-5-3-3-1" />
|
||||
</defs>
|
||||
<g
|
||||
id="layer1"
|
||||
transform="translate(-3.1044175,-14.33817)">
|
||||
<g
|
||||
id="g3747"
|
||||
transform="translate(0,0.18150994)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136377;stroke-opacity:1"
|
||||
id="rect31"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="3.172606"
|
||||
y="40.275291" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,-10.07571,10.507238)"
|
||||
id="text6326"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="45.007812"
|
||||
y="0"><tspan
|
||||
x="126.48828"
|
||||
y="240.85156"
|
||||
id="tspan43284"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43282">Total Fabric </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43288"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43286">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="m 23.417828,44.182431 h 7.744823"
|
||||
id="path20529"
|
||||
sodipodi:nodetypes="cc" />
|
||||
<g
|
||||
id="g3739"
|
||||
transform="translate(10.059995,2.72298)">
|
||||
<rect
|
||||
style="opacity:0.28;fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136377;stroke-opacity:1"
|
||||
id="rect31-4"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="31.404562"
|
||||
y="28.797853" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,18.156244,-0.9701983)"
|
||||
id="text6326-8"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0);opacity:0.28;fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="133.16016"
|
||||
y="240.85156"
|
||||
id="tspan43292"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43290">32B Read </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43296"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43294">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g204"
|
||||
transform="translate(10.059995)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136377;stroke-opacity:1"
|
||||
id="rect31-4-1"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="31.404562"
|
||||
y="14.407581" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,18.156246,-15.360471)"
|
||||
id="text6326-8-2"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="133.16016"
|
||||
y="240.85156"
|
||||
id="tspan43300"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43298">64B Read </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43304"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43302">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g33085"
|
||||
transform="translate(0,0.26317766)">
|
||||
<rect
|
||||
style="opacity:1;fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect31-4-6"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="41.464558"
|
||||
y="48.84304" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,28.216241,19.074987)"
|
||||
id="text6326-8-3"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-3);opacity:1;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.997231;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="132.14062"
|
||||
y="240.85156"
|
||||
id="tspan43308"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43306">32B Write </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43312"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43310">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,-0.0308419,9.5190479)"
|
||||
id="text58744"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect58746);fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.997231;stroke-miterlimit:4;stroke-dasharray:none" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,-0.0308419,9.5190479)"
|
||||
id="text64745"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect64747);fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.997231;stroke-miterlimit:4;stroke-dasharray:none" />
|
||||
<g
|
||||
id="g54852"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,28.426265,12.492382)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-0"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="25.295307"
|
||||
y="104.1685" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,-0.40746419,46.416146)"
|
||||
id="text6326-8-2-2"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-3);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="132.14062"
|
||||
y="240.85156"
|
||||
id="tspan43316"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43314">64B Write </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43320"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43318">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 51.601269,66.186146 V 61.556441"
|
||||
id="path69447-9-7-5-2-3-93-6" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="M 31.07042,44.609772 V 26.783617"
|
||||
id="path69449" />
|
||||
<g
|
||||
id="g6799"
|
||||
transform="translate(-0.85908839)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136377;stroke-opacity:1"
|
||||
id="rect31-4-1-7"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="73.9366"
|
||||
y="14.407581" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,60.688286,-15.360471)"
|
||||
id="text6326-8-2-8"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="109.13281"
|
||||
y="240.85156"
|
||||
id="tspan43326"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43322">Uncached </tspan><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43324">Read </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43330"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43328">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,23.273945,0.03952421)"
|
||||
id="text97991"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect97993);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:2.64068px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.0660172"
|
||||
x="65.804695"
|
||||
y="17.049156"
|
||||
id="text104993"><tspan
|
||||
id="tspan104991"
|
||||
style="stroke-width:0.0660172"
|
||||
x="65.804695"
|
||||
y="17.049156">x2</tspan></text>
|
||||
<g
|
||||
id="g23519"
|
||||
transform="translate(-8.0320305,-0.27460261)">
|
||||
<g
|
||||
id="g33659">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.136377;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2"
|
||||
width="20.273424"
|
||||
height="7.6810331"
|
||||
x="81.756866"
|
||||
y="66.459923" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.13637766,0,0,0.13637766,68.508552,36.707843)"
|
||||
id="text6326-8-2-8-6"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="108.11328"
|
||||
y="240.85156"
|
||||
id="tspan43336"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43332">Uncached </tspan><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43334">Write </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43340"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43338">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,23.273945,52.107839)"
|
||||
id="text97991-3"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect97993-7);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<g
|
||||
id="g10025"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,23.359942,44.057639)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2-9"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="81.170959"
|
||||
y="9.7946386" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,55.363782,-47.957714)"
|
||||
id="text6326-8-2-8-6-3"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2-2);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="141.15234"
|
||||
y="240.85156"
|
||||
id="tspan43344"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43342">Atomic
|
||||
</tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43348"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43346">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,23.273945,37.671054)"
|
||||
id="text97991-3-6"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect97993-7-7);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,23.273945,66.483549)"
|
||||
id="text97991-3-6-7"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect97993-7-7-6);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<g
|
||||
id="g10025-9-6"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,62.851448,9.3577801)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2-9-1-1"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="81.170959"
|
||||
y="9.7946386" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,55.363782,-47.957714)"
|
||||
id="text6326-8-2-8-6-3-2-8"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2-2-5-3);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="130.42188"
|
||||
y="240.85156"
|
||||
id="tspan43352"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43350">HBM Read
|
||||
</tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43356"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43354">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,23.273945,14.460151)"
|
||||
id="text97991-3-6-7-7"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect97993-7-7-6-6);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<g
|
||||
id="g13641"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,62.851448,26.472254)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2-9-1-1-7"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="81.170959"
|
||||
y="9.7946386" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,55.363782,-47.957714)"
|
||||
id="text6326-8-2-8-6-3-2-8-5"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2-2-5-3-3);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="117.96094"
|
||||
y="240.85156"
|
||||
id="tspan43360"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43358">Remote Read
|
||||
</tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43364"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43362">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:0.252, 0.252;stroke-dashoffset:0;stroke-opacity:1;marker-end:url(#Arrow1Mend-36-0)"
|
||||
d="M 61.835501,17.827625 H 72.628293"
|
||||
id="path69449-1-4-5-5-0" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="M 31.07042,44.18384 V 61.525736"
|
||||
id="path69449-9" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.251943;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="M 30.944463,26.804724 H 114.94704"
|
||||
id="path69449-3" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 51.601269,28.986028 V 26.930672"
|
||||
id="path69447-9-7-5-2" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="m 52.807545,30.383236 -1.17844,-1.410071"
|
||||
id="path69447-9-7-5-6-7" />
|
||||
<ellipse
|
||||
style="fill:#ffffff;stroke:#000000;stroke-width:0.0583236;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="path2455-3-6-3-1"
|
||||
cx="-51.593498"
|
||||
cy="28.936687"
|
||||
rx="0.26853767"
|
||||
ry="0.29816741"
|
||||
transform="scale(-1,1)" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:0.3"
|
||||
d="M 51.601269,31.456218 V 30.329011"
|
||||
id="path69447-9-7-5-2-5" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 51.601269,26.688316 V 22.058611"
|
||||
id="path69447-9-7-5-2-3" />
|
||||
<ellipse
|
||||
style="fill:#ffffff;stroke:#000000;stroke-width:0.107;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="path2455-3-6-3-6"
|
||||
cx="51.61137"
|
||||
cy="28.97942"
|
||||
rx="0.49265727"
|
||||
ry="0.54701579" />
|
||||
<ellipse
|
||||
style="fill:#ffffff;stroke:#000000;stroke-width:0.107;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="path2455-3-6-3-6-2"
|
||||
cx="52.914024"
|
||||
cy="30.493517"
|
||||
rx="0.49265727"
|
||||
ry="0.54701579" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 114.82717,31.453752 V 22.110106"
|
||||
id="path69447-9-7-5-2-3-9" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252188;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="m 30.9454,61.491997 h 84.16591"
|
||||
id="path69449-3-1" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 51.601269,61.398519 V 56.768814"
|
||||
id="path69447-9-7-5-2-3-93" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 75.335667,61.434975 V 56.80527"
|
||||
id="path69447-9-7-5-2-3-93-0" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 83.861548,66.11139 V 61.481685"
|
||||
id="path69447-9-7-5-2-3-93-62" />
|
||||
<g
|
||||
id="g10025-9-6-8"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,63.102859,44.045664)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2-9-1-1-79"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="81.170959"
|
||||
y="9.7946386" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,55.363782,-47.957714)"
|
||||
id="text6326-8-2-8-6-3-2-8-2"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2-2-5-3-6);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="129.40234"
|
||||
y="240.85156"
|
||||
id="tspan43368"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43366">HBM Write </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43372"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43370">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g13641-0"
|
||||
transform="matrix(0.51544312,0,0,0.51544312,63.102859,61.160138)">
|
||||
<rect
|
||||
style="fill:none;fill-rule:evenodd;stroke:#000000;stroke-width:0.264583;stroke-opacity:1"
|
||||
id="rect31-4-1-7-2-9-1-1-7-2"
|
||||
width="39.332031"
|
||||
height="14.901806"
|
||||
x="81.170959"
|
||||
y="9.7946386" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="matrix(0.26458333,0,0,0.26458333,55.363782,-47.957714)"
|
||||
id="text6326-8-2-8-6-3-2-8-5-3"
|
||||
style="font-style:normal;font-weight:normal;font-size:16px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect6328-0-6-8-2-2-5-3-3-1);fill:#000000;fill-opacity:1;stroke:none"
|
||||
x="158.11719"
|
||||
y="0"><tspan
|
||||
x="116.94141"
|
||||
y="240.85156"
|
||||
id="tspan43376"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43374">Remote Write </tspan></tspan><tspan
|
||||
x="134.80859"
|
||||
y="260.85156"
|
||||
id="tspan43380"><tspan
|
||||
style="text-align:center;text-anchor:middle"
|
||||
id="tspan43378">Requests</tspan></tspan></text>
|
||||
</g>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.252;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||
d="M 115.07858,66.141636 V 56.79799"
|
||||
id="path69447-9-7-5-2-3-9-7" />
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 33 KiB |
|
После Ширина: | Высота: | Размер: 8.0 KiB |
|
После Ширина: | Высота: | Размер: 45 KiB |
|
После Ширина: | Высота: | Размер: 20 KiB |
|
После Ширина: | Высота: | Размер: 15 KiB |
|
После Ширина: | Высота: | Размер: 25 KiB |
@@ -0,0 +1,584 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
width="127.5mm"
|
||||
height="32.5mm"
|
||||
viewBox="0 0 127.5 32.5"
|
||||
version="1.1"
|
||||
id="svg8"
|
||||
inkscape:version="0.92.5 (2060ec1f9f, 2020-04-08)"
|
||||
sodipodi:docname="l1perf_model2.svg"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/l1perf_model.png"
|
||||
inkscape:export-xdpi="96"
|
||||
inkscape:export-ydpi="96">
|
||||
<defs
|
||||
id="defs2">
|
||||
<marker
|
||||
inkscape:stockid="Arrow2Mend"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow2Mend"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
id="path4559"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.625;stroke-linejoin:round;stroke-opacity:1"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
transform="scale(-0.6)"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow2Mstart"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow2Mstart"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
id="path4556"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.625;stroke-linejoin:round;stroke-opacity:1"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
transform="scale(0.6)"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow2Lstart"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow2Lstart"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
id="path4550"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.625;stroke-linejoin:round;stroke-opacity:1"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
transform="matrix(1.1,0,0,1.1,1.1,0)"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:isstock="true"
|
||||
style="overflow:visible"
|
||||
id="marker4982"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Lend">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1.00000003pt;stroke-opacity:1"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path4980"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow1Lend"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow1Lend-3"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true"
|
||||
inkscape:collect="always">
|
||||
<path
|
||||
inkscape:connector-curvature="0"
|
||||
id="path4535-6"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1.00000003pt;stroke-opacity:1"
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow2Lstart"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow2Lstart-8"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
id="path4550-1"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.625;stroke-linejoin:round;stroke-opacity:1"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
transform="matrix(1.1,0,0,1.1,1.1,0)"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow2Lstart"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow2Lstart-0"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
id="path4550-3"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.625;stroke-linejoin:round;stroke-opacity:1"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
transform="matrix(1.1,0,0,1.1,1.1,0)"
|
||||
inkscape:connector-curvature="0" />
|
||||
</marker>
|
||||
<marker
|
||||
inkscape:stockid="Arrow1Lend"
|
||||
orient="auto"
|
||||
refY="0"
|
||||
refX="0"
|
||||
id="Arrow1Lend-3-4"
|
||||
style="overflow:visible"
|
||||
inkscape:isstock="true"
|
||||
inkscape:collect="always">
|
||||
<path
|
||||
inkscape:connector-curvature="0"
|
||||
id="path4535-6-0"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:1.00000003pt;stroke-opacity:1"
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)" />
|
||||
</marker>
|
||||
</defs>
|
||||
<sodipodi:namedview
|
||||
id="base"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:zoom="5.6"
|
||||
inkscape:cx="293.09582"
|
||||
inkscape:cy="20.610939"
|
||||
inkscape:document-units="mm"
|
||||
inkscape:current-layer="layer1"
|
||||
showgrid="false"
|
||||
inkscape:window-width="2488"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="72"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
showguides="true" />
|
||||
<metadata
|
||||
id="metadata5">
|
||||
<rdf:RDF>
|
||||
<cc:Work
|
||||
rdf:about="">
|
||||
<dc:format>image/svg+xml</dc:format>
|
||||
<dc:type
|
||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||
<dc:title />
|
||||
</cc:Work>
|
||||
</rdf:RDF>
|
||||
</metadata>
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1"
|
||||
transform="translate(0,-264.5)">
|
||||
<rect
|
||||
id="rect3717"
|
||||
width="12.756697"
|
||||
height="31.844492"
|
||||
x="0.16001961"
|
||||
y="264.8248"
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26499999;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.82222223px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="-280.79251"
|
||||
y="7.3169599"
|
||||
id="text4526"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan1391"
|
||||
x="-280.79251"
|
||||
y="7.3169599">Compute Unit</tspan></text>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:10.58333302px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="19.342445"
|
||||
y="269.90857"
|
||||
id="text4816"><tspan
|
||||
sodipodi:role="line"
|
||||
x="19.342445"
|
||||
y="269.90857"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.26458332"
|
||||
id="tspan4818">Cmd/Data</tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26753739;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4843"
|
||||
width="52.205414"
|
||||
height="31.841953"
|
||||
x="37.515408"
|
||||
y="264.82605"
|
||||
ry="0"
|
||||
rx="0" />
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26433226;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847"
|
||||
width="12.880525"
|
||||
height="12.567707"
|
||||
x="37.579292"
|
||||
y="264.8248"
|
||||
rx="1.0342027"
|
||||
ry="0.37797582" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:5.28136396px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.13203409"
|
||||
x="44.815056"
|
||||
y="19.832005"
|
||||
id="text4851"
|
||||
transform="scale(1.3075045,0.76481574)"><tspan
|
||||
sodipodi:role="line"
|
||||
x="44.815056"
|
||||
y="24.504774"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:4.23333311px;line-height:0;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.13203409"
|
||||
id="tspan4857" /></text>
|
||||
<flowRoot
|
||||
xml:space="preserve"
|
||||
id="flowRoot4859"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none"><flowRegion
|
||||
id="flowRegion4861"><rect
|
||||
id="rect4863"
|
||||
width="71.071426"
|
||||
height="43.57143"
|
||||
x="195.35715"
|
||||
y="38.59111" /></flowRegion><flowPara
|
||||
id="flowPara4865" /></flowRoot> <text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.25103042"
|
||||
x="40.514164"
|
||||
y="264.33435"
|
||||
id="text1823"
|
||||
transform="scale(0.98186128,1.0184738)"><tspan
|
||||
sodipodi:role="line"
|
||||
x="40.514164"
|
||||
y="264.33435"
|
||||
id="tspan1813"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"><tspan
|
||||
x="40.514164"
|
||||
y="264.33435"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"
|
||||
id="tspan1811">Address </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="39.07756"
|
||||
y="266.98016"
|
||||
id="tspan1817"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"><tspan
|
||||
x="39.07756"
|
||||
y="266.98016"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"
|
||||
id="tspan1815">Processing </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="42.574501"
|
||||
y="269.62601"
|
||||
id="tspan1821"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"><tspan
|
||||
x="42.574501"
|
||||
y="269.62601"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666679px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25103042"
|
||||
id="tspan1819">Unit</tspan></tspan></text>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.21152194;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;marker-start:url(#Arrow2Mstart);marker-end:url(#Arrow2Mend)"
|
||||
d="m 43.986979,277.84477 v 5.7019"
|
||||
id="path4904"
|
||||
inkscape:connector-curvature="0" />
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26499999;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-2"
|
||||
width="12.945681"
|
||||
height="12.567707"
|
||||
x="37.514137"
|
||||
y="284.10156"
|
||||
rx="1.0394342"
|
||||
ry="0.37797582" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:10.58333302px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="-283.25629"
|
||||
y="42.902218"
|
||||
id="text5371"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan5369"
|
||||
x="-283.25629"
|
||||
y="42.902218"
|
||||
style="font-size:2.11666656px;stroke-width:0.26458332">Sync</tspan></text>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:1.25406051px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.2351373"
|
||||
x="41.356129"
|
||||
y="288.49612"
|
||||
id="text940"><tspan
|
||||
sodipodi:role="line"
|
||||
x="41.356129"
|
||||
y="288.49612"
|
||||
id="tspan930"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"><tspan
|
||||
x="41.356129"
|
||||
y="288.49612"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"
|
||||
id="tspan928">Data </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="38.231773"
|
||||
y="291.14197"
|
||||
id="tspan934"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"><tspan
|
||||
x="38.231773"
|
||||
y="291.14197"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"
|
||||
id="tspan932">Processing </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="41.728718"
|
||||
y="293.78778"
|
||||
id="tspan938"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"><tspan
|
||||
x="41.728718"
|
||||
y="293.78778"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.2351373"
|
||||
id="tspan936">Unit</tspan></tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26499999;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-6"
|
||||
width="12.945681"
|
||||
height="12.567707"
|
||||
x="51.913925"
|
||||
y="264.8251"
|
||||
rx="1.0394342"
|
||||
ry="0.37797582" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.25566792"
|
||||
x="53.571041"
|
||||
y="267.50827"
|
||||
id="text1809"><tspan
|
||||
sodipodi:role="line"
|
||||
x="53.571041"
|
||||
y="267.50827"
|
||||
id="tspan1795"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="53.571041"
|
||||
y="267.50827"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan1793">Virtual To </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="54.174622"
|
||||
y="270.15408"
|
||||
id="tspan1799"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="54.174622"
|
||||
y="270.15408"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan1797">Physical </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="54.265057"
|
||||
y="272.79993"
|
||||
id="tspan1803"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="54.265057"
|
||||
y="272.79993"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan1801">Address </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="52.713211"
|
||||
y="275.44577"
|
||||
id="tspan1807"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="52.713211"
|
||||
y="275.44577"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.11666656px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan1805">Translation</tspan></tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26499999;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-6-4"
|
||||
width="12.945681"
|
||||
height="12.567707"
|
||||
x="66.313728"
|
||||
y="264.8251"
|
||||
rx="1.0394342"
|
||||
ry="0.37797582" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:1.36356223px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.25566792"
|
||||
x="72.785965"
|
||||
y="270.58688"
|
||||
id="text1599"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan1825"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle"
|
||||
x="73.178444"
|
||||
y="270.58688">Tag </tspan><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan1827"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle"
|
||||
x="72.785965"
|
||||
y="273.67368">RAM</tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.25661802;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-6-4-5"
|
||||
width="27.324272"
|
||||
height="5.5836082"
|
||||
x="51.880585"
|
||||
y="277.95538"
|
||||
rx="2.1939197"
|
||||
ry="0.16792791" />
|
||||
<flowRoot
|
||||
xml:space="preserve"
|
||||
id="flowRoot4896-6-6-6"
|
||||
style="font-style:normal;font-weight:normal;font-size:5.33333349px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none"
|
||||
transform="matrix(0.25566792,0,0,0.25566792,21.981703,13.242276)"><flowRegion
|
||||
id="flowRegion4898-4-2-9"
|
||||
style="font-size:5.33333349px"><rect
|
||||
id="rect4900-0-6-8"
|
||||
width="74.800339"
|
||||
height="17.377857"
|
||||
x="220.71429"
|
||||
y="50.733971"
|
||||
style="font-size:5.33333349px" /></flowRegion><flowPara
|
||||
style="font-size:9.24484825px;text-align:center;text-anchor:middle"
|
||||
id="flowPara5633-2" /></flowRoot> <text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:1.36355662px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.25566792"
|
||||
x="59.399857"
|
||||
y="280.12439"
|
||||
id="text914"><tspan
|
||||
sodipodi:role="line"
|
||||
x="59.399857"
|
||||
y="280.12439"
|
||||
id="tspan908"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="59.399857"
|
||||
y="280.12439"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan906">L1 Cache </tspan></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="59.399857"
|
||||
y="283.21121"
|
||||
id="tspan912"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"><tspan
|
||||
x="59.399857"
|
||||
y="283.21121"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.25566792"
|
||||
id="tspan910">Controller</tspan></tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.25977203;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-6-4-5-7"
|
||||
width="27.322025"
|
||||
height="12.587595"
|
||||
x="51.882832"
|
||||
y="284.0853"
|
||||
rx="2.1937392"
|
||||
ry="0.37857395" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944444px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.25566792;"
|
||||
x="61.700409"
|
||||
y="289.7738"
|
||||
id="text926"><tspan
|
||||
sodipodi:role="line"
|
||||
x="61.700409"
|
||||
y="289.7738"
|
||||
id="tspan920"
|
||||
style="stroke-width:0.25566792;-inkscape-font-specification:'sans-serif, Normal';font-family:sans-serif;font-weight:normal;font-style:normal;font-stretch:normal;font-variant:normal;font-size:2.46944444px;text-anchor:start;text-align:start;writing-mode:lr;font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;"><tspan
|
||||
x="61.700409"
|
||||
y="289.7738"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944444px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr;text-anchor:start;stroke-width:0.25566792;"
|
||||
id="tspan916">Cache</tspan><tspan
|
||||
dx="0"
|
||||
x="69.380043"
|
||||
y="289.7738"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944444px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr;text-anchor:start;stroke-width:0.25566792;"
|
||||
id="tspan918" /></tspan><tspan
|
||||
sodipodi:role="line"
|
||||
x="62.822392"
|
||||
y="292.8606"
|
||||
id="tspan924"
|
||||
style="stroke-width:0.25566792;-inkscape-font-specification:'sans-serif, Normal';font-family:sans-serif;font-weight:normal;font-style:normal;font-stretch:normal;font-variant:normal;font-size:2.46944444px;text-anchor:start;text-align:start;writing-mode:lr;font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;"><tspan
|
||||
x="62.822392"
|
||||
y="292.8606"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944444px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr;text-anchor:start;stroke-width:0.25566792;"
|
||||
id="tspan922">RAM</tspan></tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.35042927;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
id="rect4847-6-4-5-1"
|
||||
width="8.9711571"
|
||||
height="31.713299"
|
||||
x="80.756233"
|
||||
y="264.86783"
|
||||
rx="0.72031188"
|
||||
ry="0.95378256" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.36361098px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="-280.84842"
|
||||
y="85.92308"
|
||||
id="text4526-5"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan5786"
|
||||
x="-280.84842"
|
||||
y="85.92308"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle">L2 Memory Interface</tspan></text>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:10.58333302px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="22.10359"
|
||||
y="289.48212"
|
||||
id="text4816-5"><tspan
|
||||
sodipodi:role="line"
|
||||
x="22.10359"
|
||||
y="289.48212"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.26458332"
|
||||
id="tspan4818-8">Data</tspan></text>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.17609379;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;marker-start:url(#Arrow2Lstart);marker-end:url(#Arrow1Lend-3)"
|
||||
d="M 90.208048,280.72448 H 114.26491"
|
||||
id="path4530-75"
|
||||
inkscape:connector-curvature="0" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:10.58333302px;line-height:1.25;font-family:sans-serif;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="99.92643"
|
||||
y="278.60959"
|
||||
id="text4816-3"><tspan
|
||||
sodipodi:role="line"
|
||||
x="99.92643"
|
||||
y="278.60959"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.46944451px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:start;writing-mode:lr-tb;text-anchor:start;stroke-width:0.26458332"
|
||||
id="tspan4818-5">Bus</tspan></text>
|
||||
<rect
|
||||
id="rect3717-6"
|
||||
width="12.756697"
|
||||
height="31.844494"
|
||||
x="114.5292"
|
||||
y="264.75391"
|
||||
style="fill:none;stroke:#000000;stroke-width:0.26499999;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.36361122px;line-height:1.25;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:middle;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458332"
|
||||
x="-280.73953"
|
||||
y="121.95969"
|
||||
id="text4526-5-2"
|
||||
transform="rotate(-90)"><tspan
|
||||
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.82222223px;font-family:sans-serif;-inkscape-font-specification:'sans-serif, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;font-feature-settings:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle;stroke-width:0.26458332"
|
||||
sodipodi:role="line"
|
||||
id="tspan5786-9"
|
||||
x="-280.73953"
|
||||
y="121.95969">L2 Cache</tspan></text>
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.17609379;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;marker-start:url(#Arrow2Lstart-8)"
|
||||
d="m 13.179534,290.78598 h 24.05686"
|
||||
id="path4530-75-1"
|
||||
inkscape:connector-curvature="0" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.17696008;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#Arrow1Lend-3-4)"
|
||||
d="M 13.04999,271.40894 H 37.370029"
|
||||
id="path4530-75-3"
|
||||
inkscape:connector-curvature="0" />
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 36 KiB |
|
После Ширина: | Высота: | Размер: 55 KiB |
|
После Ширина: | Высота: | Размер: 20 KiB |
|
После Ширина: | Высота: | Размер: 48 KiB |
|
После Ширина: | Высота: | Размер: 66 KiB |
|
После Ширина: | Высота: | Размер: 21 KiB |
|
После Ширина: | Высота: | Размер: 17 KiB |
|
После Ширина: | Высота: | Размер: 33 KiB |
|
После Ширина: | Высота: | Размер: 18 KiB |
@@ -0,0 +1,393 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="78.030128mm"
|
||||
height="59.956924mm"
|
||||
viewBox="0 0 78.030128 59.956924"
|
||||
version="1.1"
|
||||
id="svg5"
|
||||
inkscape:version="1.1.2 (0a00cf5339, 2022-02-04)"
|
||||
sodipodi:docname="lds.svg"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/lds.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg">
|
||||
<sodipodi:namedview
|
||||
id="namedview7"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
inkscape:zoom="2.8284271"
|
||||
inkscape:cx="7.9549513"
|
||||
inkscape:cy="93.161318"
|
||||
inkscape:window-width="2490"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="70"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
inkscape:current-layer="layer1"
|
||||
fit-margin-top="0"
|
||||
fit-margin-left="0"
|
||||
fit-margin-right="0"
|
||||
fit-margin-bottom="0" />
|
||||
<defs
|
||||
id="defs2">
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="marker35467"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path35465" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow2Mend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow2Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(-0.6)"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:0.625;stroke-linejoin:round"
|
||||
id="path34770" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="marker35449"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path35447" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path34752" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="marker35115"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow2Mstart"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(0.6)"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:0.625;stroke-linejoin:round"
|
||||
id="path35113" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow2Mstart"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow2Mstart"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(0.6)"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:0.625;stroke-linejoin:round"
|
||||
id="path34767" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lstart"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Lstart"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(0.8,0,0,0.8,10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path34743" />
|
||||
</marker>
|
||||
<rect
|
||||
x="175.93893"
|
||||
y="253.99336"
|
||||
width="234.12074"
|
||||
height="100.54605"
|
||||
id="rect3930" />
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Mend-5"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(-0.4,0,0,-0.4,-4,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path34752-6" />
|
||||
</marker>
|
||||
</defs>
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1"
|
||||
transform="translate(-38.921551,-41.961155)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.5;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect846"
|
||||
width="77.212677"
|
||||
height="40.499405"
|
||||
x="39.330276"
|
||||
y="61.168674" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
transform="scale(0.26458333)"
|
||||
id="text3928"
|
||||
style="font-style:normal;font-weight:normal;font-size:40px;line-height:1.25;font-family:sans-serif;white-space:pre;shape-inside:url(#rect3930);fill:#000000;fill-opacity:1;stroke:none" />
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.5;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect846-3"
|
||||
width="31.886179"
|
||||
height="13.072078"
|
||||
x="39.171551"
|
||||
y="42.211155" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="47.24173"
|
||||
y="49.892689"
|
||||
id="text25740"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan25738"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="47.24173"
|
||||
y="49.892689">SIMD 0/1</tspan></text>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="92.864143"
|
||||
y="49.892689"
|
||||
id="text25740-7"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan25738-5"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="92.864143"
|
||||
y="49.892689">SIMD 2/3</tspan></text>
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.5;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect846-3-3"
|
||||
width="31.886179"
|
||||
height="13.072078"
|
||||
x="84.815498"
|
||||
y="42.211155" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.239054px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker35115);marker-end:url(#Arrow2Mend)"
|
||||
d="m 55.11464,55.888713 v 4.575516"
|
||||
id="path35236" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:0.239437px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-start:url(#marker35115);marker-end:url(#Arrow2Mend)"
|
||||
d="m 100.75859,55.863706 v 4.584345"
|
||||
id="path35236-2" />
|
||||
<g
|
||||
id="g91757"
|
||||
transform="translate(0.09337305,-1.490623)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.5;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect846-3-9"
|
||||
width="57.741043"
|
||||
height="6.0837841"
|
||||
x="49.066093"
|
||||
y="64.83651" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="62.166679"
|
||||
y="69.054901"
|
||||
id="text43239"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan43237"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="62.166679"
|
||||
y="69.054901">Conflict Detection</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g94249">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.5;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect846-3-9-7"
|
||||
width="57.741043"
|
||||
height="6.0837841"
|
||||
x="49.159466"
|
||||
y="69.429672" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="69.083069"
|
||||
y="73.648064"
|
||||
id="text43239-9"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan43237-2"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="69.083069"
|
||||
y="73.648064">Scheduler</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g75031">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.499999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect53227"
|
||||
width="10.155521"
|
||||
height="20.193951"
|
||||
x="41.817165"
|
||||
y="78.846886" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="-95.113167"
|
||||
y="48.210091"
|
||||
id="text58467"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan58465"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="-95.113167"
|
||||
y="48.210091">Bank 0</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g75036"
|
||||
transform="translate(-0.28890355,0.10812378)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.499999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect53227-1"
|
||||
width="10.155521"
|
||||
height="20.193951"
|
||||
x="55.210358"
|
||||
y="78.738762" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="-95.005043"
|
||||
y="61.603283"
|
||||
id="text58467-2"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan58465-7"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="-95.005043"
|
||||
y="61.603283">Bank 1</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g75041"
|
||||
transform="translate(-0.42640324,0.12826538)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.499999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect53227-0"
|
||||
width="10.155521"
|
||||
height="20.193951"
|
||||
x="68.452148"
|
||||
y="78.71862" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="-94.984901"
|
||||
y="74.845078"
|
||||
id="text58467-9"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan58465-3"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="-94.984901"
|
||||
y="74.845078">Bank 2</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g75046"
|
||||
transform="translate(0,-0.36049652)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.499999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect53227-6"
|
||||
width="10.155521"
|
||||
height="20.193951"
|
||||
x="81.130043"
|
||||
y="79.207382" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="-95.473663"
|
||||
y="87.522972"
|
||||
id="text58467-0"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan58465-6"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="-95.473663"
|
||||
y="87.522972">Bank 3</tspan></text>
|
||||
</g>
|
||||
<g
|
||||
id="g75106"
|
||||
transform="translate(0,0.88236237)">
|
||||
<rect
|
||||
style="fill:none;stroke:#000000;stroke-width:0.499999;stroke-miterlimit:4;stroke-dasharray:none"
|
||||
id="rect53227-2"
|
||||
width="10.155521"
|
||||
height="20.193951"
|
||||
x="103.69362"
|
||||
y="77.964523" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="-95.307404"
|
||||
y="110.08656"
|
||||
id="text58467-6"
|
||||
transform="rotate(-90)"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan58465-1"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="-95.307404"
|
||||
y="110.08656">Bank 31</tspan></text>
|
||||
</g>
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:3.52778px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="95.809242"
|
||||
y="89.162628"
|
||||
id="text80928"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan80926"
|
||||
style="font-size:3.52778px;stroke-width:0.264583"
|
||||
x="95.809242"
|
||||
y="89.162628">...</tspan></text>
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 14 KiB |
|
После Ширина: | Высота: | Размер: 39 KiB |
|
После Ширина: | Высота: | Размер: 86 KiB |
|
После Ширина: | Высота: | Размер: 26 KiB |
|
После Ширина: | Высота: | Размер: 31 KiB |
|
После Ширина: | Высота: | Размер: 34 KiB |
|
После Ширина: | Высота: | Размер: 34 KiB |
|
После Ширина: | Высота: | Размер: 108 KiB |
|
После Ширина: | Высота: | Размер: 662 B |
@@ -0,0 +1,71 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="23.89308mm"
|
||||
height="24.000153mm"
|
||||
viewBox="0 0 23.89308 24.000153"
|
||||
version="1.1"
|
||||
id="svg370"
|
||||
inkscape:version="1.1.2 (0a00cf5339, 2022-02-04)"
|
||||
sodipodi:docname="nosplit.svg"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/nosplit.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg">
|
||||
<sodipodi:namedview
|
||||
id="namedview372"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
fit-margin-top="0"
|
||||
fit-margin-left="0"
|
||||
fit-margin-right="0"
|
||||
fit-margin-bottom="0"
|
||||
inkscape:zoom="6.2217172"
|
||||
inkscape:cx="-18.242552"
|
||||
inkscape:cy="62.764023"
|
||||
inkscape:window-width="2490"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="70"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
inkscape:current-layer="layer1" />
|
||||
<defs
|
||||
id="defs367" />
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1"
|
||||
transform="translate(-30.085626,-76.587497)">
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="m 30.085626,88.555587 h 23.89308"
|
||||
id="path69449-3-1"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/nosplit.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="m 34.808926,76.587497 v 10.78438"
|
||||
id="path69449-3-1-6"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/nosplit.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="M 48.947196,89.803267 V 100.58765"
|
||||
id="path69449-3-1-6-7"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/nosplit.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 2.7 KiB |
|
После Ширина: | Высота: | Размер: 110 KiB |
|
После Ширина: | Высота: | Размер: 75 KiB |
|
После Ширина: | Высота: | Размер: 41 KiB |
|
После Ширина: | Высота: | Размер: 15 KiB |
|
После Ширина: | Высота: | Размер: 15 KiB |
|
После Ширина: | Высота: | Размер: 72 KiB |
|
После Ширина: | Высота: | Размер: 49 KiB |
|
После Ширина: | Высота: | Размер: 34 KiB |
|
После Ширина: | Высота: | Размер: 653 B |
@@ -0,0 +1,64 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="23.89308mm"
|
||||
height="23.893078mm"
|
||||
viewBox="0 0 23.89308 23.893078"
|
||||
version="1.1"
|
||||
id="svg370"
|
||||
inkscape:version="1.1.2 (0a00cf5339, 2022-02-04)"
|
||||
sodipodi:docname="split.svg"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/split.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg">
|
||||
<sodipodi:namedview
|
||||
id="namedview372"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
fit-margin-top="0"
|
||||
fit-margin-left="0"
|
||||
fit-margin-right="0"
|
||||
fit-margin-bottom="0"
|
||||
inkscape:zoom="24.886869"
|
||||
inkscape:cx="30.397556"
|
||||
inkscape:cy="53.984292"
|
||||
inkscape:window-width="2490"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="70"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
inkscape:current-layer="layer1" />
|
||||
<defs
|
||||
id="defs367" />
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1"
|
||||
transform="translate(-30.085626,-76.637833)">
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="m 30.085626,88.584373 h 23.89308"
|
||||
id="path69449-3-1"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/split.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||
d="M 42.032166,76.637833 V 100.53091"
|
||||
id="path69449-3-1-3"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/split.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 2.3 KiB |
|
После Ширина: | Высота: | Размер: 39 KiB |
|
После Ширина: | Высота: | Размер: 51 KiB |
|
После Ширина: | Высота: | Размер: 24 KiB |
|
После Ширина: | Высота: | Размер: 75 KiB |
|
После Ширина: | Высота: | Размер: 2.3 KiB |
@@ -0,0 +1,125 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="27.472563mm"
|
||||
height="17.499945mm"
|
||||
viewBox="0 0 27.472563 17.499945"
|
||||
version="1.1"
|
||||
id="svg370"
|
||||
inkscape:version="1.1.2 (0a00cf5339, 2022-02-04)"
|
||||
sodipodi:docname="uncached.svg"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/uncached.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg">
|
||||
<sodipodi:namedview
|
||||
id="namedview372"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
fit-margin-top="0"
|
||||
fit-margin-left="0"
|
||||
fit-margin-right="0"
|
||||
fit-margin-bottom="0"
|
||||
inkscape:zoom="6.2217172"
|
||||
inkscape:cx="-18.242552"
|
||||
inkscape:cy="72.086208"
|
||||
inkscape:window-width="2490"
|
||||
inkscape:window-height="1376"
|
||||
inkscape:window-x="70"
|
||||
inkscape:window-y="27"
|
||||
inkscape:window-maximized="1"
|
||||
inkscape:current-layer="layer1" />
|
||||
<defs
|
||||
id="defs367">
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="TriangleOutS"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="TriangleOutS"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(0.2)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 5.77,0 -2.88,5 V -5 Z"
|
||||
id="path1132" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="marker1262"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow2Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(-0.6)"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:0.625;stroke-linejoin:round"
|
||||
id="path1260" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow2Mend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow2Mend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="scale(-0.6)"
|
||||
d="M 8.7185878,4.0337352 -2.2072895,0.01601326 8.7185884,-4.0017078 c -1.7454984,2.3720609 -1.7354408,5.6174519 -6e-7,8.035443 z"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:0.625;stroke-linejoin:round"
|
||||
id="path1011" />
|
||||
</marker>
|
||||
<marker
|
||||
style="overflow:visible"
|
||||
id="Arrow1Lend"
|
||||
refX="0"
|
||||
refY="0"
|
||||
orient="auto"
|
||||
inkscape:stockid="Arrow1Lend"
|
||||
inkscape:isstock="true">
|
||||
<path
|
||||
transform="matrix(-0.8,0,0,-0.8,-10,0)"
|
||||
style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt"
|
||||
d="M 0,0 5,-5 -12.5,0 5,5 Z"
|
||||
id="path987" />
|
||||
</marker>
|
||||
</defs>
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1"
|
||||
transform="translate(-30.085626,-74.157956)">
|
||||
<path
|
||||
style="fill:none;stroke:#000000;stroke-width:2.52;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:2.52, 2.52;stroke-dashoffset:0;stroke-opacity:1;marker-end:url(#TriangleOutS)"
|
||||
d="m 30.085626,88.555587 h 23.89308"
|
||||
id="path69449-3-1"
|
||||
inkscape:export-filename="/home/nick/Documents/software_repos/omniperf/src/docs/images/nosplit.png"
|
||||
inkscape:export-xdpi="180"
|
||||
inkscape:export-ydpi="180" />
|
||||
<text
|
||||
xml:space="preserve"
|
||||
style="font-style:normal;font-weight:normal;font-size:10.5833px;line-height:1.25;font-family:sans-serif;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.264583"
|
||||
x="37.700855"
|
||||
y="82.012749"
|
||||
id="text7915"><tspan
|
||||
sodipodi:role="line"
|
||||
id="tspan7913"
|
||||
style="stroke-width:0.264583"
|
||||
x="37.700855"
|
||||
y="82.012749">x2</tspan></text>
|
||||
</g>
|
||||
</svg>
|
||||
|
После Ширина: | Высота: | Размер: 4.3 KiB |
|
После Ширина: | Высота: | Размер: 20 KiB |
|
После Ширина: | Высота: | Размер: 53 KiB |
|
После Ширина: | Высота: | Размер: 18 KiB |
|
После Ширина: | Высота: | Размер: 16 KiB |
|
После Ширина: | Высота: | Размер: 18 KiB |
|
После Ширина: | Высота: | Размер: 34 KiB |
|
После Ширина: | Высота: | Размер: 36 KiB |
@@ -12,5 +12,6 @@
|
||||
getting_started
|
||||
profiling
|
||||
analysis
|
||||
performance_model
|
||||
faq
|
||||
```
|
||||
|
||||
@@ -17,7 +17,7 @@ Omniperf is broken into two installation components:
|
||||
- Mongo DB backend + Grafana instance
|
||||
- Packaged in a Docker container for easy setup
|
||||
|
||||
Determine what you need to install based on how you'd like to interact with Omniperf. See the decision tree below to help determine what installation is right for you.
|
||||
Determine what you need to install based on how you would like to interact with Omniperf. See the decision tree below to help determine what installation is right for you.
|
||||
|
||||

|
||||
|
||||
@@ -55,14 +55,14 @@ available from the
|
||||
of the Omniperf development site. From there, untar and descend into
|
||||
the top-level directory as follows:
|
||||
|
||||
```shell
|
||||
```shell-session
|
||||
$ tar xfz omniperf-v{__VERSION__}.tar.gz
|
||||
$ cd omniperf-v{__VERSION__}
|
||||
```
|
||||
|
||||
Next, install Python dependencies and complete the Omniperf configuration/install process as follows:
|
||||
|
||||
```shell
|
||||
```shell-session
|
||||
# define top-level install path
|
||||
$ export INSTALL_DIR=<your-top-level-desired-install-path>
|
||||
|
||||
@@ -87,7 +87,7 @@ do not have write access to the chosen install path.
|
||||
|
||||
|
||||
After completing these steps, a successful top-level installation directory looks as follows:
|
||||
```shell
|
||||
```shell-session
|
||||
$ ls $INSTALL_DIR
|
||||
modulefiles {__VERSION__} python-libs
|
||||
```
|
||||
@@ -102,7 +102,7 @@ follows:
|
||||
|
||||
|
||||
|
||||
```shell
|
||||
```shell-session
|
||||
$ module use $INSTALL_DIR/modulefiles
|
||||
$ module load omniperf
|
||||
$ which omniperf
|
||||
@@ -125,14 +125,14 @@ To use Omniperf without the companion modulefile, update your `PATH`
|
||||
settings to enable access to the command-line binary. If you installed Python
|
||||
dependencies in a shared location, update your `PYTHONPATH` config as well:
|
||||
|
||||
```shell
|
||||
```shell-session
|
||||
export PATH=$INSTALL_DIR/{__VERSION__}/bin:$PATH
|
||||
export PYTHONPATH=$INSTALL_DIR/python-libs
|
||||
```
|
||||
|
||||
### rocProf
|
||||
|
||||
Omniperf relies on a rocprof binary during the profiling
|
||||
Omniperf relies on a rocProf binary during the profiling
|
||||
process. Normally the path to this binary will be detected
|
||||
automatically, but it can also be overridden via the setting the
|
||||
optional `ROCPROF` environment variable to the path of the binary the user
|
||||
@@ -162,9 +162,9 @@ Omniperf server-side requires the following basic software dependencies prior to
|
||||
|
||||
The recommended process for enabling the server-side of Omniperf is to use the provided Docker file to build the Grafana and MongoDB instance.
|
||||
|
||||
Once you've decided which machine you'd like to use to host the Grafana and MongoDB instance, please follow the set up instructions below.
|
||||
Once you have decided which machine you would like to use to host the Grafana and MongoDB instance, please follow the set up instructions below.
|
||||
|
||||
### 1) Install MongoDB Utils
|
||||
### Install MongoDB Utils
|
||||
Omniperf uses [mongoimport](https://www.mongodb.com/docs/database-tools/mongoimport/) to upload data to Grafana's backend database. Install for Ubuntu 20.04 is as follows:
|
||||
|
||||
```bash
|
||||
@@ -173,7 +173,7 @@ $ sudo apt install ./mongodb-database-tools-ubuntu2004-x86_64-100.6.1.deb
|
||||
```
|
||||
> Installation instructions for alternative distributions can be found [here](https://www.mongodb.com/download-center/database-tools/releases/archive)
|
||||
|
||||
### 2) Persistent Storage
|
||||
### Persistent Storage
|
||||
|
||||
The user will also bind MongoDB to a directory on the host OS to create a local backup in case of a crash or reset. In the Docker world, this is known as "creating a persistent volume":
|
||||
|
||||
@@ -184,24 +184,24 @@ $ sudo docker volume create --driver local --opt type=none --opt device=/usr/loc
|
||||
$ sudo docker volume create --driver local --opt type=none --opt device=/usr/local/persist/mongodb --opt o=bind grafana-mongo-db
|
||||
```
|
||||
|
||||
### 3) Build and Launch
|
||||
### Build and Launch
|
||||
|
||||
We're now ready to build our Docker file. Navigate to your Omniperf install directory to begin.
|
||||
We are now ready to build our Docker file. Navigate to your Omniperf install directory to begin.
|
||||
```bash
|
||||
$ sudo docker-compose build
|
||||
$ sudo docker-compose up -d
|
||||
```
|
||||
> Note that TCP ports for Grafana (4000) and MongoDB (27017) in the docker container are mapped to 14000 and 27018, respectively, on the host side.
|
||||
|
||||
### 4) Setup Grafana Instance
|
||||
Once you've launced your docker container you should be able to reach Grafana at **http://\<host-ip>:14000**. The default login credentials for the first-time Grafana setup are:
|
||||
### Setup Grafana Instance
|
||||
Once you have launched your docker container you should be able to reach Grafana at **http://\<host-ip>:14000**. The default login credentials for the first-time Grafana setup are:
|
||||
|
||||
- Username: **admin**
|
||||
- Password: **admin**
|
||||
|
||||

|
||||
|
||||
MongoDB Datasource Configuration
|
||||
### MongoDB Datasource Configuration
|
||||
|
||||
The MongoDB Datasource must be configured prior to the first-time use. Navigate to Grafana's Configuration page (shown below) to add the **Omniperf Data** connection.
|
||||
|
||||
@@ -219,7 +219,7 @@ After properly configuring these fields click **Save & Test** (as shown below) t
|
||||
|
||||

|
||||
|
||||
Omniperf Dashboard Import
|
||||
### Omniperf Dashboard Import
|
||||
|
||||
From *Create* → *Import*, (as shown below) upload the dashboard file, `/dashboards/Omniperf_v{__VERSION__}_pub.json`, from the Omniperf tarball.
|
||||
|
||||
@@ -227,17 +227,17 @@ Edit both the Dashboard Name and the Unique Identifier (UID) to uniquely identif
|
||||
|
||||

|
||||
|
||||
Using your dashboard
|
||||
### Using your dashboard
|
||||
|
||||
Once you've imported a dashboard you're ready to begin! Start by browsing available dashboards and selecting the dashboard you've just imported.
|
||||
Once you have imported a dashboard you are ready to begin! Start by browsing available dashboards and selecting the dashboard you have just imported.
|
||||
|
||||

|
||||
|
||||
Remeber, you'll need to upload workload data to the DB backend before analyzing in your Grafana interface. We provide a detailed example of this in our [Analysis section](./analysis.md#grafana-gui-import).
|
||||
Remeber, you will need to upload workload data to the DB backend before analyzing in your Grafana interface. We provide a detailed example of this in our [Analysis section](./analysis.md#grafana-gui-import).
|
||||
|
||||
After a workload has been successfully uploaded, you should be able to select it from the workload dropdown located at the top of your Grafana dashboard.
|
||||
|
||||

|
||||
|
||||
For more information on how to use the Grafana interface for anlysis please see the [Grafana section](./analysis.md#grafana-based-gui) in the Analyze Mode tab.
|
||||
For more information on how to use the Grafana interface for analysis please see the [Grafana section](./analysis.md#grafana-based-gui) in the Analyze Mode tab.
|
||||
|
||||
|
||||
@@ -6,15 +6,19 @@
|
||||
:maxdepth: 4
|
||||
```
|
||||
|
||||
This documentation was created to provide a detailed breakdown of all facets of Omniperf. In addition to a full deployment guide with installation instructions, we also explain the design of the tool and each of its components. If you are new to Omniperf, these chapters can be followed in order to gradually acquaint you with the tool and progressively introduce its more advanced features.
|
||||
|
||||
This project is proudly open source, and we welcome all feedback! For more details on how to contribute, please see our Contribution Guide.
|
||||
|
||||
[Browse Omniperf source code on Github](https://github.com/AMDResearch/omniperf)
|
||||
|
||||
## Scope
|
||||
## What is Omniperf
|
||||
|
||||
MI Performance Profiler ([Omniperf](https://github.com/AMDResearch/omniperf)) is a system performance profiling tool for Machine Learning/HPC workloads running on AMD Instinct (tm) Accelerators. It is currently built on top of the [rocProfiler](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html) to monitor hardware performance counters. The Omniperf tool primarily targets accelerators in the MI100 and MI200 families. Development is in progress to support MI300 and Radeon (tm) RDNA (tm) GPUs.
|
||||
Omniperf is a kernel level profiling tool for Machine Learning/HPC workloads running on AMD Instinct (tm) MI accelerators. AMD's Instinct (tm) MI accelerators are Data Center GPUs designed for compute and with some graphics functions disabled or removed. Omniperf is currently built on top of [rocProf](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html) to monitor hardware performance counters. The Omniperf tool primarily targets accelerators in the MI100 and MI200 families. Development is in progress to support AMD Instinct (tm) MI300 and Radeon (tm) RDNA (tm) GPUs.
|
||||
|
||||
## Features
|
||||
|
||||
The Omniperf tool performs system profiling based on all available hardware counters for the target accelerator. It provides high level performance analysis features including System Speed-of-Light, IP block Speed-of-Light, Memory Chart Analysis, Roofline Analysis, Baseline Comparisons, and more...
|
||||
The Omniperf tool performs profiling based on all available hardware counters for the target accelerator. It provides high level performance analysis features including System Speed-of-Light, Hardware block level Speed-of-Light, Memory Chart Analysis, Roofline Analysis, Baseline Comparisons, and more...
|
||||
|
||||
Both command line analysis and GUI analysis are supported.
|
||||
|
||||
@@ -32,25 +36,25 @@ Detailed Feature List:
|
||||
- System Speed-of-Light Panel
|
||||
- Kernel Statistic Panel
|
||||
- Memory Chart Analysis Panel
|
||||
- Roofline Analysis Panel (*Supported on MI200 only, SLES 15 SP3 or RHEL8*)
|
||||
- Roofline Analysis Panel (*Supported on MI200 only, Ubuntu 20.04, SLES 15 SP3 or RHEL8*)
|
||||
- Command Processor (CP) Panel
|
||||
- Shader Processing Input (SPI) Panel
|
||||
- Workgroup Manager (SPI) Panel
|
||||
- Wavefront Launch Panel
|
||||
- Compute Unit - Instruction Mix Panel
|
||||
- Compute Unit - Pipeline Panel
|
||||
- Local Data Share (LDS) Panel
|
||||
- Instruction Cache Panel
|
||||
- Scalar L1D Cache Panel
|
||||
- Texture Addresser and Data Panel
|
||||
- L1 Address Processing Unit, a.k.a. Texture Addresser (TA) / L1 Backend Data Processing Unit, a.k.a. Texture Data (TD) panel(s)
|
||||
- Vector L1D Cache Panel
|
||||
- L2 Cache Panel
|
||||
- L2 Cache (per-Channel) Panel
|
||||
|
||||
## Compatible SOCs
|
||||
## Compatible SoCs
|
||||
|
||||
| Platform | Status |
|
||||
| :------- | :------------- |
|
||||
| Vega 20 (MI-50/60) | No |
|
||||
| Vega 20 (MI50/60) | No |
|
||||
| MI100 | Supported |
|
||||
| MI200 | Supported |
|
||||
| MI300 | In development |
|
||||
|
||||
@@ -23,7 +23,7 @@ the MI200 platform.
|
||||
$ hipcc vcopy.cpp -o vcopy
|
||||
$ ls
|
||||
vcopy vcopy.cpp
|
||||
$ ./vcopy -n 1048576 -b 256
|
||||
$ ./vcopy 1048576 256
|
||||
Finished allocating vectors on the CPU
|
||||
Finished allocating vectors on the GPU
|
||||
Finished copying vectors to the GPU
|
||||
@@ -37,49 +37,50 @@ Releasing CPU memory
|
||||
```
|
||||
|
||||
## Omniperf Profiling
|
||||
The *omniperf* script, available through the [Omniperf](https://github.com/AMDResearch/omniperf) repository, is used to aquire all necessary perfmon data through analysis of compute workloads.
|
||||
The *omniperf* script, available through the Omniperf repository, is used to aquire all necessary performance monitoring data through analysis of compute workloads.
|
||||
|
||||
**omniperf help:**
|
||||
```shell-session
|
||||
$ omniperf profile --help
|
||||
usage:
|
||||
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
usage:
|
||||
|
||||
omniperf profile --name <workload_name> [profile options] [roofline options] -- <profile_cmd>
|
||||
|
||||
|
||||
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
|
||||
|
||||
Examples:
|
||||
|
||||
omniperf profile -n vcopy_all -- ./vcopy -n 1048576 -b 256
|
||||
|
||||
omniperf profile -n vcopy_SPI_TCC -b SQ TCC -- ./vcopy -n 1048576 -b 256
|
||||
|
||||
omniperf profile -n vcopy_kernel -k vecCopy -- ./vcopy -n 1048576 -b 256
|
||||
|
||||
omniperf profile -n vcopy_disp -d 0 -- ./vcopy -n 1048576 -b 256
|
||||
|
||||
omniperf profile -n vcopy_roof --roof-only -- ./vcopy -n 1048576 -b 256
|
||||
|
||||
|
||||
omniperf profile -n vcopy_all -- ./vcopy 1048576 256
|
||||
|
||||
omniperf profile -n vcopy_SPI_TCC -b SQ TCC -- ./vcopy 1048576 256
|
||||
|
||||
omniperf profile -n vcopy_kernel -k vecCopy -- ./vcopy 1048576 256
|
||||
|
||||
omniperf profile -n vcopy_disp -d 0 -- ./vcopy 1048576 256
|
||||
|
||||
omniperf profile -n vcopy_roof --roof-only -- ./vcopy 1048576 256
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
|
||||
|
||||
|
||||
|
||||
Help:
|
||||
-h, --help show this help message and exit
|
||||
-h, --help show this help message and exit
|
||||
|
||||
General Options:
|
||||
-v, --version show program's version number and exit
|
||||
-V, --verbose Increase output verbosity
|
||||
-v, --version show program's version number and exit
|
||||
-V, --verbose Increase output verbosity
|
||||
|
||||
Profile Options:
|
||||
-n , --name Assign a name to workload.
|
||||
-p , --path Specify path to save workload.
|
||||
(DEFAULT: {os.getcwd()}/workloads/<name>)
|
||||
(DEFAULT: /home/colramos/GitHub/omniperf/workloads/<name>)
|
||||
-k [ ...], --kernel [ ...] Kernel filtering.
|
||||
-d [ ...], --dispatch [ ...] Dispatch ID filtering.
|
||||
-b [ ...], --ipblocks [ ...] IP block filtering:
|
||||
-b [ ...], --ipblocks [ ...] Hardware block filtering:
|
||||
SQ
|
||||
SQC
|
||||
TA
|
||||
@@ -89,19 +90,16 @@ Profile Options:
|
||||
SPI
|
||||
CPC
|
||||
CPF
|
||||
--join-type Choose how to join rocprof runs: (DEFAULT: grid)
|
||||
kernel (i.e. By unique kernel name dispatches)
|
||||
grid (i.e. By unique kernel name + grid size dispatches)
|
||||
-d [ ...], --dispatch [ ...] Dispatch ID filtering.
|
||||
--no-roof Profile without collecting roofline data.
|
||||
-- [ ...] Provide command for profiling after double dash.
|
||||
--kernel-verbose Specify Kernel Name verbose level 1-5. Lower the level, shorter the kernel name. (DEFAULT: 2) (DISABLE: 5)
|
||||
|
||||
Standalone Roofline Options:
|
||||
--roof-only Profile roofline data only.
|
||||
--sort Overlay top kernels or top dispatches: (DEFAULT: kernels)
|
||||
kernels
|
||||
dispatches
|
||||
-m [ ...], --mem-level [ ...] Filter by memory level: (DEFAULT: ALL)
|
||||
-m , --mem-level Filter by memory level: (DEFAULT: ALL)
|
||||
HBM
|
||||
L2
|
||||
vL1D
|
||||
@@ -110,45 +108,47 @@ Standalone Roofline Options:
|
||||
--kernel-names Include kernel names in roofline plot.
|
||||
```
|
||||
|
||||
- The `-k` \<kernel> flag allows for kernel filtering, which is compatible with the current rocProf utility.
|
||||
|
||||
- The `-d` \<dispatch> flag allows for dispatch ID filtering, which is compatible with the current rocProf utility.
|
||||
|
||||
- The `-b` \<ipblocks> allows system profiling on one or more selected hardware components to speed up the profiling process. One can gradually include more hardware components, without overwriting performance data acquired on other hardware components.
|
||||
|
||||
|
||||
The following sample command profiles the *vcopy* workload.
|
||||
|
||||
**vcopy profiling:**
|
||||
```shell-session
|
||||
$ omniperf profile --name vcopy -- ./vcopy 1048576 256
|
||||
ROC Profiler: /opt/rocm-5.2.1/bin/rocprof
|
||||
Execution mode = profile
|
||||
___ _ __
|
||||
/ _ \ _ __ ___ _ __ (_)_ __ ___ _ __ / _|
|
||||
| | | | '_ ` _ \| '_ \| | '_ \ / _ \ '__| |_
|
||||
| |_| | | | | | | | | | | |_) | __/ | | _|
|
||||
\___/|_| |_| |_|_| |_|_| .__/ \___|_| |_|
|
||||
|_|
|
||||
Resolving rocprof
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
SoC = mi200
|
||||
Profiler choice = rocprofv1
|
||||
omniperf ver: 1.0.10
|
||||
Path: {os.getcwd()}/workloads/vcopy/mi200
|
||||
Target: mi200
|
||||
Command: ./vcopy -n 1048576 -b 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: None
|
||||
-------------
|
||||
Profile only
|
||||
-------------
|
||||
|
||||
omniperf ver: 1.0.8-PR1
|
||||
Path: /home/colramos/GitHub/omniperf-pub/workloads
|
||||
Target: mi200
|
||||
Command: /home/colramos/vcopy 1048576 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: None
|
||||
IP Blocks: All
|
||||
KernelName verbose: 2
|
||||
Log: /home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/log.txt
|
||||
|
||||
Current input file: {os.getcwd()}/workloads/vcopy/mi200/perfmon/pmc_perf_2.txt
|
||||
RPL: on '231120_142934' from '/opt/rocm-5.2.1' in '{os.getcwd()}'
|
||||
RPL: profiling '""./vcopy -n 1048576 -b 256""'
|
||||
RPL: input file '{os.getcwd()}/workloads/vcopy/mi200/perfmon/pmc_perf_2.txt'
|
||||
RPL: output dir '/tmp/rpl_data_231120_142934_262088'
|
||||
RPL: result dir '/tmp/rpl_data_231120_142934_262088/input0_results_231120_142934'
|
||||
ROCProfiler: input from "/tmp/rpl_data_231120_142934_262088/input0.xml"
|
||||
/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt
|
||||
RPL: on '230411_165021' from '/opt/rocm-5.2.1' in '/home/colramos/GitHub/omniperf-pub'
|
||||
RPL: profiling '""/home/colramos/vcopy 1048576 256""'
|
||||
RPL: input file '/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt'
|
||||
RPL: output dir '/tmp/rpl_data_230411_165021_26406'
|
||||
RPL: result dir '/tmp/rpl_data_230411_165021_26406/input0_results_230411_165021'
|
||||
Finished allocating vectors on the CPU
|
||||
ROCProfiler: input from "/tmp/rpl_data_230411_165021_26406/input0.xml"
|
||||
gpu_index =
|
||||
kernel =
|
||||
range =
|
||||
26 metrics
|
||||
SQ_INSTS_VALU_TRANS_F16, SQ_INSTS_VALU_ADD_F32, SQ_INSTS_VALU_MUL_F32, SQ_INSTS_VALU_FMA_F32, SQ_INSTS_VALU_TRANS_F32, SQ_INSTS_VALU_ADD_F64, SQ_INSTS_VALU_MUL_F64, SQ_INSTS_VALU_FMA_F64, TCP_VOLATILE_sum, TCP_TOTAL_ACCESSES_sum, TCP_TOTAL_READ_sum, TCP_TOTAL_WRITE_sum, TA_BUFFER_ATOMIC_WAVEFRONTS_sum, TA_BUFFER_TOTAL_CYCLES_sum, TD_ATOMIC_WAVEFRONT_sum, TD_STORE_WAVEFRONT_sum, SPI_RA_REQ_NO_ALLOC, SPI_RA_REQ_NO_ALLOC_CSN, CPC_CPC_STAT_STALL, CPC_UTCL1_STALL_ON_TRANSLATION, CPF_CPF_STAT_IDLE, CPF_CPF_TCIU_IDLE, TCC_REQ_sum, TCC_STREAMING_REQ_sum, TCC_HIT_sum, TCC_MISS_sum
|
||||
vcopy testing on GCD 0
|
||||
Finished allocating vectors on the CPU
|
||||
3 metrics
|
||||
SQ_INSTS_SMEM, SQ_INST_LEVEL_SMEM, SQ_ACCUM_PREV_HIRES
|
||||
Finished allocating vectors on the GPU
|
||||
Finished copying vectors to the GPU
|
||||
sw thinks it moved 1.000000 KB per wave
|
||||
@@ -158,11 +158,10 @@ Finished executing kernel
|
||||
Finished copying the output vector from the GPU to the CPU
|
||||
Releasing GPU memory
|
||||
Releasing CPU memory
|
||||
|
||||
...
|
||||
|
||||
Empirical Roofline Calculation
|
||||
Copyright © 2022 Advanced Micro Devices, Inc. All rights reserved.
|
||||
... ...
|
||||
ROCPRofiler: 1 contexts collected, output directory /tmp/rpl_data_220527_130317_1787038/input_results_220527_130317
|
||||
File 'workloads/vcopy/mi200/timestamps.csv' is generating
|
||||
Total detected GPU devices: 2
|
||||
GPU Device 0: Profiling...
|
||||
99% [||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| ]
|
||||
@@ -211,14 +210,14 @@ Peak MFMA FLOPs (F64), GPU ID: 1, workgroupSize:256, workgroups:16384, experimen
|
||||
99% [||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| ]
|
||||
Peak MFMA IOPs (I8), GPU ID: 1, workgroupSize:256, workgroups:16384, experiments:100, IOP:2147483648000, duration:14.3 ms, mean:150317.8 GOPS, stdev=203.5 GOPS
|
||||
```
|
||||
You'll notice two stages in *default* Omniperf profiling. The first stage collects all the counters needed for Omniperf analysis (omitting any filters you've provided). The second stage collects data for the roofline analysis (this stage can be disabled using `--no-roof`)
|
||||
You will notice two stages in *default* Omniperf profiling. The first stage collects all the counters needed for Omniperf analysis (omitting any filters you have provided). The second stage collects data for the roofline analysis (this stage can be disabled using `--no-roof`)
|
||||
|
||||
At the end of the profiling, all resulting csv files should be located in a SOC specific target directory, e.g.:
|
||||
- "mi200" for the AMD Instinct (tm) MI-200 family of accelerators
|
||||
- "mi100" for the AMD Instinct (tm) MI-100 family of accelerators
|
||||
etc. The SOC names are generated as a part of Omniperf, and do not necessarily distinguish between different accelerators in the same family (e.g., an AMD Instinct (tm) MI-210 vs an MI-250)
|
||||
In this document, we use the term System on Chip (SoC) to refer to a particular family of accelerators. At the end of profiling, all resulting csv files should be located in a SoC specific target directory, e.g.:
|
||||
- "mi200" for the AMD Instinct (tm) MI200 family of accelerators
|
||||
- "mi100" for the AMD Instinct (tm) MI100 family of accelerators
|
||||
etc. The SoC names are generated as a part of Omniperf, and do not necessarily distinguish between different accelerators in the same family (e.g., an AMD Instinct (tm) MI210 vs an MI250)
|
||||
|
||||
> Note: Additionally, you'll notice a few extra files. An SoC parameters file, *sysinfo.csv*, is created to reflect the target device settings. All profiling output is stored in *log.txt*. Roofline specific benchmark results are stored in *roofline.csv*.
|
||||
> Note: Additionally, you will notice a few extra files. An SoC parameters file, *sysinfo.csv*, is created to reflect the target device settings. All profiling output is stored in *log.txt*. Roofline specific benchmark results are stored in *roofline.csv*.
|
||||
|
||||
```shell-session
|
||||
$ ls workloads/vcopy/mi200/
|
||||
@@ -239,17 +238,17 @@ drwxrwxr-x 2 colramos colramos 4096 Apr 11 16:42 perfmon
|
||||
```
|
||||
|
||||
### Filtering
|
||||
To reduce profiling time and the counters collected one may use profiling filters. Profiling filters and their functionality depend on the underlying profiler being used. While Omniperf is profiler agnostic, we've provided a detailed description of profiling filters available when using Omniperf with [rocProfiler](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html) below.
|
||||
To reduce profiling time and the counters collected one may use profiling filters. Profiling filters and their functionality depend on the underlying profiler being used. While Omniperf is profiler agnostic, we have provided a detailed description of profiling filters available when using Omniperf with [rocProf](https://rocm.docs.amd.com/projects/rocprofiler/en/latest/rocprof.html) below.
|
||||
|
||||
|
||||
|
||||
Filtering Options:
|
||||
|
||||
- The `-k` \<kernel> flag allows for kernel filtering. Useage is equivalent with the current rocprof utility ([see details below](#kernel-filtering)).
|
||||
- The `-k` \<kernel> flag allows for kernel filtering. Useage is equivalent with the current rocProf utility ([see details below](#kernel-filtering)).
|
||||
|
||||
- The `-d` \<dispatch> flag allows for dispatch ID filtering. Useage is equivalent with the current rocprof utility ([see details below](#dispatch-filtering)).
|
||||
- The `-d` \<dispatch> flag allows for dispatch ID filtering. Useage is equivalent with the current rocProf utility ([see details below](#dispatch-filtering)).
|
||||
|
||||
- The `-b` \<ipblocks> allows system profiling on one or more selected IP blocks to speed up the profiling process. One can gradually incorporate more IP blocks, without overwriting performance data acquired on other IP blocks.
|
||||
- The `-b` \<ipblocks> allows system profiling on one or more selected hardware components to speed up the profiling process. One can gradually include more hardware components, without overwriting performance data acquired on other hardware components.
|
||||
|
||||
```{note}
|
||||
Be cautious while combining different profiling filters in the same call. Conflicting filters may result in error.
|
||||
@@ -257,75 +256,80 @@ Be cautious while combining different profiling filters in the same call. Confli
|
||||
i.e. filtering dispatch X, but dispatch X does not match your kernel name filter
|
||||
```
|
||||
|
||||
#### IP Block Filtering
|
||||
One can profile a selected IP Block to speed up the profiling process. All profiling results are accumulated in the same target directory, without overwriting those for other IP blocks, hence enabling the incremental profiling and analysis.
|
||||
#### Hardware Component Filtering
|
||||
One can profile specific hardware components to speed up the profiling process. In Omniperf, we use the term IP block to refer to a hardware component or a group of hardware components. All profiling results are accumulated in the same target directory, without overwriting those for other hardware components, hence enabling the incremental profiling and analysis.
|
||||
|
||||
The following example only gathers hardware counters for SQ and TCC, skipping all other IP Blocks:
|
||||
The following example only gathers hardware counters for the Shader Sequencer (SQ) and L2 Cache (TCC) components, skipping all other hardware components:
|
||||
```shell-session
|
||||
$ omniperf profile --name vcopy -b SQ TCC -- ./sample/vcopy -n 1048576 -b 256
|
||||
ROC Profiler: /opt/rocm-5.2.1/bin/rocprof
|
||||
Execution mode = profile
|
||||
___ _ __
|
||||
/ _ \ _ __ ___ _ __ (_)_ __ ___ _ __ / _|
|
||||
| | | | '_ ` _ \| '_ \| | '_ \ / _ \ '__| |_
|
||||
| |_| | | | | | | | | | | |_) | __/ | | _|
|
||||
\___/|_| |_| |_|_| |_|_| .__/ \___|_| |_|
|
||||
|_|
|
||||
$ omniperf profile --name vcopy -b SQ TCC -- ./sample/vcopy 1048576 256
|
||||
Resolving rocprof
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
SoC = mi200
|
||||
Profiler choice = rocprofv1
|
||||
fname: pmc_cpc_perf: Skipped
|
||||
fname: pmc_spi_perf: Skipped
|
||||
fname: pmc_cpf_perf: Skipped
|
||||
fname: pmc_tcp_perf: Skipped
|
||||
fname: pmc_sq_perf4: Added
|
||||
fname: pmc_tcc_perf: Added
|
||||
fname: pmc_sq_perf8: Added
|
||||
fname: pmc_ta_perf: Skipped
|
||||
fname: pmc_sq_perf1: Added
|
||||
fname: pmc_sq_perf3: Added
|
||||
|
||||
-------------
|
||||
Profile only
|
||||
-------------
|
||||
|
||||
omniperf ver: 1.0.8-PR1
|
||||
Path: /home/colramos/GitHub/omniperf-pub/workloads
|
||||
Target: mi200
|
||||
Command: /home/colramos/vcopy 1048576 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: None
|
||||
IP Blocks: ['SQ', 'TCC']
|
||||
fname: pmc_sq_perf2: Added
|
||||
fname: pmc_td_perf: Skipped
|
||||
fname: pmc_tcc2_perf: Skipped
|
||||
fname: pmc_tcp_perf: Skipped
|
||||
fname: pmc_spi_perf: Skipped
|
||||
fname: pmc_sq_perf4: Added
|
||||
fname: pmc_sqc_perf1: Skipped
|
||||
fname: pmc_tcc_perf: Added
|
||||
fname: pmc_cpf_perf: Skipped
|
||||
fname: pmc_sq_perf8: Added
|
||||
fname: pmc_cpc_perf: Skipped
|
||||
fname: pmc_sq_perf1: Added
|
||||
fname: pmc_ta_perf: Skipped
|
||||
fname: pmc_sq_perf3: Added
|
||||
fname: pmc_sq_perf6: Added
|
||||
fname: pmc_sq_perf2: Added
|
||||
omniperf ver: 1.0.10
|
||||
Path: {os.getcwd()}/vcopy_/mi200
|
||||
Target: mi200
|
||||
Command: ./vcopy -n 1048576 -b 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: None
|
||||
IP Blocks: ['sq', 'tcc']
|
||||
KernelName verbose: 2
|
||||
Log: /home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/log.txt
|
||||
...
|
||||
```
|
||||
|
||||
#### Kernel Filtering
|
||||
Kernel filtering is based on the name of the kernel(s) you'd like to isolate. Use a kernel name substring list to isolate desired kernels.
|
||||
Kernel filtering is based on the name of the kernel(s) you would like to isolate. Use a kernel name substring list to isolate desired kernels.
|
||||
|
||||
The following example demonstrates profiling isolating the kernel matching substring "vecCopy":
|
||||
```shell-session
|
||||
$ omniperf profile --name vcopy -k vecCopy -- ./vcopy -n 1048576 -b 256
|
||||
ROC Profiler: /opt/rocm-5.2.1/bin/rocprof
|
||||
Execution mode = profile
|
||||
___ _ __
|
||||
/ _ \ _ __ ___ _ __ (_)_ __ ___ _ __ / _|
|
||||
| | | | '_ ` _ \| '_ \| | '_ \ / _ \ '__| |_
|
||||
| |_| | | | | | | | | | | |_) | __/ | | _|
|
||||
\___/|_| |_| |_|_| |_|_| .__/ \___|_| |_|
|
||||
|_|
|
||||
$ omniperf profile --name vcopy -k vecCopy -- ./vcopy 1048576 256
|
||||
Resolving rocprof
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
SoC = mi200
|
||||
Profiler choice = rocprofv1
|
||||
omniperf ver: 1.0.10
|
||||
Path: {os.getcwd()}/workloads/vcopy/mi200
|
||||
Target: mi200
|
||||
Command: ./vcopy -n 1048576 -b 256
|
||||
Kernel Selection: ['vecCopy']
|
||||
Dispatch Selection: None
|
||||
-------------
|
||||
Profile only
|
||||
-------------
|
||||
|
||||
omniperf ver: 1.0.8-PR1
|
||||
Path: /home/colramos/GitHub/omniperf-pub/workloads
|
||||
Target: mi200
|
||||
Command: /home/colramos/vcopy 1048576 256
|
||||
Kernel Selection: ['vecCopy']
|
||||
Dispatch Selection: None
|
||||
IP Blocks: All
|
||||
KernelName verbose: 2
|
||||
...
|
||||
Log: /home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/log.txt
|
||||
|
||||
/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt
|
||||
RPL: on '230411_170300' from '/opt/rocm-5.2.1' in '/home/colramos/GitHub/omniperf-pub'
|
||||
RPL: profiling '""/home/colramos/vcopy 1048576 256""'
|
||||
RPL: input file '/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt'
|
||||
RPL: output dir '/tmp/rpl_data_230411_170300_29696'
|
||||
RPL: result dir '/tmp/rpl_data_230411_170300_29696/input0_results_230411_170300'
|
||||
Finished allocating vectors on the CPU
|
||||
ROCProfiler: input from "/tmp/rpl_data_230411_170300_29696/input0.xml"
|
||||
gpu_index =
|
||||
kernel = vecCopy
|
||||
|
||||
... ...
|
||||
```
|
||||
|
||||
#### Dispatch Filtering
|
||||
@@ -333,70 +337,76 @@ Dispatch filtering is based on the *global* dispatch index of kernels in a run.
|
||||
|
||||
The following example profiles only the 0th dispatched kernel in execution of the application:
|
||||
```shell-session
|
||||
$ omniperf profile --name vcopy -d 0 -- ./vcopy -n 1048576 -b 256
|
||||
ROC Profiler: /opt/rocm-5.2.1/bin/rocprof
|
||||
Execution mode = profile
|
||||
___ _ __
|
||||
/ _ \ _ __ ___ _ __ (_)_ __ ___ _ __ / _|
|
||||
| | | | '_ ` _ \| '_ \| | '_ \ / _ \ '__| |_
|
||||
| |_| | | | | | | | | | | |_) | __/ | | _|
|
||||
\___/|_| |_| |_|_| |_|_| .__/ \___|_| |_|
|
||||
|_|
|
||||
$ omniperf profile --name vcopy -d 0 -- ./vcopy 1048576 256
|
||||
Resolving rocprof
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
SoC = mi200
|
||||
Profiler choice = rocprofv1
|
||||
omniperf ver: 1.0.10
|
||||
Path: {os.getcwd()}/workloads/vcopy/mi200
|
||||
Target: mi200
|
||||
Command: ./vcopy -n 1048576 -b 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: ['0']
|
||||
-------------
|
||||
Profile only
|
||||
-------------
|
||||
|
||||
omniperf ver: 1.0.8-PR1
|
||||
Path: /home/colramos/GitHub/omniperf-pub/workloads
|
||||
Target: mi200
|
||||
Command: /home/colramos/vcopy 1048576 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: ['0']
|
||||
IP Blocks: All
|
||||
KernelName verbose: 2
|
||||
Log: /home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/log.txt
|
||||
|
||||
/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt
|
||||
RPL: on '230411_170356' from '/opt/rocm-5.2.1' in '/home/colramos/GitHub/omniperf-pub'
|
||||
RPL: profiling '""/home/colramos/vcopy 1048576 256""'
|
||||
RPL: input file '/home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200/perfmon/SQ_INST_LEVEL_SMEM.txt'
|
||||
RPL: output dir '/tmp/rpl_data_230411_170356_30314'
|
||||
RPL: result dir '/tmp/rpl_data_230411_170356_30314/input0_results_230411_170356'
|
||||
Finished allocating vectors on the CPU
|
||||
ROCProfiler: input from "/tmp/rpl_data_230411_170356_30314/input0.xml"
|
||||
gpu_index =
|
||||
kernel =
|
||||
range = 0
|
||||
...
|
||||
```
|
||||
|
||||
|
||||
|
||||
### Standalone Roofline
|
||||
If you're only interested in generating roofline analysis data try using `--roof-only`. This will only collect counters relevent to roofline, as well as generate a standalone .pdf output of your roofline plot.
|
||||
If you are only interested in generating roofline analysis data try using `--roof-only`. This will only collect counters relevant to roofline, as well as generate a standalone .pdf output of your roofline plot.
|
||||
|
||||
Standalone Roofline Options:
|
||||
|
||||
- The `--sort` \<desired_sort> allows you to specify whether you'd like to overlay top kernel or top dispatch data in your roofline plot.
|
||||
- The `--sort` \<desired_sort> allows you to specify whether you would like to overlay top kernel or top dispatch data in your roofline plot.
|
||||
|
||||
- The `-m` \<cache_level> allows you to specify specific level(s) of cache you'd like to include in your roofline plot.
|
||||
- The `-m` \<cache_level> allows you to specify specific level(s) of cache you would like to include in your roofline plot.
|
||||
|
||||
- The `--device` \<gpu_id> allows you to specify a device id to collect performace data from when running our roofline benchmark on your system.
|
||||
|
||||
- If you'd like to distinguish different kernels in your .pdf roofline plot use `--kernel-names`. This will give each kernel a unique marker identifiable from the plot's key.
|
||||
- If you would like to distinguish different kernels in your .pdf roofline plot use `--kernel-names`. This will give each kernel a unique marker identifiable from the plot's key.
|
||||
|
||||
|
||||
#### Roofline Only
|
||||
The following example demonstrates profiling roofline data only:
|
||||
```shell-session
|
||||
$ omniperf profile --name vcopy --roof-only -- ./vcopy -n 1048576 -b 256
|
||||
ROC Profiler: /opt/rocm-5.2.1/bin/rocprof
|
||||
Execution mode = profile
|
||||
___ _ __
|
||||
/ _ \ _ __ ___ _ __ (_)_ __ ___ _ __ / _|
|
||||
| | | | '_ ` _ \| '_ \| | '_ \ / _ \ '__| |_
|
||||
| |_| | | | | | | | | | | |_) | __/ | | _|
|
||||
\___/|_| |_| |_|_| |_|_| .__/ \___|_| |_|
|
||||
|_|
|
||||
$ omniperf profile --name vcopy --roof-only -- ./vcopy 1048576 256
|
||||
Resolving rocprof
|
||||
ROC Profiler: /usr/bin/rocprof
|
||||
|
||||
SoC = mi200
|
||||
Profiler choice = rocprofv1
|
||||
[roofline] Generating pmc_perf.csv
|
||||
omniperf ver: 1.0.10
|
||||
Path: {os.getcwd()}/workloads/vcopy/mi200
|
||||
Target: mi200
|
||||
Command: ./vcopy -n 1048576 -b 256
|
||||
Kernel Selection: None
|
||||
Dispatch Selection: None
|
||||
IP Blocks: All
|
||||
KernelName verbose: 2
|
||||
...
|
||||
|
||||
--------
|
||||
Roofline only
|
||||
--------
|
||||
|
||||
Checking for roofline.csv in /home/colramos/GitHub/omniperf-pub/workloads/vcopy/mi200
|
||||
No roofline data found. Generating...
|
||||
Empirical Roofline Calculation
|
||||
Copyright © 2022 Advanced Micro Devices, Inc. All rights reserved.
|
||||
Total detected GPU devices: 4
|
||||
GPU Device 0: Profiling...
|
||||
99% [||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| ]
|
||||
... ...
|
||||
Checking for roofline.csv in /home/colramos/GitHub/omniperf-pub/workloads/mix/mi200
|
||||
Checking for sysinfo.csv in /home/colramos/GitHub/omniperf-pub/workloads/mix/mi200
|
||||
Checking for pmc_perf.csv in /home/colramos/GitHub/omniperf-pub/workloads/mix/mi200
|
||||
Empirical Roofline PDFs saved!
|
||||
```
|
||||
An inspection of our workload output folder shows .pdf plots were generated successfully
|
||||
```shell-session
|
||||
@@ -415,4 +425,4 @@ drwxrwxr-x 2 colramos colramos 4096 Apr 11 17:16 perfmon
|
||||
```
|
||||
A sample *empirRoof_gpu-ALL_fp32.pdf* looks something like this:
|
||||
|
||||

|
||||

|
||||
|
||||