Skip to content
This repository has been archived by the owner on Jan 10, 2025. It is now read-only.

Commit

Permalink
Condenses "reserved" ranges into single rows.
Browse files Browse the repository at this point in the history
  • Loading branch information
Lichtso committed Jul 3, 2024
1 parent 0508834 commit 7a6e742
Showing 1 changed file with 13 additions and 134 deletions.
147 changes: 13 additions & 134 deletions docs/bytecode.md
Original file line number Diff line number Diff line change
Expand Up @@ -113,10 +113,7 @@ The following Rust equivalents assume that:
| `CC` / `11001100` | all | `ash32 dst, src` | `dst = (dst as i32).wrapping_shr(src as u32) as u32 as u64`
| `D4` / `11010100` | until v2 | `le dst, imm=16/32/64` | `dst = dst`
| `DC` / `11011100` | all | `be dst, imm=16/32/64`
| `E4` / `11100100` | | -- reserved --
| `EC` / `11101100` | | -- reserved --
| `F4` / `11110100` | | -- reserved --
| `FC` / `11111100` | | -- reserved --
| `E4` to `FC` | | -- reserved --

### 64 bit Arithmetic and Logic
| opcode (hex / bin) | feature set | assembler mnemonic | Rust equivalent
Expand Down Expand Up @@ -148,10 +145,7 @@ The following Rust equivalents assume that:
| `BF` / `10111111` | all | `mov64 dst, src` | `dst = src`
| `C7` / `11000111` | all | `ash64 dst, imm` | `dst = (dst as i64).wrapping_shr(imm)`
| `CF` / `11001111` | all | `ash64 dst, src` | `dst = (dst as i64).wrapping_shr(src as u32)`
| `D7` / `11010111` | | -- reserved --
| `DF` / `11011111` | | -- reserved --
| `E7` / `11100111` | | -- reserved --
| `EF` / `11101111` | | -- reserved --
| `D7` to `EF` | | -- reserved --
| `F7` / `11110111` | from v2 | `hor64 dst, imm` | `dst = dst.or((imm as u64).wrapping_shl(32))`
| `FF` / `11111111` | | -- reserved --

Expand All @@ -170,12 +164,7 @@ The following Rust equivalents assume that:

