

Автор: Васильев В.И.  
Место: Россия, г. С.-Петербург  
Copyright © [Vladimir.V.askfind@ya.ru](mailto:Vladimir.V.askfind@ya.ru)

Дата созд.: 14.11.2025  
Дата ред.: 25.11.2025  
Версия: 0.04

#### Ссылки:

- [https://t.me/setun\\_1958](https://t.me/setun_1958) // [Электронный ресурс] . - группа «Ternary Computers: The Setun and the Setun 70», тема «SOFT Лабораторные работы»
- <https://www.trinary.su> // [Электронный ресурс] . - Троичная логика и троичная цифровая техника.

**Таблица 2 : TRIT-RISC-V (32-trits) instruction formats**

| 31:25               | 24:20  | 19:15  | 14:12        | 11:7      | 6:0    |          |
|---------------------|--------|--------|--------------|-----------|--------|----------|
| <b>func7</b>        | rs2    | rs1    | <b>func3</b> | rd        | op     | R-TYPE   |
| imm11:0             |        | rs1    | <b>func3</b> | rd        | op     | I-TYPE   |
| imm11:5             | rs2    | rs1    | <b>func3</b> | imm4:0    | op     | S-TYPE   |
| imm12,10:5          | rs2    | rs1    | <b>func3</b> | imm4:1,11 | op     | SB-TYPE  |
| imm31:12            |        |        |              | rd        | op     | U-TYPE   |
| imm20,10:1,11,19:12 |        |        |              | rd        | op     | UJ-TYPE  |
| fs3                 | func2  | fs2    | <b>func3</b> | fd        | op     | R4-TYPE  |
| 5trits              | 2trits | 5trits | 3trits       | 5trits    | 7trits | 32 trits |

#### Instruction formats details

\* R-TYPE Register-register ALU instructions : tadd, txor, tmul  
\* I-TYPE Immediate ALU instructions, load instructions :taddi,tlw, tjalr, tslli  
\* S-TYPE Store instructions : tsw, tsb  
\* SB-TYPE Comparison and branch instructions: tbeg, tbge  
\* U-TYPE Instructions with upper immediates  
\* UJ-TYPES Jump instructions: tjal

\* **func2** type of operation on 2trits  
\* **func3** type of operation on 3trits  
\* **func4** type of operation on 4trits  
\* **func6** type of operation on 6trits  
\* **func7** type of operation on 7trits

#### Glossary of instruction descriptions

\* **rs1, rs2** Register descriptors\* : Source operands 1 and 2  
\* **rd** Register descriptor\* : Destination operand  
\* **op** Operation code

\* Register descriptors (rs1, rs2, rd) always need 5 trits to address working registers (from t0 to t31).

\* That is partly why it is not possible to use CSR directly into regular instructions.

\* In "Priviledge / CSR instructions" that are all I-TYPE, the csr operand is coded by imm11:0 (on 12 trits), and that is what theoretically allows to address up to 12 trits CSR.

\* In addition, in the "Priviledge / CSR instructions", the 5-trit unsigned immediate (uimm) is coded in the rs1 field and not in the imm11:0 field as it should be because of its previous use.

|                    |                                                       |
|--------------------|-------------------------------------------------------|
| * <b>imm</b>       | signed immediate in imm11:0                           |
| * <b>uimm</b>      | 5-trits unsigned immediate in imm4:0                  |
| * <b>upimm</b>     | 20 upper trits of a 32-trit immediate, in imm31:12    |
| * <b>Address</b>   | memory address : rs1 + SignExt(imm11:0)               |
| * <b>[Address]</b> | data at memory location Address                       |
| * <b>BTA</b>       | branch target address : PC + SignExt({imm12:1, 1't0}) |
| * <b>JTA</b>       | jump target address : PC + SignExt({imm20:1, 1't0})   |
| * <b>Label</b>     | text indicating instruction address                   |
| * <b>SignExt</b>   | value sign-extended to 32 trits                       |
| * <b>ZeroExt</b>   | value zero-extended to 32 trits                       |
| * <b>csr</b>       | control and status register                           |

## Краткое описание набора команд TRIT-RISC-V

Таблица 3 : TRIT-RV32I RISC-V Integer instructions

| op                         | Func3           | Func7                     | Type | Mnemonic | Description   | Operation                        |
|----------------------------|-----------------|---------------------------|------|----------|---------------|----------------------------------|
| 0000011(3), t00000++(4)    | 000(0),t000(0)  |                           | I    | tLB      | rd, imm(rs1)  | Load tryte                       |
| 0000011(3), t00000++(4)    | 001(1),t00+(0)  |                           | I    | tLH      | rd, imm(rs1)  | Load half                        |
| 0000011(3), t00000++(4)    | 010(2),t0+0(3)  |                           | I    | tLW      | rd, imm(rs1)  | Load word                        |
| 0000011(3), t00000++(4)    | 100(4),t+00(9)  |                           | I    | tLBU     | rd, imm(rs1)  | Load byte unsigned               |
| 0000011(3), t00000++(4)    | 101(5),t+0+(10) |                           | I    | tLHU     | rd, imm(rs1)  | Load half unsigned               |
| 0010011(19), t00+00++(85)  | 000(0),t000(0)  |                           | I    | tADDI    | rd, rs1, imm  | ADD immediate                    |
| 0010011(19), t00+00++(85)  | 001(1),t00+(1)  |                           | I    | tSLLI    | rd, rs1, uimm | Shift left logical immediate     |
| 0010011(19), t00+00++(85)  | 010(2),t0+0(3)  |                           | I    | tSLTI    | rd, rs1, imm  | Set less than immediate          |
| 0010011(19), t00+00++(85)  | 011(3),t0++(4)  | 0000000(0),t0000000(0)    | I    | tSLTIU   | rd, rs1, imm  | Set less than imm. unsigned      |
| 0010011(19), t00+00++(85)  | 100(4),t+00(9)  |                           | I    | tXORI    | rd, rs1, imm  | XOR immediate                    |
| 0010011(19), t00+00++(85)  | 101(4),t+0+(10) | 0000000(0),t0000000(0)    | I    | tSRRI    | rd, rs1, imm  | Shift right logical immediate    |
| 0010011(19), t00+00++(85)  | 101(4),t+0+(10) | 0100000(32),t0+00000(243) | I    | tSRAI    | rd, rs1, imm  | Shift right arithmetic immediate |
| 0010011(19), t00+00++(85)  | 110(6),t++0(12) |                           | I    | tORI     | rd, rs1, imm  | OR immediate                     |
| 0010011(19), t00+00++(85)  | 111(7),t+++(13) |                           | I    | tANDI    | rd, rs1, imm  | AND immediate                    |
| 0010111(23), t00+0+++(94)  |                 |                           | U    | tAUIPC   | rd, rs1, imm  | ADD upper immediate to PC        |
| 0100011(35), t0+000++(247) |                 |                           | S    | tSB      | rs2,imm(rs1)  | Store byte                       |
| 0100011(35), t0+000++(247) |                 |                           | S    | tSH      | rs2,imm(rs1)  | Store half                       |
| 0100011(35), t0+000++(247) |                 |                           | S    | tSW      | rs2,imm(rs1)  | Store word                       |
| 0110011(51), t0++00++(328) | 000(0),t000(0)  | 0000000(0),t0000000(0)    | R    | tADD     | rd, rs1, rs2  | tADD                             |
|                            |                 |                           |      |          |               | rd = rs1 + rs2                   |

Троичный набор команд TRIT-RISC-V

|                                     |                        |                                  |          |              |                       |                                            |                                            |
|-------------------------------------|------------------------|----------------------------------|----------|--------------|-----------------------|--------------------------------------------|--------------------------------------------|
| <b>0110011(51), t0++00++(328)</b>   | <b>000(0),t000(0)</b>  | <b>0100000(32),t0+00000(243)</b> | <b>R</b> | <b>tSUB</b>  | <b>rd, rs1, rs2</b>   | <b>tSUB</b>                                | <b>rd = rs1 - rs2</b>                      |
| <b>0110011(51), t0++00++(328)</b>   | <b>001(1),t00+(1)</b>  | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tSLL</b>  | <b>rd, rs1, rs2</b>   | <b>Shift left logical immediate</b>        | <b>rd = rs1 &lt;&lt; rs24:0</b>            |
| <b>0110011(51), t0++00++(328)</b>   | <b>010(2),t0+0(3)</b>  | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tSLT</b>  | <b>rd, rs1, rs2</b>   | <b>Set less than</b>                       | <b>rd = rs1 &lt; rs2</b>                   |
| <b>0110011(51), t0++00++(328)</b>   | <b>011(3),t0++(4)</b>  | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tSLTU</b> | <b>rd, rs1, rs2</b>   | <b>Set less than unsigned</b>              | <b>rd = rs1 &lt; rs2</b>                   |
| <b>0110011(51), t0++00++(328)</b>   | <b>100(4),t+00(9)</b>  | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tXOR</b>  | <b>rd, rs1, rs2</b>   | <b>tXOR</b>                                | <b>rd = rs1 ^ rs2</b>                      |
| <b>0110011(51), t0++00++(328)</b>   | <b>101(5),t+0+(10)</b> | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tSRL</b>  | <b>rd, rs1, rs2</b>   | <b>Shift right logical immediate</b>       | <b>rd = rs1 &gt;&gt; rs24:0</b>            |
| <b>0110011(51), t0++00++(328)</b>   | <b>101(5),t+0+(10)</b> | <b>0100000(32),t0+00000(243)</b> | <b>R</b> | <b>tSRAI</b> | <b>rd, rs1, rs2</b>   | <b>Shift right arithmetic immediate</b>    | <b>rd = rs1 &gt;&gt;&gt; rs24:0</b>        |
| <b>0110011(51), t0++00++(328)</b>   | <b>110(6),t++0(12)</b> | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tOR</b>   | <b>rd, rs1, rs2</b>   | <b>tOR</b>                                 | <b>rd = rs1   rs2</b>                      |
| <b>0110011(51), t0++00++(328)</b>   | <b>111(7),t+++(13)</b> | <b>0000000(0),t0000000(0)</b>    | <b>R</b> | <b>tAND</b>  | <b>rd, rs1, rs2</b>   | <b>tAND</b>                                | <b>rd = rs1 &amp; rs2</b>                  |
| <b>0110111(55), t0++0+++(337)</b>   |                        |                                  | <b>U</b> | <b>tLUI</b>  | <b>rd, upimm</b>      | <b>Load upper immediate</b>                | <b>rd = {upimm, 12't0}</b>                 |
| <b>1100011(99), t++000++(976)</b>   | <b>000(0),t000(0)</b>  |                                  | <b>B</b> | <b>tBEQ</b>  | <b>rs1,rs2, label</b> | <b>Branch if equal =</b>                   | <b>if (rs1 == rs2) PC = BTA</b>            |
| <b>1100011(99), t++000++(976)</b>   | <b>001(0),t00+(1)</b>  |                                  | <b>B</b> | <b>tBNE</b>  | <b>rs1,rs2, label</b> | <b>Branch if not equal ≠</b>               | <b>if (rs1 != rs2) PC = BTA</b>            |
| <b>1100011(99), t++000++(976)</b>   | <b>010(2),t0+0(3)</b>  |                                  | <b>B</b> | <b>tBLT</b>  | <b>rs1,rs2, label</b> | <b>Branch if lower than &lt;</b>           | <b>if (rs1 &lt; rs2) PC = BTA</b>          |
| <b>1100011(99), t++000++(976)</b>   | <b>011(3),t0++(4)</b>  |                                  | <b>B</b> | <b>tBGE</b>  | <b>rs1,rs2, label</b> | <b>Branch if greater / equal ≥</b>         | <b>if (rs1 ≥ rs2) PC = BTA</b>             |
| <b>1100011(99), t++000++(976)</b>   | <b>100(4),t+00(9)</b>  |                                  | <b>B</b> | <b>tBLTU</b> | <b>rs1,rs2, label</b> | <b>Branch if lower than unsigned &lt;</b>  | <b>if (rs1 &lt; rs2) PC = BTA</b>          |
| <b>1100011(99), t++000++(976)</b>   | <b>101(5),t+0+(10)</b> |                                  | <b>B</b> | <b>tBGEU</b> | <b>rs1,rs2, label</b> | <b>Branch if greater / equal unsign. ≥</b> | <b>if (rs1 &lt; rs2) PC = BTA</b>          |
| <b>1100111(103), t++00+++(985)</b>  | <b>000(0),t000(0)</b>  |                                  | <b>I</b> | <b>tJALR</b> | <b>rd, rs1, label</b> | <b>Jump and link register</b>              | <b>PC = rs1 + SignExt(imm) rd = PC + 4</b> |
| <b>1101111(111), t++0++++(1012)</b> |                        |                                  | <b>J</b> | <b>tJAL</b>  | <b>rd, label</b>      | <b>Jump and link</b>                       | <b>PC = JTA rd = PC + 4</b>                |

Таблица 4 : Common TRIT-RV32I RISC-V Integer pseudoinstructions

| Pseudoinstruction     | RISC-V Instructions      | Description                        | Operation                 |
|-----------------------|--------------------------|------------------------------------|---------------------------|
| nop                   | taddi x0, x0, 0          | no operation                       |                           |
| tli rd,imm11:0        | taddi rd, x0, imm11:0    | load 12-bit immediate              | rd =SignExtend(imm11:0)   |
| tlir d,imm31:0        | tlui rd, imm31:12        | load 32-bit immediate              | rd =imm31:0               |
| tmv rd,rs1            | taddi rd, rs1, 0         | move (also called "register copy") | rd =rs1                   |
| not rd,rs1            | txori rd,rs1, -1         | one's complement                   | rd = ~rs1                 |
| tneg rd,rs1           | tsub rd,x0, rs1          | two's complement                   | rd =—rs1                  |
| tseqz rd,rs1          | tsltiu rd,rs1, 1         | set if = 0                         | rd = (rs1 == 0)           |
| tsnez rd,rs1          | tsltiu rd, x0, rs1       | set if ≠ 0                         | rd = (rs1 ≠ 0)            |
| tsltz rd,rs1          | tslt rd,rs1, x0          | set if < 0                         | rd = (rs1 < 0)            |
| tsgtz rd,rs1          | tslt rd,x0,rs1           | set if > 0                         | rd = (rs1 > 0)            |
| tbeqz rs1, label      | tbeqr s1, x0, label      | branch if = 0                      | PC = label                |
| tbnez rs1, label      | tbner s1, x0,label       | branch if ≠ 0                      | if (rs1 ≠ 0)PC = label    |
| tblez rs1, label      | tbge x0, rs1, label      | branch if ≤ 0                      | if (rs1 ≤ 0)PC = label    |
| tbgez rs1, label      | tbge rs1, x0,label       | branch if ≥ 0                      | if (rs1 ≥ 0)PC = label    |
| tblkz rs1, label      | tblk rs1, x0,label       | branch if < 0                      | if (rs1 < 0)PC = label    |
| tbgtz rs1, label      | tblk x0, rs1, label      | branch if > 0                      | if (rs1 > 0)PC = label    |
| tbleu rs1, rs2, label | tbgeu rs2, rs1, label    | branch if ≤ (unsigned)             | if (rs1 ≤ rs2) PC = label |
| tbgtu rs1, rs2, label | tblk tu rs2, rs1, offset | branch if > (unsigned)             | if (rs1 > rs2) PC = label |
| tbgtu rs1, rs2, label | tblk tu rs2, rs1, offset | branch if > (unsigned)             | if (rs1 > rs2) PC = label |
| tj label              | tjal x0,label            | jump                               | PC = label                |
| tjal label            | rjal ra,label            | jump and link                      | PC = label,               |
| tjrr s1               | tjalr x0,rs1, 0          | jump register                      | ra = PC + 4<br>PC = rs1   |

Троичный набор команд TRIT-RISC-V

|                           |                                                                       |                                                |                                     |
|---------------------------|-----------------------------------------------------------------------|------------------------------------------------|-------------------------------------|
| tjalr rs1                 | tjalr ra,rs1, 0                                                       | jump and link register<br>return from function | PC = rs1,<br>ra = PC + 4<br>PC = ra |
| ret                       | tjalr x0,rs1, 0                                                       |                                                | PC = label,<br>ra = PC + 4          |
| call label                | tjal ra,label<br>tauipc ra,<br>tjalr ra,offset31:12                   | call nearby function                           |                                     |
| call label                | Tra, offset11:0                                                       | call far away function                         | PC = PC + offset, ra = PC + 4       |
| la rd, symbol             | tauipc ra, jalr ra,offset31:12 ra, offset11:0                         | load address of global variable                | rd = PC + symbol                    |
| l{b h w} rd, symbol       | tauipc rd, symbol                                                     | load address of global variable                | rd = PC + symbol                    |
| s{b h w} rs2, symbol, rs1 | tauipc rs1, symbol31:12 ts{b h w} rs2, symbol11:store global variable |                                                | [PC + symbol] = rs2                 |
| tcsr rd, csr              | tcsrrs rd, csr, x0                                                    | read CSR                                       | rd = csr                            |
| tcsrw csr, rs1            | tcsrrw x0, csr, rs1                                                   | write CSR                                      | csr = rs1                           |
| tcsrs/tcsrc csr, rs1      | tcsrrs/tcsrrc x0, csr, rs1                                            | set/clear bits in CSR                          | csr = csr   rs1 / csr = csr & ~rs1  |

\* if trit 11 of the immediate/offset/symbol is 1, the upper immediate is incremented by 1. offset/symbol are the 32-trit PC-relative addresses of a label/global variable.