Skip to content

Commit

Permalink
Merge branch 'master' into dev/next-release
Browse files Browse the repository at this point in the history
Fixed Conflicts:
	benchmarks/config/rv64-zscrypto.conf
	tools/patch-binutils.patch
	tools/patch-spike.patch

 Please enter the commit message for your changes. Lines starting
 with '#' will be ignored, and an empty message aborts the commit.

 On branch dev/next-release
 Your branch is up-to-date with 'origin/dev/next-release'.

 All conflicts fixed but you are still merging.

 Changes to be committed:
	modified:   README.md
	modified:   bin/parse_opcodes.py
	modified:   doc/tex/sec-entropy-source.tex
	modified:   sail/riscv_crypto_entropy_source.sail
	modified:   tools/README.md
	new file:   tools/gcc-patch-tasks.adoc
	modified:   tools/patch-binutils.patch

 Changes not staged for commit:
	modified:   extern/riscv-compliance (modified content)
	modified:   extern/riscv-gnu-toolchain (modified content)
	modified:   extern/riscv-isa-sim (modified content)
	modified:   extern/sail-riscv (modified content, untracked content)
  • Loading branch information
ben-marshall committed Dec 4, 2020
2 parents 1c81684 + deb5ac9 commit af986a0
Show file tree
Hide file tree
Showing 7 changed files with 145 additions and 4 deletions.
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,10 @@ and use it.
See [tools/README.md](tools/README.md) for instructions on how to
build the experimental toolchain.

There is also a [task list](tools/gcc-patch-tasks.adoc) for
implementing an upstreamable patch.
If you can implement this patch, please get in touch.

## Compliance

See [tests/compliance/README.md](tests/compliance/README.md) for
Expand Down
2 changes: 1 addition & 1 deletion bin/parse_opcodes.py
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,7 @@ def make_c(match,mask):

argstring = ",".join([acodes[a] for a in arguments[mnemonic]])

