Start of adding code word support.
This commit is contained in:
2
Makefile
2
Makefile
@ -211,7 +211,7 @@ COMMON_PHASE1e = common/comments.fs \
|
|||||||
common/floats.fs \
|
common/floats.fs \
|
||||||
common/structures.fs
|
common/structures.fs
|
||||||
|
|
||||||
COMMON_PHASE2 = common/utils.fs common/locals.fs
|
COMMON_PHASE2 = common/utils.fs common/code.fs common/locals.fs
|
||||||
|
|
||||||
COMMON_FILETOOLS = common/tasks.fs common/streams.fs \
|
COMMON_FILETOOLS = common/tasks.fs common/streams.fs \
|
||||||
common/filetools.fs common/including.fs \
|
common/filetools.fs common/including.fs \
|
||||||
|
|||||||
@ -25,6 +25,9 @@ typedef cell_t (CALLTYPE *call_t)();
|
|||||||
#define ct0 ((call_t) n0)
|
#define ct0 ((call_t) n0)
|
||||||
|
|
||||||
#define CALLING_OPCODE_LIST \
|
#define CALLING_OPCODE_LIST \
|
||||||
|
YV(internals, CALLCODE, float *t_fp = fp; DUP; \
|
||||||
|
sp = (cell_t *) (*(call_t*) (w + sizeof(cell_t)))(sp, &t_fp); \
|
||||||
|
fp = t_fp; DROP) \
|
||||||
YV(internals, CALL0, n0 = ct0()) \
|
YV(internals, CALL0, n0 = ct0()) \
|
||||||
YV(internals, CALL1, n0 = ct0(n1); --sp) \
|
YV(internals, CALL1, n0 = ct0(n1); --sp) \
|
||||||
YV(internals, CALL2, n0 = ct0(n2, n1); sp -= 2) \
|
YV(internals, CALL2, n0 = ct0(n2, n1); sp -= 2) \
|
||||||
|
|||||||
58
common/code.fs
Normal file
58
common/code.fs
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
\ Copyright 2022 Bradley D. Nelson
|
||||||
|
\
|
||||||
|
\ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
\ you may not use this file except in compliance with the License.
|
||||||
|
\ You may obtain a copy of the License at
|
||||||
|
\
|
||||||
|
\ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
\
|
||||||
|
\ Unless required by applicable law or agreed to in writing, software
|
||||||
|
\ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
\ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
\ See the License for the specific language governing permissions and
|
||||||
|
\ limitations under the License.
|
||||||
|
|
||||||
|
( Lazy loaded code words )
|
||||||
|
: asm r|
|
||||||
|
|
||||||
|
also forth definitions
|
||||||
|
vocabulary asm asm definitions
|
||||||
|
also internals
|
||||||
|
|
||||||
|
variable code-start
|
||||||
|
variable code-at
|
||||||
|
|
||||||
|
DEFINED? posix [IF]
|
||||||
|
also posix
|
||||||
|
: reserve ( n -- )
|
||||||
|
0 swap PROT_READ PROT_WRITE PROT_EXEC or or MAP_ANONYMOUS -1 0 mmap code-start ! ;
|
||||||
|
previous
|
||||||
|
4096 reserve
|
||||||
|
[THEN]
|
||||||
|
|
||||||
|
DEFINED? esp [IF]
|
||||||
|
also esp
|
||||||
|
: reserve ( n -- ) MALLOC_CAP_EXEC heap_caps_malloc code-start ! ;
|
||||||
|
previous
|
||||||
|
1024 reserve
|
||||||
|
[THEN]
|
||||||
|
|
||||||
|
code-start code-at !
|
||||||
|
|
||||||
|
: chere ( -- a ) code-at @ ;
|
||||||
|
: callot ( n -- ) code-at +! ;
|
||||||
|
: code, ( n -- ) chere ! cell callot ;
|
||||||
|
: code1, ( n -- ) chere c! 1 callot ;
|
||||||
|
: code2, ( n -- ) chere w! 2 callot ;
|
||||||
|
: code4, ( n -- ) chere l! 4 callot ;
|
||||||
|
: end-code previous ;
|
||||||
|
|
||||||
|
also forth definitions
|
||||||
|
|
||||||
|
: code ( "name" ) create ['] callcode @ latestxt !
|
||||||
|
code-at @ latestxt cell+ ! also asm ;
|
||||||
|
|
||||||
|
previous previous previous
|
||||||
|
asm
|
||||||
|
|
||||||
|
| evaluate ;
|
||||||
@ -479,8 +479,13 @@ e: check-filetools
|
|||||||
check-tasks
|
check-tasks
|
||||||
;e
|
;e
|
||||||
|
|
||||||
|
e: check-asm
|
||||||
|
out: asm
|
||||||
|
;e
|
||||||
|
|
||||||
e: check-phase2
|
e: check-phase2
|
||||||
check-locals
|
check-locals
|
||||||
|
check-asm
|
||||||
check-utils
|
check-utils
|
||||||
;e
|
;e
|
||||||
|
|
||||||
|
|||||||
@ -56,6 +56,7 @@ static cell_t ResizeFile(cell_t fd, cell_t size);
|
|||||||
OPTIONAL_RMT_SUPPORT \
|
OPTIONAL_RMT_SUPPORT \
|
||||||
OPTIONAL_OLED_SUPPORT \
|
OPTIONAL_OLED_SUPPORT \
|
||||||
OPTIONAL_SPI_FLASH_SUPPORT \
|
OPTIONAL_SPI_FLASH_SUPPORT \
|
||||||
|
CALLING_OPCODE_LIST \
|
||||||
FLOATING_POINT_LIST
|
FLOATING_POINT_LIST
|
||||||
|
|
||||||
#define REQUIRED_MEMORY_SUPPORT \
|
#define REQUIRED_MEMORY_SUPPORT \
|
||||||
|
|||||||
@ -19,6 +19,7 @@
|
|||||||
#define SIM_PRINT_ONLY
|
#define SIM_PRINT_ONLY
|
||||||
#define ENABLE_OLED_SUPPORT
|
#define ENABLE_OLED_SUPPORT
|
||||||
#include "esp32/options.h"
|
#include "esp32/options.h"
|
||||||
|
#define CALLING_OPCODE_LIST
|
||||||
#define FLOATING_POINT_LIST
|
#define FLOATING_POINT_LIST
|
||||||
#define USER_WORDS
|
#define USER_WORDS
|
||||||
#include "builtins.h"
|
#include "builtins.h"
|
||||||
|
|||||||
@ -17,6 +17,7 @@
|
|||||||
#include "common/tier1_opcodes.h"
|
#include "common/tier1_opcodes.h"
|
||||||
#include "common/tier2_opcodes.h"
|
#include "common/tier2_opcodes.h"
|
||||||
#include "common/floats.h"
|
#include "common/floats.h"
|
||||||
|
#include "common/calls.h"
|
||||||
#include "common/calling.h"
|
#include "common/calling.h"
|
||||||
|
|
||||||
#define SIM_HEAP_SIZE (100 * 1024 + 1024 * 1024)
|
#define SIM_HEAP_SIZE (100 * 1024 + 1024 * 1024)
|
||||||
@ -25,6 +26,7 @@ static cell_t *simulated(cell_t *sp, const char *op);
|
|||||||
|
|
||||||
#define PLATFORM_OPCODE_LIST \
|
#define PLATFORM_OPCODE_LIST \
|
||||||
PLATFORM_SIMULATED_OPCODE_LIST \
|
PLATFORM_SIMULATED_OPCODE_LIST \
|
||||||
|
CALLING_OPCODE_LIST \
|
||||||
FLOATING_POINT_LIST
|
FLOATING_POINT_LIST
|
||||||
|
|
||||||
#include "gen/esp32_sim_opcodes.h"
|
#include "gen/esp32_sim_opcodes.h"
|
||||||
|
|||||||
12
examples/code_x64.fs
Normal file
12
examples/code_x64.fs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#! /usr/bin/env ueforth
|
||||||
|
|
||||||
|
asm forth
|
||||||
|
|
||||||
|
code my2*
|
||||||
|
$48 code1, $89 code1, $f8 code1, ( mov %rdi, %rax )
|
||||||
|
$48 code1, $d1 code1, $27 code1, ( shlq [%rdi] )
|
||||||
|
$c3 code1, ( ret )
|
||||||
|
end-code
|
||||||
|
|
||||||
|
123 my2* . cr
|
||||||
|
bye
|
||||||
@ -48,6 +48,7 @@ z" wait" 1 sysfunc wait
|
|||||||
z" waitpid" 3 sysfunc waitpid
|
z" waitpid" 3 sysfunc waitpid
|
||||||
z" mmap" 6 sysfunc mmap
|
z" mmap" 6 sysfunc mmap
|
||||||
z" munmap" 2 sysfunc munmap
|
z" munmap" 2 sysfunc munmap
|
||||||
|
z" mprotect" 3 sysfunc mprotect
|
||||||
z" unlink" 1 sysfunc unlink
|
z" unlink" 1 sysfunc unlink
|
||||||
z" rename" 2 sysfunc rename
|
z" rename" 2 sysfunc rename
|
||||||
z" malloc" 1 sysfunc malloc
|
z" malloc" 1 sysfunc malloc
|
||||||
|
|||||||
Reference in New Issue
Block a user