Start of adding code word support.

This commit is contained in:
Brad Nelson
2022-09-04 16:58:11 -07:00
parent 17a8dbbf59
commit 8bed92bef9
9 changed files with 84 additions and 1 deletions

View File

@ -211,7 +211,7 @@ COMMON_PHASE1e = common/comments.fs \
common/floats.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.fs common/including.fs \

View File

@ -25,6 +25,9 @@ typedef cell_t (CALLTYPE *call_t)();
#define ct0 ((call_t) n0)
#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, CALL1, n0 = ct0(n1); --sp) \
YV(internals, CALL2, n0 = ct0(n2, n1); sp -= 2) \

58
common/code.fs Normal file
View 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 ;

View File

@ -479,8 +479,13 @@ e: check-filetools
check-tasks
;e
e: check-asm
out: asm
;e
e: check-phase2
check-locals
check-asm
check-utils
;e

View File

@ -56,6 +56,7 @@ static cell_t ResizeFile(cell_t fd, cell_t size);
OPTIONAL_RMT_SUPPORT \
OPTIONAL_OLED_SUPPORT \
OPTIONAL_SPI_FLASH_SUPPORT \
CALLING_OPCODE_LIST \
FLOATING_POINT_LIST
#define REQUIRED_MEMORY_SUPPORT \

View File

@ -19,6 +19,7 @@
#define SIM_PRINT_ONLY
#define ENABLE_OLED_SUPPORT
#include "esp32/options.h"
#define CALLING_OPCODE_LIST
#define FLOATING_POINT_LIST
#define USER_WORDS
#include "builtins.h"

View File

@ -17,6 +17,7 @@
#include "common/tier1_opcodes.h"
#include "common/tier2_opcodes.h"
#include "common/floats.h"
#include "common/calls.h"
#include "common/calling.h"
#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 \
PLATFORM_SIMULATED_OPCODE_LIST \
CALLING_OPCODE_LIST \
FLOATING_POINT_LIST
#include "gen/esp32_sim_opcodes.h"

12
examples/code_x64.fs Normal file
View 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

View File

@ -48,6 +48,7 @@ z" wait" 1 sysfunc wait
z" waitpid" 3 sysfunc waitpid
z" mmap" 6 sysfunc mmap
z" munmap" 2 sysfunc munmap
z" mprotect" 3 sysfunc mprotect
z" unlink" 1 sysfunc unlink
z" rename" 2 sysfunc rename
z" malloc" 1 sysfunc malloc