line = "{%-22s, 0, INSN_CLASS_ZSCRYPTO, %10s, %s, %s, match_opcode, 0}," % (
line = "{%-22s, 0, INSN_CLASS_K, %10s, %s, %s, match_opcode, 0}," % (
"\"%s\""%mnemonic,
"\"%s\""%argstring,
match_vars[mnemonic],
Expand Down
2 changes: 1 addition & 1 deletion doc/tex/sec-entropy-source.tex
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ \subsection{Entropy Source Requirements}
at least 256 bits of secret entropy (Example: a CTR\_DRBG built from
AES-128 is not sufficient). Any implementation of \mnemonic{pollentropy}
that limits the security strength shall not reduce it to less than
256 bits,
256 bits.

RISC-V requires drivers to implement at least 2-to-1 cryptographic
post-processing in software with the expectation that the final output
Expand Down
2 changes: 1 addition & 1 deletion sail/riscv_crypto_entropy_source.sail
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ function clause ext_write_CSR(0x7A9, value) = {
Some(mnoise)
}

val in_noise_capture_mode : unit -> bool
val in_noise_capture_mode : unit -> bool effect {rreg}
function in_noise_capture_mode() = {
if(bit_to_bool(mnoise[31])) then true else false
}
Expand Down
3 changes: 3 additions & 0 deletions tools/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ toolchain and ISA simulator.*

---

**NOTE:** There is a task-list for creating an official GCC/Binutils patch
for the scalar cryptography extension [here](gcc-patch-tasks.adoc).

## Building the Toolchain

**TL;DR:**
Expand Down
134 changes: 134 additions & 0 deletions tools/gcc-patch-tasks.adoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@

= RISC-V Scalar Crypto GCC Implementation Tasks
Ben Marshall <[email protected]>
:toc:

== Introduction & Purpose

This document describes the work neccessary to implement support
the scalar crypto extension in GCC and Binutils.

We currently have experimental patches for Binutils in the same
directory as this file (link:patch-binutils.patch[`patch-binutils.patch`]).
This has been used to develop benchmarks and compliance tests, but
cannot be upstreamed because

1. The author (Ben) doesn't have an FSF copyright assignment and

2. has no experience contributing to GCC or Binutils, so the coding
style might be off and

3. It is incomplete: it doesn't implement the feature groupings properly.

*The purpose of this document* is to describe the necessary work
for creating an upstream appropriate patch, in the hope that someone who
is well qualified to do so can follow it.

NOTE: This doc was written by someone with _very_ cursory experience
of hacking on GCC and Binutils. Please forgive any transgressions as
appropriate.

Broadly, the scalar crypto extension only needs Binutils and intrinsics
support for instructions exclusive to it.
It also _shares_ some instructions with Bitmanip, which should be available
to the compiler if _either_ the relevant Bitmanip _or_ scalar crypto
feature sets are enabled.

== Binutils Support

Instruction Opcodes can be generated by running

make opcodes

From the root of this repository. The resulting C code files are placed
in the `build/` directory.
These files contain the `MATCH_` and `MASK_` macros for defining the
encodings:

#ifndef RISCV_ENCODING_H
#define RISCV_ENCODING_H
#define MATCH_SM4ED 0x800302b
#define MASK_SM4ED 0x3e00707f
#define MATCH_SM4KS 0xa00302b
[...]

These generated macros can be pasted directly into
`include/opcode/riscv-opc.h`
in the Binutils source tree.

They also contain _most_ of the code needed to describe the assembly code
syntax at the very end of the file. For example, it generates

{"sm4ed" , 0, INSN_CLASS_K, "d,s,t,w", MATCH_SM4ED, MASK_SM4ED, match_opcode, 0},
{"sm4ks" , 0, INSN_CLASS_K, "d,s,t,w", MATCH_SM4KS, MASK_SM4KS, match_opcode, 0},
[...]

Which can be mostly just pasted into `opcodes/riscv-opc.c` in the
binutils source tree.
Modifications are needed to specify which instructions
are RV32/RV64 only and the feature groups they belong too, which is described
in section 2 of the
https://github.com/riscv/riscv-crypto/releases[specification].

=== CSR Support

The scalar crypto extension adds two CSRs, detailed in the
Entropy Source section of the specification: `mnoise` and `mentropy`.
These need adding to the list of CSRs recognised by Binutils.

Additionally, there are two pseudo instructions defined, which alias
`csrr` instructions:

* `pollentropy rd` - Alias for `csrrs rd, mentropy, x0`.

* `getnoise rd` - Alias for `csrrs rd, mnoise , x0`.

=== Additional Immediate Fields

The scalar crypto extension introduces two new immediate fields:

* `bs` - used by the 32-bit AES instructions, and the SM4 instructions.
It is 2 bits wide.

* `rcon` - Used by the `aes64ks1` instruction. 4-bits wide. The assembler
should only allow values `0<=rcon<=0xA`.
Values `rcon>0xA` are ignored by the instruction in hardware.

The link:patch-binutils.patch[patch] shows how these were added up to now.
Most of the modifications are in `gas/config/tc-riscv.c` of the
binutils source tree.
Constants to define their size and position were added in
`include/opcode/riscv.h`, and disassembly information
was added in `opcodes/riscv-dis.c`.

=== Feature Groups

Feature groups for the scalar crypto extension are described in
section 2 of the
https://github.com/riscv/riscv-crypto/releases[specification].

These have not been implemented at all in the current patches.
It is expected that they can be added in a very similar way to the
existing Bitmanip feature groups.

The additional complexity comes from some instructions being _shared_
between Bitmanip and the scalar crypto extension.

== GCC Support

There are two components to the GCC support:

* Implementing the parsing for the `-march` string features, per
the feature groups described in the specification.

* Making sure the compiler can use the set of Bitmanip instructions
which are shared with the scalar crypto extension when _either_ of
the extensions are enabled.

We do not expect the compiler to use the complex algorithm specific
instructions.

NOTE: It _might_ be possible to write a matching pattern for the
SHA2 and SM3 instructions, but this is not neccessary for inital
support.

2 changes: 1 addition & 1 deletion tools/patch-binutils.patch
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,7 @@ index 19f10c0e55..7506f2bc80 100644
case 'z':
print (info->stream, "%s", riscv_gpr_names[0]);
diff --git a/opcodes/riscv-opc.c b/opcodes/riscv-opc.c
index e99febc823..14257679e4 100644
index e99febc823..016734c618 100644
--- a/opcodes/riscv-opc.c
+++ b/opcodes/riscv-opc.c
@@ -496,27 +496,27 @@ const struct riscv_opcode riscv_opcodes[] =
Expand Down

0 comments on commit af986a0

Please sign in to comment.