diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2021-01-11 07:47:42 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2021-01-11 07:47:42 -0800 |
commit | e9b3403ca46b64153914695cc3ab3eb6a0e057ac (patch) | |
tree | 321f27d7fc72ab524efe4fc33b1b2124c67f728a | |
parent | baa34c7282046e70dd6c3ca4c63ef865c1b351a0 (diff) | |
download | txr-e9b3403ca46b64153914695cc3ab3eb6a0e057ac.tar.gz txr-e9b3403ca46b64153914695cc3ab3eb6a0e057ac.tar.bz2 txr-e9b3403ca46b64153914695cc3ab3eb6a0e057ac.zip |
vm: derive duplicated constants from Lisp origin.
Some constnats in vm.c are hand-duplicates of ones in
vm-param.tl. Let's put them in vmop.h instead, where they can
be generated by the genvmop.txr script.
The two new constants are anticipated for some upcoming
VM work.
* genvmop.txr: Generate the existing VM_LEV_BITS,
VM_LEV_MASK, VM_SM_LEV_BITS and VM_SM_LEV_MASK from the
Lisp constants. Also, let's add two new ones.
* vm.c (VM_LEV_BITS, VM_LEV_MASK, VM_SM_LEV_BITS,
VM_SM_LEV_MASK): Preprocessor symbols removed.
* vmop.h (VM_LEV_BITS, VM_LEV_MASK, VM_SM_LEV_BITS,
VM_SM_LEV_MASK): Preprocessor symbols generated here with
identical values.
(VM_MAX_LEV, VM_MAX_V_LEV): New constants.
-rw-r--r-- | genvmop.txr | 7 | ||||
-rw-r--r-- | vm.c | 4 | ||||
-rw-r--r-- | vmop.h | 7 |
3 files changed, 14 insertions, 4 deletions
diff --git a/genvmop.txr b/genvmop.txr index 73864d08..5e80948a 100644 --- a/genvmop.txr +++ b/genvmop.txr @@ -16,4 +16,11 @@ typedef enum vm_op { " /* deprecated */") @ (end) } vm_op_t; + +#define VM_LEV_BITS @{sys:%lev-bits%} +#define VM_LEV_MASK @(fmt "0x~X" (pred (ash 1 sys:%lev-bits%))) +#define VM_SM_LEV_BITS @{sys:%sm-lev-bits%} +#define VM_SM_LEV_MASK @(fmt "0x~X" (pred (ash 1 sys:%sm-lev-bits%))) +#define VM_MAX_LEV @{sys:%max-lev%} +#define VM_MAX_V_LEV @{sys:%max-v-lev%} @(end) @@ -343,10 +343,6 @@ static void vm_reset(struct vm *vm, struct vm_desc *vd, #define vm_insn_bigop(insn) (((insn) & 0x3FFFFFFU)) #define vm_arg_operand_lo(arg) ((arg) & 0xFFFFU) #define vm_arg_operand_hi(arg) ((arg) >> 16) -#define VM_LEV_BITS 10 -#define VM_LEV_MASK 0x3FF -#define VM_SM_LEV_BITS 6 -#define VM_SM_LEV_MASK 0x3F #define vm_lev(arg) ((arg) >> VM_LEV_BITS) #define vm_idx(arg) ((arg) & VM_LEV_MASK) #define vm_sm_lev(arg) ((arg) >> VM_SM_LEV_BITS) @@ -70,3 +70,10 @@ typedef enum vm_op { SETLX = 41, GETF = 42, } vm_op_t; + +#define VM_LEV_BITS 10 +#define VM_LEV_MASK 0x3FF +#define VM_SM_LEV_BITS 6 +#define VM_SM_LEV_MASK 0x3F +#define VM_MAX_LEV 63 +#define VM_MAX_V_LEV 61 |