Skip to content
This repository has been archived by the owner on Aug 28, 2024. It is now read-only.

Commit

Permalink
formatting and version tweaks for gdoc to adoc conversion
Browse files Browse the repository at this point in the history
  • Loading branch information
bcstrongx committed Oct 30, 2023
1 parent e6e6432 commit fc8a2f4
Show file tree
Hide file tree
Showing 5 changed files with 15 additions and 6 deletions.
4 changes: 2 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,12 @@

DATE ?= $(shell date +%Y-%m-%d)
VERSION ?= v0.0.0
REVMARK ?= Draft
REVMARK ?= Stable
DOCKER_RUN := docker run --rm -v ${PWD}:/build -w /build \
riscvintl/riscv-docs-base-container-image:latest

HEADER_SOURCE := header.adoc
PDF_RESULT := spec-sample.pdf
PDF_RESULT := riscv-smcdeleg-ssccfg-latest.pdf

ASCIIDOCTOR_PDF := asciidoctor-pdf
OPTIONS := --trace \
Expand Down
6 changes: 5 additions & 1 deletion body.adoc
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
[[body]]
== Counter Delegation Enable (menvcfg.CDE)

Bit 60 of menvcfg (bit 28 of menvcfgh) is Counter Delegation Enable
Expand Down Expand Up @@ -26,7 +27,7 @@ Table 1 below.
|===
|*siselect value* |*sireg* |*sireg4* |*sireg2* |*sireg5*
|0x40 |cycle^1^ |cycleh^1^ |cyclecfg^14^ |cyclecfgh^14^
|0x41 |_See below_ | | |
|0x41 4+^|_See below_
|0x42 |instret^1^ |instreth^1^ |instretcfg^14^ |instretcfgh^14^
|0x43 |hpmcounter3^2^ |hpmcounter3h^2^ |hpmevent3^2^ |hpmevent3h^23^
|… |… |… |… |…
Expand Down Expand Up @@ -89,6 +90,7 @@ instruction exception.
* An attempt from VS-mode to access any sireg* (really vsireg*) raises
either an illegal instruction exception if menvcfg.CDE = 0, or a virtual
instruction exception if menvcfg.CDE = 1.

If Sscofpmf is implemented, sireg2 and sireg5 provide access only to a
subset of the event selector registers. Specifically, event selector bit
62 (MINH) is read-only 0 when accessed through sireg*. Similarly, if
Expand Down Expand Up @@ -161,6 +163,7 @@ LCOFI is the result of an overflow of a delegated counter (selective
delegation)._
* _“Bare Metal” Configuration_
_The operating system (running in S-mode) can determine which counters
have been delegated by writing all ones to scountinhibit, then reading
back the resulting value. It can then use siselect and sireg* to program
Expand All @@ -186,6 +189,7 @@ state. Finally it can resume counting, by clearing scountinhibit, before
resuming workload execution._
* _Hypervisor Configuration_
_A hypervisor may use the counters as described above, and can utilize
the xINH bits in the event selectors (via sireg2/sireg5) to dictate
whether the counter increments during hypervisor execution, guest
Expand Down
2 changes: 2 additions & 0 deletions contributors.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,5 @@ This RISC-V specification has been contributed to directly or indirectly by:
* Beeman Strong <beeman@rivosinc.com>
* Atish Patra <atishp@rivosinc.com>
* Allen Baum <allen.baum@esperantotech.com>
* Greg Favor <gfavor@ventanamicro.com>
* John Hauser <jh.riscv@jhauser.us>
4 changes: 2 additions & 2 deletions header.adoc
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
= RISC-V Supervisor Counter Delegation Specification (Smcdeleg/Ssccfg)
Authors: Author 1, Author 2
:docgroup: Fast-track
Authors: Beeman Strong, Atish Patra, Allen Baum
:docgroup: RISC-V Performance Analysis SIG
:description: RISC-V Supervisor Counter Delegation Specification (Smcdeleg/Ssccfg)
:company: RISC-V.org
:revdate: 10/2023
Expand Down
5 changes: 4 additions & 1 deletion intro.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ transitions to and from M-mode that add latency to these performance
critical supervisor/hypervisor code sections. This extension also
defines one new CSR, scountinhibit.

[NOTE]
====
__Indirect vs direct access to counters and event selectors was
discussed at length. While a direct access method (e.g., new
shpmcounter__i _CSRs) has the potential to reduce latency for
Expand All @@ -65,4 +67,5 @@ read/write the associated alias register. While strong ordering between
the index write and the alias register access is required, it is
believed that pipelining of CSR accesses can ensure that the costs
associated with this ordering are less than the cost associated with the
mispredictions that result from the direct method._
mispredictions that result from the direct method._
====

0 comments on commit fc8a2f4

Please sign in to comment.