| opcode (hex / bin) | feature set | assembler mnemonic | Rust equivalent
| ------------------ | ----------- | ------------------ | ---------------
| `06` / `00000110` | | -- reserved --
| `0E` / `00001110` | | -- reserved --
| `16` / `00010110` | | -- reserved --
| `1E` / `00011110` | | -- reserved --
| `26` / `00100110` | | -- reserved --
| `2E` / `00101110` | | -- reserved --
| `06` to `2E` | | -- reserved --
| `36` / `00110110` | from v2 | `uhmul64 dst, imm` | `dst = (dst as u128).wrapping_mul(imm as u128).wrapping_shr(64) as u64`
| `3E` / `00111110` | from v2 | `uhmul64 dst, src` | `dst = (dst as u128).wrapping_mul(src as u128).wrapping_shr(64) as u64`
| `46` / `01000110` | from v2 | `udiv32 dst, imm` | `dst = ((dst as u32) / imm) as u64`
Expand All @@ -190,8 +179,7 @@ The following Rust equivalents assume that:
| `8E` / `10001110` | from v2 | `lmul32 dst, src` | `dst = (dst as i32).wrapping_mul(src as i32) as u32 as u64`
| `96` / `10010110` | from v2 | `lmul64 dst, imm` | `dst = dst.wrapping_mul(imm as u64)`
| `9E` / `10011110` | from v2 | `lmul64 dst, src` | `dst = dst.wrapping_mul(src)`
| `A6` / `10100110` | | -- reserved --
| `AE` / `10101110` | | -- reserved --
| `A6` to `AE` | | -- reserved --
| `B6` / `10110110` | from v2 | `shmul64 dst, imm` | `dst = (dst as i128).wrapping_mul(imm as i32 as i128).wrapping_shr(64) as i64 as u64`
| `BE` / `10111110` | from v2 | `shmul64 dst, src` | `dst = (dst as i128).wrapping_mul(src as i64 as i128).wrapping_shr(64) as i64 as u64`
| `C6` / `11000110` | from v2 | `sdiv32 dst, imm` | `dst = ((dst as i32) / (imm as i32)) as u32 as u64`
Expand All @@ -212,142 +200,36 @@ The following Rust equivalents assume that:
| opcode (hex / bin) | feature set | assembler mnemonic | Rust equivalent
| ------------------ | ----------- | ------------------ | ---------------
| `00` / `00000000` | until v2 | `lddw dst, imm` | `dst = dst.or((imm as u64).wrapping_shl(32))`
| `08` / `00001000` | | -- reserved --
| `10` / `00010000` | | -- reserved --
| `08` to `10` | | -- reserved --
| `18` / `00011000` | until v2 | `lddw dst, imm` | `dst = imm as u64`
| `20` / `00100000` | | -- reserved --
| `28` / `00101000` | | -- reserved --
| `30` / `00110000` | | -- reserved --
| `38` / `00111000` | | -- reserved --
| `40` / `01000000` | | -- reserved --
| `48` / `01001000` | | -- reserved --
| `50` / `01010000` | | -- reserved --
| `58` / `01011000` | | -- reserved --
| `60` / `01100000` | | -- reserved --
| `68` / `01101000` | | -- reserved --
| `70` / `01110000` | | -- reserved --
| `78` / `01111000` | | -- reserved --
| `80` / `10000000` | | -- reserved --
| `88` / `10001000` | | -- reserved --
| `90` / `10010000` | | -- reserved --
| `98` / `10011000` | | -- reserved --
| `A0` / `10100000` | | -- reserved --
| `A8` / `10101000` | | -- reserved --
| `B0` / `10110000` | | -- reserved --
| `B8` / `10111000` | | -- reserved --
| `C0` / `11000000` | | -- reserved --
| `C8` / `11001000` | | -- reserved --
| `D0` / `11010000` | | -- reserved --
| `D8` / `11011000` | | -- reserved --
| `E0` / `11100000` | | -- reserved --
| `E8` / `11101000` | | -- reserved --
| `F0` / `11110000` | | -- reserved --
| `F8` / `11111000` | | -- reserved --
| `20` to `F8` | | -- reserved --

| opcode (hex / bin) | feature set | assembler mnemonic
| ------------------ | ----------- | ------------------
| `01` / `00000001` | | -- reserved --
| `09` / `00001001` | | -- reserved --
| `11` / `00010001` | | -- reserved --
| `19` / `00011001` | | -- reserved --
| `21` / `00100001` | | -- reserved --
| `29` / `00101001` | | -- reserved --
| `31` / `00110001` | | -- reserved --
| `39` / `00111001` | | -- reserved --
| `41` / `01000001` | | -- reserved --
| `49` / `01001001` | | -- reserved --
| `51` / `01010001` | | -- reserved --
| `59` / `01011001` | | -- reserved --
| `01` to `59` | | -- reserved --
| `61` / `01100001` | all | `ldxw dst, [src + off]`
| `69` / `01101001` | all | `ldxh dst, [src + off]`
| `71` / `01110001` | all | `ldxb dst, [src + off]`
| `79` / `01111001` | all | `ldxdw dst, [src + off]`
| `81` / `10000001` | | -- reserved --
| `89` / `10001001` | | -- reserved --
| `91` / `10010001` | | -- reserved --
| `99` / `10011001` | | -- reserved --
| `A1` / `10100001` | | -- reserved --
| `A9` / `10101001` | | -- reserved --
| `B1` / `10110001` | | -- reserved --
| `B9` / `10111001` | | -- reserved --
| `C1` / `11000001` | | -- reserved --
| `C9` / `11001001` | | -- reserved --
| `D1` / `11010001` | | -- reserved --
| `D9` / `11011001` | | -- reserved --
| `E1` / `11100001` | | -- reserved --
| `E9` / `11101001` | | -- reserved --
| `F1` / `11110001` | | -- reserved --
| `F9` / `11111001` | | -- reserved --
| `81` to `F9` | | -- reserved --

