Registers
Summary
Name | Offset | Length | Description |
---|---|---|---|
hmac.INTR_STATE | 0x0 | 4 | Interrupt State Register |
hmac.INTR_ENABLE | 0x4 | 4 | Interrupt Enable Register |
hmac.INTR_TEST | 0x8 | 4 | Interrupt Test Register |
hmac.ALERT_TEST | 0xc | 4 | Alert Test Register |
hmac.CFG | 0x10 | 4 | HMAC Configuration register. |
hmac.CMD | 0x14 | 4 | HMAC command register |
hmac.STATUS | 0x18 | 4 | HMAC Status register |
hmac.ERR_CODE | 0x1c | 4 | HMAC Error Code |
hmac.WIPE_SECRET | 0x20 | 4 | Clear internal secret registers. |
hmac.KEY_0 | 0x24 | 4 | HMAC Secret Key |
hmac.KEY_1 | 0x28 | 4 | HMAC Secret Key |
hmac.KEY_2 | 0x2c | 4 | HMAC Secret Key |
hmac.KEY_3 | 0x30 | 4 | HMAC Secret Key |
hmac.KEY_4 | 0x34 | 4 | HMAC Secret Key |
hmac.KEY_5 | 0x38 | 4 | HMAC Secret Key |
hmac.KEY_6 | 0x3c | 4 | HMAC Secret Key |
hmac.KEY_7 | 0x40 | 4 | HMAC Secret Key |
hmac.KEY_8 | 0x44 | 4 | HMAC Secret Key |
hmac.KEY_9 | 0x48 | 4 | HMAC Secret Key |
hmac.KEY_10 | 0x4c | 4 | HMAC Secret Key |
hmac.KEY_11 | 0x50 | 4 | HMAC Secret Key |
hmac.KEY_12 | 0x54 | 4 | HMAC Secret Key |
hmac.KEY_13 | 0x58 | 4 | HMAC Secret Key |
hmac.KEY_14 | 0x5c | 4 | HMAC Secret Key |
hmac.KEY_15 | 0x60 | 4 | HMAC Secret Key |
hmac.KEY_16 | 0x64 | 4 | HMAC Secret Key |
hmac.KEY_17 | 0x68 | 4 | HMAC Secret Key |
hmac.KEY_18 | 0x6c | 4 | HMAC Secret Key |
hmac.KEY_19 | 0x70 | 4 | HMAC Secret Key |
hmac.KEY_20 | 0x74 | 4 | HMAC Secret Key |
hmac.KEY_21 | 0x78 | 4 | HMAC Secret Key |
hmac.KEY_22 | 0x7c | 4 | HMAC Secret Key |
hmac.KEY_23 | 0x80 | 4 | HMAC Secret Key |
hmac.KEY_24 | 0x84 | 4 | HMAC Secret Key |
hmac.KEY_25 | 0x88 | 4 | HMAC Secret Key |
hmac.KEY_26 | 0x8c | 4 | HMAC Secret Key |
hmac.KEY_27 | 0x90 | 4 | HMAC Secret Key |
hmac.KEY_28 | 0x94 | 4 | HMAC Secret Key |
hmac.KEY_29 | 0x98 | 4 | HMAC Secret Key |
hmac.KEY_30 | 0x9c | 4 | HMAC Secret Key |
hmac.KEY_31 | 0xa0 | 4 | HMAC Secret Key |
hmac.DIGEST_0 | 0xa4 | 4 | Digest output. |
hmac.DIGEST_1 | 0xa8 | 4 | Digest output. |
hmac.DIGEST_2 | 0xac | 4 | Digest output. |
hmac.DIGEST_3 | 0xb0 | 4 | Digest output. |
hmac.DIGEST_4 | 0xb4 | 4 | Digest output. |
hmac.DIGEST_5 | 0xb8 | 4 | Digest output. |
hmac.DIGEST_6 | 0xbc | 4 | Digest output. |
hmac.DIGEST_7 | 0xc0 | 4 | Digest output. |
hmac.DIGEST_8 | 0xc4 | 4 | Digest output. |
hmac.DIGEST_9 | 0xc8 | 4 | Digest output. |
hmac.DIGEST_10 | 0xcc | 4 | Digest output. |
hmac.DIGEST_11 | 0xd0 | 4 | Digest output. |
hmac.DIGEST_12 | 0xd4 | 4 | Digest output. |
hmac.DIGEST_13 | 0xd8 | 4 | Digest output. |
hmac.DIGEST_14 | 0xdc | 4 | Digest output. |
hmac.DIGEST_15 | 0xe0 | 4 | Digest output. |
hmac.MSG_LENGTH_LOWER | 0xe4 | 4 | Received Message Length calculated by the HMAC in bits [31:0] |
hmac.MSG_LENGTH_UPPER | 0xe8 | 4 | Received Message Length calculated by the HMAC in bits [63:32] |
hmac.MSG_FIFO | 0x1000 | 4096 | Message FIFO. Any write to this window will be appended to the FIFO. |
INTR_STATE
Interrupt State Register
- Offset:
0x0
- Reset default:
0x0
- Reset mask:
0x7
Fields
{"reg": [{"name": "hmac_done", "bits": 1, "attr": ["rw1c"], "rotate": -90}, {"name": "fifo_empty", "bits": 1, "attr": ["ro"], "rotate": -90}, {"name": "hmac_err", "bits": 1, "attr": ["rw1c"], "rotate": -90}, {"bits": 29}], "config": {"lanes": 1, "fontsize": 10, "vspace": 120}}
Bits | Type | Reset | Name |
---|---|---|---|
31:3 | Reserved | ||
2 | rw1c | 0x0 | hmac_err |
1 | ro | 0x0 | fifo_empty |
0 | rw1c | 0x0 | hmac_done |
INTR_STATE . hmac_err
HMAC error has occurred. ERR_CODE register shows which error occurred.
INTR_STATE . fifo_empty
The message FIFO is empty. This interrupt is raised only if the message FIFO is actually writable by software, i.e., if all of the following conditions are met: i) The HMAC block is not running in HMAC mode and performing the second round of computing the final hash of the outer key as well as the result of the first round using the inner key. ii) Software has not yet written the Process or Stop command to finish the hashing operation. For the interrupt to be raised, the message FIFO must also have been full previously. Otherwise, the hardware empties the FIFO faster than software can fill it and there is no point in interrupting the software to inform it about the message FIFO being empty.
INTR_STATE . hmac_done
HMAC/SHA-2 has completed.
INTR_ENABLE
Interrupt Enable Register
- Offset:
0x4
- Reset default:
0x0
- Reset mask:
0x7
Fields
{"reg": [{"name": "hmac_done", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "fifo_empty", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "hmac_err", "bits": 1, "attr": ["rw"], "rotate": -90}, {"bits": 29}], "config": {"lanes": 1, "fontsize": 10, "vspace": 120}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:3 | Reserved | |||
2 | rw | 0x0 | hmac_err | Enable interrupt when INTR_STATE.hmac_err is set. |
1 | rw | 0x0 | fifo_empty | Enable interrupt when INTR_STATE.fifo_empty is set. |
0 | rw | 0x0 | hmac_done | Enable interrupt when INTR_STATE.hmac_done is set. |
INTR_TEST
Interrupt Test Register
- Offset:
0x8
- Reset default:
0x0
- Reset mask:
0x7
Fields
{"reg": [{"name": "hmac_done", "bits": 1, "attr": ["wo"], "rotate": -90}, {"name": "fifo_empty", "bits": 1, "attr": ["wo"], "rotate": -90}, {"name": "hmac_err", "bits": 1, "attr": ["wo"], "rotate": -90}, {"bits": 29}], "config": {"lanes": 1, "fontsize": 10, "vspace": 120}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:3 | Reserved | |||
2 | wo | 0x0 | hmac_err | Write 1 to force INTR_STATE.hmac_err to 1. |
1 | wo | 0x0 | fifo_empty | Write 1 to force INTR_STATE.fifo_empty to 1. |
0 | wo | 0x0 | hmac_done | Write 1 to force INTR_STATE.hmac_done to 1. |
ALERT_TEST
Alert Test Register
- Offset:
0xc
- Reset default:
0x0
- Reset mask:
0x1
Fields
{"reg": [{"name": "fatal_fault", "bits": 1, "attr": ["wo"], "rotate": -90}, {"bits": 31}], "config": {"lanes": 1, "fontsize": 10, "vspace": 130}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:1 | Reserved | |||
0 | wo | 0x0 | fatal_fault | Write 1 to trigger one alert event of this kind. |
CFG
HMAC Configuration register.
The register is updated when the engine is in Idle. If the software updates the register while the engine computes the hash, the updated value is discarded.
- Offset:
0x10
- Reset default:
0x4100
- Reset mask:
0x7fff
Fields
{"reg": [{"name": "hmac_en", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "sha_en", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "endian_swap", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "digest_swap", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "key_swap", "bits": 1, "attr": ["rw"], "rotate": -90}, {"name": "digest_size", "bits": 4, "attr": ["rw"], "rotate": -90}, {"name": "key_length", "bits": 6, "attr": ["rw"], "rotate": 0}, {"bits": 17}], "config": {"lanes": 1, "fontsize": 10, "vspace": 130}}
Bits | Type | Reset | Name |
---|---|---|---|
31:15 | Reserved | ||
14:9 | rw | 0x20 | key_length |
8:5 | rw | 0x8 | digest_size |
4 | rw | 0x0 | key_swap |
3 | rw | 0x0 | digest_swap |
2 | rw | 0x0 | endian_swap |
1 | rw | x | sha_en |
0 | rw | x | hmac_en |
CFG . key_length
Key length configuration.
This is a 6-bit one-hot encoded field to configure the key length for HMAC.
The HMAC can be programmed with the following key lengths: 128-bit, 256-bit, 384-bit, 512-bit and 1024-bit.
But the HMAC supports any arbitrary key length: the software should configure the HMAC with the next largest supported key length and concatenate zeros to reach the programmed key length.
The position of these zeros depends on the endianness, thus on the programmed CFG.key_swap
.
For example, for an 80-bit key, HMAC should be configured with an 128-bit key length, fed with the 80-bit key and with 48 zero-bits.
Note that the key length cannot be greater than the block size: up to 1024-bit for SHA-2 384/512 and up to 512-bit for SHA-2 256.
The value of this register is irrelevant when only SHA-2 (not keyed HMAC) is configured.
However, for HMAC mode (hmac_en == 1
), when HMAC is triggered to start while KEY_LENGTH
holds Key_None
or KEY_LENGTH
holds Key_1024
for DIGEST_SIZE
= SHA2_256
, starting is blocked and an error is signalled to SW.
Value | Name | Description |
---|---|---|
0x01 | Key_128 | 6’b00_0001: 128-bit secret key. |
0x02 | Key_256 | 6’b00_0010: 256-bit secret key. |
0x04 | Key_384 | 6’b00_0100: 384-bit secret key. |
0x08 | Key_512 | 6’b00_1000: 512-bit secret key. |
0x10 | Key_1024 | 6’b01_0000: 1024-bit secret key. |
0x20 | Key_None | 6’b10_0000: Unsupported/invalid values and all-zero values are mapped to Key_None. With this value, when HMAC is triggered to start operation (via hash_start or hash_continue ), it will be blocked from starting and an error is signalled to the SW. If only unkeyed SHA-2 is configured (hmac_en == 0 ), starting is not blocked, since this does not require a key. |
Other values are reserved.
CFG . digest_size
Digest size configuration.
This is a 4-bit one-hot encoded field to select digest size for either HMAC or SHA-2. Invalid/unsupported values, i.e., values that don’t correspond to SHA2_256, SHA2_384, or SHA2_512, are mapped to SHA2_None.
Value | Name | Description |
---|---|---|
0x1 | SHA2_256 | 4’b0001: SHA-2 256 digest. |
0x2 | SHA2_384 | 4’b0010: SHA-2 384 digest. |
0x4 | SHA2_512 | 4’b0100: SHA-2 512 digest. |
0x8 | SHA2_None | 4’b1000: Unsupported/invalid values and all-zero values are mapped to SHA2_None. With this value, when HMAC/SHA-2 is triggered to start operation (via hash_start or hash_continue ), it will be blocked from starting and an error is signalled to the SW. |
Other values are reserved.
CFG . key_swap
Key register byte swap.
If 1 the endianness of each KEY_* register is swapped. Default value (value 0) is big endian representation of the KEY_* CSRs.
CFG . digest_swap
Digest register byte swap.
If 1 the value in each digest output register is converted to big-endian byte order.
This setting does not affect the order of the digest output registers, DIGEST_0
still contains the first 4 bytes of the digest.
CFG . endian_swap
Endian swap.
If 0, each value will be added to the message in little-endian byte order.
The value is written to MSG_FIFO same to the SW writes.
If 1, then each individual multi-byte value, regardless of its alignment, written to MSG_FIFO
will be added to the message in big-endian byte order.
A message written to MSG_FIFO
one byte at a time will not be affected by this setting.
From a hardware perspective byte swaps are performed on a TL-UL word granularity.
CFG . sha_en
SHA-2 enable.
If 0, the SHA engine will not initiate compression, this is used to stop operation of the SHA-2 engine until configuration has been done. When the SHA-2 engine is disabled the digest is cleared.
CFG . hmac_en
HMAC datapath enable.
If this bit is 1, HMAC operates when hash_start
toggles.
CMD
HMAC command register
- Offset:
0x14
- Reset default:
0x0
- Reset mask:
0xf
Fields
{"reg": [{"name": "hash_start", "bits": 1, "attr": ["r0w1c"], "rotate": -90}, {"name": "hash_process", "bits": 1, "attr": ["r0w1c"], "rotate": -90}, {"name": "hash_stop", "bits": 1, "attr": ["r0w1c"], "rotate": -90}, {"name": "hash_continue", "bits": 1, "attr": ["r0w1c"], "rotate": -90}, {"bits": 28}], "config": {"lanes": 1, "fontsize": 10, "vspace": 150}}
Bits | Type | Reset | Name |
---|---|---|---|
31:4 | Reserved | ||
3 | r0w1c | x | hash_continue |
2 | r0w1c | x | hash_stop |
1 | r0w1c | x | hash_process |
0 | r0w1c | x | hash_start |
CMD . hash_continue
When 1 is written to this field, SHA-2 or HMAC will continue hashing based on the current hash in the digest registers and the message length, which both have to be restored to switch context.
CMD . hash_stop
When 1 is written to this field, SHA-2 or HMAC will afterwards set the hmac_done
interrupt as soon as the current block has been hashed.
The hash can then be read from the registers DIGEST_0
to DIGEST_15.
Together with the message length in MSG_LENGTH_LOWER
and MSG_LENGTH_UPPER
, this forms the information that has to be saved before switching context.
CMD . hash_process
If 1 is written to this field, SHA-2 or HMAC calculates the digest or signing based on currently received message.
CMD . hash_start
If 1 is written into this field, SHA-2 or HMAC begins its operation. CPU must configure relative information first, such as the digest size, secret key and the key length.
STATUS
HMAC Status register
- Offset:
0x18
- Reset default:
0x3
- Reset mask:
0x3f7
Fields
{"reg": [{"name": "hmac_idle", "bits": 1, "attr": ["ro"], "rotate": -90}, {"name": "fifo_empty", "bits": 1, "attr": ["ro"], "rotate": -90}, {"name": "fifo_full", "bits": 1, "attr": ["ro"], "rotate": -90}, {"bits": 1}, {"name": "fifo_depth", "bits": 6, "attr": ["ro"], "rotate": 0}, {"bits": 22}], "config": {"lanes": 1, "fontsize": 10, "vspace": 120}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:10 | Reserved | |||
9:4 | ro | x | fifo_depth | FIFO entry count. |
3 | Reserved | |||
2 | ro | x | fifo_full | FIFO full. Data written to the FIFO whilst it is full will cause back-pressure on the interconnect |
1 | ro | 0x1 | fifo_empty | FIFO empty |
0 | ro | 0x1 | hmac_idle | HMAC idle status. When IDLE, the DIGEST and the MSG_LENGTH_LOWER /MSG_LENGTH_UPPER can be written to from SW which enables restoring context (to support context switching). |
ERR_CODE
HMAC Error Code
- Offset:
0x1c
- Reset default:
0x0
- Reset mask:
0xffffffff
Fields
{"reg": [{"name": "err_code", "bits": 32, "attr": ["ro"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | ro | 0x0 | err_code | If an error interrupt occurs, this register has information of error cause. Please take a look at `hw/ip/prim/rtl/prim_sha2_pkg.sv:err_code_e enum type. |
WIPE_SECRET
Clear internal secret registers.
If the CPU writes a value into the register, the value is used to clear some internal variables such as the secret key, intermediate hash results, digest and internal message scheduling array. The clear secret operation overwrites the internal variables with the provided 32-bit value. For SHA-2 384/512 that work with 64-bit words, the 32-bit value is duplicated and concatenated to generate the 64-bit value. It is recommended to use a value extracted from an entropy source.
- Offset:
0x20
- Reset default:
0x0
- Reset mask:
0xffffffff
Fields
{"reg": [{"name": "secret", "bits": 32, "attr": ["wo"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | wo | x | secret | Secret value |
KEY
HMAC Secret Key
HMAC using SHA-2 256/384/512 assumes any hashed secret key length up to the block size, thus capped at 1024-bit.
key_length
determines how many of these registers are relevant for the HMAC operation. Order of the secret key is:
key[1023:0] = {KEY0, KEY1, KEY2, … , KEY31};
The registers are allowed to be updated only when the engine is in Idle state. If the engine computes the hash, it discards any attempts to update the secret keys and report an error.
- Reset default:
0x0
- Reset mask:
0xffffffff
Instances
Name | Offset |
---|---|
KEY_0 | 0x24 |
KEY_1 | 0x28 |
KEY_2 | 0x2c |
KEY_3 | 0x30 |
KEY_4 | 0x34 |
KEY_5 | 0x38 |
KEY_6 | 0x3c |
KEY_7 | 0x40 |
KEY_8 | 0x44 |
KEY_9 | 0x48 |
KEY_10 | 0x4c |
KEY_11 | 0x50 |
KEY_12 | 0x54 |
KEY_13 | 0x58 |
KEY_14 | 0x5c |
KEY_15 | 0x60 |
KEY_16 | 0x64 |
KEY_17 | 0x68 |
KEY_18 | 0x6c |
KEY_19 | 0x70 |
KEY_20 | 0x74 |
KEY_21 | 0x78 |
KEY_22 | 0x7c |
KEY_23 | 0x80 |
KEY_24 | 0x84 |
KEY_25 | 0x88 |
KEY_26 | 0x8c |
KEY_27 | 0x90 |
KEY_28 | 0x94 |
KEY_29 | 0x98 |
KEY_30 | 0x9c |
KEY_31 | 0xa0 |
Fields
{"reg": [{"name": "key", "bits": 32, "attr": ["wo"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | wo | x | key | 32-bit chunk of 1024-bit secret key |
DIGEST
Digest output.
If HMAC is disabled, the register shows result of SHA-2 256/384/512. Order of the 512-bit digest[511:0] = {DIGEST0, DIGEST1, DIGEST2, … , DIGEST15}. For SHA-2 256 order of the 256-bit digest[255:0] = {DIGEST0, DIGEST1, DIGEST2, DIGEST3, DIGEST4, DIGEST5, DIGEST6, DIGEST7} and {DIGEST8 - DIGEST15} are irrelevant and should not be read out. For SHA-2 384, {DIGEST12-DIGEST15} are truncated; they are irrelevant and should not be read out.
The digest gets cleared when CFG.sha_en
transitions from 1 to 0.
When STATUS.hmac_idle
is 1, these registers may be written to by software.
Outside of this window, writes can cause unpredictable behavior.
- Reset default:
0x0
- Reset mask:
0xffffffff
Instances
Name | Offset |
---|---|
DIGEST_0 | 0xa4 |
DIGEST_1 | 0xa8 |
DIGEST_2 | 0xac |
DIGEST_3 | 0xb0 |
DIGEST_4 | 0xb4 |
DIGEST_5 | 0xb8 |
DIGEST_6 | 0xbc |
DIGEST_7 | 0xc0 |
DIGEST_8 | 0xc4 |
DIGEST_9 | 0xc8 |
DIGEST_10 | 0xcc |
DIGEST_11 | 0xd0 |
DIGEST_12 | 0xd4 |
DIGEST_13 | 0xd8 |
DIGEST_14 | 0xdc |
DIGEST_15 | 0xe0 |
Fields
{"reg": [{"name": "digest", "bits": 32, "attr": ["rw"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | rw | x | digest | 32-bit chunk of 512-bit digest |
MSG_LENGTH_LOWER
Received Message Length calculated by the HMAC in bits [31:0]
Message is byte granularity. Lower 3 bits [2:0] are ignored.
When STATUS.hmac_idle
is 1, this register may be written by software.
Outside of this window, writes can cause unpredictable behavior.
- Offset:
0xe4
- Reset default:
0x0
- Reset mask:
0xffffffff
Fields
{"reg": [{"name": "v", "bits": 32, "attr": ["rw"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | rw | x | v | Message Length [31:0] |
MSG_LENGTH_UPPER
Received Message Length calculated by the HMAC in bits [63:32]
When STATUS.hmac_idle
is 1, this register may be written by software.
Outside of this window, writes can cause unpredictable behavior.
For SHA-2-2 256 computations, message length is 64-bit {MSG_LENGTH_UPPER, MSG_LENGTH_LOWER}.f
For SHA-2 384/512 message length is extended to 128-bit in line with [nist-fips-180-4] where the upper 64 bits get zero-padded: {32’b0, 32’b0, MSG_LENGTH_UPPER, MSG_LENGTH_LOWER}.
- Offset:
0xe8
- Reset default:
0x0
- Reset mask:
0xffffffff
Fields
{"reg": [{"name": "v", "bits": 32, "attr": ["rw"], "rotate": 0}], "config": {"lanes": 1, "fontsize": 10, "vspace": 80}}
Bits | Type | Reset | Name | Description |
---|---|---|---|---|
31:0 | rw | x | v | Message Length [63:32] |
MSG_FIFO
Message FIFO. Any write to this window will be appended to the FIFO. Only the lower [1:0] bits of the address matter to writes within the window (for correctly dealing with non 32-bit writes)
- Word Aligned Offset Range:
0x1000
to0x1ffc
- Size (words):
1024
- Access:
wo
- Byte writes are supported.