ocmbytecode
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| ocmbytecode [2023/04/13 14:06] – [Opcodes 60..6F] nopsled | ocmbytecode [2025/09/21 18:55] (current) – nopsled | ||
|---|---|---|---|
| Line 59: | Line 59: | ||
| ===== Small numbers (tag 0): signed 16 bit numbers ===== | ===== Small numbers (tag 0): signed 16 bit numbers ===== | ||
| - | ===== Large integers (tag 1): arbitraty | + | ===== Large integers (tag 1): arbitary | 
| Serialization format: Length followed by two's complement little endian representation. The length is according to ASN.1 lengths: Length is directly encoded as one byte for lengths 0..127. A length encoding starting with 128 is invalid (would mean unspecified). If the first byte of the length is above 128, subtract 128 and take that many bytes. They make up a big-endian unsigned integer. | Serialization format: Length followed by two's complement little endian representation. The length is according to ASN.1 lengths: Length is directly encoded as one byte for lengths 0..127. A length encoding starting with 128 is invalid (would mean unspecified). If the first byte of the length is above 128, subtract 128 and take that many bytes. They make up a big-endian unsigned integer. | ||
| ===== Binary blobs (tag 2) ===== | ===== Binary blobs (tag 2) ===== | ||
| Line 69: | Line 69: | ||
| ===== Opcodes 00..0F ===== | ===== Opcodes 00..0F ===== | ||
| - | === Opcode | + | === Opcode | 
| does nothing | does nothing | ||
| === Opcode 0x01: Immediate byte (value) === | === Opcode 0x01: Immediate byte (value) === | ||
| Line 173: | Line 173: | ||
| stack output: smallint containing lowest 16 bits of a*b | stack output: smallint containing lowest 16 bits of a*b | ||
| - | === Opcode 0x14: Divide Small Ints (div) === | + | === Opcode 0x14 (20): Divide Small Ints (div) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a/b | stack output: smallint containing a/b | ||
| - | === Opcode 0x15: Divide and Modulus of Small Ints (moddiv) === | + | === Opcode 0x15 (21): Divide and Modulus of Small Ints (moddiv) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a/b (next to top); smallint containing a%b (top of stack) | stack output: smallint containing a/b (next to top); smallint containing a%b (top of stack) | ||
| - | === Opcode 0x16: Modulus of Small Ints (divmod) === | + | === Opcode 0x16 (22): Modulus of Small Ints (divmod) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a%b | stack output: smallint containing a%b | ||
| - | === Opcode 0x17: Xor Small Ints (xor) === | + | === Opcode 0x17 (23): Xor Small Ints (xor) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a ^ b | stack output: smallint containing a ^ b | ||
| - | === Opcode 0x18: And Small Ints (and) === | + | === Opcode 0x18 (24): And Small Ints (and) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a & b | stack output: smallint containing a & b | ||
| - | === Opcode 0x19: Or Small Ints === (or) === | + | === Opcode 0x19 (25): Or Small Ints === (or) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing a | b | stack output: smallint containing a | b | ||
| - | === Opcode 0x1A: Bitwise Negate Small Int (neg) === | + | === Opcode 0x1A (26): Bitwise Negate Small Int (neg) === | 
| stack input: smallint a | stack input: smallint a | ||
| stack output: smallint containing ~a | stack output: smallint containing ~a | ||
| - | === Opcode 0x1B: Shift Left Small Int (shl) === | + | === Opcode 0x1B (27): Shift Left Small Int (shl) === | 
| stack input: smallint a (next to top); smallint count (top of stack) | stack input: smallint a (next to top); smallint count (top of stack) | ||
| stack output: smallint containing a << count | stack output: smallint containing a << count | ||
| - | === Opcode 0x1C: Shift Right Small Int (shr) === | + | === Opcode 0x1C (28): Shift Right Small Int (shr) === | 
| stack input: smallint a (next to top); smallint count (top of stack) | stack input: smallint a (next to top); smallint count (top of stack) | ||
| stack output: smallint containing ( (unsigned)a) >> count | stack output: smallint containing ( (unsigned)a) >> count | ||
| - | === Opcode 0x1D: Shift Right Arithmetic Small Int (sar) === | + | === Opcode 0x1D (29): Shift Right Arithmetic Small Int (sar) === | 
| stack input: smallint a (next to top); smallint count (top of stack) | stack input: smallint a (next to top); smallint count (top of stack) | ||
| stack output: smallint containing a >> count | stack output: smallint containing a >> count | ||
| - | === Opcode 0x1E: Compare Small Ints for Greater (cmp) === | + | === Opcode 0x1E (30): Compare Small Ints for Greater (cmp) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing 1 if a > b, 0 otherwise | stack output: smallint containing 1 if a > b, 0 otherwise | ||
| - | === Opcode 0x1F: Compare Small Ints for Less (cmp) === | + | === Opcode 0x1F (31): Compare Small Ints for Less (cmp) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| Line 236: | Line 236: | ||
| ===== Opcodes 20..2F ===== | ===== Opcodes 20..2F ===== | ||
| - | === Opcode 0x20 (32): Compare Small Ints for equal === | + | === Opcode 0x20 (32): Compare Small Ints for equal (cmp) === | 
| stack input: smallint a (next to top); smallint b (top of stack) | stack input: smallint a (next to top); smallint b (top of stack) | ||
| stack output: smallint containing 1 if a == b, 0 otherwise | stack output: smallint containing 1 if a == b, 0 otherwise | ||
| - | === Opcode 0x21 (33): Test for Small Int Zero === | + | === Opcode 0x21 (33): Test for Small Int Zero (iszerow) | 
| stack input: object of any type (maybe only smallint intended) | stack input: object of any type (maybe only smallint intended) | ||
| stack output: 1 if object has type smallint and is zero | stack output: 1 if object has type smallint and is zero | ||
| - | === Opcode 0x22 (34): Add DWORDs === | + | === Opcode 0x22 (34): Add DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 253: | Line 253: | ||
| note: DWORD instructions only use the 32 least significant bits in bigint input operands, and samllint operands are treated as unsigned for unknown reasons. All arithmetic is unsigned. As bigints are in sign/ | note: DWORD instructions only use the 32 least significant bits in bigint input operands, and samllint operands are treated as unsigned for unknown reasons. All arithmetic is unsigned. As bigints are in sign/ | ||
| - | === Opcode 0x23 (35): Subtract DWORDs === | + | === Opcode 0x23 (35): Subtract DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 260: | Line 260: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x24 (36): Multiply DWORDs === | + | === Opcode 0x24 (36): Multiply DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 267: | Line 267: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x25 (37): Divide DWORDs === | + | === Opcode 0x25 (37): Divide DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 274: | Line 274: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x26 (38): Division and Modulus of DWORDs === | + | === Opcode 0x26 (38): Division and Modulus of DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 281: | Line 281: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x27 (39): Modulus of DWORDs === | + | === Opcode 0x27 (39): Modulus of DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 288: | Line 288: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x28 (40): Xor DWORDs === | + | === Opcode 0x28 (40): Xor DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 295: | Line 295: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x29 (41): And DWORDs === | + | === Opcode 0x29 (41): And DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 302: | Line 302: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2A (42): Or DWORDs === | + | === Opcode 0x2A (42): Or DWORDs | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 309: | Line 309: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2B (43): Bitwise Not DWORD === | + | === Opcode 0x2B (43): Bitwise Not DWORD (not) === | 
| stack input: small/big int a (top of stack) | stack input: small/big int a (top of stack) | ||
| Line 316: | Line 316: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2C (44): Shift Left DWORD === | + | === Opcode 0x2C (44): Shift Left DWORD (shl) === | 
| stack input: small/big int a (next to top); small/big int count (top of stack) | stack input: small/big int a (next to top); small/big int count (top of stack) | ||
| Line 323: | Line 323: | ||
| note: See Opcode 0x22 for important notes on DWORD instructions. | note: See Opcode 0x22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2D (45): Shift Right DWORD === | + | === Opcode 0x2D (45): Shift Right DWORD (shr) === | 
| stack input: small/big int a (next to top); small/big int count (top of stack) | stack input: small/big int a (next to top); small/big int count (top of stack) | ||
| Line 330: | Line 330: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2E (46): Compare DWORDs for Less === | + | === Opcode 0x2E (46): Compare DWORDs for Less (cmp) === | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 337: | Line 337: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x2F (47): Compare DWORDs for Greater === | + | === Opcode 0x2F (47): Compare DWORDs for Greater | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 346: | Line 346: | ||
| ===== Opcodes 30..3F ===== | ===== Opcodes 30..3F ===== | ||
| - | === Opcode 0x30 (48): Compare DWORDs for Equality === | + | === Opcode 0x30 (48): Compare DWORDs for Equality | 
| stack input: small/big int a (next to top); small/big int b (top of stack) | stack input: small/big int a (next to top); small/big int b (top of stack) | ||
| Line 353: | Line 353: | ||
| note: See Opcode 22 for important notes on DWORD instructions. | note: See Opcode 22 for important notes on DWORD instructions. | ||
| - | === Opcode 0x31 (49): Execute === | + | === Opcode 0x31 (49): Execute | 
| stack input: binary blob containing bytecode | stack input: binary blob containing bytecode | ||
| Line 362: | Line 362: | ||
| PostScript equivalent: " | PostScript equivalent: " | ||
| - | === Opcode 0x32 (50): If/Else === | + | === Opcode 0x32 (50): If/ | 
| stack input: selector (smallint at second to top of stack), blob for the true case (next to top), blob for the false case (top of stack) | stack input: selector (smallint at second to top of stack), blob for the true case (next to top), blob for the false case (top of stack) | ||
| effect: if the selector is not zero, the true blob is executed (as in Opcode 31), otherwise the false blob is executed. | effect: if the selector is not zero, the true blob is executed (as in Opcode 31), otherwise the false blob is executed. | ||
| - | === Opcode 0x33 (51): While === | + | === Opcode 0x33 (51): While (while) | 
| stack input: condition flag (smallint) | stack input: condition flag (smallint) | ||
| Line 376: | Line 376: | ||
| note: The blob reference on the alternate stack is **not** removed by this instruction, | note: The blob reference on the alternate stack is **not** removed by this instruction, | ||
| - | === Opcode 0x34 (52): Push to alternate stack === | + | === Opcode 0x34 (52): Push to alternate stack (toalt) | 
| stack input: value of any type | stack input: value of any type | ||
| Line 383: | Line 383: | ||
| effect: The value is moved from the standard stack to the alternate stack | effect: The value is moved from the standard stack to the alternate stack | ||
| - | === Opcode 0x35 (53): Pop from alternate stack === | + | === Opcode 0x35 (53): Pop from alternate stack (fromalt) | 
| **alternate** stack input: value of any type | **alternate** stack input: value of any type | ||
| Line 390: | Line 390: | ||
| effect: The value is moved from the alternate stack to the standard stack | effect: The value is moved from the alternate stack to the standard stack | ||
| - | === Opcode 0x36 (54): Peek alternate stack === | + | === Opcode 0x36 (54): Peek alternate stack (peekalt) | 
| **alternate** stack input: value of any type (not removed by this instruction) | **alternate** stack input: value of any type (not removed by this instruction) | ||
| Line 397: | Line 397: | ||
| effect: The value is **copied** from the alternate stack to the standard stack | effect: The value is **copied** from the alternate stack to the standard stack | ||
| - | === Opcode 0x37 (55): Push 0 === | + | === Opcode 0x37 (55): Push 0 (0) === | 
| stack output: smallint containing 0 | stack output: smallint containing 0 | ||
| - | === Opcode 0x38 (56): Push 1 === | + | === Opcode 0x38 (56): Push 1 (1) === | 
| stack output: smallint containing 1 | stack output: smallint containing 1 | ||
| - | === Opcode 0x39 (57): Push 2 === | + | === Opcode 0x39 (57): Push 2 (2) === | 
| stack output: smallint containing 2 | stack output: smallint containing 2 | ||
| - | === Opcode 0x3A (58): Push 3 === | + | === Opcode 0x3A (58): Push 3 (3) === | 
| stack output: smallint containing 3 | stack output: smallint containing 3 | ||
| - | === Opcode 0x3B (59): Push 4 === | + | === Opcode 0x3B (59): Push 4 (4) === | 
| stack output: smallint containing 4 | stack output: smallint containing 4 | ||
| - | === Opcode 0x3C (60): Push 5 === | + | === Opcode 0x3C (60): Push 5 (5) === | 
| stack output: smallint containing 5 | stack output: smallint containing 5 | ||
| - | === Opcode 0x3D (61): Push 6 === | + | === Opcode 0x3D (61): Push 6 (6) === | 
| stack output: smallint containing 6 | stack output: smallint containing 6 | ||
| - | === Opcode 0x3E (62): Push 7 === | + | === Opcode 0x3E (62): Push 7 (7) === | 
| stack output: smallint containing 7 | stack output: smallint containing 7 | ||
| - | === Opcode 0x3F (63): Push 8 === | + | === Opcode 0x3F (63): Push 8 (8) === | 
| stack output: smallint containing 8 | stack output: smallint containing 8 | ||
| ===== Opcodes 40..4F ===== | ===== Opcodes 40..4F ===== | ||
| - | === Opcode 0x40: Push 9 === | + | === Opcode 0x40 (64): Push 9 === | 
| stack output: smallint containing 9 | stack output: smallint containing 9 | ||
| - | === Opcode 0x41: Push -1 === | + | === Opcode 0x41 (65): Push -1 === | 
| stack output: smallint containing -1 | stack output: smallint containing -1 | ||
| - | === Opcode 0x42: Push -2 === | + | === Opcode 0x42 (66): Push -2 === | 
| stack output: smallint containing -2 | stack output: smallint containing -2 | ||
| - | === Opcode 0x43: Push -3 === | + | === Opcode 0x43 (67): Push -3 === | 
| stack output: smallint containing -3 | stack output: smallint containing -3 | ||
| - | === Opcode 0x44: Test Small Int Positive === | + | === Opcode 0x44 (68): Test Small Int Positive === | 
| stack input: smallint a | stack input: smallint a | ||
| stack ouput: smallint 1 if a > 0, smallint 0 else | stack ouput: smallint 1 if a > 0, smallint 0 else | ||
| - | === Opcode 0x45: Test Small Int Negative === | + | === Opcode 0x45 (69): Test Small Int Negative === | 
| stack input: smallint a | stack input: smallint a | ||
| stack ouput: smallint 1 if a < 0, smallint 0 else | stack ouput: smallint 1 if a < 0, smallint 0 else | ||
| - | === Opcode 0x46: Test Small Int for Zero === | + | === Opcode 0x46 (70): Test Small Int for Zero === | 
| stack input: smallint a | stack input: smallint a | ||
| Line 455: | Line 455: | ||
| note: in contrast to Opcode 21 "Test for Small Int Zero", this opcode has undefined behaviour of the operand is not a small integer. | note: in contrast to Opcode 21 "Test for Small Int Zero", this opcode has undefined behaviour of the operand is not a small integer. | ||
| - | === Opcode 0x47: Duplicate second-to-top === | + | === Opcode 0x47 (71): Duplicate second-to-top | 
| effect: pushes a copy of the second-to-top (the third value if you call top-of-stack the first one) to the standard stack. | effect: pushes a copy of the second-to-top (the third value if you call top-of-stack the first one) to the standard stack. | ||
| PostScript equivalent: "2 index" | PostScript equivalent: "2 index" | ||
| - | === Opcode 0x48: Duplicate third-to-top === | + | === Opcode 0x48 (72): Duplicate third-to-top | 
| effect: pushes a copy of the third-to-top (the fourth value if you call top-of-stack the first one) to the standard stack. | effect: pushes a copy of the third-to-top (the fourth value if you call top-of-stack the first one) to the standard stack. | ||
| PostScript equivalent: "3 index" | PostScript equivalent: "3 index" | ||
| - | === Opcode 0x49: Duplicate fourth-to-top === | + | === Opcode 0x49 (73): Duplicate fourth-to-top | 
| effect: pushes a copy of the fourth-to-top (the 5th value if you call top-of-stack the first one) to the standard stack. | effect: pushes a copy of the fourth-to-top (the 5th value if you call top-of-stack the first one) to the standard stack. | ||
| PostScript equivalent: "4 index" | PostScript equivalent: "4 index" | ||
| - | === Opcode 0x4A: Duplicate 5th-to-top === | + | === Opcode 0x4A (74): Duplicate 5th-to-top | 
| effect: pushes a copy of the 5th-to-top (the 6th value if you call top-of-stack the first one) to the standard stack. | effect: pushes a copy of the 5th-to-top (the 6th value if you call top-of-stack the first one) to the standard stack. | ||
| PostScript equivalent: "5 index" | PostScript equivalent: "5 index" | ||
| - | === Opcode 0x4B: Move Top-3 to top === | + | === Opcode 0x4B (75): Move Top-3 to top (rollin.5) | 
| effect: The value at Top-3 gets moved to top of stack, top of stack becomes top-1 and so on. | effect: The value at Top-3 gets moved to top of stack, top of stack becomes top-1 and so on. | ||
| PostScript equivalent: "4 -1 roll" | PostScript equivalent: "4 -1 roll" | ||
| - | === Opcode 0x4C: Move Top-4 to top === | + | === Opcode 0x4C (76): Move Top-4 to top (rollin.4) | 
| effect: The value at Top-4 gets moved to top of stack, top of stack becomes top-1 and so on. | effect: The value at Top-4 gets moved to top of stack, top of stack becomes top-1 and so on. | ||
| PostScript equivalent: "5 -1 roll" | PostScript equivalent: "5 -1 roll" | ||
| - | === Opcode 0x4D: Move Top-5 to top === | + | === Opcode 0x4D (77): Move Top-5 to top (rollin.3) | 
| effect: The value at Top-5 gets moved to top of stack, top of stack becomes top-1 and so on. | effect: The value at Top-5 gets moved to top of stack, top of stack becomes top-1 and so on. | ||
| PostScript equivalent: "6 -1 roll" | PostScript equivalent: "6 -1 roll" | ||
| - | === Opcode 0x4E: Increment Small Int === | + | === Opcode 0x4E (78): Increment Small Int (inc.w) | 
| stack input: smallint a | stack input: smallint a | ||
| stack ouput: smallint (a+1) | stack ouput: smallint (a+1) | ||
| - | === Opcode 0x4F: Decrement Small Int === | + | === Opcode 0x4F (79): Decrement Small Int (dec.w) | 
| stack input: smallint a | stack input: smallint a | ||
| Line 501: | Line 501: | ||
| ===== Opcodes 50..5F ===== | ===== Opcodes 50..5F ===== | ||
| - | === Opcode | + | === Opcode | 
| stack input: value //a// that is not an array | stack input: value //a// that is not an array | ||
| stack output: //a// if a is numeric (smallint or bigint). If //a// is a blob, is is read as a two's complement signed big-endian number and returned in a bigint. | stack output: //a// if a is numeric (smallint or bigint). If //a// is a blob, is is read as a two's complement signed big-endian number and returned in a bigint. | ||
| - | === Opcode | + | === Opcode | 
| stack input: value //a// that is not an array | stack input: value //a// that is not an array | ||
| Line 513: | Line 513: | ||
| note: Negative smallints or bigints are unchanged by this operation. Compare opcode 53 "Make operand unsigned" | note: Negative smallints or bigints are unchanged by this operation. Compare opcode 53 "Make operand unsigned" | ||
| - | === Opcode | + | === Opcode | 
| stack input: value //a// that is not an array | stack input: value //a// that is not an array | ||
| stack output: If the input is a blob, it remains unchanged. Otherwise, it is returned as two's complement big-endian number in a blob. | stack output: If the input is a blob, it remains unchanged. Otherwise, it is returned as two's complement big-endian number in a blob. | ||
| - | === Opcode | + | === Opcode | 
| stack input: numeric value //a// | stack input: numeric value //a// | ||
| stack output: A numeric value that results from interpreting the bits in //a// as unsigned number. I.e. smallints 0..32767 are returned unchanged. smallints -1..-32768 are converted to bigints 65536..32768 respsctively. Negative big-ints are sign-extended to whole bytes and the resulting value is treated as unsigned value | stack output: A numeric value that results from interpreting the bits in //a// as unsigned number. I.e. smallints 0..32767 are returned unchanged. smallints -1..-32768 are converted to bigints 65536..32768 respsctively. Negative big-ints are sign-extended to whole bytes and the resulting value is treated as unsigned value | ||
| - | === Opcode | + | === Opcode | 
| stack input: numeric value //a// | stack input: numeric value //a// | ||
| stack output: smallints stay unchanged. The low 16 bits of the absolute value are returned for bigints, so unless you know what you are doing, only use this instruction for the range 0..32767 | stack output: smallints stay unchanged. The low 16 bits of the absolute value are returned for bigints, so unless you know what you are doing, only use this instruction for the range 0..32767 | ||
| - | === Opcode | + | === Opcode | 
| stack input: //n// value of any type; smallint //n// (at top of stack) | stack input: //n// value of any type; smallint //n// (at top of stack) | ||
| stack output: (reference to) a newly created array containing the //n// elements from the stack below the count itself | stack output: (reference to) a newly created array containing the //n// elements from the stack below the count itself | ||
| - | === Opcode | + | === Opcode | 
| stack input: an array of //n// elements | stack input: an array of //n// elements | ||
| stack output: //n// values of any type (the array element); smallint //n// (count of elements; at top of stack) | stack output: //n// values of any type (the array element); smallint //n// (count of elements; at top of stack) | ||
| - | === Opcode | + | === Opcode | 
| stack input: an array with //n// elements | stack input: an array with //n// elements | ||
| stack output: smallint //n// | stack output: smallint //n// | ||
| - | === Opcode | + | === Opcode | 
| stack input: //entry// (any type, second to top); an array (next to top); //index// (small or big int at top of stack) | stack input: //entry// (any type, second to top); an array (next to top); //index// (small or big int at top of stack) | ||
| stack output: A (reference to a) copy of the array with the new element //entry// inserted before the // | stack output: A (reference to a) copy of the array with the new element //entry// inserted before the // | ||
| - | === Opcode | + | === Opcode | 
| stack input: an array (next to top); //index// (small or big int at top of stack) | stack input: an array (next to top); //index// (small or big int at top of stack) | ||
| stack output: A (reference to a) copy of the array with the element at position //index// removed (and all further elements moved one position to the front) | stack output: A (reference to a) copy of the array with the element at position //index// removed (and all further elements moved one position to the front) | ||
| - | === Opcode | + | === Opcode | 
| stack input: (reference to) an array (next to top); smallint //k// (top of stack) | stack input: (reference to) an array (next to top); smallint //k// (top of stack) | ||
| stack output: The // | stack output: The // | ||
| - | === Opcode | + | === Opcode | 
| stack input: value //x// of any type (second to top); (reference to) an array (next to top); smallint //k// (at top) | stack input: value //x// of any type (second to top); (reference to) an array (next to top); smallint //k// (at top) | ||
| Line 567: | Line 567: | ||
| note: This operation does **not** copy the array, so the element changes globally. | note: This operation does **not** copy the array, so the element changes globally. | ||
| - | === Opcode | + | === Opcode | 
| stack input: //n// (smallint at top of stack) | stack input: //n// (smallint at top of stack) | ||
| stack output: A newly allocated array of //n// elements. All elements are initialized with smallint zero. | stack output: A newly allocated array of //n// elements. All elements are initialized with smallint zero. | ||
| - | === Opcode | + | === Opcode | 
| stack input: value to encode (any type) | stack input: value to encode (any type) | ||
| Line 582: | Line 582: | ||
| * arrays are encoded as SEQUENCE (ASN.1 tag 0x30), the sequence is always encoded as unknown-length and double-zero-terminated. | * arrays are encoded as SEQUENCE (ASN.1 tag 0x30), the sequence is always encoded as unknown-length and double-zero-terminated. | ||
| - | === Opcode | + | === Opcode | 
| stack input: //n// blobs (should contain ASN.1 encoded data, first element pushed first, last element next-to-top); | stack input: //n// blobs (should contain ASN.1 encoded data, first element pushed first, last element next-to-top); | ||
| Line 589: | Line 589: | ||
| note: The output is just 0x30 (SEQUENCE); 0x80 (unknown length); catenation of all blobs; 0x00; 0x00 | note: The output is just 0x30 (SEQUENCE); 0x80 (unknown length); catenation of all blobs; 0x00; 0x00 | ||
| - | === Opcode | + | === Opcode | 
| stack input: a blob containing an ASN.1 encoded object. | stack input: a blob containing an ASN.1 encoded object. | ||
| Line 604: | Line 604: | ||
| ===== Opcodes 60..6F ===== | ===== Opcodes 60..6F ===== | ||
| - | === Opcode 0x60: Enclose Smallint === | + | === Opcode 0x60 (96): Enclose Smallint | 
| stack input: A smallint | stack input: A smallint | ||
| Line 611: | Line 611: | ||
| Note: the blob that gets returned is non-refcounted and lives until explicit destruction (for example by opcode 08) | Note: the blob that gets returned is non-refcounted and lives until explicit destruction (for example by opcode 08) | ||
| - | === Opcode 0x61: Get Enclosed Smallint === | + | === Opcode 0x61 (97): Get Enclosed Smallint | 
| stack input: A blob that encloses a small integer, created by opcode 60 | stack input: A blob that encloses a small integer, created by opcode 60 | ||
| stack output: The enclosed small integer | stack output: The enclosed small integer | ||
| - | === Opcode 0x62: Get Significant Bits === | + | === Opcode 0x62 (98): Get Significant Bits (countbits) | 
| stack input: Object of any type | stack input: Object of any type | ||
| stack ouput: Significant bit in that object. For smallints and bigints its the minimal number of bits to represent the absolute value of that number, for blobs the number of bytes multiplied by 8 and for arrays the sum of the number of significant bits of all entries. | stack ouput: Significant bit in that object. For smallints and bigints its the minimal number of bits to represent the absolute value of that number, for blobs the number of bytes multiplied by 8 and for arrays the sum of the number of significant bits of all entries. | ||
| - | === Opcode 0x63: Immediate Crypted Byte === | + | === Opcode 0x63 (99): Immediate Crypted Byte (0x?? | 
| immediate data: 1 byte (encrypted if OCM code encryption is enabled) | immediate data: 1 byte (encrypted if OCM code encryption is enabled) | ||
| Line 628: | Line 628: | ||
| note: Is often used to refer to the dictionary index where the data is stored. | note: Is often used to refer to the dictionary index where the data is stored. | ||
| - | === Opcode 0x64: Immediate Crypted Word === | + | === Opcode 0x64 (100): Immediate Crypted Word (0x? | 
| immediate data: 1 16-bit-word (encrypted if OCM code encryption is enabled) | immediate data: 1 16-bit-word (encrypted if OCM code encryption is enabled) | ||
| effect: pushes the signed 16 bit value of the immediate operand to the stack as small number | effect: pushes the signed 16 bit value of the immediate operand to the stack as small number | ||
| - | === Opcode 0x65: Immediate Crypted BigInt === | + | === Opcode 0x65 (101): Immediate Crypted BigInt | 
| immediate data: 1 big int (encrypted if OCM code encryption is enabled) | immediate data: 1 big int (encrypted if OCM code encryption is enabled) | ||
| Line 640: | Line 640: | ||
| note: If the OCM module uses the DWORD-based decryptor (it doesn' | note: If the OCM module uses the DWORD-based decryptor (it doesn' | ||
| - | === Opcode 0x66: Immediate Crypted Blob === | + | === Opcode 0x66 (102): Immediate Crypted Blob (value) | 
| immediate data: 1 blob (encrypted if OCM code encryption is enabled) | immediate data: 1 blob (encrypted if OCM code encryption is enabled) | ||
| Line 647: | Line 647: | ||
| note: If the OCM module uses the DWORD-based decryptor (it doesn' | note: If the OCM module uses the DWORD-based decryptor (it doesn' | ||
| - | === Opcode 0x67 (103): Start Threads === | + | === Opcode 0x67 (103): Start Threads | 
| stack input: common thread arg (any type); //n// blobs containing byte code; smallint //n// (at top of stack) | stack input: common thread arg (any type); //n// blobs containing byte code; smallint //n// (at top of stack) | ||
| effect: Starts pseudo-parallel execution of all n blobs. Execution of the main code (that invoked this opcode) stops until all threads are finished or the threaded evaluation mode is cancelled. All threads have their own stack, each containing just the common arg. Also every thread has its private alternate stack. | effect: Starts pseudo-parallel execution of all n blobs. Execution of the main code (that invoked this opcode) stops until all threads are finished or the threaded evaluation mode is cancelled. All threads have their own stack, each containing just the common arg. Also every thread has its private alternate stack. | ||
| - | === Opcode 0x68 (104): Set Time Slice Length === | + | === Opcode 0x68 (104): Set Time Slice Length | 
| stack input: smallint or bigint //len// | stack input: smallint or bigint //len// | ||
| effect: Sets the time slice length for this subthread to //len//. That is the number of bytecode instructions executed for this thread until execution continues with another thread. The current timeslice is unmodified, it just affects the following slices. | effect: Sets the time slice length for this subthread to //len//. That is the number of bytecode instructions executed for this thread until execution continues with another thread. The current timeslice is unmodified, it just affects the following slices. | ||
| - | === Opcode 0x69 (105): Cancel Threaded Execution === | + | === Opcode 0x69 (105): Cancel Threaded Execution | 
| effect: Aborts executing of all subthreads and immediately continues the main thread past its start threads opcode. | effect: Aborts executing of all subthreads and immediately continues the main thread past its start threads opcode. | ||
| - | === Opcode 0x6A (106): Push To Main Thread Stack === | + | === Opcode 0x6A (106): Push To Main Thread Stack (tomain) | 
| stack input: a value of any type | stack input: a value of any type | ||
| Line 667: | Line 667: | ||
| note: This opcode does only make sense in subthreads. | note: This opcode does only make sense in subthreads. | ||
| - | === Opcode 0x6B (107): Pop From Main Thread Stack === | + | === Opcode 0x6B (107): Pop From Main Thread Stack (frommain) | 
| effect: Pops the top value from the stack of the suspended main thread | effect: Pops the top value from the stack of the suspended main thread | ||
| Line 674: | Line 674: | ||
| note: This opcode does only make sense in subthreads. | note: This opcode does only make sense in subthreads. | ||
| - | === Opcode 0x6C (108): Copy From Main Thread Stack === | + | === Opcode 0x6C (108): Copy From Main Thread Stack (peekmain) | 
| effect: Copies the top value from the stack of the suspended main thread | effect: Copies the top value from the stack of the suspended main thread | ||
| Line 681: | Line 681: | ||
| note: This opcode does only make sense in subthreads. | note: This opcode does only make sense in subthreads. | ||
| - | === Opcode 0x6D: gettimeofday === | + | === Opcode 0x6D (109): gettimeofday | 
| stack output: seconds since midnight (tv_sec) as bigint (next to top); microseconds within current second (tv_usec) as bigint (top of stack) | stack output: seconds since midnight (tv_sec) as bigint (next to top); microseconds within current second (tv_usec) as bigint (top of stack) | ||
| - | === Opcode 0x6E: mktime === | + | === Opcode 0x6E (110): mktime | 
| stack input: 6 smallint or bigint values in the following order: seconds, minutes, hours, day (1-based), month (0-based), year (top of stack) | stack input: 6 smallint or bigint values in the following order: seconds, minutes, hours, day (1-based), month (0-based), year (top of stack) | ||
| stack output: the corresponding unix timestamp | stack output: the corresponding unix timestamp | ||
| - | === Opcode 0x6F: localtime === | + | === Opcode 0x6F (111): localtime | 
| stack input: a small/big int containing a unix timestamp | stack input: a small/big int containing a unix timestamp | ||
| Line 695: | Line 695: | ||
| ===== Opcodes 70..7F ===== | ===== Opcodes 70..7F ===== | ||
| - | === Opcode | + | === Opcode | 
| stack input: object of any type | stack input: object of any type | ||
| stack output: The type tag of that object (see top of the page) | stack output: The type tag of that object (see top of the page) | ||
| - | === Opcode | + | === Opcode | 
| stack input: smallint //n// of values to skip | stack input: smallint //n// of values to skip | ||
| stack output: The number generated by the user RNG after skipping //n// values. | stack output: The number generated by the user RNG after skipping //n// values. | ||
| - | === Opcode | + | === Opcode | 
| stack input: smallint //n// | stack input: smallint //n// | ||
| effect: Enables autoskipping, | effect: Enables autoskipping, | ||
| - | === Opcode | + | === Opcode | 
| stack input: smallint //n// as 16 bit seed value. | stack input: smallint //n// as 16 bit seed value. | ||
| Line 717: | Line 717: | ||
| note: This will indicate that the following bytes are encrypted. | note: This will indicate that the following bytes are encrypted. | ||
| - | === Opcode | + | === Opcode | 
| stack input: A reference to a block of bytes. The size must be a power of 2 | stack input: A reference to a block of bytes. The size must be a power of 2 | ||
| effect: Replaces the standard table in the Stream PRNG by the one given as parameter | effect: Replaces the standard table in the Stream PRNG by the one given as parameter | ||
| - | === Opcode | + | === Opcode | 
| stack input: A blob containing a (possibly compressed) module of native code | stack input: A blob containing a (possibly compressed) module of native code | ||
| Line 729: | Line 729: | ||
| effect: The contents of that blob gets loaded into the virtual machine. The first 0x60 bytes of the blob are a header for the module that, amongst other things, contains the name of the module which is used to identify it. The module is decompressed, | effect: The contents of that blob gets loaded into the virtual machine. The first 0x60 bytes of the blob are a header for the module that, amongst other things, contains the name of the module which is used to identify it. The module is decompressed, | ||
| - | === Opcode | + | === Opcode | 
| stack input: A module handle (as smallint) | stack input: A module handle (as smallint) | ||
| Line 736: | Line 736: | ||
| effect: Unloads the given native module. If it is not named " | effect: Unloads the given native module. If it is not named " | ||
| - | === Opcode | + | === Opcode | 
| stack input: args for the native module (type(s) module specific); module handle (smallint at top) | stack input: args for the native module (type(s) module specific); module handle (smallint at top) | ||
| Line 743: | Line 743: | ||
| effect: Runs the native code associated with the given module handle. It removes the module handle from the stack before running that module. The module itself can do to the stack whatever it wants. | effect: Runs the native code associated with the given module handle. It removes the module handle from the stack before running that module. The module itself can do to the stack whatever it wants. | ||
| - | === Opcode | + | === Opcode | 
| stack input: possible module args; a blob containing a non-compressed module (at top; like for Opcode 75) | stack input: possible module args; a blob containing a non-compressed module (at top; like for Opcode 75) | ||
| Line 750: | Line 750: | ||
| effect: Executes the native code from the blob given as parameter. The blob is relocated and exports are loaded (unless it is a " | effect: Executes the native code from the blob given as parameter. The blob is relocated and exports are loaded (unless it is a " | ||
| - | === Opcode | + | === Opcode | 
| stack input: module handle (as smallint) | stack input: module handle (as smallint) | ||
| stack ouput: blob containing name of that module | stack ouput: blob containing name of that module | ||
| - | === Opcode | + | === Opcode | 
| stack input: blob containing of module name | stack input: blob containing of module name | ||
| stack ouput: smallint containing module handle | stack ouput: smallint containing module handle | ||
| - | === Opcode | + | === Opcode | 
| stack input: module name (blob next to top); module contents (blob at top) | stack input: module name (blob next to top); module contents (blob at top) | ||
| Line 767: | Line 767: | ||
| Creates an entry in the module list that references the address range of the blob. | Creates an entry in the module list that references the address range of the blob. | ||
| - | === Opcode | + | === Opcode | 
| stack input: module contents (blob); module name (blob at top, optional) | stack input: module contents (blob); module name (blob at top, optional) | ||
| Line 774: | Line 774: | ||
| Copies the blob contents into the interpreter as bytecode module. If top of stack is <= 8 chars, it is treated as a name. Otherwise the standard name " | Copies the blob contents into the interpreter as bytecode module. If top of stack is <= 8 chars, it is treated as a name. Otherwise the standard name " | ||
| - | === Opcode | + | === Opcode | 
| stack input: smallint containing module handle. | stack input: smallint containing module handle. | ||
| Line 786: | Line 786: | ||
|  |  | ||
| - | === Opcode | + | === Opcode | 
| stack input: smallint; blob (at top of stack) | stack input: smallint; blob (at top of stack) | ||
| effect: uses the smallint and the blob to seed the User PRNG. | effect: uses the smallint and the blob to seed the User PRNG. | ||
| - | === Opcode | + | === Opcode | 
| effect: none | effect: none | ||
| Line 840: | Line 840: | ||
| ===== Opcode 0x87..0x8F ===== | ===== Opcode 0x87..0x8F ===== | ||
| - | === Opcode 0x87: Add Big Integers === | + | === Opcode 0x87 (135): Add Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 846: | Line 846: | ||
| stack output: bigint //a// + //b// | stack output: bigint //a// + //b// | ||
| - | === Opcode 0x88: Subtract Big Integers === | + | === Opcode 0x88 (136): Subtract Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 852: | Line 852: | ||
| stack output: bigint //a// - //b// | stack output: bigint //a// - //b// | ||
| - | === Opcode 0x89: Multiply Big Integers === | + | === Opcode 0x89 (137): Multiply Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 858: | Line 858: | ||
| stack output: bigint //a// * //b// | stack output: bigint //a// * //b// | ||
| - | === Opcode 0x8A: Divide Big Integers === | + | === Opcode 0x8A (138): Divide Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 864: | Line 864: | ||
| stack output: bigint //a// / //b// | stack output: bigint //a// / //b// | ||
| - | === Opcode 0x8B: Divide and Modulus of Big Integers === | + | === Opcode 0x8B (139): Divide and Modulus of Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 870: | Line 870: | ||
| stack output: bigint //a// % //b//; //a// / //b// (careful, different order than DivMod for smallints and dwords. Somerthing wrong here?) | stack output: bigint //a// % //b//; //a// / //b// (careful, different order than DivMod for smallints and dwords. Somerthing wrong here?) | ||
| - | === Opcode 0x8C: Modulus of Big Integers === | + | === Opcode 0x8C (140): Modulus of Big Integers === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 877: | Line 877: | ||
| - | === Opcode 0x8D: Compare Big Integers for Greater === | + | === Opcode 0x8D (141): Compare Big Integers for Greater === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 883: | Line 883: | ||
| stack output: smallint 1 if // | stack output: smallint 1 if // | ||
| - | === Opcode 0x8E: Compare Big Integers for Less === | + | === Opcode 0x8E (142): Compare Big Integers for Less === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 889: | Line 889: | ||
| stack output: smallint 1 if // | stack output: smallint 1 if // | ||
| - | === Opcode 0x8F: Compare Big Integers for Equal === | + | === Opcode 0x8F (143): Compare Big Integers for Equal === | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 897: | Line 897: | ||
| ===== Opcode 0x90..0x9F ===== | ===== Opcode 0x90..0x9F ===== | ||
| - | === Opcode 0x90: Bitwise XOR Big Integers | + | === Opcode 0x90 (144): Bitwise XOR Big Integers | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 903: | Line 903: | ||
| stack output: bigint //a// & //b// | stack output: bigint //a// & //b// | ||
| - | === Opcode 0x91: Bitwise AND Big Integers | + | === Opcode 0x91 (145): Bitwise AND Big Integers | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 909: | Line 909: | ||
| stack output: bigint //a// | //b// | stack output: bigint //a// | //b// | ||
| - | === Opcode 0x92: Bitwise OR Big Integers | + | === Opcode 0x92 (146): Bitwise OR Big Integers | 
| stack input: small/big int //a//; small/big int //b// | stack input: small/big int //a//; small/big int //b// | ||
| Line 915: | Line 915: | ||
| stack output: bigint //a// ^ //b// | stack output: bigint //a// ^ //b// | ||
| - | === Opcode 0x93: Shift Left Big Integers | + | === Opcode 0x93 (147): Shift Left Big Integers | 
| stack input: small/big int //a//; DWORD //b// | stack input: small/big int //a//; DWORD //b// | ||
| Line 923: | Line 923: | ||
| note: DWORDs means that smallints are treated as unsigned 16 bit values in that case. See Instruction 0x22 for details. | note: DWORDs means that smallints are treated as unsigned 16 bit values in that case. See Instruction 0x22 for details. | ||
| - | === Opcode 0x94: Shift Right Big Integers | + | === Opcode 0x94 (148): Shift Right Big Integers | 
| stack input: small/big int //a//; DWORD //b// | stack input: small/big int //a//; DWORD //b// | ||
| Line 931: | Line 931: | ||
| note: DWORDs means that smallints are treated as unsigned 16 bit values in that case. See Instruction 0x22 for details. | note: DWORDs means that smallints are treated as unsigned 16 bit values in that case. See Instruction 0x22 for details. | ||
| - | === Opcode 0x95: Add Big Integers (in Modular Arithmetics) === | + | === Opcode 0x95 (149): Add Big Integers (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //b//; small/big int //m// | stack input: small/big int //a//; small/big int //b//; small/big int //m// | ||
| Line 937: | Line 937: | ||
| stack output: bigint //a// + //b// (mod //m//) | stack output: bigint //a// + //b// (mod //m//) | ||
| - | === Opcode 0x96: Subtract Big Integers (in Modular Arithmetics) === | + | === Opcode 0x96 (150): Subtract Big Integers (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //b//; small/big int //m// | stack input: small/big int //a//; small/big int //b//; small/big int //m// | ||
| Line 943: | Line 943: | ||
| stack output: bigint //a// - //b// (mod //m//) | stack output: bigint //a// - //b// (mod //m//) | ||
| - | === Opcode 0x97: Multiply Big Integers (in Modular Arithmetics) === | + | === Opcode 0x97 (151): Multiply Big Integers (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //b//; small/big int //m// | stack input: small/big int //a//; small/big int //b//; small/big int //m// | ||
| Line 949: | Line 949: | ||
| stack output: bigint //a// * //b// (mod //m//) | stack output: bigint //a// * //b// (mod //m//) | ||
| - | === Opcode 0x98: Negate Big Integer (in Modular Arithmetics) === | + | === Opcode 0x98 (152): Negate Big Integer (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //m// | stack input: small/big int //a//; small/big int //m// | ||
| Line 955: | Line 955: | ||
| stack output: bigint -//a// (mod //m//) | stack output: bigint -//a// (mod //m//) | ||
| - | === Opcode 0x99: Reciprocal of Big Integer (in Modular Arithmetics) === | + | === Opcode 0x99 (153): Reciprocal of Big Integer (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //m// | stack input: small/big int //a//; small/big int //m// | ||
| Line 961: | Line 961: | ||
| stack output: bigint (1 / //a//) (mod //m//) | stack output: bigint (1 / //a//) (mod //m//) | ||
| - | === Opcode 0x9A: Power of Big Integers (in Modular Arithmetics) === | + | === Opcode 0x9A (154): Power of Big Integers (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //e//; small/big int //m// | stack input: small/big int //a//; small/big int //e//; small/big int //m// | ||
| Line 967: | Line 967: | ||
| stack output: bigint (//a// to the // | stack output: bigint (//a// to the // | ||
| - | === Opcode 0x9B: Product of Powers of Big Integers (in Modular Arithmetics) === | + | === Opcode 0x9B (155): Product of Powers of Big Integers (in Modular Arithmetics) === | 
| stack input: small/big int //a1//; small/big int //e1//; small/big int //a2//; small/big int //e2//; small/big int //m// | stack input: small/big int //a1//; small/big int //e1//; small/big int //a2//; small/big int //e2//; small/big int //m// | ||
| Line 975: | Line 975: | ||
| note: This is more efficient than using 0x9A twice and then multiply the result with 0x97, but yields the same result. | note: This is more efficient than using 0x9A twice and then multiply the result with 0x97, but yields the same result. | ||
| - | === Opcode 0x9C: Root of Big Integer (in Modular Arithmetics) === | + | === Opcode 0x9C (156): Root of Big Integer (in Modular Arithmetics) === | 
| stack input: small/big int //a//; small/big int //m// | stack input: small/big int //a//; small/big int //m// | ||
| Line 981: | Line 981: | ||
| stack output bigint //r// such that //r//*//r// == //a// (mod //m//), or //r// == 0 if no value satisfies that equation. | stack output bigint //r// such that //r//*//r// == //a// (mod //m//), or //r// == 0 if no value satisfies that equation. | ||
| - | === Opcode 0x9D: Initialize Fuzzing Context === | + | === Opcode 0x9D (157): Initialize Fuzzing Context === | 
| stack input: small/big int //m// | stack input: small/big int //m// | ||
| Line 987: | Line 987: | ||
| stack ouptut: fuzzing context object for modulus //m// | stack ouptut: fuzzing context object for modulus //m// | ||
| - | === Opcode 0x9E: Fuzz Number === | + | === Opcode 0x9E (158): Fuzz Number === | 
| stack input: small/big int //a//; fuzzing context | stack input: small/big int //a//; fuzzing context | ||
| Line 993: | Line 993: | ||
| stack output: fuzzed value of //a// | stack output: fuzzed value of //a// | ||
| - | === Opcode 0x9F: Unfuzz Number === | + | === Opcode 0x9F (159): Unfuzz Number === | 
| stack input: fuzzed int //f//; fuzzing context | stack input: fuzzed int //f//; fuzzing context | ||
| Line 1001: | Line 1001: | ||
| ===== Opcode 0xA0..0xAF ===== | ===== Opcode 0xA0..0xAF ===== | ||
| - | === Opcode 0xA0: Add Fuzzed Numbers (Modular arithmetics) === | + | === Opcode 0xA0 (160): Add Fuzzed Numbers (Modular arithmetics) === | 
| stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | ||
| Line 1007: | Line 1007: | ||
| stack ouput: fuzzed int //f//+//g// (mod //m// from fuzzing context) | stack ouput: fuzzed int //f//+//g// (mod //m// from fuzzing context) | ||
| - | === Opcode 0xA1: Subtracted Fuzzed Numbers (Modular arithmetics) === | + | === Opcode 0xA1 (161): Subtracted Fuzzed Numbers (Modular arithmetics) === | 
| stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | ||
| Line 1013: | Line 1013: | ||
| stack ouput: fuzzed int //f//-//g// (mod //m// from fuzzing context) | stack ouput: fuzzed int //f//-//g// (mod //m// from fuzzing context) | ||
| - | === Opcode 0xA2: Multiply Fuzzed Numbers (Modular arithmetics) === | + | === Opcode 0xA2 (162): Multiply Fuzzed Numbers (Modular arithmetics) === | 
| stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | stack input: fuzzed int //f//; fuzzed int //g//; fuzzing context | ||
| Line 1019: | Line 1019: | ||
| stack ouput: fuzzed int //f//*//g// (mod //m// from fuzzing context) | stack ouput: fuzzed int //f//*//g// (mod //m// from fuzzing context) | ||
| - | === Opcode 0xA3: Negate Fuzzed Numbers (Modular arithmetics) === | + | === Opcode 0xA3 (163): Negate Fuzzed Numbers (Modular arithmetics) === | 
| stack input: fuzzed int //f//; fuzzing context | stack input: fuzzed int //f//; fuzzing context | ||
| Line 1025: | Line 1025: | ||
| stack ouput: fuzzed int -//f// (mod //m// from fuzzing context) | stack ouput: fuzzed int -//f// (mod //m// from fuzzing context) | ||
| - | === Opcode 0xA4: Reciprocal of Fuzzed Number (Modular arithmetics) === | + | === Opcode 0xA4 (164): Reciprocal of Fuzzed Number (Modular arithmetics) === | 
| stack input: fuzzed int //f//; fuzzing context | stack input: fuzzed int //f//; fuzzing context | ||
| Line 1031: | Line 1031: | ||
| stack ouput: fuzzed int 1 / //f// (mod //m// from fuzzing context) | stack ouput: fuzzed int 1 / //f// (mod //m// from fuzzing context) | ||
| - | === Opcode 0xA5: Power of Fuzzed Number (Modular arithmetics) === | + | === Opcode 0xA5 (165): Power of Fuzzed Number (Modular arithmetics) === | 
| stack input: fuzzed int //f//; (unfuzzed) small/big int //e//; fuzzing context | stack input: fuzzed int //f//; (unfuzzed) small/big int //e//; fuzzing context | ||
| Line 1037: | Line 1037: | ||
| stack ouput: fuzzed int //f// to the // | stack ouput: fuzzed int //f// to the // | ||
| - | === Opcode 0xA6: Product of Powers of Fuzzed Numbers (in Modular Arithmetics) === | + | === Opcode 0xA6 (166): Product of Powers of Fuzzed Numbers (in Modular Arithmetics) === | 
| stack input: fuzzed int //f1//; (unfuzzed) small/big int //e1//; fuzzed int //a2//; (unfuzzed) small/big int //e2//; fuzzing context | stack input: fuzzed int //f1//; (unfuzzed) small/big int //e1//; fuzzed int //a2//; (unfuzzed) small/big int //e2//; fuzzing context | ||
| Line 1045: | Line 1045: | ||
| note: This is more efficient than using 0xA5 twice and then multiply the result with 0xA2, but yields the same result. | note: This is more efficient than using 0xA5 twice and then multiply the result with 0xA2, but yields the same result. | ||
| - | === Opcode 0xA7: Initialize Power Context === | + | === Opcode 0xA7 (167): Initialize Power Context === | 
| stack input: fuzzed int //base//; DWORD //bits//; DWORD //parts//; fuzzing context | stack input: fuzzed int //base//; DWORD //bits//; DWORD //parts//; fuzzing context | ||
| Line 1053: | Line 1053: | ||
| note: A power context contains helper data to calculate different powers of the same base in with the same modulus. The power context gets optimized for exponents with approximately //bits// significant bits. The underlying algorithm is a divide-and-conquer algorithm. The number of parts the exponent will be divided to is given in //parts//, with an upper bound of 16. | note: A power context contains helper data to calculate different powers of the same base in with the same modulus. The power context gets optimized for exponents with approximately //bits// significant bits. The underlying algorithm is a divide-and-conquer algorithm. The number of parts the exponent will be divided to is given in //parts//, with an upper bound of 16. | ||
| - | === Opcode 0xA8: Calculate Power using Power Context === | + | === Opcode 0xA8 (168): Calculate Power using Power Context === | 
| stack input: small/big int //exp//; power context | stack input: small/big int //exp//; power context | ||
| Line 1059: | Line 1059: | ||
| stack output: unfuzzed(!) result of //base// (from the context) to the // | stack output: unfuzzed(!) result of //base// (from the context) to the // | ||
| - | === Opcode 0xA9: Calculate Product of Powers using Power Contexts === | + | === Opcode 0xA9 (169): Calculate Product of Powers using Power Contexts === | 
| stack input: small/big int //exp1//; power context //ctx1//; small/big int //exp2//; power context //ctx2// | stack input: small/big int //exp1//; power context //ctx1//; small/big int //exp2//; power context //ctx2// | ||
| Line 1067: | Line 1067: | ||
| note: Does only work if the modulus in //ctx1// und //ctx2// is the same. Otherwise strange things will happen. | note: Does only work if the modulus in //ctx1// und //ctx2// is the same. Otherwise strange things will happen. | ||
| - | === Opcode 0xAA: Create Mod-P Elliptic Curve Context === | + | === Opcode 0xAA (170): Create Mod-P Elliptic Curve Context === | 
| stack input: small/big int //p//; small/big int //a//; small/big int //b// | stack input: small/big int //p//; small/big int //a//; small/big int //b// | ||
| Line 1073: | Line 1073: | ||
| stack output: elliptic curve context describing the elliptic curve with the parameters //a// and //b// in the finite field of modular arithmetics to the base //p//, which should be prime. | stack output: elliptic curve context describing the elliptic curve with the parameters //a// and //b// in the finite field of modular arithmetics to the base //p//, which should be prime. | ||
| - | === Opcode 0xAB: Add Points in Mod-P Elliptic Curve === | + | === Opcode 0xAB (171): Add Points in Mod-P Elliptic Curve === | 
| stack input: small/big int //x1//; small/big int //y1//; small/big int //x2//; small/big int //y2//; elliptic curve context | stack input: small/big int //x1//; small/big int //y1//; small/big int //x2//; small/big int //y2//; elliptic curve context | ||
| Line 1081: | Line 1081: | ||
| note: This is about addition within an elliptic curve. This is **not** standard vector addition, it is just called addition, as it has a mathematical similar structure. If you want to understand what is really going on, read an introduction into elliptic curve arithmetics. | note: This is about addition within an elliptic curve. This is **not** standard vector addition, it is just called addition, as it has a mathematical similar structure. If you want to understand what is really going on, read an introduction into elliptic curve arithmetics. | ||
| - | === Opcode 0xAC: Negate in Mod-P Elliptic Curve === | + | === Opcode 0xAC (172): Negate in Mod-P Elliptic Curve === | 
| stack input: small/big int //x//; small/big int //y//; elliptic curve context | stack input: small/big int //x//; small/big int //y//; elliptic curve context | ||
| Line 1087: | Line 1087: | ||
| stack output: bigint //x//; bigint -//y// (mod //p// from context) | stack output: bigint //x//; bigint -//y// (mod //p// from context) | ||
| - | === Opcode 0xAD: Multiplication with Scalar in Mod-P Elliptic Curve === | + | === Opcode 0xAD (173): Multiplication with Scalar in Mod-P Elliptic Curve === | 
| stack input: small/big int //n//; small/big int //x//; small/big int //y//; elliptic curve context | stack input: small/big int //n//; small/big int //x//; small/big int //y//; elliptic curve context | ||
| Line 1095: | Line 1095: | ||
| note: This is multiplication with a scalar within an elliptic curve. It is the same as adding up (// | note: This is multiplication with a scalar within an elliptic curve. It is the same as adding up (// | ||
| - | === Opcode 0xAE: Dual Multiplication with Scalar in Mod-P Elliptic Curve === | + | === Opcode 0xAE (174): Dual Multiplication with Scalar in Mod-P Elliptic Curve === | 
| stack input: small/big int //n1//; small/big int //x1//; small/big int //y1//; small/big int //n2//; small/big int //x2//; small/big int //y2//; elliptic curve context | stack input: small/big int //n1//; small/big int //x1//; small/big int //y1//; small/big int //n2//; small/big int //x2//; small/big int //y2//; elliptic curve context | ||
| Line 1103: | Line 1103: | ||
| note: This is faster than doing two multiplications with 0xAD and adding with 0xAB, but yields the same result. Notes of that opcodes apply here, too. | note: This is faster than doing two multiplications with 0xAD and adding with 0xAB, but yields the same result. Notes of that opcodes apply here, too. | ||
| - | === Opcode 0xAF: Create Mod-P Elliptic Curve Multiplication Context === | + | === Opcode 0xAF (175): Create Mod-P Elliptic Curve Multiplication Context === | 
| stack input: small/big int //x//; small/big int //y//; DWORD //bits//; DWORD //parts//; elliptic curve context | stack input: small/big int //x//; small/big int //y//; DWORD //bits//; DWORD //parts//; elliptic curve context | ||
| Line 1245: | Line 1245: | ||
| This list shows an overview over the opcodes C2..E0 (from compat, a module inside init.ocm). The numbers are **relative** opcode numbers, i.e. the opcode minus the base opcode of C2. | This list shows an overview over the opcodes C2..E0 (from compat, a module inside init.ocm). The numbers are **relative** opcode numbers, i.e. the opcode minus the base opcode of C2. | ||
| - | < | + | === Opcode 0xC2 (194): Extracts a subblob of a given (length) beginning at position (index) from blob (blob.part) === | 
| - | dd 0 (0xc2)		; DATA XREF: initproc: | + | If the length is -1, the subblob is taken until the end of the blob. | 
| - | dd offset BCX_00_Subblob ; DATA XREF: initproc+42r | + | stack input: string; index; length | 
| - | ; string index length -> substring | + | stack output: | 
| - | Marcus: If length == -1, take until end of blob. | + | |
| + | < | ||
| dd 1 (0xc3) | dd 1 (0xc3) | ||
ocmbytecode.1681394764.txt.gz · Last modified: 2023/04/13 14:06 by nopsled
                
                