File:  [gforth] / gforth / arch / lm32 / testasm.fs
Revision 1.4: download - view: text, annotated - select for diffs
Thu Feb 9 00:37:39 2012 UTC (12 years, 2 months ago) by dvdkhlng
Branches: MAIN
CVS tags: HEAD
After some debugging&fixing, Gforth-EC boots on Milkymist1 (started from Bios)

\ testasm.fs	tests for LatticeMico32 assembler
\
\ Copyright (C) 2012 Free Software Foundation, Inc.

\ This file is part of Gforth.

\ Gforth is free software; you can redistribute it and/or
\ modify it under the terms of the GNU General Public License
\ as published by the Free Software Foundation, either version 3
\ of the License, or (at your option) any later version.

\ This program is distributed in the hope that it will be useful,
\ but WITHOUT ANY WARRANTY; without even the implied warranty of
\ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
\ GNU General Public License for more details.

\ You should have received a copy of the GNU General Public License
\ along with this program. If not, see http://www.gnu.org/licenses/.

\ Author: David Kühling
\ Created: Feb 2012

require ./asm.fs 

ALIGN
ALSO ASSEMBLER

0 VALUE first  0 VALUE last

HERE TO first

\ todo: pseudo instructions for these:

ra b,
r1 r2 mv,
r1 $7fff mvhi,
r1 r2 not,
r2 $7fff mvi,
r4 r9 r10 add,
r4 r9 123 addi,
r4 r9 r10 and,
r4 r9 123 andhi,
r4 r9 123 andi,
r9 b,
r9 r10 first be,
r9 r10 first bg,
r9 r10 first bge,
r9 r10 first bgeu,
r9 r10 first bgu,
first bi,
r9 r10 first bne,
break,
bret,
r9 call,
first calli,
r4 r9 r10 cmpe,
r4 r9 123 cmpei,
r4 r9 r10 cmpg,
r4 r9 123 cmpgi,
r4 r9 r10 cmpge,
r4 r9 123 cmpgei,
r4 r9 r10 cmpgeu,
r4 r9 123 cmpgeui,
r4 r9 r10 cmpgu,
r4 r9 123 cmpgui,
r4 r9 r10 cmpne,
r4 r9 123 cmpnei,
r4 r9 r10 divu,
eret,
r4 r18 123 lb,
r4 r18 123 lbu,
r4 r18 123 lh,
r4 r18 123 lhu,
r4 r18 123 lw,
r4 r9 r10 modu,
r4 r9 r10 mul,
r4 r9 123 muli,
r4 r9 r10 nor,
r4 r9 $123 nori,
r4 r9 r10 or,
r4 r9 123 ori,
r4 r9 123 orhi,
r4 IM rcsr,
ret,
r18 123 r9 sb,
scall,
r4 r9 sextb,
r4 r9 sexth,
r18 123 r9 sh,
r4 r9 r10 sl,
r4 r9 123 sli,
r4 r9 r10 sr,
r4 r9 123 sri,
r4 r9 r10 sru,
r4 r9 123 srui,
r4 r9 r10 sub,
r18 123 r9 sw,
IM r4 wcsr,
r4 r9 r10 xnor,
r4 r9 $123 xnori,
r4 r9 r10 xor,
r4 r9 $123 xori,

r5 r6 ?< if,
r5 r6 mv,
then,

r5 r0 ?<> if,
r6 'Y mvi,
else,
r6 'N mvi,
then,

begin,
r5 r5 -1 addi,
r5 r0 ?= until,

begin, r5 r0 ?<> while,
r5 r5 -1 addi,
repeat,

r1 $7234 li,
r2 $72340000 li,
r3 -$7234 li,
r4 $89abcdef li,
r3 $e0000000 li,
HERE TO last

\ write out assembled data to file
s" testasm.bin" w/o create-file throw CONSTANT fid
first  last over - fid write-file throw
fid close-file throw


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>