

# Register

## Spec



| Name                | Direction | Width  | Description                          |
|---------------------|-----------|--------|--------------------------------------|
| <b>clk</b>          | Input     | 1 bit  | Clock signal (rising edge triggered) |
| <b>reset_n</b>      | Input     | 1 bit  | Active-low asynchronous reset        |
| <b>load</b>         | Input     | 1 bit  | Load enable signal                   |
| <b>inc</b>          | Input     | 1 bit  | Increment enable signal              |
| <b>rotate_right</b> | Input     | 1 bit  | Rotate-right enable signal           |
| <b>D</b>            | Input     | 8 bits | Input data for load                  |
| <b>Q</b>            | Output    | 8 bits | Current value of the register        |

# Register

## Functional Behavior



- The register is triggered on the **rising edge of clk**, unless **asynchronously reset**.
- The register supports **four main operations with the following Priority** (highest to lowest):
  1. **Asynchronous reset** (if  $\text{reset\_n} == 0$ )  $\rightarrow$  Clear Q to 8'b0
  2. **Load** ( $\text{load} == 1$ )  $\rightarrow$  Load data from input D to output Q
  3. **Increment** ( $\text{inc} == 1$ )  $\rightarrow$  Increment Q by 1
  4. **Rotate Right** ( $\text{rotate\_right} == 1$ )  $\rightarrow$  Circular right shift of Q by 1 bit
- **NOTE:** If No control active  $\rightarrow$  Hold previous value Only