| opcode (hex / bin) | feature set | assembler mnemonic
| ------------------ | ----------- | ------------------
| `02` / `00000010` | | -- reserved --
| `0A` / `00001010` | | -- reserved --
| `12` / `00010010` | | -- reserved --
| `1A` / `00011010` | | -- reserved --
| `22` / `00100010` | | -- reserved --
| `2A` / `00101010` | | -- reserved --
| `32` / `00110010` | | -- reserved --
| `3A` / `00111010` | | -- reserved --
| `42` / `01000010` | | -- reserved --
| `4A` / `01001010` | | -- reserved --
| `52` / `01010010` | | -- reserved --
| `5A` / `01011010` | | -- reserved --
| `02` to `5A` | | -- reserved --
| `62` / `01100010` | all | `stw [dst + off], imm`
| `6A` / `01101010` | all | `sth [dst + off], imm`
| `72` / `01110010` | all | `stb [dst + off], imm`
| `7A` / `01111010` | all | `stdw [dst + off], imm`
| `82` / `10000010` | | -- reserved --
| `8A` / `10001010` | | -- reserved --
| `92` / `10010010` | | -- reserved --
| `9A` / `10011010` | | -- reserved --
| `A2` / `10100010` | | -- reserved --
| `AA` / `10101010` | | -- reserved --
| `B2` / `10110010` | | -- reserved --
| `BA` / `10111010` | | -- reserved --
| `C2` / `11000010` | | -- reserved --
| `CA` / `11001010` | | -- reserved --
| `D2` / `11010010` | | -- reserved --
| `DA` / `11011010` | | -- reserved --
| `E2` / `11100010` | | -- reserved --
| `EA` / `11101010` | | -- reserved --
| `F2` / `11110010` | | -- reserved --
| `FA` / `11111010` | | -- reserved --
| `82` to `FA` | | -- reserved --

| opcode (hex / bin) | feature set | assembler mnemonic
| ------------------ | ----------- | ------------------
| `03` / `00000011` | | -- reserved --
| `0B` / `00001011` | | -- reserved --
| `13` / `00010011` | | -- reserved --
| `1B` / `00011011` | | -- reserved --
| `23` / `00100011` | | -- reserved --
| `2B` / `00101011` | | -- reserved --
| `33` / `00110011` | | -- reserved --
| `3B` / `00111011` | | -- reserved --
| `43` / `01000011` | | -- reserved --
| `4B` / `01001011` | | -- reserved --
| `53` / `01010011` | | -- reserved --
| `5B` / `01011011` | | -- reserved --
| `03` to `5B` | | -- reserved --
| `63` / `01100011` | all | `stxw [dst + off], src`
| `6B` / `01101011` | all | `stxh [dst + off], src`
| `73` / `01110011` | all | `stxb [dst + off], src`
| `7B` / `01111011` | all | `stxdw [dst + off], src`
| `83` / `10000011` | | -- reserved --
| `8B` / `10001011` | | -- reserved --
| `93` / `10010011` | | -- reserved --
| `9B` / `10011011` | | -- reserved --
| `A3` / `10100011` | | -- reserved --
| `AB` / `10101011` | | -- reserved --
| `B3` / `10110011` | | -- reserved --
| `BB` / `10111011` | | -- reserved --
| `C3` / `11000011` | | -- reserved --
| `CB` / `11001011` | | -- reserved --
| `D3` / `11010011` | | -- reserved --
| `DB` / `11011011` | | -- reserved --
| `E3` / `11100011` | | -- reserved --
| `EB` / `11101011` | | -- reserved --
| `F3` / `11110011` | | -- reserved --
| `FB` / `11111011` | | -- reserved --
| `83` to `FB` | | -- reserved --

### Control Flow

Expand Down Expand Up @@ -402,10 +284,7 @@ The `exit` (a.k.a. return) instruction does:
| `CD` / `11001101` | all | `jslt dst, src, off` | `(dst as i64) < (src as i64)`
| `D5` / `11010101` | all | `jsle dst, imm, off` | `(dst as i64) <= (imm as i32 as i64)`
| `DD` / `11011101` | all | `jsle dst, src, off` | `(dst as i64) <= (src as i64)`
| `E5` / `11100101` | | -- reserved --
| `ED` / `11101101` | | -- reserved --
| `F5` / `11110101` | | -- reserved --
| `FD` / `11111101` | | -- reserved --
| `E5` to `FD` | | -- reserved --


Verification
Expand Down

0 comments on commit 7a6e742

Please sign in to comment.