From 712a570237ec8b9528d3072d8d066ae08ff263ab Mon Sep 17 00:00:00 2001 From: Yogev Ezra Date: Mon, 30 May 2011 23:36:25 +0000 Subject: [PATCH] Create "AutoBuild" folder for Vortex86MX systems (eBox-3300MX / Gecko Edubook) git-svn-id: svn://kolibrios.org@1944 a494cfbc-eb01-0410-851d-a64ba20cac60 --- data/Vortex86MX-eng/3d/3dsheart | Bin 0 -> 18362 bytes data/Vortex86MX-eng/3d/cubeline | Bin 0 -> 16726 bytes data/Vortex86MX-eng/3d/cubetext | Bin 0 -> 18137 bytes data/Vortex86MX-eng/3d/gears | Bin 0 -> 17690 bytes data/Vortex86MX-eng/3d/house.3ds | Bin 0 -> 11977 bytes data/Vortex86MX-eng/3d/logio.bmp | Bin 0 -> 39774 bytes data/Vortex86MX-eng/File Managers/eolite.ini | 42 + data/Vortex86MX-eng/File Managers/icons.ini | 141 + data/Vortex86MX-eng/File Managers/kfar.ini | 71 + data/Vortex86MX-eng/File Managers/kfm.ini | 191 + data/Vortex86MX-eng/Makefile | 520 +++ data/Vortex86MX-eng/Makefile.cmm | 15 + data/Vortex86MX-eng/Makefile.copy | 6 + data/Vortex86MX-eng/Makefile.fasm | 52 + data/Vortex86MX-eng/Makefile.gcc | 8 + data/Vortex86MX-eng/Makefile.msvc | 13 + data/Vortex86MX-eng/Makefile.nasm | 16 + data/Vortex86MX-eng/asciivju | Bin 0 -> 684 bytes data/Vortex86MX-eng/autorun.dat | 16 + data/Vortex86MX-eng/background.gif | Bin 0 -> 1226 bytes data/Vortex86MX-eng/default.skn | Bin 0 -> 1203 bytes data/Vortex86MX-eng/demos/use_mb | Bin 0 -> 1194 bytes data/Vortex86MX-eng/docs/COPYING.TXT | 347 ++ data/Vortex86MX-eng/docs/FARA.TXT | 48 + data/Vortex86MX-eng/docs/FASM.TXT | 3591 ++++++++++++++++++ data/Vortex86MX-eng/docs/HOT_KEYS.TXT | 10 + data/Vortex86MX-eng/docs/INI.TXT | 25 + data/Vortex86MX-eng/docs/KFAR_KEYS.TXT | 94 + data/Vortex86MX-eng/docs/MTDBG.TXT | 214 ++ data/Vortex86MX-eng/docs/README.TXT | 268 ++ data/Vortex86MX-eng/docs/STACK.TXT | 387 ++ data/Vortex86MX-eng/docs/VRR_ENG.TXT | 104 + data/Vortex86MX-eng/doexe2.asm | 68 + data/Vortex86MX-eng/drivers/sound.obj | Bin 0 -> 7761 bytes data/Vortex86MX-eng/fonts/bold.chr | Bin 0 -> 9522 bytes data/Vortex86MX-eng/fonts/char.mt | Bin 0 -> 2304 bytes data/Vortex86MX-eng/fonts/char2.mt | Bin 0 -> 2560 bytes data/Vortex86MX-eng/games/kosskin.gfx | Bin 0 -> 13824 bytes data/Vortex86MX-eng/games/megamaze | Bin 0 -> 17326 bytes data/Vortex86MX-eng/games/reversi | Bin 0 -> 3294 bytes data/Vortex86MX-eng/games/rforces | Bin 0 -> 4857 bytes data/Vortex86MX-eng/games/xonix | Bin 0 -> 6481 bytes data/Vortex86MX-eng/hdread | Bin 0 -> 1287 bytes data/Vortex86MX-eng/htmlv | Bin 0 -> 9915 bytes data/Vortex86MX-eng/icons.dat | 27 + data/Vortex86MX-eng/iconstrp.gif | Bin 0 -> 12050 bytes data/Vortex86MX-eng/index_htm | 30 + data/Vortex86MX-eng/kerpack | Bin 0 -> 6421 bytes data/Vortex86MX-eng/keymap.key | Bin 0 -> 2688 bytes data/Vortex86MX-eng/kuzkina.mid | Bin 0 -> 456 bytes data/Vortex86MX-eng/lang.inc | 1 + data/Vortex86MX-eng/lang.ini | 28 + data/Vortex86MX-eng/lib/cnv_png.obj | Bin 0 -> 3182 bytes data/Vortex86MX-eng/lib/msgbox.obj | Bin 0 -> 981 bytes data/Vortex86MX-eng/lib/pixlib.obj | Bin 0 -> 4620 bytes data/Vortex86MX-eng/lib/sort.obj | Bin 0 -> 851 bytes data/Vortex86MX-eng/menu.dat | 177 + data/Vortex86MX-eng/network/jmail | Bin 0 -> 1976 bytes data/Vortex86MX-eng/network/zeroconf.ini | 19 + data/Vortex86MX-eng/panel.dat | 1 + data/Vortex86MX-eng/setup.dat | Bin 0 -> 48 bytes data/Vortex86MX-eng/vmode | Bin 0 -> 8628 bytes 62 files changed, 6530 insertions(+) create mode 100644 data/Vortex86MX-eng/3d/3dsheart create mode 100644 data/Vortex86MX-eng/3d/cubeline create mode 100644 data/Vortex86MX-eng/3d/cubetext create mode 100644 data/Vortex86MX-eng/3d/gears create mode 100644 data/Vortex86MX-eng/3d/house.3ds create mode 100644 data/Vortex86MX-eng/3d/logio.bmp create mode 100644 data/Vortex86MX-eng/File Managers/eolite.ini create mode 100644 data/Vortex86MX-eng/File Managers/icons.ini create mode 100644 data/Vortex86MX-eng/File Managers/kfar.ini create mode 100644 data/Vortex86MX-eng/File Managers/kfm.ini create mode 100644 data/Vortex86MX-eng/Makefile create mode 100644 data/Vortex86MX-eng/Makefile.cmm create mode 100644 data/Vortex86MX-eng/Makefile.copy create mode 100644 data/Vortex86MX-eng/Makefile.fasm create mode 100644 data/Vortex86MX-eng/Makefile.gcc create mode 100644 data/Vortex86MX-eng/Makefile.msvc create mode 100644 data/Vortex86MX-eng/Makefile.nasm create mode 100644 data/Vortex86MX-eng/asciivju create mode 100644 data/Vortex86MX-eng/autorun.dat create mode 100644 data/Vortex86MX-eng/background.gif create mode 100644 data/Vortex86MX-eng/default.skn create mode 100644 data/Vortex86MX-eng/demos/use_mb create mode 100644 data/Vortex86MX-eng/docs/COPYING.TXT create mode 100644 data/Vortex86MX-eng/docs/FARA.TXT create mode 100644 data/Vortex86MX-eng/docs/FASM.TXT create mode 100644 data/Vortex86MX-eng/docs/HOT_KEYS.TXT create mode 100644 data/Vortex86MX-eng/docs/INI.TXT create mode 100644 data/Vortex86MX-eng/docs/KFAR_KEYS.TXT create mode 100644 data/Vortex86MX-eng/docs/MTDBG.TXT create mode 100644 data/Vortex86MX-eng/docs/README.TXT create mode 100644 data/Vortex86MX-eng/docs/STACK.TXT create mode 100644 data/Vortex86MX-eng/docs/VRR_ENG.TXT create mode 100644 data/Vortex86MX-eng/doexe2.asm create mode 100644 data/Vortex86MX-eng/drivers/sound.obj create mode 100644 data/Vortex86MX-eng/fonts/bold.chr create mode 100644 data/Vortex86MX-eng/fonts/char.mt create mode 100644 data/Vortex86MX-eng/fonts/char2.mt create mode 100644 data/Vortex86MX-eng/games/kosskin.gfx create mode 100644 data/Vortex86MX-eng/games/megamaze create mode 100644 data/Vortex86MX-eng/games/reversi create mode 100644 data/Vortex86MX-eng/games/rforces create mode 100644 data/Vortex86MX-eng/games/xonix create mode 100644 data/Vortex86MX-eng/hdread create mode 100644 data/Vortex86MX-eng/htmlv create mode 100644 data/Vortex86MX-eng/icons.dat create mode 100644 data/Vortex86MX-eng/iconstrp.gif create mode 100644 data/Vortex86MX-eng/index_htm create mode 100644 data/Vortex86MX-eng/kerpack create mode 100644 data/Vortex86MX-eng/keymap.key create mode 100644 data/Vortex86MX-eng/kuzkina.mid create mode 100644 data/Vortex86MX-eng/lang.inc create mode 100644 data/Vortex86MX-eng/lang.ini create mode 100644 data/Vortex86MX-eng/lib/cnv_png.obj create mode 100644 data/Vortex86MX-eng/lib/msgbox.obj create mode 100644 data/Vortex86MX-eng/lib/pixlib.obj create mode 100644 data/Vortex86MX-eng/lib/sort.obj create mode 100644 data/Vortex86MX-eng/menu.dat create mode 100644 data/Vortex86MX-eng/network/jmail create mode 100644 data/Vortex86MX-eng/network/zeroconf.ini create mode 100644 data/Vortex86MX-eng/panel.dat create mode 100644 data/Vortex86MX-eng/setup.dat create mode 100644 data/Vortex86MX-eng/vmode diff --git a/data/Vortex86MX-eng/3d/3dsheart b/data/Vortex86MX-eng/3d/3dsheart new file mode 100644 index 0000000000000000000000000000000000000000..451432efc9a3c6d931a58311fab3077479ecdd3d GIT binary patch literal 18362 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 V+}-#He!2sNjc`x9mia(jwg5gRqI&=U literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/3d/cubeline b/data/Vortex86MX-eng/3d/cubeline new file mode 100644 index 0000000000000000000000000000000000000000..49e6bb14e0fc512adbd93a7b1f11694f3547cf64 GIT binary patch literal 16726 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 Zk{r@~%JAM4!%&N-WjoLd0K)+Q00G8+ewP3M literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/3d/house.3ds b/data/Vortex86MX-eng/3d/house.3ds new file mode 100644 index 0000000000000000000000000000000000000000..5cd6911c4085d93f66518889f3304743e51b721f GIT binary patch literal 11977 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 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/File Managers/eolite.ini b/data/Vortex86MX-eng/File Managers/eolite.ini new file mode 100644 index 0000000000..bbe1631f0f --- /dev/null +++ b/data/Vortex86MX-eng/File Managers/eolite.ini @@ -0,0 +1,42 @@ +[Associations] +rtf=/sys/htmlv +asm=TinyPad +inc=TinyPad +ini=TinyPad +txt=TinyPad +gif=/sys/media/kiv +bmp=/sys/media/kiv +png=/sys/media/kiv +tga=/sys/media/kiv +jpg=/sys/media/kiv +jpeg=/sys/media/kiv +ico=/sys/media/kiv +cur=/sys/media/kiv +pcx=/sys/media/kiv +xcf=/sys/media/kiv +3ds=/sys/3d/view3ds +lif=/sys/demos/life2 +skn=/sys/desktop +htm=/sys/HTMLv +html=/sys/HTMLv +rtf=/sys/RtfRead +obj=/sys/develop/cObj +sna=/sys/e80 +nes=/sys/games/fceu +xm=/sys/media/AC97SND +wav=/sys/media/AC97SND +mp3=/sys/media/AC97SND +mid=/sys/media/MIDAMP +m3u=/sys/media/listplay +lap=/sys/media/listplay +asf=/sys/media/listplay +mht=/sys/htmlv + + +[Config] +;åñëè ïîñòàâèòü 1 âìåñòî êíîïîê áóäåò ñòðîêà àäðåñà +ShowEditBoxPath=0 +;öâåò âûäåëåíîãî ýëåìåíòà è âûäåëåíèå åäèòáîêñà +;ïî-óìîë÷àíèþ 94AECE, äëÿ òåñòà FEA4B7,8BCDFF,B8C9B8 +BorderColor=94AECE + diff --git a/data/Vortex86MX-eng/File Managers/icons.ini b/data/Vortex86MX-eng/File Managers/icons.ini new file mode 100644 index 0000000000..e4690bf7bc --- /dev/null +++ b/data/Vortex86MX-eng/File Managers/icons.ini @@ -0,0 +1,141 @@ +asm=4 +inc=4 +txt=3 +rtf=3 +ini=3 +log=3 +dic=3 +doc=3 +exc=3 +wtx=3 +inf=3 +xml=3 +odt=3 +jpg=6 +jpe=6 +jpeg=6 +jif=6 +jfif=6 +jp2=6 +jpx=6 +jpk=6 +j2k=6 +jpc=6 +j2c=6 +bmp=6 +dib=6 +rle=6 +pbm=6 +wbm=6 +wbmp=6 +xbm=6 +xpm=6 +gif=6 +png=6 +ico=6 +cur=6 +ani=6 +tif=6 +tiff=6 +xif=6 +tga=6 +pcx=6 +dcx=6 +ppm=6 +psd=6 +psp=6 +raw=6 +raf=6 +x3f=6 +orf=6 +nef=6 +mrw=6 +dcr=6 +crw=6 +cr2=6 +ras=6 +pix=6 +pict=6 +pct=6 +pic=6 +pgm=6 +pef=6 +pcd=6 +iff=6 +lbm=6 +ilbm=6 +fpx=6 +djv=6 +djvu=6 +iw4=6 +wav=7 +mp3=7 +xm=7 +mid=7 +midi=7 +aif=7 +aifc=7 +aiff=7 +au=7 +snd=7 +wma=7 +wm=7 +avi=11 +mpg=11 +mpe=11 +mpeg=11 +flv=11 +3gp=11 +mkv=11 +wmv=11 +mov=11 +mp4=11 +img=5 +ima=5 +imz=5 +bwz=5 +dsk=5 +vfd=5 +wil=5 +wlz=5 +exe=8 +com=8 +bat=8 +7z=9 +rar=9 +zip=9 +cab=9 +arj=9 +lha=9 +lzh=9 +tar=9 +taz=9 +tbz=9 +tbz2=9 +bz=9 +bz2=9 +ice=9 +gz=9 +tgz=9 +uue=9 +uu=9 +xxe=9 +z=9 +dat=10 +ttf=12 +ttc=12 +chr=12 +mt=12 +htm=13 +html=13 +mht=13 +eml=13 +lif=14 +3ds=15 +kex=16 +skn=17 +obj=18 +dll=18 +ocx=18 +so=18 +drv=18 diff --git a/data/Vortex86MX-eng/File Managers/kfar.ini b/data/Vortex86MX-eng/File Managers/kfar.ini new file mode 100644 index 0000000000..9824508f49 --- /dev/null +++ b/data/Vortex86MX-eng/File Managers/kfar.ini @@ -0,0 +1,71 @@ +[Associations] +asm=/sys/TinyPad; AsmMenu1,AsmMenu2 +inc=/sys/TinyPad +ini=/sys/TinyPad +txt=/sys/TinyPad +jpg=/sys/media/kiv +jpeg=/sys/media/kiv +gif=/sys/media/kiv; ViewGraph,MenuAnimage +wav=/sys/media/AC97SND +mp3=/sys/media/AC97SND +xm=/sys/media/AC97SND +mid=/sys/media/MIDAMP +bmp=/sys/media/kiv; ViewGraph,MenuAnimage +png=/sys/media/kiv +ico=/sys/media/kiv +cur=/sys/media/kiv +pcx=/sys/media/kiv +xcf=/sys/media/kiv +rtf=/sys/RtfRead +3ds=/sys/3d/view3ds +lif=/sys/demos/life2 +skn=/sys/desktop +m3u=/sys/media/listplay +lap=/sys/media/listplay +asf=/sys/media/listplay +cvs=/sys/graph +obj=/sys/develop/cObj +nes=/sys/fceu +sna=/sys/e80 +htm=/sys/HTMLv +html=/sys/HTMLv + +[Menu] +AsmMenu1=&Edit,/sys/TinyPad +AsmMenu2=&Compile,/sys/develop/fasm +ViewGraph=&View,/sys/media/kiv +MenuAnimage=&Edit,/sys/media/animage + +[Panels] +; View modes for files on panels +; values correspond to digits for LCtrl+<1-4> +LeftViewMode=2 +RightViewMode=2 +; Sort modes for files on panels +; values are 2 * N + M, where +; M = 0 - normal sorting, M = 1 - reverse sorting +; N = 0-6 correspond to sort mode for Ctrl+F<3-9> +LeftSortMode=0 +RightSortMode=0 + +[Editor] +; Symbols for end-of-line, which will be added by kfar editor +; when new line will be created: +; DOS - like in DOS/Win (0D 0A), Unix - like in Unix (0A), +; Mac - like in Mac (0D) +EOLStyle=Unix + +[FolderShortcuts] +; You can define up to 10 links to folders Shortcut0...Shortcut9, +; the quick jump to such folders can be done with RCtrl+ +Shortcut0=/rd/1 + +[Confirmations] +Delete=1 +DeleteIncomplete=0 + +[Plugins] +; On left of the equal sign any sensical or nonsensical name can appear; +; on right - path to plugin. +; If path is not absolute, it is counted from the folder with kfar binary. +ArchiveReader=/sys/lib/archiver.obj diff --git a/data/Vortex86MX-eng/File Managers/kfm.ini b/data/Vortex86MX-eng/File Managers/kfm.ini new file mode 100644 index 0000000000..c5055e6cdb --- /dev/null +++ b/data/Vortex86MX-eng/File Managers/kfm.ini @@ -0,0 +1,191 @@ +start +<>icons_associations +asm 0004 +inc 0004 +txt 0003 +rtf 0003 +ini 0003 +log 0003 +dic 0003 +doc 0003 +exc 0003 +wtx 0003 +inf 0003 +jpg 0006 +jpe 0006 +jpeg 0006 +jif 0006 +jfif 0006 +jp2 0006 +jpx 0006 +jpk 0006 +j2k 0006 +jpc 0006 +j2c 0006 +bmp 0006 +dib 0006 +rle 0006 +pbm 0006 +wbm 0006 +wbmp 0006 +xbm 0006 +xpm 0006 +gif 0006 +png 0006 +ico 0006 +cur 0006 +ani 0006 +tif 0006 +tiff 0006 +xif 0006 +tga 0006 +pcx 0006 +xcf 0006 +dcx 0006 +ppm 0006 +psd 0006 +psp 0006 +raw 0006 +raf 0006 +x3f 0006 +orf 0006 +nef 0006 +mrw 0006 +dcr 0006 +crw 0006 +cr2 0006 +ras 0006 +pix 0006 +pict 0006 +pct 0006 +pic 0006 +pgm 0006 +pef 0006 +pcd 0006 +iff 0006 +lbm 0006 +ilbm 0006 +fpx 0006 +djv 0006 +djvu 0006 +iw4 0006 +wav 0007 +mp3 0007 +xm 0007 +mid 0007 +midi 0007 +aif 0007 +aifc 0007 +aiff 0007 +au 0007 +snd 0007 +wma 0007 +wm 0007 +avi 0011 +mpg 0011 +mov 0011 +flv 0011 +wmv 0011 +vob 0011 +mkv 0011 +mp4 0011 +mpeg 0011 +3gp 0011 +img 0005 +ima 0005 +imz 0005 +bwz 0005 +dsk 0005 +vfd 0005 +wil 0005 +wlz 0005 +exe 0008 +com 0008 +bat 0008 +7z 0009 +rar 0009 +zip 0009 +cab 0009 +arj 0009 +lha 0009 +lzh 0009 +tar 0009 +taz 0009 +tbz 0009 +tbz2 0009 +bz 0009 +bz2 0009 +ice 0009 +gz 0009 +tgz 0009 +uue 0009 +uu 0009 +xxe 0009 +z 0009 +dat 0010 +ttf 0012 +ttc 0012 +chr 0012 +mt 0012 +htm 0013 +html 0013 +lif 0014 +3ds 0015 +kex 0016 +skn 0017 +<>end + +<>files_associations +asm /sys/tinypad +inc /sys/tinypad +txt /sys/tinypad +ini /sys/tinypad +log /sys/tinypad +dat /sys/tinypad +inf /sys/tinypad +bat /sys/tinypad +jpg /sys/media/kiv +jpeg /sys/media/kiv +jpe /sys/media/kiv +gif /sys/media/kiv +wav /sys/media/ac97snd +mp3 /sys/media/ac97snd +xm /sys/media/ac97snd +mid /sys/media/midamp +bmp /sys/media/kiv +png /sys/media/kiv +ico /sys/media/kiv +cur /sys/media/kiv +pcx /sys/media/kiv +xcf /sys/media/kiv +rtf /sys/rtfread +3ds /sys/3d/view3ds +lif /sys/demos/life2 +skn /sys/desktop +avi /hd0/1/fplay.kex +mpg /hd0/1/fplay.kex +mov /hd0/1/fplay.kex +flv /hd0/1/fplay.kex +wmv /hd0/1/fplay.kex +vob /hd0/1/fplay.kex +mkv /hd0/1/fplay.kex +mp4 /hd0/1/fplay.kex +mpeg /hd0/1/fplay.kex +3gp /hd0/1/fplay.kex +m3u /sys/media/listplay +lap /sys/media/listplay +asf /sys/media/listplay +cvs /sys/graph +obj /sys/develop/cObj +nes /sys/fceu +sna /sys/e80 +htm /sys/HTMLv +html /sys/HTMLv +kla /sys/games/klavisha +<>end + +<>files_association1 +bmp /sys/media/animage +<>end + +end diff --git a/data/Vortex86MX-eng/Makefile b/data/Vortex86MX-eng/Makefile new file mode 100644 index 0000000000..a9c92a8936 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile @@ -0,0 +1,520 @@ +# General rule for naming: variables with CAPITALIZED names hold settings, +# you can - and are expected - to modify it; variables with lowercase names +# are intermediate variables and macroses not to be modified unless you +# know what you're doing. + +# Define directories for destination, source repository, sources of kernel, sources of programs. +BUILD_DIR:=build +REPOSITORY:=../.. +KERNEL:=$(REPOSITORY)/kernel/trunk +PROGS:=$(REPOSITORY)/programs + +# Docpak requires some documents; we place them +# into 'docs' subdir and communicate with FASM +# through environment var DOCDIR. +DOCDIR:=docs/ +export DOCDIR + +# Because most programs are written in FASM and have +# the common structure of one main .asm file possibly including +# several .inc files, we handle this case separately. +# Namely, we organize one big list of such programs +# (FASM_PROGRAMS, see below) containing name of local binary file, +# name of file inside kolibri.img and name of the source file. +# This list is maintained by hand, and the rest is done with some macroses... +# well, slightly complicated macroses - however, you do not need to +# understand them in order to maintain the list. +# To add a FASM program with one .asm file, just +# add the corresponding item to the list and enjoy +# the power of GNU make. + +# The list of all FASM programs with one main FASM file. +# Every item consists of three parts, separated by ':'. +# First part is the real name of binary file in $(BUILD_DIR) +# as it should be produced by make. +# Second part is the name of a file inside kolibri.img, +# usually uppercased version of first part - to save space +# for FAT filesystem. +# Third part is the name of the source file. +# Spaces separate items, so spaces in names should be +# represented as '|'. +FASM_PROGRAMS:=\ + @clip:@CLIP:$(PROGS)/system/clip/trunk/@clip.ASM \ + @menu:@MENU:$(PROGS)/system/menu/trunk/menu.asm \ + @notify:@NOTIFY:$(PROGS)/system/notify/trunk/@notify.asm \ + @panel:@PANEL:$(PROGS)/system/panel/trunk/@PANEL.ASM \ + @rb:@RB:$(PROGS)/system/rb/trunk/@RB.ASM \ + @ss:@SS:$(PROGS)/system/ss/trunk/@ss.asm\ + calc:CALC:$(PROGS)/other/calc/trunk/calc.asm \ + calendar:CALENDAR:$(PROGS)/system/calendar/trunk/calendar.asm \ + commouse:COMMOUSE:$(PROGS)/system/commouse/trunk/commouse.asm \ + copyr:COPYR:$(PROGS)/fs/copyr/trunk/copyr.asm \ + cpu:CPU:$(PROGS)/system/cpu/trunk/cpu.asm \ + cpuid:CPUID:$(PROGS)/system/cpuid/trunk/CPUID.ASM \ + desktop:DESKTOP:$(PROGS)/system/desktop/trunk/desktop.asm \ + disptest:DISPTEST:$(PROGS)/system/disptest/trunk/disptest.ASM \ + docpak:DOCPAK:$(PROGS)/system/docpack/trunk/docpack.asm \ + downloader:downloader:$(PROGS)/network/downloader/trunk/downloader.asm \ + end:END:$(PROGS)/system/end/light/end.asm \ + gmon:GMON:$(PROGS)/system/gmon/gmon.asm \ + hdd_info:HDD_INFO:$(PROGS)/system/hdd_info/trunk/hdd_info.asm \ + icon:ICON:$(PROGS)/system/icon/trunk/icon.asm \ + kbd:KBD:$(PROGS)/system/kbd/trunk/kbd.ASM \ + kpack:KPACK:$(PROGS)/other/kpack/trunk/kpack.asm \ + launcher:LAUNCHER:$(PROGS)/system/launcher/trunk/launcher.asm \ + magnify:MAGNIFY:$(PROGS)/demos/magnify/trunk/magnify.asm \ + mgb:MGB:$(PROGS)/system/mgb/trunk/mgb.asm \ + mousemul:MOUSEMUL:$(PROGS)/system/mousemul/trunk/mousemul.asm \ + mykey:MYKEY:$(PROGS)/system/MyKey/trunk/MyKey.asm \ + pcidev:PCIDEV:$(PROGS)/system/pcidev/trunk/PCIDEV.ASM \ + period:PERIOD:$(PROGS)/other/period/trunk/period.asm \ + pic4:PIC4:$(PROGS)/media/pic4/trunk/pic4.asm \ + rdsave:RDSAVE:$(PROGS)/system/rdsave/trunk/rdsave.asm \ + rtfread:RTFREAD:$(PROGS)/other/rtfread/trunk/rtfread.asm \ + run:RUN:$(PROGS)/system/run/trunk/run.asm \ + scrshoot:SCRSHOOT:$(PROGS)/media/scrshoot/scrshoot.asm \ + setup:SETUP:$(PROGS)/system/setup/trunk/setup.asm \ + spanel:SPANEL:$(PROGS)/system/spanel/trunk/spanel.asm \ + test:TEST:$(PROGS)/system/test/trunk/test.asm \ + tinypad:TINYPAD:$(PROGS)/develop/tinypad/trunk/tinypad.asm \ + vrr:VRR:$(PROGS)/system/vrr/trunk/vrr.asm \ + vrr_m:VRR_M:$(PROGS)/system/vrr_m/trunk/vrr_m.asm \ + zkey:ZKEY:$(PROGS)/system/zkey/trunk/ZKEY.ASM \ + 3d/3dcube2:3D/3DCUBE2:$(PROGS)/demos/3dcube2/trunk/3DCUBE2.ASM \ + 3d/3dspiral:3D/3DSPIRAL:$(PROGS)/demos/3dspiral/trunk/3dspiral.asm \ + 3d/3dtcub10:3D/3DTCUB10:$(PROGS)/demos/3dtcub10/trunk/3DTCUB10.ASM \ + 3d/crownscr:3D/CROWNSCR:$(PROGS)/demos/crownscr/trunk/crownscr.asm \ + 3d/flatwav:3D/FLATWAV:$(PROGS)/demos/flatwav/trunk/FLATWAV.ASM \ + 3d/free3d04:3D/FREE3D04:$(PROGS)/demos/free3d04/trunk/free3d04.asm \ + 3d/view3ds:3D/VIEW3DS:$(PROGS)/demos/3DS/VIEW3DS.ASM \ + demos/bcdclk:DEMOS/BCDCLK:$(PROGS)/demos/bcdclk/trunk/bcdclk.asm \ + demos/circle:DEMOS/CIRCLE:$(PROGS)/develop/examples/circle/trunk/circle.asm \ + demos/colorref:DEMOS/COLORREF:$(PROGS)/demos/colorref/trunk/colorref.asm \ + demos/cslide:DEMOS/CSLIDE:$(PROGS)/demos/cslide/trunk/cslide.asm \ + demos/eyes:DEMOS/EYES:$(PROGS)/demos/eyes/trunk/eyes.asm \ + demos/fire:DEMOS/FIRE:$(PROGS)/demos/fire/trunk/fire.asm \ + demos/firework:DEMOS/FIREWORK:$(PROGS)/demos/firework/trunk/firework.asm \ + demos/movback:DEMOS/MOVBACK:$(PROGS)/demos/movback/trunk/movback.asm \ + demos/plasma:DEMOS/PLASMA:$(PROGS)/demos/plasma/trunk/plasma.asm \ + demos/timer:DEMOS/TIMER:$(PROGS)/demos/timer/trunk/timer.asm \ + demos/tinyfrac:DEMOS/TINYFRAC:$(PROGS)/demos/tinyfrac/trunk/tinyfrac.asm \ + demos/trantest:DEMOS/TRANTEST:$(PROGS)/demos/trantest/trunk/trantest.asm \ + demos/tube:DEMOS/TUBE:$(PROGS)/demos/tube/trunk/tube.asm \ + demos/unvwater:DEMOS/UNVWATER:$(PROGS)/demos/unvwater/trunk/unvwater.asm \ + demos/web:DEMOS/WEB:$(PROGS)/demos/web/trunk/web.asm \ + develop/board:DEVELOP/BOARD:$(PROGS)/system/board/trunk/board.asm \ + develop/cObj:DEVELOP/cObj:$(PROGS)/develop/cObj/trunk/cObj.asm \ + develop/fasm:DEVELOP/FASM:$(PROGS)/develop/fasm/trunk/fasm.asm \ + develop/h2d2b:DEVELOP/H2D2B:$(PROGS)/develop/h2d2b/trunk/h2d2b.asm \ + develop/heed:DEVELOP/HEED:$(PROGS)/develop/heed/trunk/heed.asm \ + develop/ipc:DEVELOP/IPC:$(PROGS)/network/ipc/trunk/ipc.asm \ + develop/keyascii:DEVELOP/KEYASCII:$(PROGS)/develop/keyascii/trunk/keyascii.asm \ + develop/mtdbg:DEVELOP/MTDBG:$(PROGS)/develop/mtdbg/mtdbg.asm \ + develop/scancode:DEVELOP/SCANCODE:$(PROGS)/develop/scancode/trunk/scancode.asm \ + develop/test_gets:DEVELOP/test_gets:$(PROGS)/develop/libraries/console/examples/test_gets.asm \ + develop/testcon2:DEVELOP/TESTCON2:$(PROGS)/develop/libraries/console/examples/testcon2.asm \ + develop/thread:DEVELOP/THREAD:$(PROGS)/develop/examples/thread/trunk/thread.asm \ + drivers/com_mouse.obj:DRIVERS/COM_MOUSE.OBJ:$(KERNEL)/drivers/com_mouse.asm \ + drivers/emu10k1x.obj:DRIVERS/EMU10K1X.OBJ:$(KERNEL)/drivers/emu10k1x.asm \ + drivers/fm801.obj:DRIVERS/FM801.OBJ:$(KERNEL)/drivers/fm801.asm \ + drivers/infinity.obj:DRIVERS/INFINITY.OBJ:$(KERNEL)/drivers/infinity.asm \ + drivers/ps2mouse.obj:DRIVERS/PS2MOUSE.OBJ:$(REPOSITORY)/drivers/mouse/ps2mouse4d/trunk/ps2mouse.asm \ + drivers/sb16.obj:DRIVERS/SB16.OBJ:$(KERNEL)/drivers/sb16/sb16.asm \ + drivers/vmode.mdr:DRIVERS/VMODE.MDR:$(KERNEL)/drivers/vmode.asm \ + drivers/vt8235.obj:DRIVERS/VT8235.OBJ:$(KERNEL)/drivers/vt823x.asm \ + File|Managers/kfar:File|Managers/KFAR:$(PROGS)/fs/kfar/trunk/kfar.asm \ + File|Managers/kfm:File|Managers/KFM:$(PROGS)/fs/kfm/trunk/kfm.asm \ + File|Managers/OpenDial:File|Managers/OPENDIAL:$(PROGS)/develop/libraries/box_lib/asm/trunk/OpenDial.asm \ + fonts/bgitest:FONTS/BGITEST:$(PROGS)/demos/bgitest/trunk/bgitest.asm \ + games/15:GAMES/15:$(PROGS)/games/15/trunk/15.ASM \ + games/arcanii:GAMES/ARCANII:$(PROGS)/games/arcanii/trunk/arcanii.asm \ + games/bnc:GAMES/BNC:$(PROGS)/games/bnc/trunk/bnc.asm \ + games/freecell:GAMES/FREECELL:$(PROGS)/games/freecell/freecell.ASM \ + games/gomoku:GAMES/GOMOKU:$(PROGS)/games/gomoku/trunk/gomoku.asm \ + games/invaders:GAMES/INVADERS:$(PROGS)/games/invaders/invaders.asm \ + games/klavisha:GAMES/KLAVISHA:$(PROGS)/games/klavisha/trunk/klavisha.asm \ + games/kox:GAMES/KOX:$(PROGS)/games/kox/trunk/kox.asm \ + games/lights:GAMES/LIGHTS:$(PROGS)/games/lights/trunk/lights.asm \ + games/lines:GAMES/LINES:$(PROGS)/games/lines/lines.asm \ + games/mblocks:GAMES/MBLOCKS:$(PROGS)/games/mblocks/trunk/mblocks.asm \ + games/msquare:GAMES/MSQUARE:$(PROGS)/games/MSquare/trunk/MSquare.asm \ + games/phenix:GAMES/PHENIX:$(PROGS)/games/phenix/trunk/phenix.asm \ + games/pipes:GAMES/PIPES:$(PROGS)/games/pipes/pipes.asm \ + games/pong:GAMES/PONG:$(PROGS)/games/pong/trunk/pong.asm \ + games/pong3:GAMES/PONG3:$(PROGS)/games/pong3/trunk/pong3.asm \ + games/rsquare:GAMES/RSQUARE:$(PROGS)/games/rsquare/trunk/rsquare.asm \ + games/soko:GAMES/SOKO:$(PROGS)/games/soko/trunk/SOKO.ASM \ + games/snake:GAMES/SNAKE:$(PROGS)/games/snake/trunk/snake.asm \ + games/sq_game:GAMES/SQ_GAME:$(PROGS)/games/sq_game/trunk/SQ_GAME.ASM \ + games/sudoku:GAMES/SUDOKU:$(PROGS)/games/sudoku/trunk/sudoku.asm \ + games/sw:GAMES/SW:$(PROGS)/games/sw/trunk/sw.asm \ + games/tanks:GAMES/TANKS:$(PROGS)/games/tanks/trunk/tanks.asm \ + games/tetris:GAMES/TETRIS:$(PROGS)/games/tetris/trunk/tetris.asm \ + lib/archiver.obj:LIB/ARCHIVER.OBJ:$(PROGS)/fs/kfar/trunk/kfar_arc/kfar_arc.asm \ + lib/box_lib.obj:LIB/BOX_LIB.OBJ:$(PROGS)/develop/libraries/box_lib/trunk/box_lib.asm \ + lib/console.obj:LIB/CONSOLE.OBJ:$(PROGS)/develop/libraries/console/console.asm \ + lib/libgfx.obj:LIB/LIBGFX.OBJ:$(PROGS)/develop/libraries/libs-dev/libgfx/libgfx.asm \ + lib/libimg.obj:LIB/LIBIMG.OBJ:$(PROGS)/develop/libraries/libs-dev/libimg/libimg.asm \ + lib/libini.obj:LIB/LIBINI.OBJ:$(PROGS)/develop/libraries/libs-dev/libini/libini.asm \ + lib/libio.obj:LIB/LIBIO.OBJ:$(PROGS)/develop/libraries/libs-dev/libio/libio.asm \ + lib/network.obj:LIB/NETWORK.OBJ:$(PROGS)/develop/libraries/network/network.asm \ + lib/proc_lib.obj:LIB/PROC_LIB.OBJ:$(PROGS)/develop/libraries/proc_lib/trunk/proc_lib.asm \ + media/animage:MEDIA/ANIMAGE:$(PROGS)/media/animage/trunk/animage.asm \ + media/cdp:MEDIA/CDP:$(PROGS)/media/cdp/trunk/cdp.asm \ + media/kiv:MEDIA/KIV:$(PROGS)/media/kiv/trunk/kiv.asm \ + media/listplay:MEDIA/LISTPLAY:$(PROGS)/media/listplay/trunk/listplay.asm \ + media/midamp:MEDIA/MIDAMP:$(PROGS)/media/midamp/trunk/midamp.asm \ + media/startmus:MEDIA/STARTMUS:$(PROGS)/media/startmus/trunk/STARTMUS.ASM \ + network/airc:NETWORK/AIRC:$(PROGS)/network/airc/trunk/airc.asm \ + network/arpstat:NETWORK/ARPSTAT:$(PROGS)/network/arpstat/trunk/arpstat.asm \ + network/chess:NETWORK/CHESS:$(PROGS)/network/chess/trunk/chess.asm \ + network/ethstat:NETWORK/ETHSTAT:$(PROGS)/network/ethstat/trunk/ethstat.asm \ + network/ftps:NETWORK/FTPS:$(PROGS)/network/ftps/trunk/FTPS.ASM \ + network/httpc:NETWORK/HTTPC:$(PROGS)/network/httpc/trunk/httpc.asm \ + network/https:NETWORK/HTTPS:$(PROGS)/network/https/trunk/https.asm \ + network/nntpc:NETWORK/NNTPC:$(PROGS)/network/nntpc/trunk/nntpc.asm \ + network/nslookup:NETWORK/NSLOOKUP:$(PROGS)/develop/libraries/network/examples/nslookup.asm \ + network/popc:NETWORK/POPC:$(PROGS)/network/popc/trunk/popc.asm \ + network/smtps:NETWORK/SMTPS:$(PROGS)/network/smtps/trunk/smtps.asm \ + network/stackcfg:NETWORK/STACKCFG:$(PROGS)/network/stackcfg/trunk/stackcfg.asm \ + network/telnet:NETWORK/TELNET:$(PROGS)/network/telnet/trunk/telnet.asm \ + network/tftpc:NETWORK/TFTPC:$(PROGS)/network/tftpc/trunk/tftpc.asm \ + network/VNCclient:NETWORK/VNCclient:$(PROGS)/network/VNCclient/VNCclient.asm \ + network/ym:NETWORK/YM:$(PROGS)/network/ym/trunk/ym.asm \ + network/zeroconf:NETWORK/ZEROCONF:$(PROGS)/network/zeroconf/trunk/zeroconf.asm \ +# end of list + +# The list of all NASM programs with one main NASM file. +# Format of an item is exactly the same as in the previous list. +NASM_PROGRAMS:=\ + demos/aclock:DEMOS/ACLOCK:$(PROGS)/demos/aclock/trunk/aclock.asm \ + games/c4:GAMES/C4:$(PROGS)/games/c4/trunk/c4.asm \ +# end of list + +# The list of files which should be copied from somewhere. +# Format of an item is exactly the same as in the previous list. +COPY_FILES:=\ + macros.inc:MACROS.INC:$(PROGS)/macros.inc \ + config.inc:CONFIG.INC:$(PROGS)/config.inc \ + struct.inc:STRUCT.INC:$(PROGS)/struct.inc \ + File|Managers/z_icons.png:File|Managers/Z_ICONS.PNG:$(PROGS)/develop/libraries/box_lib/asm/trunk/z_icons.png \ + File|Managers/kfm_keys.txt:File|Managers/KFM_KEYS.TXT:$(PROGS)/fs/kfm/trunk/docs/english/kfm_keys.txt \ + File|Managers/buttons.bmp:File|Managers/BUTTONS.BMP:$(PROGS)/fs/kfm/trunk/buttons.bmp \ + File|Managers/icons.bmp:File|Managers/ICONS.BMP:$(PROGS)/fs/kfm/trunk/icons.bmp \ + fonts/euro.chr:FONTS/EURO.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/EURO.CHR \ + fonts/goth.chr:FONTS/GOTH.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/GOTH.CHR \ + fonts/lcom.chr:FONTS/LCOM.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/LCOM.CHR \ + fonts/litt.chr:FONTS/LITT.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/LITT.CHR \ + fonts/sans.chr:FONTS/SANS.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/SANS.CHR \ + fonts/scri.chr:FONTS/SCRI.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/SCRI.CHR \ + fonts/simp.chr:FONTS/SIMP.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/SIMP.CHR \ + fonts/smal.chr:FONTS/SMAL.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/SMAL.CHR \ + fonts/trip.chr:FONTS/TRIP.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/TRIP.CHR \ + fonts/tscr.chr:FONTS/TSCR.CHR:$(PROGS)/demos/bgitest/trunk/FONTS/TSCR.CHR \ + games/snake.ini:GAMES/SNAKE.INI:$(PROGS)/games/snake/trunk/snake.ini \ + games/skin.raw:GAMES/SKIN.RAW:$(PROGS)/games/soko/trunk/SKIN.RAW \ + games/soko-4.lev:GAMES/SOKO-4.LEV:$(PROGS)/games/soko/trunk/SOKO-4.LEV \ + games/soko-5.lev:GAMES/SOKO-5.LEV:$(PROGS)/games/soko/trunk/SOKO-5.LEV \ + games/soko-6.lev:GAMES/SOKO-6.LEV:$(PROGS)/games/soko/trunk/SOKO-6.LEV \ + games/soko-7.lev:GAMES/SOKO-7.LEV:$(PROGS)/games/soko/trunk/SOKO-7.LEV \ + games/soko-8.lev:GAMES/SOKO-8.LEV:$(PROGS)/games/soko/trunk/SOKO-8.LEV \ + games/soko-9.lev:GAMES/SOKO-9.LEV:$(PROGS)/games/soko/trunk/SOKO-9.LEV \ + media/kiv.ini:MEDIA/KIV.INI:$(PROGS)/media/kiv/trunk/kiv.ini \ + .shell:.shell:$(PROGS)/system/shell/bin/eng/.shell \ + mykey.ini:MYKEY.INI:$(PROGS)/system/MyKey/trunk/mykey.ini \ +# end of list + +# The list of all C-- programs with one main C-- file. +# Format of an item is exactly the same as in the previous list, +# except that there can be fourth field with parameters for a compiler. +CMM_PROGRAMS:=\ + File|Managers/eolite:File|Managers/EOLITE:$(PROGS)/fs/Eolite/trunk/Eolite.c-- \ + games/clicks:GAMES/CLICKS:$(PROGS)/games/clicks/trunk/clicks.c-- \ + games/FindNumbers:GAMES/FindNumbers:$(PROGS)/games/FindNumbers/trunk/FindNumbers.c-- \ + games/mine:GAMES/MINE:$(PROGS)/games/mine/trunk/mine.c--:/MEOS \ +#develop/c--:DEVELOP/C--:$(PROGS)/develop/c--/trunk/32.c-- \ +# end of list + +# List of other files to be included in the image file. +# Some of them are auto-built with special rules, some just exist before build. +# Each item is of the form :. +# Spaces should be represented as |. +OTHER_FILES:=asciivju:ASCIIVJU autorun.dat:AUTORUN.DAT \ + background.gif:background.gif default.skn:DEFAULT.SKN \ + e80:E80 graph:GRAPH hdread:HDREAD htmlv:HTMLV \ + icons.dat:ICONS.DAT iconstrp.gif:ICONSTRP.GIF index_htm:INDEX.HTM \ + kernel.mnt:KERNEL.MNT kerpack:KERPACK keymap.key:KEYMAP.KEY \ + kuzkina.mid:KUZKINA.MID lang.inc:LANG.INC lang.ini:LANG.INI \ + menu.dat:MENU.DAT \ + panel.dat:PANEL.DAT setup.dat:SETUP.DAT \ + shell:SHELL table:TABLE \ + vmode:VMODE 3d/3dsheart:3D/3DSHEART \ + 3d/cubeline:3D/CUBELINE 3d/gears:3D/GEARS 3d/house.3ds:3D/HOUSE.3DS \ + demos/use_mb:DEMOS/USE_MB \ + drivers/sound.obj:DRIVERS/SOUND.OBJ \ + File|Managers/eolite.ini:File|Managers/EOLITE.INI \ + File|Managers/icons.ini:File|Managers/ICONS.INI \ + File|Managers/kfar.ini:File|Managers/KFAR.INI \ + File|Managers/kfm.ini:File|Managers/KFM.INI \ + fonts/bold.chr:FONTS/BOLD.CHR fonts/char2.mt:FONTS/CHAR2.MT \ + fonts/char.mt:FONTS/CHAR.MT \ + games/kosilka:GAMES/KOSILKA games/kosskin.gfx:GAMES/KOSSKIN.GFX \ + games/reversi:GAMES/REVERSI games/rforces:GAMES/RFORCES \ + games/xonix:GAMES/XONIX games/megamaze:GAMES/MEGAMAZE \ + lib/cnv_png.obj:LIB/CNV_PNG.OBJ lib/msgbox.obj:LIB/MSGBOX.OBJ \ + lib/pixlib.obj:LIB/PIXLIB.OBJ lib/sort.obj:LIB/SORT.OBJ \ + media/ac97snd:MEDIA/AC97SND \ + network/jmail:NETWORK/JMAIL network/zeroconf.ini:NETWORK/ZEROCONF.INI \ +#end of list +#3d/logio.bmp:3D/LOGIO.BMP 3d/cubetext:3D/CUBETEXT + +# Extra targets for LiveCD image in the syntax of mkisofs +MKISOFS_EXTRA:=\ + dosbox/=$(PROGS)/emulator/DosBox/dosbox \ + dosbox/=$(PROGS)/emulator/DosBox/dosbox.conf \ + dosbox/=$(PROGS)/emulator/DosBox/readme.txt \ +#end of list + +# Some macro for convenient work. +# Macros for replacing '|' to escaped space '\ '. +space:=\ #plus space +respace=$(subst |,$(space),$(1)) +# Macro for selecting different parts of ':'-separated items. +binarypart=$(word 1,$(subst :, ,$(1))) +imagepart=$(word 2,$(subst :, ,$(1))) +sourcepart=$(word 3,$(subst :, ,$(1))) +parampart=$(word 4,$(subst :, ,$(1))) +# Get file names, possibly with spaces inside, from an item. +# Here $(f) is an item - in fact, macro argument. +fbinary=$(call respace,$(call binarypart,$(f))) +fimage=$(call respace,$(call imagepart,$(f))) +fsource=$(call respace,$(call sourcepart,$(f))) +fparam=$(call respace,$(call parampart,$(f))) + +# Define targets for image file. +# Join all the lists above. +targets_full:=$(COPY_FILES) $(FASM_PROGRAMS) $(NASM_PROGRAMS) $(OTHER_FILES) $(CMM_PROGRAMS) +# For each item in the united list call fbinary. +targets:=$(foreach f,$(targets_full),$(fbinary)) + +# Define a command for copying a file inside the image. +# mcopy_command is a macro with two parameters, +# local file name $(1) and image file name $(2). +# Note that spaces in these have to be escaped with backslashes. +mcopy_command=mcopy -moi $(BUILD_DIR)/kolibri.img $(1) ::$(2) +# Specialize a previous command for an item $(f) in one of lists. +mcopy_item_command=$(call mcopy_command,$(fbinary),$(fimage)) + +# Join all $(mcopy_item_command) for all items, +# append newline after each item. +# The first newline character after "define" line and +# the last newline character before "endef" line get away +# with define/endef, so we make three newline characters, +# that is two empty lines, in order to get one in $(newline). +define newline + + +endef +mcopy_all_items:=$(foreach f,$(targets_full),$(mcopy_item_command)$(newline)) + +# dependencies of MKISOFS_EXTRA; we iterate through $(MKISOFS_EXTRA), +# substitute "=" with space, get the 2nd word and join all results +mkisofs_extra_targets:=$(foreach f,$(MKISOFS_EXTRA),$(word 2,$(subst =, ,$(f)))) + +# The main goal: build kolibri.img and kolibri.iso +all: $(BUILD_DIR)/kolibri.img $(BUILD_DIR)/kolibri.iso + +# The first goal: floppy image. +$(BUILD_DIR)/kolibri.img: $(BUILD_DIR)/.dir \ + Makefile \ + $(BUILD_DIR)/boot_fat12.bin \ + $(targets) +# SYSXTREE +# 3d/CUBETEXT +# 3d/LOGIO.BMP + str=`date -u +"[auto-build %d %b %Y %R, r$(REV)]"`; \ + echo -n $$str|dd of=kernel.mnt bs=1 seek=`expr 279 - length "$$str"` conv=notrunc 2>/dev/null + dd if=/dev/zero of=$(BUILD_DIR)/kolibri.img count=2880 bs=512 2>&1 + mformat -f 1440 -i $(BUILD_DIR)/kolibri.img :: + dd if=$(BUILD_DIR)/boot_fat12.bin of=$(BUILD_DIR)/kolibri.img count=1 bs=512 conv=notrunc 2>&1 + mmd -i $(BUILD_DIR)/kolibri.img ::3D + mmd -i $(BUILD_DIR)/kolibri.img ::DEMOS + mmd -i $(BUILD_DIR)/kolibri.img ::DEVELOP + mmd -i $(BUILD_DIR)/kolibri.img ::DRIVERS + mmd -i $(BUILD_DIR)/kolibri.img ::File\ Managers + mmd -i $(BUILD_DIR)/kolibri.img ::FONTS + mmd -i $(BUILD_DIR)/kolibri.img ::GAMES + mmd -i $(BUILD_DIR)/kolibri.img ::LIB + mmd -i $(BUILD_DIR)/kolibri.img ::MEDIA + mmd -i $(BUILD_DIR)/kolibri.img ::NETWORK + $(mcopy_all_items) + +# The second goal: LiveCD image. +$(BUILD_DIR)/kolibri.iso: $(BUILD_DIR)/kolibri.img $(mkisofs_extra_targets) + mkisofs -U -J -pad -b kolibri.img -c boot.catalog -hide-joliet boot.catalog -hide-joliet kolibri.img -graft-points \ + -A "KolibriOS AutoBuilder" -p "CleverMouse" -publisher "KolibriOS Team" -V "KolibriOS r$(REV)" -sysid "KOLIBRI" \ + -iso-level 3 -o $(BUILD_DIR)/kolibri.iso $(BUILD_DIR)/kolibri.img $(MKISOFS_EXTRA) 2>&1 + +# Special targets to modify behaviour of make. +.DELETE_ON_ERROR: +.SUFFIXES: # delete all predefined rules + +# The floppy bootsector. +$(BUILD_DIR)/boot_fat12.bin: $(KERNEL)/bootloader/boot_fat12.asm $(KERNEL)/bootloader/floppy1440.inc + fasm $(KERNEL)/bootloader/boot_fat12.asm $(BUILD_DIR)/boot_fat12.bin + +$(BUILD_DIR)/.dir 3d/.dir demos/.dir develop/.dir drivers/.dir fonts/.dir \ + games/.dir lib/.dir media/.dir network/.dir .deps/.dir: + mkdir -p $(dir $@) + touch $@ +File\ Managers/.dir: + mkdir -p "File Managers" + touch "File Managers/.dir" + +# FASM black magic goes to Makefile.fasm. +include Makefile.fasm + +# Similar for NASM. +include Makefile.nasm + +# Similar for copying files. +include Makefile.copy + +# Special rules for copying sysfuncs.txt - it isn't directly included in the image. +docpak: $(DOCDIR)SYSFUNCS.TXT $(wildcard $(DOCDIR)*) +$(DOCDIR)SYSFUNCS.TXT: $(KERNEL)/docs/sysfuncs.txt + cp $(KERNEL)/docs/sysfuncs.txt $(DOCDIR)SYSFUNCS.TXT + +# Similar for C--. +include Makefile.cmm + +# Sorry, even black magic seems to be insufficient for +# auto-handling all subtle effects. So we just define +# command lines for compiling and linking, and +# maintain the list of sources and objects by hand. +include Makefile.msvc + +# Rules for table +table: .obj.table/table.exe + $(msvc_final) +TABLE_OBJECTS:=.obj.table/calc.obj .obj.table/func.obj .obj.table/hello.obj \ + .obj.table/KosFile.obj .obj.table/kosSyst.obj .obj.table/math2.obj \ + .obj.table/mcsmemm.obj .obj.table/parser.obj +TABLE_H_FILES:=$(wildcard $(PROGS)/other/table/*.h) +.obj.table/table.exe: $(TABLE_OBJECTS) + $(msvc_link) +$(TABLE_OBJECTS): .obj.table/%.obj: $(PROGS)/other/table/%.cpp $(TABLE_H_FILES) Makefile.msvc | .obj.table + $(msvc_compile) +.obj.table: + mkdir -p .obj.table + +# Rules for graph +graph: .obj.graph/graph.exe + $(msvc_final) +GRAPH_CPP_OBJECTS:=.obj.graph/func.obj .obj.graph/hello.obj .obj.graph/kolibri.obj \ + .obj.graph/KosFile.obj .obj.graph/kosSyst.obj .obj.graph/math2.obj \ + .obj.graph/mcsmemm.obj .obj.graph/parser.obj +GRAPH_C_OBJECTS:=.obj.graph/string.obj +GRAPH_H_FILES:=$(wildcard $(PROGS)/other/graph/*.h) +GRAPH_FASM_OBJECTS:=.obj.graph/memcpy.obj .obj.graph/memset.obj +.obj.graph/graph.exe: $(GRAPH_CPP_OBJECTS) $(GRAPH_C_OBJECTS) $(GRAPH_FASM_OBJECTS) + $(msvc_link) +$(GRAPH_CPP_OBJECTS): .obj.graph/%.obj: $(PROGS)/other/graph/%.cpp $(GRAPH_H_FILES) Makefile.msvc | .obj.graph + $(msvc_compile) +$(GRAPH_C_OBJECTS): .obj.graph/%.obj: $(PROGS)/other/graph/%.c $(GRAPH_H_FILES) Makefile.msvc | .obj.graph + $(msvc_compile) +$(GRAPH_FASM_OBJECTS): .obj.graph/%.obj: $(PROGS)/other/graph/%.asm Makefile.msvc | .obj.graph + fasm $< $@ +.obj.graph: + mkdir -p .obj.graph + +# Rules for kosilka +games/kosilka: .obj.kosilka/kosilka.exe + $(msvc_final) +KOSILKA_OBJECTS:=.obj.kosilka/kosilka.obj .obj.kosilka/KosFile.obj .obj.kosilka/kosSyst.obj .obj.kosilka/mcsmemm.obj +KOSILKA_H_FILES:=$(PROGS)/games/kosilka/*.h +.obj.kosilka/kosilka.exe: $(KOSILKA_OBJECTS) + $(msvc_link) +$(KOSILKA_OBJECTS): .obj.kosilka/%.obj: $(PROGS)/games/kosilka/%.cpp $(KOSILKA_H_FILES) Makefile.msvc | .obj.kosilka + $(msvc_compile) +.obj.kosilka: + mkdir -p .obj.kosilka + +include Makefile.gcc + +# Rules for shell +shell: .obj.shell/start.o .obj.shell/shell.o .obj.shell/kolibri.o .obj.shell/stdlib.o .obj.shell/string.o \ + $(PROGS)/system/shell/kolibri.ld + $(call gcc_link,$(PROGS)/system/shell/kolibri.ld) +.obj.shell/shell.o: $(PROGS)/system/shell/shell.c \ + $(PROGS)/system/shell/all.h \ + $(PROGS)/system/shell/system/*.h \ + $(PROGS)/system/shell/cmd/*.c \ + $(PROGS)/system/shell/modules/*.c \ + $(PROGS)/system/shell/locale/rus/globals.h \ + Makefile.gcc | .obj.shell + $(gcc_compile) +.obj.shell/kolibri.o .obj.shell/stdlib.o .obj.shell/string.o: .obj.shell/%.o: \ + $(PROGS)/system/shell/system/%.c $(PROGS)/system/shell/system/*.h \ + Makefile.gcc | .obj.shell + $(gcc_compile) + win32-gcc -c -Os -o $@ $< +.obj.shell/start.o: $(PROGS)/system/shell/start.asm | .obj.shell + fasm $< $@ +.obj.shell: + mkdir -p .obj.shell + +# Rules for e80 +E80DIR=$(PROGS)/emulator/e80/trunk +e80: .obj.e80/start.o .obj.e80/kolibri.o .obj.e80/stdlib.o .obj.e80/string.o .obj.e80/z80.o .obj.e80/e80.o + $(call gcc_link,$(E80DIR)/kolibri.ld) +.obj.e80/e80.o: $(E80DIR)/e80.c $(E80DIR)/48.h \ + $(E80DIR)/system/*.h $(E80DIR)/system/msgbox.c \ + $(E80DIR)/z80/z80.h Makefile.gcc | .obj.e80 + $(gcc_compile) +.obj.e80/kolibri.o .obj.e80/stdlib.o .obj.e80/string.o: .obj.e80/%.o: \ + $(E80DIR)/system/%.c $(E80DIR)/system/*.h Makefile.gcc | .obj.e80 + $(gcc_compile) +.obj.e80/z80.o: $(E80DIR)/z80/z80.c $(E80DIR)/z80/* + $(gcc_compile) +.obj.e80/start.o: $(E80DIR)/asm_code.asm | .obj.e80 + fasm $< $@ +.obj.e80: + mkdir -p .obj.e80 + +# Rules for sdk/sound, used by media/ac97snd +SOUNDDIR=$(PROGS)/develop/sdk/trunk/sound/src +SOUND_OBJECTS:=$(patsubst $(SOUNDDIR)/%.asm,.sdk/%.obj,$(wildcard $(SOUNDDIR)/*.asm)) +SOUND_INC_FILES:=$(wildcard $(SOUNDDIR)/*.inc) +.sdk/sound.lib: $(SOUND_OBJECTS) + win32-link /lib /out:$@ $^ +$(SOUND_OBJECTS): .sdk/%.obj: $(SOUNDDIR)/%.asm $(SOUND_INC_FILES) | .sdk + fasm $< $@ +.sdk: + mkdir -p .sdk +# Rules for media/ac97snd +AC97DIR=$(PROGS)/media/ac97snd +media/ac97snd: .obj.ac97snd/ac97snd.exe + $(msvc_final) +.obj.ac97snd/ac97snd.exe: .obj.ac97snd/ac97wav.obj .obj.ac97snd/crt.obj .obj.ac97snd/k_lib.obj \ + .obj.ac97snd/mpg.lib .sdk/sound.lib $(AC97DIR)/ufmod.obj + $(msvc_link) +.obj.ac97snd/ac97wav.obj: $(AC97DIR)/ac97snd/ac97wav.c \ + $(AC97DIR)/kolibri.h $(AC97DIR)/ac97snd/ac97wav.h $(AC97DIR)/mpg/mpg123.h \ + $(AC97DIR)/sound.h $(AC97DIR)/ufmod-codec.h Makefile.msvc | .obj.ac97snd + $(msvc_compile) +.obj.ac97snd/crt.obj: $(AC97DIR)/ac97snd/crt.c $(AC97DIR)/ac97snd/crt.h Makefile.msvc | .obj.ac97snd + $(msvc_compile) +.obj.ac97snd/k_lib.obj: $(AC97DIR)/ac97snd/k_lib.asm $(AC97DIR)/ac97snd/proc32.inc | .obj.ac97snd + fasm $< $@ +AC97SND_MPG_C_FILES:=$(wildcard $(AC97DIR)/mpg/*.c) +AC97SND_MPG_H_FILES:=$(wildcard $(AC97DIR)/mpg/*.h) +AC97SND_MPG_C_OBJECTS:=$(patsubst $(AC97DIR)/mpg/%.c,.obj.ac97snd/%.o,$(AC97SND_MPG_C_FILES)) +.obj.ac97snd/mpg.lib: $(AC97SND_MPG_C_OBJECTS) .obj.ac97snd/pow.obj + win32-link /lib /ltcg /out:$@ $^ +$(AC97SND_MPG_C_OBJECTS): .obj.ac97snd/%.o: $(AC97DIR)/mpg/%.c $(AC97SND_MPG_H_FILES) Makefile.msvc | .obj.ac97snd + $(msvc_compile) +.obj.ac97snd/pow.obj: $(AC97DIR)/mpg/pow.asm $(AC97DIR)/mpg/proc32.inc | .obj.ac97snd + fasm $< $@ +.obj.ac97snd: + mkdir -p .obj.ac97snd diff --git a/data/Vortex86MX-eng/Makefile.cmm b/data/Vortex86MX-eng/Makefile.cmm new file mode 100644 index 0000000000..4b847b2ee9 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.cmm @@ -0,0 +1,15 @@ +# This is similar to Makefile.fasm, look there for comments. +# No dependency tracking, so force dependencies on all files +# in dir/* and dir/*/* +# Also, we cannot set output file name and need to guess +# whether c-- has created .com file or no-extension file. +define cmm_meta_rule +$(1): $(2) Makefile.cmm $$(call respace,$$(addsuffix .dir,$(3))) \ + $$(wildcard $$(dir $(2))*) $$(wildcard $$(dir $(2))*/*) + flock $$(dir $(2)).lock -c '\ + win32-c-- /D=AUTOBUILD /D=LANG_ENG $(5) /IP=Z:$$(dir $(2)) Z:$$< >&2 && \ + if [ -e $$(basename $$<) ]; then f=$$(basename $$<); else f=$$(basename $$<).com; fi && \ + kpack --nologo $$$$f "$$@" && rm $$$$f' +endef + +$(foreach f,$(CMM_PROGRAMS),$(eval $(call cmm_meta_rule,$(fbinary),$(fsource),$(binarydir),$(progname),$(fparam)))) diff --git a/data/Vortex86MX-eng/Makefile.copy b/data/Vortex86MX-eng/Makefile.copy new file mode 100644 index 0000000000..538ecb4ef6 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.copy @@ -0,0 +1,6 @@ +# This is similar to Makefile.fasm, look there for comments. +define copy_meta_rule +$(1): $(2) Makefile.copy $$(call respace,$$(addsuffix .dir,$(3))) + cp $$< "$$@" +endef +$(foreach f,$(COPY_FILES),$(eval $(call copy_meta_rule,$(fbinary),$(fsource),$(binarydir)))) diff --git a/data/Vortex86MX-eng/Makefile.fasm b/data/Vortex86MX-eng/Makefile.fasm new file mode 100644 index 0000000000..9fab3ed7b1 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.fasm @@ -0,0 +1,52 @@ +# This is not a independent Makefile; it is auxiliary file +# included from main Makefile. +# It depends on the following variables and macro: +# $(FASM_PROGRAMS) is a list of all programs to build with FASM rule; +# $(binarypart) is a macro which converts from $(1)=item of $(FASM_PROGRAMS) +# to space-escaped full name of binary, $(respace) unescapes spaces; +# $(fbinary) and $(fsource) gives space-unescaped full name of binary +# and source (respectively) of $(f)=item of $(FASM_PROGRAMS). + +# Define the rule for all FASM programs. +# Yes, this looks like a black magic. +# But it is not so scary as it seems. +# First, we define "meta-rule" as a rule which is +# macro depending on $(fasmprog). +# Second, the construction foreach+eval creates +# usual rules, one for each $(fasmprog) in $(FASM_PROGRAMS). +# Note that meta-rule is double-expanded, first +# time as the arg of eval - it is the place where $(fasmprog) +# gets expanded - and second time as the rule; +# so all $ which are expected to expand at the second time should be escaped. +# And all $ which are expected to be expanded by the shell should be escaped +# twice, so they become $$$$. + +# The arguments of macro fasm_meta_rule: +# $(1) = name of binary file, +# $(2) = name of main source file. +# $(3) = folder of binary file - without spaces. +# $(4) = name of program - without path and extension, +define fasm_meta_rule +$(1): $(2) Makefile.fasm .deps/.dir $$(call respace,$$(addsuffix .dir,$(3))) + fasm -m 65536 $$< "$$@" -s .deps/$(4).fas + prepsrc .deps/$(4).fas /dev/null + prepsrc .deps/$(4).fas /dev/stdout | \ + perl -n -e 's|\\|/|g;push @a,$$$$1 if/^;include \x27(.*?)\x27/;' \ + -e 'END{$$$$a=join " \\\n ",@a;print "$(1): $$$$a\n$$$$a:\n"}' > .deps/$(4).Po + kpack --nologo "$$@" +-include .deps/$(4).Po +endef + +progname=$(call respace,$(basename $(notdir $(call binarypart,$(f))))) +binarydir=$(subst ./,,$(dir $(call binarypart,$(f)))) +$(foreach f,$(FASM_PROGRAMS),$(eval $(call fasm_meta_rule,$(fbinary),$(fsource),$(binarydir),$(progname)))) + +# Rule for the kernel differs: it uses kerpack instead of kpack. +kernel.mnt: $(KERNEL)/kernel.asm Makefile.fasm .deps/.dir + fasm -m 65536 $< "$@" -s .deps/kernel.fas + prepsrc .deps/kernel.fas /dev/null + prepsrc .deps/kernel.fas /dev/stdout | \ + perl -n -e 's|\\|/|g;push @a,$$1 if/^;include \x27(.*?)\x27/;' \ + -e 'END{$$a=join " \\\n ",@a;print "$@: $$a\n$$a:\n"}' > .deps/kernel.Po + kerpack $@ +-include .deps/kernel.Po diff --git a/data/Vortex86MX-eng/Makefile.gcc b/data/Vortex86MX-eng/Makefile.gcc new file mode 100644 index 0000000000..14ae973a61 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.gcc @@ -0,0 +1,8 @@ +define gcc_compile + win32-gcc -c -Os -DAUTOBUILD -DLANG_ENG=1 -o $@ $< +endef +define gcc_link + win32-ld -nostdlib -T $(1) -o "$@" $^ + win32-objcopy "$@" -O binary + kpack --nologo "$@" +endef diff --git a/data/Vortex86MX-eng/Makefile.msvc b/data/Vortex86MX-eng/Makefile.msvc new file mode 100644 index 0000000000..0902ceed22 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.msvc @@ -0,0 +1,13 @@ +define msvc_compile +win32-cl /c /O2 /Os /Oy /GF /GS- /GR- /EHs-c- /fp:fast /GL /QIfist /Gr /DAUTOBUILD /Fo$@ Z:$< >&2 +endef +define msvc_link +win32-link /section:.bss,E /fixed:no /subsystem:native \ +/merge:.data=.text /merge:.rdata=.text /merge:.1seg=.text \ +/entry:crtStartUp /out:$@ /ltcg /nodefaultlib \ +$(addprefix Z:,$^) >&2 +endef +define msvc_final +EXENAME=$< fasm doexe2.asm "$@" +kpack --nologo "$@" +endef diff --git a/data/Vortex86MX-eng/Makefile.nasm b/data/Vortex86MX-eng/Makefile.nasm new file mode 100644 index 0000000000..cb4714fd21 --- /dev/null +++ b/data/Vortex86MX-eng/Makefile.nasm @@ -0,0 +1,16 @@ +# This is similar to Makefile.fasm, look there for comments. +define nasm_meta_rule +.deps/$(4).Po: $(2) Makefile.nasm .deps/.dir + nasm -I$$(dir $(2)) -o "$(1)" -M $$< > .deps/$(4).Tpo 2>/dev/null; \ + if [ $$$$? -eq 0 ]; then perl -ln -e 'next unless $$$$_;' \ + -e 'm/((.*): )?(.*)/;$$$$a=$$$$2 if $$$$2;push @b,$$$$3;' \ + -e 'END{$$$$b=join "\n",@b;print "$$$$a .deps/$(4).Po: $$$$b\n$$$$b:"}' \ + .deps/$(4).Tpo > .deps/$(4).Po; fi + rm -f .deps/$(4).Tpo +$(1): $(2) Makefile.nasm $$(call respace,$$(addsuffix .dir,$(3))) + nasm -I$$(dir $(2)) -o "$$@" $$< + kpack --nologo "$$@" +-include .deps/$(4).Po +endef + +$(foreach f,$(NASM_PROGRAMS),$(eval $(call nasm_meta_rule,$(fbinary),$(fsource),$(binarydir),$(progname)))) diff --git a/data/Vortex86MX-eng/asciivju b/data/Vortex86MX-eng/asciivju new file mode 100644 index 0000000000000000000000000000000000000000..bcf76e26d07b9c28695f6b1c416c180cf9cd479b GIT binary patch literal 684 zcmV;d0#p4e1poj+00001Mv*2LLXK;4&&M{gp_IzXQTp%9D8t}4T<%p-1^^&8 ze?=HpR~kyo#9vKIQKC|4mRVLlhwqFNJZ8?iqQN>$_ z470eNAmaJaWL3c8d{#qlEO05Jtl8UTNB&~%89RaW*vH41`nM+s1|oLKXz@SkA=DZ)!crriLW8ob zy5>X$p>Lxsj38^$eHZs??;GI%KeJMa-lLIJmcPj!-fJczf&5H9j%Z!siY zO;E1VhtpXrU!LS$(WUG*%EnCu&Oy}wyt=X4vuQ=dRJZTA?-UI#wKoHPifK(%=OJYw znku{D&ZgRAvwb36)p@X>uku(8neKBTM{$?nV8TFZYEV&9P~l&i4%l_`J5+ktE0!WC z0aYMAv-DJtIfotc;Nfu73#&H>v>IyTAGil#K2;1DZSdm}8BKX!Smi#1eRvwKJYGe3 zsx1r02WE{cS%87(AR|zdC{~|6ra!fm8jh&q%PGMXLcJneUaKKKC?7XNd;#~fFN45E S +# Use in parameter value if program is started without parameters. +# Delay time means how much the system should wait, before running the next line. It is measured in 1/100 seconds. +# If delay is negative, wait for termination of the spawned process. Otherwise, simply wait +# +#/RD/1/COMMOUSE 1 # COM mice detector +/RD/1/MEDIA/KIV \T__background.gif -1 # Desktop background image +/RD/1/@CLIP 1 # Clipboard +/RD/1/@RB 1 # Desktop right-click menu +/RD/1/@SS 1 # Screensaver +/RD/1/@PANEL 1 # Start panel +/RD/1/DEVELOP/BOARD 1 # Load DEBUG board +/RD/1/SETUP BOOT 1 # Load device settings +/RD/1/ICON BOOT 1 # Multithread icon +/RD/1/NETWORK/ZEROCONF 1 # Network configuration +### Hello, ASM World! ### diff --git a/data/Vortex86MX-eng/background.gif b/data/Vortex86MX-eng/background.gif new file mode 100644 index 0000000000000000000000000000000000000000..fd67e638541a63bc0c3102b4d880f8f10245054c GIT binary patch literal 1226 zcmZ?wbhEHboWL-F;X4BeNOA>;>1A4(RXJJqd1S1MoN+98_QR&IZM8M$H{~4J)BL3G zz}w?TzdYXb_SOAwU>&2xXb23G5YPen1C$pSIQ}y*a>#gWSa7hJLs%>3#D;~3+Xa-p z=6GyebhKN-IP1=djf;=>D>!$_cy3y9agwu<%~^M)f;7UHG7DAw_1d=P=4P$q zi(*f2TN1c6HVL1=!PsN3L}#^WB7YZ;Gw&-Ol_)Ac}9 zV^KEev$n~7+m^l%o*4GG<8iu}mcYYIE}I1h8ZKEzE}Z0@w({vTS+)j-X=@cvKAn*= XEpwS~lGgVFGjq1ROp9S;WUvMRj>YTi literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/default.skn b/data/Vortex86MX-eng/default.skn new file mode 100644 index 0000000000000000000000000000000000000000..e6b4f208e5839a6c60e1b3bbb93d597ecad3a28f GIT binary patch literal 1203 zcmV;k1Wfx&P(w>}BLDya0000%#gZwsj&&}CIeQq_5y2*c66<(MrJAFs1dhDf@5CH!0yt25 z)Nt!*cMpbDFFlK@C}UqflaQ!-FGl|=H-(=w9=7N4q26wDNH}0#>t=kQG*t1@_E$J3 zb7cnSLPa7IYAo{=PYnOWWAF1@YnmV4C6{^_)eB8;Q?Lc?2N>5o> zocGN8dLYf6?Tr+-?Ww9gr6yUR(L5mY@APMnCTz$$!dYXHy9eYN{DHAm3mprUd?JZ& z_^=Ysq=%aUqcshf_IUv3Kj{xm=4CWm*cDJ_%)}&{&w+w=LQIOFha5vQ>&HVErq-2y zuJ^DNH`ABZ>{X=7rfTT@vi4L6qX|1`otw7X!0z&}f2iaP`lx&f_bfe+3j@eL-4wHm z*zmsk-4)@o=JlFY8M@Oe3E7-?0WB;50*uU}1t(>xZ-Au=ng(b@k#JSK^h9Br$+PfW zFOC9`_in$(-d3-`>g*DJQ;k*_Z16DcUK@Ct>fo%!HPyIaR?)zkj`4kvjWs(}MCUiQ zl@b-+QLUlbsjWkDR`Vazu( z_QBZ{gYhO2aq)Phvb-7Q-QuHfq2II+J_4d2gvA+~rh)n^XV$*L`Yt7xu+~lf1}vSF zrTNvH^(yA5UTgM^DXc|x3qZ5p(KY-W!ESZ$^rft^V|bIO^^*GWv-JRof)jS%JaMA< z{N-0{>rL3)b>HZx-nY*^&J#C=qwX$aJ~D(Z6*NLlB#g$pr`FARf~votXRnz9vq4M| zHV3j8Vm)tW@JP{O_@$((uV32|7#phaG;Xl|D++=lp-}q-HAQSz6=ekeeo|vzW}VD2 z@ixG831bMUWMz7#b_IUUN+>zUQA{KFJQsfWHk9Sk#yNWr9`jsYS=rRN6!13Oo;>M^ zHj;a*n7E!8oqGd59M;zykK$vvnXw}}PE8aM?tL^Bv&rz_*+QeT#Mbj-yjfcFTiXC!uSt}Q&{Y@Iz4IQ z?WYREO8c%E^48|Oo_i~7=d~N`I7==^0XKjl3)Is6=`BUF4KC84t;D((&N{Ug%1crq zevLBSVc@%@NYDURL_B5^T#K15hnZNMq=>b(t$PBMWIBKF?xKT)rD;6#bavtyRU|y} zW_@m#xPno818kI?d!r`hb0>QTdN|V R!Cd0u72r}9T!jyL`JTz#UI73A literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/demos/use_mb b/data/Vortex86MX-eng/demos/use_mb new file mode 100644 index 0000000000000000000000000000000000000000..c395975c230680a6ba140375fd92bb480cffbaf4 GIT binary patch literal 1194 zcmV;b1XcS>P(w=@2><{A00001Mv*2LLXK;4&&M{uW+J}PWu31<_((SS^9|dxs>2$r z4K9RFx}Urzhlcx-Aq$xn6;9g`qN<4=g4&Y$GVn|&i4O?S3p`aey^k5);Dl~vH)~Zq z(|9c;OljeMQf~aQoIG`l6@qt-ChCa|S_X2wH+_!G7nNxZ70O>ofFWC^&n}YL-~1CW z4iE@1>V)Q`YH3kKhyO= zYy$!kaSr+g*;Sp0S^Ri^8kUui-KmE#0cZfGANkBXgzxzv-4|EAw9bq`&jdHDU~&Q7 zRKbnQgzP!Cb&~hRrj!I!-ytbb%370T>tL6*HX^!=@v&3@1N7?oC@5>36fU zibh=ZQMofs3*4il6_4pf4E31tAlL&h2W$~~LN}}%RAgMUiHNfMz!cVPO>07nuW->U z#_aRw5L#}>VY;sv3u2fZ`A@zfZ6Tq*jGLH&T8-ON7naOH3JathLPg|6ROM$%*ra{? zX5G2#q{s7j^%{yD18Dxd!RTr(VUkZNx`>eN5o}S543D$sq{;C}5&!>j90JH;#Aty( z=W93Vs3wl&jlYB-Y&?AH!Omu;AwGM6@JyFMXi@f~8%bU&zU+UOSJ&RBq%dsT55giO zglzVnAb&9*@OUxS$E59UkH@}=ukZW6LLvOK&7QLt=c}5+^lr7M16|iL^3yxq&n@VY zwH!9UQAbFVX#8~FNwecSvJ6*b3_Q{_H_rpx8~ZAYLqLiW%q1Vh0`Cx8L@PacwocK}6K!sZp_Wikj6#V<;CQPK%z{f*^Q2OQ=gS9BxD4BADxLuIBP>=ywnw~S~_-I zI(3EIzZzCb{d7U^LP;Td?@7v6H_qriu{f;h5n#Q`=c;+)OIIp3Kg7(~@1VB}v=t@* ziD_}iN)SHkfMsF)Jp%a2W_PYJxojoR9T642oVfhN9C;PDih(Ckkq)wQ+-a?RFD2HJ zwQc#!1^J@Xln7V$duTVcS)%<3xk@VSE561I`aXXrBI+@xkFK>=;F)507lk-soLzkpg;dl&Jq5oh0<+IW>r%i6viHr>bDN2 z2v!7NpMtr#?Z_LvH@=j1CUF%44r!IAmKj7(_ef~S%{l9)lw&F|gLg2mS67+SwD%6z Isg-&bYjdJQfB*mh literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/docs/COPYING.TXT b/data/Vortex86MX-eng/docs/COPYING.TXT new file mode 100644 index 0000000000..f6213b69c6 --- /dev/null +++ b/data/Vortex86MX-eng/docs/COPYING.TXT @@ -0,0 +1,347 @@ + + GNU GENERAL PUBLIC LICENSE + + Version 2, June 1991 + + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 675 Mass Ave, Cambridge, MA 02139, USA + + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + + GNU GENERAL PUBLIC LICENSE + + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + Appendix: How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) 19yy + + This program 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 2 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, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) 19yy name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + , 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Library General +Public License instead of this License. diff --git a/data/Vortex86MX-eng/docs/FARA.TXT b/data/Vortex86MX-eng/docs/FARA.TXT new file mode 100644 index 0000000000..364a54dc08 --- /dev/null +++ b/data/Vortex86MX-eng/docs/FARA.TXT @@ -0,0 +1,48 @@ + PHARAOH TOMB + +The purpose of the game is to open passage by moving hieroglyphs on entrance +in the next room of the pharaoh tomb (8X8). You can exchange two hieroglyphs +located near each other on vertical or horizontal if after such transposition +a combination of three or more identical pictures abreast is generated. Such +lines are disappeared immediately, and free place is filled by hieroglyphs +which "falled" from top. Missing hieroglyphs are generated randomly. For +disappearing hieroglyphs points are added. For combination of hieroglyphs +number of points is calculated by formula L+(L+1)^(N-3), but no more than +20*L*N, where N is number of hieroglyphs in combination, and L is level number. +To pass to the next level it is required to remove certain number of +hieroglyphs (different on each level). From below of panel with hieroglyphs is +located field which indicates how many is passed and how many is remained. + +1st level - 500 +2nd level - 450 +3rd level - 400 +4th level - 350 +5th level - 300 +6th level and further - 50*(L+1) + +On the first level combinations are composed from 6 states of hieroglyphs. +With each new level one new hieroglyph is involved, but no more than 10 +(i.e. starting from 5th level and further 10 different hieroglyphs are +involved, not counting special ones). + +Starting from 2nd level for each combination from 4 and more hieroglyphs, +and also for passing each fourth of level the player gets "free" hieroglyph - +it is usual hieroglyph (generated randomly), which keeps "in pocket" of player +and can be necessarily inserted by player to any place and replace thus +located there hieroglyph. + +Starting from 3rd level for each combination from 5 and more hieroglyphs, +and also for passing each third of level the player gets "universal key", +which matches to any combination of hieroglyphs and to several different +combination simultaneously. + +Starting from 4th level for each combination from 6 and more hieroglyphs, +and also for passing a half of level the player gets "space crooker", +which allows, when is used, to make 3 moves (not obligatory successive) at +diagonal. + +The player can not have simultaneously more than 1 extra hieroglyph of each +type (1 usual, 1 joker and 1 crooker). + +The game is ended, if the player can not make any combination with existing +hieroglyphs. diff --git a/data/Vortex86MX-eng/docs/FASM.TXT b/data/Vortex86MX-eng/docs/FASM.TXT new file mode 100644 index 0000000000..2151e3f734 --- /dev/null +++ b/data/Vortex86MX-eng/docs/FASM.TXT @@ -0,0 +1,3591 @@ + + Üßßß + ÜÜÛÜÜ ÜÜÜÜ ÜÜÜÜÜ ÜÜÜ ÜÜ + Û Û Û Û Û Û + Û ÜßßßßÛ ßßßßÜ Û Û Û + Û ßÜÜÜÜÛÜ ÜÜÜÜÜß Û Û Û + + flat assembler 1.66 + Programmer's Manual + + +Table of contents +ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ + +Chapter 1 Introduction + + 1.1 Compiler overview + 1.1.1 System requirements + 1.1.2 Executing compiler from command line + 1.1.3 Compiler messages + 1.1.4 Output formats + + 1.2 Assembly syntax + 1.2.1 Instruction syntax + 1.2.2 Data definitions + 1.2.3 Constants and labels + 1.2.4 Numerical expressions + 1.2.5 Jumps and calls + 1.2.6 Size settings + +Chapter 2 Instruction set + + 2.1 The x86 architecture instructions + 2.1.1 Data movement instructions + 2.1.2 Type conversion instructions + 2.1.3 Binary arithmetic instructions + 2.1.4 Decimal arithmetic instructions + 2.1.5 Logical instructions + 2.1.6 Control transfer instructions + 2.1.7 I/O instructions + 2.1.8 Strings operations + 2.1.9 Flag control instructions + 2.1.10 Conditional operations + 2.1.11 Miscellaneous instructions + 2.1.12 System instructions + 2.1.13 FPU instructions + 2.1.14 MMX instructions + 2.1.15 SSE instructions + 2.1.16 SSE2 instructions + 2.1.17 SSE3 instructions + 2.1.18 AMD 3DNow! instructions + 2.1.19 The x86-64 long mode instructions + + 2.2 Control directives + 2.2.1 Numerical constants + 2.2.2 Conditional assembly + 2.2.3 Repeating blocks of instructions + 2.2.4 Addressing spaces + 2.2.5 Other directives + 2.2.6 Multiple passes + + 2.3 Preprocessor directives + 2.3.1 Including source files + 2.3.2 Symbolic constants + 2.3.3 Macroinstructions + 2.3.4 Structures + 2.3.5 Repeating macroinstructions + 2.3.6 Conditional preprocessing + 2.3.7 Order of processing + + 2.4 Formatter directives + 2.4.1 MZ executable + 2.4.2 Portable Executable + 2.4.3 Common Object File Format + 2.4.4 Executable and Linkable Format + + +Chapter 1 Introduction +ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ + +This chapter contains all the most important information you need to begin +using the flat assembler. If you are experienced assembly language programmer, +you should read at least this chapter before using this compiler. + + +1.1 Compiler overview + +Flat assembler is a fast assembly language compiler for the x86 architecture +processors, which does multiple passes to optimize the size of generated +machine code. It is self-compilable and versions for different operating +systems are provided. All the versions are designed to be used from the system +command line and they should not differ in behavior. + + +1.1.1 System requirements + +All versions require the x86 architecture 32-bit processor (at least 80386), +although they can produce programs for the x86 architecture 16-bit processors, +too. DOS version requires an OS compatible with MS DOS 2.0 and either true +real mode environment or DPMI. Windows version requires a Win32 console +compatible with 3.1 version. + + +1.1.2 Executing compiler from command line + +To execute flat assembler from the command line you need to provide two +parameters - first should be name of source file, second should be name of +destination file. If no second parameter is given, the name for output +file will be guessed automatically. After displaying short information about +the program name and version, compiler will read the data from source file and +compile it. When the compilation is successful, compiler will write the +generated code to the destination file and display the summary of compilation +process; otherwise it will display the information about error that occurred. + The source file should be a text file, and can be created in any text +editor. Line breaks are accepted in both DOS and Unix standards, tabulators +are treated as spaces. + In the command line you can also include "-m" option followed by a number, +which specifies how many kilobytes of memory flat assembler should maximally +use. In case of DOS version this options limits only the usage of extended +memory. The "-p" option followed by a number can be used to specify the limit +for number of passes the assembler performs. If code cannot be generated +within specified amount of passes, the assembly will be terminated with an +error message. The maximum value of this setting is 65536, while the default +limit, used when no such option is included in command line, is 100. +It is also possible to limit the number of passes the assembler +performs, with the "-p" option followed by a number specifying the maximum +number of passes. + There are no command line options that would affect the output of compiler, +flat assembler requires only the source code to include the information it +really needs. For example, to specify output format you specify it by using +the "format" directive at the beginning of source. + + +1.1.3 Compiler messages + +As it is stated above, after the successful compilation, the compiler displays +the compilation summary. It includes the information of how many passes was +done, how much time it took, and how many bytes were written into the +destination file. +The following is an example of the compilation summary: + +flat assembler version 1.66 +38 passes, 5.3 seconds, 77824 bytes. + +In case of error during the compilation process, the program will display an +error message. For example, when compiler can't find the input file, it will +display the following message: + +flat assembler version 1.66 +error: source file not found. + +If the error is connected with a specific part of source code, the source line +that caused the error will be also displayed. Also placement of this line in +the source is given to help you finding this error, for example: + +flat assembler version 1.66 +example.asm [3]: + mob ax,1 +error: illegal instruction. + +It means that in the third line of the "example.asm" file compiler has +encountered an unrecognized instruction. When the line that caused error +contains a macroinstruction, also the line in macroinstruction definition +that generated the erroneous instruction is displayed: + +flat assembler version 1.66 +example.asm [6]: + stoschar 7 +example.asm [3] stoschar [1]: + mob al,char +error: illegal instruction. + +It means that the macroinstruction in the sixth line of the "example.asm" file +generated an unrecognized instruction with the first line of its definition. + + +1.1.4 Output formats + +By default, when there is no "format" directive in source file, flat +assembler simply puts generated instruction codes into output, creating this +way flat binary file. By default it generates 16-bit code, but you can always +turn it into the 16-bit or 32-bit mode by using "use16" or "use32" directive. +Some of the output formats switch into 32-bit mode, when selected - more +information about formats which you can choose can be found in 2.4. + All output code is always in the order in which it was entered into the +source file. + + +1.2 Assembly syntax + +The information provided below is intended mainly for the assembler +programmers that have been using some other assembly compilers before. +If you are beginner, you should look for the assembly programming tutorials. + Flat assembler by default uses the Intel syntax for the assembly +instructions, although you can customize it using the preprocessor +capabilities (macroinstructions and symbolic constants). It also has its own +set of the directives - the instructions for compiler. + All symbols defined inside the sources are case-sensitive. + + +1.2.1 Instruction syntax + +Instructions in assembly language are separated by line breaks, and one +instruction is expected to fill the one line of text. If a line contains +a semicolon, except for the semicolons inside the quoted strings, the rest of +this line is the comment and compiler ignores it. If a line ends with "\" +character (eventually the semicolon and comment may follow it), the next line +is attached at this point. + Each line in source is the sequence of items, which may be one of the three +types. One type are the symbol characters, which are the special characters +that are individual items even when are not spaced from the other ones. +Any of the "+-*/=<>()[]{}:,|&~#`" is the symbol character. The sequence of +other characters, separated from other items with either blank spaces or +symbol characters, is a symbol. If the first character of symbol is either a +single or double quote, it integrates the any sequence of characters following +it, even the special ones, into a quoted string, which should end with the same +character, with which it began (the single or double quote) - however if there +are two such characters in a row (without any other character between them), +they are integrated into quoted string as just one of them and the quoted +string continues then. The symbols other than symbol characters and quoted +strings can be used as names, so are also called the name symbols. + Every instruction consists of the mnemonic and the various number of +operands, separated with commas. The operand can be register, immediate value +or a data addressed in memory, it can also be preceded by size operator to +define or override its size (table 1.1). Names of available registers you can +find in table 1.2, their sizes cannot be overridden. Immediate value can be +specified by any numerical expression. + When operand is a data in memory, the address of that data (also any +numerical expression, but it may contain registers) should be enclosed in +square brackets or preceded by "ptr" operator. For example instruction +"mov eax,3" will put the immediate value 3 into the EAX register, instruction +"mov eax,[7]" will put the 32-bit value from the address 7 into EAX and the +instruction "mov byte [7],3" will put the immediate value 3 into the byte at +address 7, it can also be written as "mov byte ptr 7,3". To specify which +segment register should be used for addressing, segment register name followed +by a colon should be put just before the address value (inside the square +brackets or after the "ptr" operator). + + Table 1.1 Size operators + ÚÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÂÄÄÄÄÄÄÄ¿ + ³ Operator ³ Bits ³ Bytes ³ + ÆÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍ͵ + ³ byte ³ 8 ³ 1 ³ + ³ word ³ 16 ³ 2 ³ + ³ dword ³ 32 ³ 4 ³ + ³ fword ³ 48 ³ 6 ³ + ³ pword ³ 48 ³ 6 ³ + ³ qword ³ 64 ³ 8 ³ + ³ tbyte ³ 80 ³ 10 ³ + ³ tword ³ 80 ³ 10 ³ + ³ dqword ³ 128 ³ 16 ³ + ÀÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÄÙ + + Table 1.2 Registers + ÚÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ¿ + ³ Type ³ Bits ³ ³ + ÆÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍ͵ + ³ ³ 8 ³ al cl dl bl ah ch dh bh ³ + ³ General ³ 16 ³ ax cx dx bx sp bp si di ³ + ³ ³ 32 ³ eax ecx edx ebx esp ebp esi edi ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ Segment ³ 16 ³ es cs ss ds fs gs ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ Control ³ 32 ³ cr0 cr2 cr3 cr4 ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ Debug ³ 32 ³ dr0 dr1 dr2 dr3 dr6 dr7 ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ FPU ³ 80 ³ st0 st1 st2 st3 st4 st5 st6 st7 ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ MMX ³ 64 ³ mm0 mm1 mm2 mm3 mm4 mm5 mm6 mm7 ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ SSE ³ 128 ³ xmm0 xmm1 xmm2 xmm3 xmm4 xmm5 xmm6 xmm7 ³ + ÀÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÙ + + +1.2.2 Data definitions + +To define data or reserve a space for it, use one of the directives listed in +table 1.3. The data definition directive should be followed by one or more of +numerical expressions, separated with commas. These expressions define the +values for data cells of size depending on which directive is used. For +example "db 1,2,3" will define the three bytes of values 1, 2 and 3 +respectively. + The "db" and "du" directives also accept the quoted string values of any +length, which will be converted into chain of bytes when "db" is used and into +chain of words with zeroed high byte when "du" is used. For example "db 'abc'" +will define the three bytes of values 61, 62 and 63. + The "dp" directive and its synonym "df" accept the values consisting of two +numerical expressions separated with colon, the first value will become the +high word and the second value will become the low double word of the far +pointer value. Also "dd" accepts such pointers consisting of two word values +separated with colon, and "dt" accepts the word and quad word value separated +with colon, the quad word is stored first. The "dt" directive with single +expression as parameter accepts only floating point values and creates data in +FPU double extended precision format. + Any of the above directive allows the usage of special "dup" operator to +make multiple copies of given values. The count of duplicates should precede +this operator and the value to duplicate should follow - it can even be the +chain of values separated with commas, but such set of values needs to be +enclosed with parenthesis, like "db 5 dup (1,2)", which defines five copies +of the given two byte sequence. + The "file" is a special directive and its syntax is different. This +directive includes a chain of bytes from file and it should be followed by the +quoted file name, then optionally numerical expression specifying offset in +file preceded by the colon, and - also optionally - comma and numerical +expression specifying count of bytes to include (if no count is specified, all +data up to the end of file is included). For example "file 'data.bin'" will +include the whole file as binary data and "file 'data.bin':10h,4" will include +only four bytes starting at offset 10h. + The data reservation directive should be followed by only one numerical +expression, and this value defines how many cells of the specified size should +be reserved. All data definition directives also accept the "?" value, which +means that this cell should not be initialized to any value and the effect is +the same as by using the data reservation directive. The uninitialized data +may not be included in the output file, so its values should be always +considered unknown. + + Table 1.3 Data directives + ÚÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄ¿ + ³ Size ³ Define ³ Reserve ³ + ³ (bytes) ³ data ³ data ³ + ÆÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍ͵ + ³ 1 ³ db ³ rb ³ + ³ ³ file ³ ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄ´ + ³ 2 ³ dw ³ rw ³ + ³ ³ du ³ ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄ´ + ³ 4 ³ dd ³ rd ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄ´ + ³ 6 ³ dp ³ rp ³ + ³ ³ df ³ rf ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄ´ + ³ 8 ³ dq ³ rq ³ + ÃÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄ´ + ³ 10 ³ dt ³ rt ³ + ÀÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÙ + + +1.2.3 Constants and labels + +In the numerical expressions you can also use constants or labels instead of +numbers. To define the constant or label you should use the specific +directives. Each label can be defined only once and it is accessible from the +any place of source (even before it was defined). Constant can be redefined +many times, but in this case it is accessible only after it was defined, and +is always equal to the value from last definition before the place where it's +used. When a constant is defined only once in source, it is - like the label - +accessible from anywhere. + The definition of constant consists of name of the constant followed by the +"=" character and numerical expression, which after calculation will become +the value of constant. This value is always calculated at the time the +constant is defined. For example you can define "count" constant by using the +directive "count = 17", and then use it in the assembly instructions, like +"mov cx,count" - which will become "mov cx,17" during the compilation process. + There are different ways to define labels. The simplest is to follow the +name of label by the colon, this directive can even be followed by the other +instruction in the same line. It defines the label whose value is equal to +offset of the point where it's defined. This method is usually used to label +the places in code. The other way is to follow the name of label (without a +colon) by some data directive. It defines the label with value equal to +offset of the beginning of defined data, and remembered as a label for data +with cell size as specified for that data directive in table 1.3. + The label can be treated as constant of value equal to offset of labeled +code or data. For example when you define data using the labeled directive +"char db 224", to put the offset of this data into BX register you should use +"mov bx,char" instruction, and to put the value of byte addressed by "char" +label to DL register, you should use "mov dl,[char]" (or "mov dl,ptr char"). +But when you try to assemble "mov ax,[char]", it will cause an error, because +fasm compares the sizes of operands, which should be equal. You can force +assembling that instruction by using size override: "mov ax,word [char]", but +remember that this instruction will read the two bytes beginning at "char" +address, while it was defined as a one byte. + The last and the most flexible way to define labels is to use "label" +directive. This directive should be followed by the name of label, then +optionally size operator (it can be preceded by a colon) and then - also +optionally "at" operator and the numerical expression defining the address at +which this label should be defined. For example "label wchar word at char" +will define a new label for the 16-bit data at the address of "char". Now the +instruction "mov ax,[wchar]" will be after compilation the same as +"mov ax,word [char]". If no address is specified, "label" directive defines +the label at current offset. Thus "mov [wchar],57568" will copy two bytes +while "mov [char],224" will copy one byte to the same address. + The label whose name begins with dot is treated as local label, and its name +is attached to the name of last global label (with name beginning with +anything but dot) to make the full name of this label. So you can use the +short name (beginning with dot) of this label anywhere before the next global +label is defined, and in the other places you have to use the full name. Label +beginning with two dots are the exception - they are like global, but they +don't become the new prefix for local labels. + The "@@" name means anonymous label, you can have defined many of them in +the source. Symbol "@b" (or equivalent "@r") references the nearest preceding +anonymous label, symbol "@f" references the nearest following anonymous label. +These special symbol are case-insensitive. + + +1.2.4 Numerical expressions + +In the above examples all the numerical expressions were the simple numbers, +constants or labels. But they can be more complex, by using the arithmetical +or logical operators for calculations at compile time. All these operators +with their priority values are listed in table 1.4. +The operations with higher priority value will be calculated first, you can +of course change this behavior by putting some parts of expression into +parenthesis. The "+", "-", "*" and "/" are standard arithmetical operations, +"mod" calculates the remainder from division. The "and", "or", "xor", "shl", +"shr" and "not" perform the same logical operations as assembly instructions +of those names. The "rva" performs the conversion of an address into the +relocatable offset and is specific to some of the output formats (see 2.4). + The numbers in the expression are by default treated as a decimal, binary +numbers should have the "b" letter attached at the end, octal number should +end with "o" letter, hexadecimal numbers should begin with "0x" characters +(like in C language) or with the "$" character (like in Pascal language) or +they should end with "h" letter. Also quoted string, when encountered in +expression, will be converted into number - the first character will become +the least significant byte of number. + The numerical expression used as an address value can also contain any of +general registers used for addressing, they can be added and multiplied by +appropriate values, as it is allowed for the x86 architecture instructions. + There are also some special symbols that can be used inside the numerical +expression. First is "$", which is always equal to the value of current +offset, while "$$" is equal to base address of current addressing space. The +other one is "%", which is the number of current repeat in parts of code that +are repeated using some special directives (see 2.2). There's also "%t" +symbol, which is always equal to the current time stamp. + Any numerical expression can also consist of single floating point value +(flat assembler does not allow any floating point operations at compilation +time) in the scientific notation, they can end with the "f" letter to be +recognized, otherwise they should contain at least one of the "." or "E" +characters. So "1.0", "1E0" and "1f" define the same floating point value, +while simple "1" defines an integer value. + + Table 1.4 Arithmetical and logical operators by priority + ÚÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄ¿ + ³ Priority ³ Operators ³ + ÆÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍ͵ + ³ 0 ³ + - ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 1 ³ * / ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 2 ³ mod ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 3 ³ and or xor ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 4 ³ shl shr ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 5 ³ not ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ 6 ³ rva ³ + ÀÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÙ + + +1.2.5 Jumps and calls + +The operand of any jump or call instruction can be preceded not only by the +size operator, but also by one of the operators specifying type of the jump: +"short", "near" of "far". For example, when assembler is in 16-bit mode, +instruction "jmp dword [0]" will become the far jump and when assembler is +in 32-bit mode, it will become the near jump. To force this instruction to be +treated differently, use the "jmp near dword [0]" or "jmp far dword [0]" form. + When operand of near jump is the immediate value, assembler will generate +the shortest variant of this jump instruction if possible (but won't create +32-bit instruction in 16-bit mode nor 16-bit instruction in 32-bit mode, +unless there is a size operator stating it). By specifying the jump type +you can force it to always generate long variant (for example "jmp near 0") +or to always generate short variant and terminate with an error when it's +impossible (for example "jmp short 0"). + + +1.2.6 Size settings + +When instruction uses some memory addressing, by default the smallest form of +instruction is generated by using the short displacement if only address +value fits in the range. This can be overridden using the "word" or "dword" +operator before the address inside the square brackets (or after the "ptr" +operator), which forces the long displacement of appropriate size to be made. +In case when address is not relative to any registers, those operators allow +also to choose the appropriate mode of absolute addressing. + Instructions "adc", "add", "and", "cmp", "or", "sbb", "sub" and "xor" with +first operand being 16-bit or 32-bit are by default generated in shortened +8-bit form when the second operand is immediate value fitting in the range +for signed 8-bit values. It also can be overridden by putting the "word" or +"dword" operator before the immediate value. The similar rules applies to the +"imul" instruction with the last operand being immediate value. + Immediate value as an operand for "push" instruction without a size operator +is by default treated as a word value if assembler is in 16-bit mode and as a +double word value if assembler is in 32-bit mode, shorter 8-bit form of this +instruction is used if possible, "word" or "dword" size operator forces the +"push" instruction to be generated in longer form for specified size. "pushw" +and "pushd" mnemonics force assembler to generate 16-bit or 32-bit code +without forcing it to use the longer form of instruction. + + +Chapter 2 Instruction set +ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ + +This chapter provides the detailed information about the instructions and +directives supported by flat assembler. Directives for defining labels were +already discussed in 1.2.3, all other directives will be described later in +this chapter. + + +2.1 The x86 architecture instructions + +In this section you can find both the information about the syntax and +purpose the assembly language instructions. If you need more technical +information, look for the Intel Architecture Software Developer's Manual. + Assembly instructions consist of the mnemonic (instruction's name) and from +zero to three operands. If there are two or more operands, usually first is +the destination operand and second is the source operand. Each operand can be +register, memory or immediate value (see 1.2 for details about syntax of +operands). After the description of each instruction there are examples +of different combinations of operands, if the instruction has any. + Some instructions act as prefixes and can be followed by other instruction +in the same line, and there can be more than one prefix in a line. Each name +of the segment register is also a mnemonic of instruction prefix, altough it +is recommended to use segment overrides inside the square brackets instead of +these prefixes. + + +2.1.1 Data movement instructions + +"mov" transfers a byte, word or double word from the source operand to the +destination operand. It can transfer data between general registers, from +the general register to memory, or from memory to general register, but it +cannot move from memory to memory. It can also transfer an immediate value to +general register or memory, segment register to general register or memory, +general register or memory to segment register, control or debug register to +general register and general register to control or debug register. The "mov" +can be assembled only if the size of source operand and size of destination +operand are the same. Below are the examples for each of the allowed +combinations: + + mov bx,ax ; general register to general register + mov [char],al ; general register to memory + mov bl,[char] ; memory to general register + mov dl,32 ; immediate value to general register + mov [char],32 ; immediate value to memory + mov ax,ds ; segment register to general register + mov [bx],ds ; segment register to memory + mov ds,ax ; general register to segment register + mov ds,[bx] ; memory to segment register + mov eax,cr0 ; control register to general register + mov cr3,ebx ; general register to control register + + "xchg" swaps the contents of two operands. It can swap two byte operands, +two word operands or two double word operands. Order of operands is not +important. The operands may be two general registers, or general register +with memory. For example: + + xchg ax,bx ; swap two general registers + xchg al,[char] ; swap register with memory + + "push" decrements the stack frame pointer (ESP register), then transfers +the operand to the top of stack indicated by ESP. The operand can be memory, +general register, segment register or immediate value of word or double word +size. If operand is an immediate value and no size is specified, it is by +default treated as a word value if assembler is in 16-bit mode and as a double +word value if assembler is in 32-bit mode. "pushw" and "pushd" mnemonics are +variants of this instruction that store the values of word or double word size +respectively. If more operands follow in the same line (separated only with +spaces, not commas), compiler will assemble chain of the "push" instructions +with these operands. The examples are with single operands: + + push ax ; store general register + push es ; store segment register + pushw [bx] ; store memory + push 1000h ; store immediate value + + "pusha" saves the contents of the eight general register on the stack. +This instruction has no operands. There are two version of this instruction, +one 16-bit and one 32-bit, assembler automatically generates the appropriate +version for current mode, but it can be overridden by using "pushaw" or +"pushad" mnemonic to always get the 16-bit or 32-bit version. The 16-bit +version of this instruction pushes general registers on the stack in the +following order: AX, CX, DX, BX, the initial value of SP before AX was pushed, +BP, SI and DI. The 32-bit version pushes equivalent 32-bit general registers +in the same order. + "pop" transfers the word or double word at the current top of stack to the +destination operand, and then increments ESP to point to the new top of stack. +The operand can be memory, general register or segment register. "popw" and +"popd" mnemonics are variants of this instruction for restoring the values of +word or double word size respectively. If more operands separated with spaces +follow in the same line, compiler will assemble chain of the "pop" +instructions with these operands. + + pop bx ; restore general register + pop ds ; restore segment register + popw [si] ; restore memory + + "popa" restores the registers saved on the stack by "pusha" instruction, +except for the saved value of SP (or ESP), which is ignored. This instruction +has no operands. To force assembling 16-bit or 32-bit version of this +instruction use "popaw" or "popad" mnemonic. + + +2.1.2 Type conversion instructions + +The type conversion instructions convert bytes into words, words into double +words, and double words into quad words. These conversions can be done using +the sign extension or zero extension. The sign extension fills the extra bits +of the larger item with the value of the sign bit of the smaller item, the +zero extension simply fills them with zeros. + "cwd" and "cdq" double the size of value AX or EAX register respectively +and store the extra bits into the DX or EDX register. The conversion is done +using the sign extension. These instructions have no operands. + "cbw" extends the sign of the byte in AL throughout AX, and "cwde" extends +the sign of the word in AX throughout EAX. These instructions also have no +operands. + "movsx" converts a byte to word or double word and a word to double word +using the sign extension. "movzx" does the same, but it uses the zero +extension. The source operand can be general register or memory, while the +destination operand must be a general register. For example: + + movsx ax,al ; byte register to word register + movsx edx,dl ; byte register to double word register + movsx eax,ax ; word register to double word register + movsx ax,byte [bx] ; byte memory to word register + movsx edx,byte [bx] ; byte memory to double word register + movsx eax,word [bx] ; word memory to double word register + + +2.1.3 Binary arithmetic instructions + +"add" replaces the destination operand with the sum of the source and +destination operands and sets CF if overflow has occurred. The operands may +be bytes, words or double words. The destination operand can be general +register or memory, the source operand can be general register or immediate +value, it can also be memory if the destination operand is register. + + add ax,bx ; add register to register + add ax,[si] ; add memory to register + add [di],al ; add register to memory + add al,48 ; add immediate value to register + add [char],48 ; add immediate value to memory + + "adc" sums the operands, adds one if CF is set, and replaces the destination +operand with the result. Rules for the operands are the same as for the "add" +instruction. An "add" followed by multiple "adc" instructions can be used to +add numbers longer than 32 bits. + "inc" adds one to the operand, it does not affect CF. The operand can be a +general register or memory, and the size of the operand can be byte, word or +double word. + + inc ax ; increment register by one + inc byte [bx] ; increment memory by one + + "sub" subtracts the source operand from the destination operand and replaces +the destination operand with the result. If a borrow is required, the CF is +set. Rules for the operands are the same as for the "add" instruction. + "sbb" subtracts the source operand from the destination operand, subtracts +one if CF is set, and stores the result to the destination operand. Rules for +the operands are the same as for the "add" instruction. A "sub" followed by +multiple "sbb" instructions may be used to subtract numbers longer than 32 +bits. + "dec" subtracts one from the operand, it does not affect CF. Rules for the +operand are the same as for the "inc" instruction. + "cmp" subtracts the source operand from the destination operand. It updates +the flags as the "sub" instruction, but does not alter the source and +destination operands. Rules for the operands are the same as for the "sub" +instruction. + "neg" subtracts a signed integer operand from zero. The effect of this +instructon is to reverse the sign of the operand from positive to negative or +from negative to positive. Rules for the operand are the same as for the "inc" +instruction. + "xadd" exchanges the destination operand with the source operand, then loads +the sum of the two values into the destination operand. Rules for the operands +are the same as for the "add" instruction. + All the above binary arithmetic instructions update SF, ZF, PF and OF flags. +SF is always set to the same value as the result's sign bit, ZF is set when +all the bits of result are zero, PF is set when low order eight bits of result +contain an even number of set bits, OF is set if result is too large for a +positive number or too small for a negative number (excluding sign bit) to fit +in destination operand. + "mul" performs an unsigned multiplication of the operand and the +accumulator. If the operand is a byte, the processor multiplies it by the +contents of AL and returns the 16-bit result to AH and AL. If the operand is a +word, the processor multiplies it by the contents of AX and returns the 32-bit +result to DX and AX. If the operand is a double word, the processor multiplies +it by the contents of EAX and returns the 64-bit result in EDX and EAX. "mul" +sets CF and OF when the upper half of the result is nonzero, otherwise they +are cleared. Rules for the operand are the same as for the "inc" instruction. + "imul" performs a signed multiplication operation. This instruction has +three variations. First has one operand and behaves in the same way as the +"mul" instruction. Second has two operands, in this case destination operand +is multiplied by the source operand and the result replaces the destination +operand. Destination operand must be a general register, it can be word or +double word, source operand can be general register, memory or immediate +value. Third form has three operands, the destination operand must be a +general register, word or double word in size, source operand can be general +register or memory, and third operand must be an immediate value. The source +operand is multiplied by the immediate value and the result is stored in the +destination register. All the three forms calculate the product to twice the +size of operands and set CF and OF when the upper half of the result is +nonzero, but second and third form truncate the product to the size of +operands. So second and third forms can be also used for unsigned operands +because, whether the operands are signed or unsigned, the lower half of the +product is the same. Below are the examples for all three forms: + + imul bl ; accumulator by register + imul word [si] ; accumulator by memory + imul bx,cx ; register by register + imul bx,[si] ; register by memory + imul bx,10 ; register by immediate value + imul ax,bx,10 ; register by immediate value to register + imul ax,[si],10 ; memory by immediate value to register + + "div" performs an unsigned division of the accumulator by the operand. +The dividend (the accumulator) is twice the size of the divisor (the operand), +the quotient and remainder have the same size as the divisor. If divisor is +byte, the dividend is taken from AX register, the quotient is stored in AL and +the remainder is stored in AH. If divisor is word, the upper half of dividend +is taken from DX, the lower half of dividend is taken from AX, the quotient is +stored in AX and the remainder is stored in DX. If divisor is double word, +the upper half of dividend is taken from EDX, the lower half of dividend is +taken from EAX, the quotient is stored in EAX and the remainder is stored in +EDX. Rules for the operand are the same as for the "mul" instruction. + "idiv" performs a signed division of the accumulator by the operand. +It uses the same registers as the "div" instruction, and the rules for +the operand are the same. + + +2.1.4 Decimal arithmetic instructions + +Decimal arithmetic is performed by combining the binary arithmetic +instructions (already described in the prior section) with the decimal +arithmetic instructions. The decimal arithmetic instructions are used to +adjust the results of a previous binary arithmetic operation to produce a +valid packed or unpacked decimal result, or to adjust the inputs to a +subsequent binary arithmetic operation so the operation will produce a valid +packed or unpacked decimal result. + "daa" adjusts the result of adding two valid packed decimal operands in +AL. "daa" must always follow the addition of two pairs of packed decimal +numbers (one digit in each half-byte) to obtain a pair of valid packed +decimal digits as results. The carry flag is set if carry was needed. +This instruction has no operands. + "das" adjusts the result of subtracting two valid packed decimal operands +in AL. "das" must always follow the subtraction of one pair of packed decimal +numbers (one digit in each half-byte) from another to obtain a pair of valid +packed decimal digits as results. The carry flag is set if a borrow was +needed. This instruction has no operands. + "aaa" changes the contents of register AL to a valid unpacked decimal +number, and zeroes the top four bits. "aaa" must always follow the addition +of two unpacked decimal operands in AL. The carry flag is set and AH is +incremented if a carry is necessary. This instruction has no operands. + "aas" changes the contents of register AL to a valid unpacked decimal +number, and zeroes the top four bits. "aas" must always follow the +subtraction of one unpacked decimal operand from another in AL. The carry flag +is set and AH decremented if a borrow is necessary. This instruction has no +operands. + "aam" corrects the result of a multiplication of two valid unpacked decimal +numbers. "aam" must always follow the multiplication of two decimal numbers +to produce a valid decimal result. The high order digit is left in AH, the +low order digit in AL. The generalized version of this instruction allows +adjustment of the contents of the AX to create two unpacked digits of any +number base. The standard version of this instruction has no operands, the +generalized version has one operand - an immediate value specifying the +number base for the created digits. + "aad" modifies the numerator in AH and AL to prepare for the division of two +valid unpacked decimal operands so that the quotient produced by the division +will be a valid unpacked decimal number. AH should contain the high order +digit and AL the low order digit. This instruction adjusts the value and +places the result in AL, while AH will contain zero. The generalized version +of this instruction allows adjustment of two unpacked digits of any number +base. Rules for the operand are the same as for the "aam" instruction. + + +2.1.5 Logical instructions + +"not" inverts the bits in the specified operand to form a one's +complement of the operand. It has no effect on the flags. Rules for the +operand are the same as for the "inc" instruction. + "and", "or" and "xor" instructions perform the standard +logical operations. They update the SF, ZF and PF flags. Rules for the +operands are the same as for the "add" instruction. + "bt", "bts", "btr" and "btc" instructions operate on a single bit which can +be in memory or in a general register. The location of the bit is specified +as an offset from the low order end of the operand. The value of the offset +is the taken from the second operand, it either may be an immediate byte or +a general register. These instructions first assign the value of the selected +bit to CF. "bt" instruction does nothing more, "bts" sets the selected bit to +1, "btr" resets the selected bit to 0, "btc" changes the bit to its +complement. The first operand can be word or double word. + + bt ax,15 ; test bit in register + bts word [bx],15 ; test and set bit in memory + btr ax,cx ; test and reset bit in register + btc word [bx],cx ; test and complement bit in memory + + "bsf" and "bsr" instructions scan a word or double word for first set bit +and store the index of this bit into destination operand, which must be +general register. The bit string being scanned is specified by source operand, +it may be either general register or memory. The ZF flag is set if the entire +string is zero (no set bits are found); otherwise it is cleared. If no set bit +is found, the value of the destination register is undefined. "bsf" scans from +low order to high order (starting from bit index zero). "bsr" scans from high +order to low order (starting from bit index 15 of a word or index 31 of a +double word). + + bsf ax,bx ; scan register forward + bsr ax,[si] ; scan memory reverse + + "shl" shifts the destination operand left by the number of bits specified +in the second operand. The destination operand can be byte, word, or double +word general register or memory. The second operand can be an immediate value +or the CL register. The processor shifts zeros in from the right (low order) +side of the operand as bits exit from the left side. The last bit that exited +is stored in CF. "sal" is a synonym for "shl". + + shl al,1 ; shift register left by one bit + shl byte [bx],1 ; shift memory left by one bit + shl ax,cl ; shift register left by count from cl + shl word [bx],cl ; shift memory left by count from cl + + "shr" and "sar" shift the destination operand right by the number of bits +specified in the second operand. Rules for operands are the same as for the +"shl" instruction. "shr" shifts zeros in from the left side of the operand as +bits exit from the right side. The last bit that exited is stored in CF. +"sar" preserves the sign of the operand by shifting in zeros on the left side +if the value is positive or by shifting in ones if the value is negative. + "shld" shifts bits of the destination operand to the left by the number +of bits specified in third operand, while shifting high order bits from the +source operand into the destination operand on the right. The source operand +remains unmodified. The destination operand can be a word or double word +general register or memory, the source operand must be a general register, +third operand can be an immediate value or the CL register. + + shld ax,bx,1 ; shift register left by one bit + shld [di],bx,1 ; shift memory left by one bit + shld ax,bx,cl ; shift register left by count from cl + shld [di],bx,cl ; shift memory left by count from cl + + "shrd" shifts bits of the destination operand to the right, while shifting +low order bits from the source operand into the destination operand on the +left. The source operand remains unmodified. Rules for operands are the same +as for the "shld" instruction. + "rol" and "rcl" rotate the byte, word or double word destination operand +left by the number of bits specified in the second operand. For each rotation +specified, the high order bit that exits from the left of the operand returns +at the right to become the new low order bit. "rcl" additionally puts in CF +each high order bit that exits from the left side of the operand before it +returns to the operand as the low order bit on the next rotation cycle. Rules +for operands are the same as for the "shl" instruction. + "ror" and "rcr" rotate the byte, word or double word destination operand +right by the number of bits specified in the second operand. For each rotation +specified, the low order bit that exits from the right of the operand returns +at the left to become the new high order bit. "rcr" additionally puts in CF +each low order bit that exits from the right side of the operand before it +returns to the operand as the high order bit on the next rotation cycle. +Rules for operands are the same as for the "shl" instruction. + "test" performs the same action as the "and" instruction, but it does not +alter the destination operand, only updates flags. Rules for the operands are +the same as for the "and" instruction. + "bswap" reverses the byte order of a 32-bit general register: bits 0 through +7 are swapped with bits 24 through 31, and bits 8 through 15 are swapped with +bits 16 through 23. This instruction is provided for converting little-endian +values to big-endian format and vice versa. + + bswap edx ; swap bytes in register + + +2.1.6 Control transfer instructions + +"jmp" unconditionally transfers control to the target location. The +destination address can be specified directly within the instruction or +indirectly through a register or memory, the acceptable size of this address +depends on whether the jump is near or far (it can be specified by preceding +the operand with "near" or "far" operator) and whether the instruction is +16-bit or 32-bit. Operand for near jump should be "word" size for 16-bit +instruction or the "dword" size for 32-bit instruction. Operand for far jump +should be "dword" size for 16-bit instruction or "pword" size for 32-bit +instruction. A direct "jmp" instruction includes the destination address as +part of the instruction (and can be preceded by "short", "near" or "far" +operator), the operand specifying address should be the numerical expression +for near or short jump, or two numerical expressions separated with colon for +far jump, the first specifies selector of segment, the second is the offset +within segment. The "pword" operator can be used to force the 32-bit far call, +and "dword" to force the 16-bit far call. An indirect "jmp" instruction +obtains the destination address indirectly through a register or a pointer +variable, the operand should be general register or memory. See also 1.2.5 for +some more details. + + jmp 100h ; direct near jump + jmp 0FFFFh:0 ; direct far jump + jmp ax ; indirect near jump + jmp pword [ebx] ; indirect far jump + + "call" transfers control to the procedure, saving on the stack the address +of the instruction following the "call" for later use by a "ret" (return) +instruction. Rules for the operands are the same as for the "jmp" instruction, +but the "call" has no short variant of direct instruction and thus it not +optimized. + "ret", "retn" and "retf" instructions terminate the execution of a procedure +and transfers control back to the program that originally invoked the +procedure using the address that was stored on the stack by the "call" +instruction. "ret" is the equivalent for "retn", which returns from the +procedure that was executed using the near call, while "retf" returns from +the procedure that was executed using the far call. These instructions default +to the size of address appropriate for the current code setting, but the size +of address can be forced to 16-bit by using the "retw", "retnw" and "retfw" +mnemonics, and to 32-bit by using the "retd", "retnd" and "retfd" mnemonics. +All these instructions may optionally specify an immediate operand, by adding +this constant to the stack pointer, they effectively remove any arguments that +the calling program pushed on the stack before the execution of the "call" +instruction. + "iret" returns control to an interrupted procedure. It differs from "ret" in +that it also pops the flags from the stack into the flags register. The flags +are stored on the stack by the interrupt mechanism. It defaults to the size of +return address appropriate for the current code setting, but it can be forced +to use 16-bit or 32-bit address by using the "iretw" or "iretd" mnemonic. + The conditional transfer instructions are jumps that may or may not transfer +control, depending on the state of the CPU flags when the instruction +executes. The mnemonics for conditional jumps may be obtained by attaching +the condition mnemonic (see table 2.1) to the "j" mnemonic, +for example "jc" instruction will transfer the control when the CF flag is +set. The conditional jumps can be short or near, and direct only, and can be +optimized (see 1.2.5), the operand should be an immediate value specifying +target address. + + Table 2.1 Conditions + ÚÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ¿ + ³ Mnemonic ³ Condition tested ³ Description ³ + ÆÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍ͵ + ³ o ³ OF = 1 ³ overflow ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ no ³ OF = 0 ³ not overflow ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ c ³ ³ carry ³ + ³ b ³ CF = 1 ³ below ³ + ³ nae ³ ³ not above nor equal ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ nc ³ ³ not carry ³ + ³ ae ³ CF = 0 ³ above or equal ³ + ³ nb ³ ³ not below ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ e ³ ZF = 1 ³ equal ³ + ³ z ³ ³ zero ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ ne ³ ZF = 0 ³ not equal ³ + ³ nz ³ ³ not zero ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ be ³ CF or ZF = 1 ³ below or equal ³ + ³ na ³ ³ not above ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ a ³ CF or ZF = 0 ³ above ³ + ³ nbe ³ ³ not below nor equal ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ s ³ SF = 1 ³ sign ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ ns ³ SF = 0 ³ not sign ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ p ³ PF = 1 ³ parity ³ + ³ pe ³ ³ parity even ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ np ³ PF = 0 ³ not parity ³ + ³ po ³ ³ parity odd ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ l ³ SF xor OF = 1 ³ less ³ + ³ nge ³ ³ not greater nor equal ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ ge ³ SF xor OF = 0 ³ greater or equal ³ + ³ nl ³ ³ not less ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ le ³ (SF xor OF) or ZF = 1 ³ less or equal ³ + ³ ng ³ ³ not greater ³ + ÃÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÅÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ´ + ³ g ³ (SF xor OF) or ZF = 0 ³ greater ³ + ³ nle ³ ³ not less nor equal ³ + ÀÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÙ + + The "loop" instructions are conditional jumps that use a value placed in +CX (or ECX) to specify the number of repetitions of a software loop. All +"loop" instructions automatically decrement CX (or ECX) and terminate the +loop (don't transfer the control) when CX (or ECX) is zero. It uses CX or ECX +whether the current code setting is 16-bit or 32-bit, but it can be forced to +us CX with the "loopw" mnemonic or to use ECX with the "loopd" mnemonic. +"loope" and "loopz" are the synonyms for the same instruction, which acts as +the standard "loop", but also terminates the loop when ZF flag is set. +"loopew" and "loopzw" mnemonics force them to use CX register while "looped" +and "loopzd" force them to use ECX register. "loopne" and "loopnz" are the +synonyms for the same instructions, which acts as the standard "loop", but +also terminate the loop when ZF flag is not set. "loopnew" and "loopnzw" +mnemonics force them to use CX register while "loopned" and "loopnzd" force +them to use ECX register. Every "loop" instruction needs an operand being an +immediate value specifying target address, it can be only short jump (in the +range of 128 bytes back and 127 bytes forward from the address of instruction +following the "loop" instruction). + "jcxz" branches to the label specified in the instruction if it finds a +value of zero in CX, "jecxz" does the same, but checks the value of ECX +instead of CX. Rules for the operands are the same as for the "loop" +instruction. + "int" activates the interrupt service routine that corresponds to the +number specified as an operand to the instruction, the number should be in +range from 0 to 255. The interrupt service routine terminates with an "iret" +instruction that returns control to the instruction that follows "int". +"int3" mnemonic codes the short (one byte) trap that invokes the interrupt 3. +"into" instruction invokes the interrupt 4 if the OF flag is set. + "bound" verifies that the signed value contained in the specified register +lies within specified limits. An interrupt 5 occurs if the value contained in +the register is less than the lower bound or greater than the upper bound. It +needs two operands, the first operand specifies the register being tested, +the second operand should be memory address for the two signed limit values. +The operands can be "word" or "dword" in size. + + bound ax,[bx] ; check word for bounds + bound eax,[esi] ; check double word for bounds + + +2.1.7 I/O instructions + + "in" transfers a byte, word, or double word from an input port to AL, AX, +or EAX. I/O ports can be addressed either directly, with the immediate byte +value coded in instruction, or indirectly via the DX register. The destination +operand should be AL, AX, or EAX register. The source operand should be an +immediate value in range from 0 to 255, or DX register. + + in al,20h ; input byte from port 20h + in ax,dx ; input word from port addressed by dx + + "out" transfers a byte, word, or double word to an output port from AL, AX, +or EAX. The program can specify the number of the port using the same methods +as the "in" instruction. The destination operand should be an immediate value +in range from 0 to 255, or DX register. The source operand should be AL, AX, +or EAX register. + + out 20h,ax ; output word to port 20h + out dx,al ; output byte to port addressed by dx + + +2.1.8 Strings operations + +The string operations operate on one element of a string. A string element +may be a byte, a word, or a double word. The string elements are addressed by +SI and DI (or ESI and EDI) registers. After every string operation SI and/or +DI (or ESI and/or EDI) are automatically updated to point to the next element +of the string. If DF (direction flag) is zero, the index registers are +incremented, if DF is one, they are decremented. The amount of the increment +or decrement is 1, 2, or 4 depending on the size of the string element. Every +string operation instruction has short forms which have no operands and use +SI and/or DI when the code type is 16-bit, and ESI and/or EDI when the code +type is 32-bit. SI and ESI by default address data in the segment selected +by DS, DI and EDI always address data in the segment selected by ES. Short +form is obtained by attaching to the mnemonic of string operation letter +specifying the size of string element, it should be "b" for byte element, +"w" for word element, and "d" for double word element. Full form of string +operation needs operands providing the size operator and the memory addresses, +which can be SI or ESI with any segment prefix, DI or EDI always with ES +segment prefix. + "movs" transfers the string element pointed to by SI (or ESI) to the +location pointed to by DI (or EDI). Size of operands can be byte, word, or +double word. The destination operand should be memory addressed by DI or EDI, +the source operand should be memory addressed by SI or ESI with any segment +prefix. + + movs byte [di],[si] ; transfer byte + movs word [es:di],[ss:si] ; transfer word + movsd ; transfer double word + + "cmps" subtracts the destination string element from the source string +element and updates the flags AF, SF, PF, CF and OF, but it does not change +any of the compared elements. If the string elements are equal, ZF is set, +otherwise it is cleared. The first operand for this instruction should be the +source string element addressed by SI or ESI with any segment prefix, the +second operand should be the destination string element addressed by DI or +EDI. + + cmpsb ; compare bytes + cmps word [ds:si],[es:di] ; compare words + cmps dword [fs:esi],[edi] ; compare double words + + "scas" subtracts the destination string element from AL, AX, or EAX +(depending on the size of string element) and updates the flags AF, SF, ZF, +PF, CF and OF. If the values are equal, ZF is set, otherwise it is cleared. +The operand should be the destination string element addressed by DI or EDI. + + scas byte [es:di] ; scan byte + scasw ; scan word + scas dword [es:edi] ; scan double word + + "stos" places the value of AL, AX, or EAX into the destination string +element. Rules for the operand are the same as for the "scas" instruction. + "lods" places the source string element into AL, AX, or EAX. The operand +should be the source string element addressed by SI or ESI with any segment +prefix. + + lods byte [ds:si] ; load byte + lods word [cs:si] ; load word + lodsd ; load double word + + "ins" transfers a byte, word, or double word from an input port addressed +by DX register to the destination string element. The destination operand +should be memory addressed by DI or EDI, the source operand should be the DX +register. + + insb ; input byte + ins word [es:di],dx ; input word + ins dword [edi],dx ; input double word + + "outs" transfers the source string element to an output port addressed by +DX register. The destination operand should be the DX register and the source +operand should be memory addressed by SI or ESI with any segment prefix. + + outs dx,byte [si] ; output byte + outsw ; output word + outs dx,dword [gs:esi] ; output double word + + The repeat prefixes "rep", "repe"/"repz", and "repne"/"repnz" specify +repeated string operation. When a string operation instruction has a repeat +prefix, the operation is executed repeatedly, each time using a different +element of the string. The repetition terminates when one of the conditions +specified by the prefix is satisfied. All three prefixes automatically +decrease CX or ECX register (depending whether string operation instruction +uses the 16-bit or 32-bit addressing) after each operation and repeat the +associated operation until CX or ECX is zero. "repe"/"repz" and +"repne"/"repnz" are used exclusively with the "scas" and "cmps" instructions +(described below). When these prefixes are used, repetition of the next +instruction depends on the zero flag (ZF) also, "repe" and "repz" terminate +the execution when the ZF is zero, "repne" and "repnz" terminate the execution +when the ZF is set. + + rep movsd ; transfer multiple double words + repe cmpsb ; compare bytes until not equal + + +2.1.9 Flag control instructions + +The flag control instructions provide a method for directly changing the +state of bits in the flag register. All instructions described in this +section have no operands. + "stc" sets the CF (carry flag) to 1, "clc" zeroes the CF, "cmc" changes the +CF to its complement. "std" sets the DF (direction flag) to 1, "cld" zeroes +the DF, "sti" sets the IF (interrupt flag) to 1 and therefore enables the +interrupts, "cli" zeroes the IF and therefore disables the interrupts. + "lahf" copies SF, ZF, AF, PF, and CF to bits 7, 6, 4, 2, and 0 of the +AH register. The contents of the remaining bits are undefined. The flags +remain unaffected. + "sahf" transfers bits 7, 6, 4, 2, and 0 from the AH register into SF, ZF, +AF, PF, and CF. + "pushf" decrements "esp" by two or four and stores the low word or +double word of flags register at the top of stack, size of stored data +depends on the current code setting. "pushfw" variant forces storing the +word and "pushfd" forces storing the double word. + "popf" transfers specific bits from the word or double word at the top +of stack, then increments "esp" by two or four, this value depends on +the current code setting. "popfw" variant forces restoring from the word +and "popfd" forces restoring from the double word. + + +2.1.10 Conditional operations + + The instructions obtained by attaching the condition mnemonic (see table +2.1) to the "set" mnemonic set a byte to one if the condition is true and set +the byte to zero otherwise. The operand should be an 8-bit be general register +or the byte in memory. + + setne al ; set al if zero flag cleared + seto byte [bx] ; set byte if overflow + + "salc" instruction sets the all bits of AL register when the carry flag is +set and zeroes the AL register otherwise. This instruction has no arguments. + The instructions obtained by attaching the condition mnemonic to the "cmov" +mnemonic transfer the word or double word from the general register or memory +to the general register only when the condition is true. The destination +operand should be general register, the source operand can be general register +or memory. + + cmove ax,bx ; move when zero flag set + cmovnc eax,[ebx] ; move when carry flag cleared + + "cmpxchg" compares the value in the AL, AX, or EAX register with the +destination operand. If the two values are equal, the source operand is +loaded into the destination operand. Otherwise, the destination operand is +loaded into the AL, AX, or EAX register. The destination operand may be a +general register or memory, the source operand must be a general register. + + cmpxchg dl,bl ; compare and exchange with register + cmpxchg [bx],dx ; compare and exchange with memory + + "cmpxchg8b" compares the 64-bit value in EDX and EAX registers with the +destination operand. If the values are equal, the 64-bit value in ECX and EBX +registers is stored in the destination operand. Otherwise, the value in the +destination operand is loaded into EDX and EAX registers. The destination +operand should be a quad word in memory. + + cmpxchg8b [bx] ; compare and exchange 8 bytes + + +2.1.11 Miscellaneous instructions + +"nop" instruction occupies one byte but affects nothing but the instruction +pointer. This instruction has no operands and doesn't perform any operation. + "ud2" instruction generates an invalid opcode exception. This instruction +is provided for software testing to explicitly generate an invalid opcode. +This is instruction has no operands. + "xlat" replaces a byte in the AL register with a byte indexed by its value +in a translation table addressed by BX or EBX. The operand should be a byte +memory addressed by BX or EBX with any segment prefix. This instruction has +also a short form "xlatb" which has no operands and uses the BX or EBX address +in the segment selected by DS depending on the current code setting. + "lds" transfers a pointer variable from the source operand to DS and the +destination register. The source operand must be a memory operand, and the +destination operand must be a general register. The DS register receives the +segment selector of the pointer while the destination register receives the +offset part of the pointer. "les", "lfs", "lgs" and "lss" operate identically +to "lds" except that rather than DS register the ES, FS, GS and SS is used +respectively. + + lds bx,[si] ; load pointer to ds:bx + + "lea" transfers the offset of the source operand (rather than its value) +to the destination operand. The source operand must be a memory operand, and +the destination operand must be a general register. + + lea dx,[bx+si+1] ; load effective address to dx + + "cpuid" returns processor identification and feature information in the +EAX, EBX, ECX, and EDX registers. The information returned is selected by +entering a value in the EAX register before the instruction is executed. +This instruction has no operands. + "pause" instruction delays the execution of the next instruction an +implementation specific amount of time. It can be used to improve the +performance of spin wait loops. This instruction has no operands. + "enter" creates a stack frame that may be used to implement the scope rules +of block-structured high-level languages. A "leave" instruction at the end of +a procedure complements an "enter" at the beginning of the procedure to +simplify stack management and to control access to variables for nested +procedures. The "enter" instruction includes two parameters. The first +parameter specifies the number of bytes of dynamic storage to be allocated on +the stack for the routine being entered. The second parameter corresponds to +the lexical nesting level of the routine, it can be in range from 0 to 31. +The specified lexical level determines how many sets of stack frame pointers +the CPU copies into the new stack frame from the preceding frame. This list +of stack frame pointers is sometimes called the display. The first word (or +double word when code is 32-bit) of the display is a pointer to the last stack +frame. This pointer enables a "leave" instruction to reverse the action of the +previous "enter" instruction by effectively discarding the last stack frame. +After "enter" creates the new display for a procedure, it allocates the +dynamic storage space for that procedure by decrementing ESP by the number of +bytes specified in the first parameter. To enable a procedure to address its +display, "enter" leaves BP (or EBP) pointing to the beginning of the new stack +frame. If the lexical level is zero, "enter" pushes BP (or EBP), copies SP to +BP (or ESP to EBP) and then subtracts the first operand from ESP. For nesting +levels greater than zero, the processor pushes additional frame pointers on +the stack before adjusting the stack pointer. + + enter 2048,0 ; enter and allocate 2048 bytes on stack + + +2.1.12 System instructions + +"lmsw" loads the operand into the machine status word (bits 0 through 15 of +CR0 register), while "smsw" stores the machine status word into the +destination operand. The operand for both those instructions can be 16-bit +general register or memory, for "smsw" it can also be 32-bit general +register. + + lmsw ax ; load machine status from register + smsw [bx] ; store machine status to memory + + "lgdt" and "lidt" instructions load the values in operand into the global +descriptor table register or the interrupt descriptor table register +respectively. "sgdt" and "sidt" store the contents of the global descriptor +table register or the interrupt descriptor table register in the destination +operand. The operand should be a 6 bytes in memory. + + lgdt [ebx] ; load global descriptor table + + "lldt" loads the operand into the segment selector field of the local +descriptor table register and "sldt" stores the segment selector from the +local descriptor table register in the operand. "ltr" loads the operand into +the segment selector field of the task register and "str" stores the segment +selector from the task register in the operand. Rules for operand are the same +as for the "lmsw" and "smsw" instructions. + "lar" loads the access rights from the segment descriptor specified by +the selector in source operand into the destination operand and sets the ZF +flag. The destination operand can be a 16-bit or 32-bit general register. +The source operand should be a 16-bit general register or memory. + + lar ax,[bx] ; load access rights into word + lar eax,dx ; load access rights into double word + + "lsl" loads the segment limit from the segment descriptor specified by the +selector in source operand into the destination operand and sets the ZF flag. +Rules for operand are the same as for the "lar" instruction. + "verr" and "verw" verify whether the code or data segment specified with +the operand is readable or writable from the current privilege level. The +operand should be a word, it can be general register or memory. If the segment +is accessible and readable (for "verr") or writable (for "verw") the ZF flag +is set, otherwise it's cleared. Rules for operand are the same as for the +"lldt" instruction. + "arpl" compares the RPL (requestor's privilege level) fields of two segment +selectors. The first operand contains one segment selector and the second +operand contains the other. If the RPL field of the destination operand is +less than the RPL field of the source operand, the ZF flag is set and the RPL +field of the destination operand is increased to match that of the source +operand. Otherwise, the ZF flag is cleared and no change is made to the +destination operand. The destination operand can be a word general register +or memory, the source operand must be a general register. + + arpl bx,ax ; adjust RPL of selector in register + arpl [bx],ax ; adjust RPL of selector in memory + + "clts" clears the TS (task switched) flag in the CR0 register. This +instruction has no operands. + "lock" prefix causes the processor's bus-lock signal to be asserted during +execution of the accompanying instruction. In a multiprocessor environment, +the bus-lock signal insures that the processor has exclusive use of any shared +memory while the signal is asserted. The "lock" prefix can be prepended only +to the following instructions and only to those forms of the instructions +where the destination operand is a memory operand: "add", "adc", "and", "btc", +"btr", "bts", "cmpxchg", "cmpxchg8b", "dec", "inc", "neg", "not", "or", "sbb", +"sub", "xor", "xadd" and "xchg". If the "lock" prefix is used with one of +these instructions and the source operand is a memory operand, an undefined +opcode exception may be generated. An undefined opcode exception will also be +generated if the "lock" prefix is used with any instruction not in the above +list. The "xchg" instruction always asserts the bus-lock signal regardless of +the presence or absence of the "lock" prefix. + "hlt" stops instruction execution and places the processor in a halted +state. An enabled interrupt, a debug exception, the BINIT, INIT or the RESET +signal will resume execution. This instruction has no operands. + "invlpg" invalidates (flushes) the TLB (translation lookaside buffer) entry +specified with the operand, which should be a memory. The processor determines +the page that contains that address and flushes the TLB entry for that page. + "rdmsr" loads the contents of a 64-bit MSR (model specific register) of the +address specified in the ECX register into registers EDX and EAX. "wrmsr" +writes the contents of registers EDX and EAX into the 64-bit MSR of the +address specified in the ECX register. "rdtsc" loads the current value of the +processor's time stamp counter from the 64-bit MSR into the EDX and EAX +registers. The processor increments the time stamp counter MSR every clock +cycle and resets it to 0 whenever the processor is reset. "rdpmc" loads the +contents of the 40-bit performance monitoring counter specified in the ECX +register into registers EDX and EAX. These instructions have no operands. + "wbinvd" writes back all modified cache lines in the processor's internal +cache to main memory and invalidates (flushes) the internal caches. The +instruction then issues a special function bus cycle that directs external +caches to also write back modified data and another bus cycle to indicate that +the external caches should be invalidated. This instruction has no operands. + "rsm" return program control from the system management mode to the program +that was interrupted when the processor received an SMM interrupt. This +instruction has no operands. + "sysenter" executes a fast call to a level 0 system procedure, "sysexit" +executes a fast return to level 3 user code. The addresses used by these +instructions are stored in MSRs. These instructions have no operands. + + +2.1.13 FPU instructions + +The FPU (Floating-Point Unit) instructions operate on the floating-point +values in three formats: single precision (32-bit), double precision (64-bit) +and double extended precision (80-bit). The FPU registers form the stack and +each of them holds the double extended precision floating-point value. When +some values are pushed onto the stack or are removed from the top, the FPU +registers are shifted, so ST0 is always the value on the top of FPU stack, ST1 +is the first value below the top, etc. The ST0 name has also the synonym ST. + "fld" pushes the floating-point value onto the FPU register stack. The +operand can be 32-bit, 64-bit or 80-bit memory location or the FPU register, +its value is then loaded onto the top of FPU register stack (the ST0 +register) and is automatically converted into the double extended precision +format. + + fld dword [bx] ; load single prevision value from memory + fld st2 ; push value of st2 onto register stack + + "fld1", "fldz", "fldl2t", "fldl2e", "fldpi", "fldlg2" and "fldln2" load the +commonly used contants onto the FPU register stack. The loaded constants are ++1.0, +0.0, lb 10, lb e, pi, lg 2 and ln 2 respectively. These instructions +have no operands. + "fild" convert the singed integer source operand into double extended +precision floating-point format and pushes the result onto the FPU register +stack. The source operand can be a 16-bit, 32-bit or 64-bit memory location. + + fild qword [bx] ; load 64-bit integer from memory + + "fst" copies the value of ST0 register to the destination operand, which +can be 32-bit or 64-bit memory location or another FPU register. "fstp" +performs the same operation as "fst" and then pops the register stack, +getting rid of ST0. "fstp" accepts the same operands as the "fst" instruction +and can also store value in the 80-bit memory. + + fst st3 ; copy value of st0 into st3 register + fstp tword [bx] ; store value in memory and pop stack + + "fist" converts the value in ST0 to a signed integer and stores the result +in the destination operand. The operand can be 16-bit or 32-bit memory +location. "fistp" performs the same operation and then pops the register +stack, it accepts the same operands as the "fist" instruction and can also +store integer value in the 64-bit memory, so it has the same rules for +operands as "fild" instruction. + "fbld" converts the packed BCD integer into double extended precision +floating-point format and pushes this value onto the FPU stack. "fbstp" +converts the value in ST0 to an 18-digit packed BCD integer, stores the result +in the destination operand, and pops the register stack. The operand should be +an 80-bit memory location. + "fadd" adds the destination and source operand and stores the sum in the +destination location. The destination operand is always an FPU register, if +the source is a memory location, the destination is ST0 register and only +source operand should be specified. If both operands are FPU registers, at +least one of them should be ST0 register. An operand in memory can be a +32-bit or 64-bit value. + + fadd qword [bx] ; add double precision value to st0 + fadd st2,st0 ; add st0 to st2 + + "faddp" adds the destination and source operand, stores the sum in the +destination location and then pops the register stack. The destination operand +must be an FPU register and the source operand must be the ST0. When no +operands are specified, ST1 is used as a destination operand. + + faddp ; add st0 to st1 and pop the stack + faddp st2,st0 ; add st0 to st2 and pop the stack + +"fiadd" instruction converts an integer source operand into double extended +precision floating-point value and adds it to the destination operand. The +operand should be a 16-bit or 32-bit memory location. + + fiadd word [bx] ; add word integer to st0 + + "fsub", "fsubr", "fmul", "fdiv", "fdivr" instruction are similar to "fadd", +have the same rules for operands and differ only in the perfomed computation. +"fsub" substracts the source operand from the destination operand, "fsubr" +substract the destination operand from the source operand, "fmul" multiplies +the destination and source operands, "fdiv" divides the destination operand by +the source operand and "fdivr" divides the source operand by the destination +operand. "fsubp", "fsubrp", "fmulp", "fdivp", "fdivrp" perform the same +operations and pop the register stack, the rules for operand are the same as +for the "faddp" instruction. "fisub", "fisubr", "fimul", "fidiv", "fidivr" +perform these operations after converting the integer source operand into +floating-point value, they have the same rules for operands as "fiadd" +instruction. + "fsqrt" computes the square root of the value in ST0 register, "fsin" +computes the sine of that value, "fcos" computes the cosine of that value, +"fchs" complements its sign bit, "fabs" clears its sign to create the absolute +value, "frndint" rounds it to the nearest integral value, depending on the +current rounding mode. "f2xm1" computes the exponential value of 2 to the +power of ST0 and substracts the 1.0 from it, the value of ST0 must lie in the +range -1.0 to +1.0. All these instruction store the result in ST0 and have no +operands. + "fsincos" computes both the sine and the cosine of the value in ST0 +register, stores the sine in ST0 and pushes the cosine on the top of FPU +register stack. "fptan" computes the tangent of the value in ST0, stores the +result in ST0 and pushes a 1.0 onto the FPU register stack. "fpatan" computes +the arctangent of the value in ST1 divided by the value in ST0, stores the +result in ST1 and pops the FPU register stack. "fyl2x" computes the binary +logarithm of ST0, multiplies it by ST1, stores the result in ST1 and pops the +FPU register stack; "fyl2xp1" performs the same operation but it adds 1.0 to +ST0 before computing the logarithm. "fprem" computes the remainder obtained +from dividing the value in ST0 by the value in ST1, and stores the result +in ST0. "fprem1" performs the same operation as "fprem", but it computes the +remainder in the way specified by IEEE Standard 754. "fscale" truncates the +value in ST1 and increases the exponent of ST0 by this value. "fxtract" +separates the value in ST0 into its exponent and significand, stores the +exponent in ST0 and pushes the significand onto the register stack. "fnop" +performs no operation. These instruction have no operands. + "fxch" exchanges the contents of ST0 an another FPU register. The operand +should be an FPU register, if no operand is specified, the contents of ST0 and +ST1 are exchanged. + "fcom" and "fcomp" compare the contents of ST0 and the source operand and +set flags in the FPU status word according to the results. "fcomp" +additionally pops the register stack after performing the comparison. The +operand can be a single or double precision value in memory or the FPU +register. When no operand is specified, ST1 is used as a source operand. + + fcom ; compare st0 with st1 + fcomp st2 ; compare st0 with st2 and pop stack + + "fcompp" compares the contents of ST0 and ST1, sets flags in the FPU status +word according to the results and pops the register stack twice. This +instruction has no operands. + "fucom", "fucomp" and "fucompp" performs an unordered comparison of two FPU +registers. Rules for operands are the same as for the "fcom", "fcomp" and +"fcompp", but the source operand must be an FPU register. + "ficom" and "ficomp" compare the value in ST0 with an integer source operand +and set the flags in the FPU status word according to the results. "ficomp" +additionally pops the register stack after performing the comparison. The +integer value is converted to double extended precision floating-point format +before the comparison is made. The operand should be a 16-bit or 32-bit +memory location. + + ficom word [bx] ; compare st0 with 16-bit integer + + "fcomi", "fcomip", "fucomi", "fucomip" perform the comparison of ST0 with +another FPU register and set the ZF, PF and CF flags according to the results. +"fcomip" and "fucomip" additionaly pop the register stack after performing the +comparison. The instructions obtained by attaching the FPU condition mnemonic +(see table 2.2) to the "fcmov" mnemonic transfer the specified FPU register +into ST0 register if the fiven test condition is true. These instruction +allow two different syntaxes, one with single operand specifying the source +FPU register, and one with two operands, in that case destination operand +should be ST0 register and the second operand specifies the source FPU +register. + + fcomi st2 ; compare st0 with st2 and set flags + fcmovb st0,st2 ; transfer st2 to st0 if below + + Table 2.2 FPU conditions + ÚÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ¿ + ³ Mnemonic ³ Condition tested ³ Description ³ + ÆÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍ͵ + ³ b ³ CF = 1 ³ below ³ + ³ e ³ ZF = 1 ³ equal ³ + ³ be ³ CF or ZF = 1 ³ below or equal ³ + ³ u ³ PF = 1 ³ unordered ³ + ³ nb ³ CF = 0 ³ not below ³ + ³ ne ³ ZF = 0 ³ not equal ³ + ³ nbe ³ CF and ZF = 0 ³ not below nor equal ³ + ³ nu ³ PF = 0 ³ not unordered ³ + ÀÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÙ + + "ftst" compares the value in ST0 with 0.0 and sets the flags in the FPU +status word according to the results. "fxam" examines the contents of the ST0 +and sets the flags in FPU status word to indicate the class of value in the +register. These instructions have no operands. + "fstsw" and "fnstsw" store the current value of the FPU status word in the +destination location. The destination operand can be either a 16-bit memory or +the AX register. "fstsw" checks for pending umasked FPU exceptions before +storing the status word, "fnstsw" does not. + "fstcw" and "fnstcw" store the current value of the FPU control word at the +specified destination in memory. "fstcw" checks for pending umasked FPU +exceptions before storing the control word, "fnstcw" does not. "fldcw" loads +the operand into the FPU control word. The operand should be a 16-bit memory +location. + "fstenv" and "fnstenv" store the current FPU operating environment at the +memory location specified with the destination operand, and then mask all FPU +exceptions. "fstenv" checks for pending umasked FPU exceptions before +proceeding, "fnstenv" does not. "fldenv" loads the complete operating +environment from memory into the FPU. "fsave" and "fnsave" store the current +FPU state (operating environment and register stack) at the specified +destination in memory and reinitializes the FPU. "fsave" check for pending +unmasked FPU exceptions before proceeding, "fnsave" does not. "frstor" +loads the FPU state from the specified memory location. All these instructions +need an operand being a memory location. + "finit" and "fninit" set the FPU operating environment into its default +state. "finit" checks for pending unmasked FPU exception before proceeding, +"fninit" does not. "fclex" and "fnclex" clear the FPU exception flags in the +FPU status word. "fclex" checks for pending unmasked FPU exception before +proceeding, "fnclex" does not. "wait" and "fwait" are synonyms for the same +instruction, which causes the processor to check for pending unmasked FPU +exceptions and handle them before proceeding. These instruction have no +operands. + "ffree" sets the tag associated with specified FPU register to empty. The +operand should be an FPU register. + "fincstp" and "fdecstp" rotate the FPU stack by one by adding or +substracting one to the pointer of the top of stack. These instruction have no +operands. + + +2.1.14 MMX instructions + +The MMX instructions operate on the packed integer types and use the MMX +registers, which are the low 64-bit parts of the 80-bit FPU registers. Because +of this MMX instructions cannot be used at the same time as FPU instructions. +They can operate on packed bytes (eight 8-bit integers), packed words (four +16-bit integers) or packed double words (two 32-bit integers), use of packed +formats allows to perform operations on multiple data at one time. + "movq" copies a quad word from the source operand to the destination +operand. At least one of the operands must be a MMX register, the second one +can be also a MMX register or 64-bit memory location. + + movq mm0,mm1 ; move quad word from register to register + movq mm2,[ebx] ; move quad word from memory to register + + "movd" copies a double word from the source operand to the destination +operand. One of the operands must be a MMX register, the second one can be a +general register or 32-bit memory location. Only low double word of MMX +register is used. + All general MMX operations have two operands, the destination operand should +be a MMX register, the source operand can be a MMX register or 64-bit memory +location. Operation is performed on the corresponding data elements of the +source and destination operand and stored in the data elements of the +destination operand. "paddb", "paddw" and "paddd" perform the addition of +packed bytes, packed words, or packed double words. "psubb", "psubw" and +"psubd" perform the substraction of appropriate types. "paddsb", "paddsw", +"psubsb" and "psubsw" perform the addition or substraction of packed bytes +or packed words with the signed saturation. "paddusb", "paddusw", "psubusb", +"psubusw" are analoguous, but with unsigned saturation. "pmulhw" and "pmullw" +performs a signed multiply of the packed words and store the high or low words +of the results in the destination operand. "pmaddwd" performs a multiply of +the packed words and adds the four intermediate double word products in pairs +to produce result as a packed double words. "pand", "por" and "pxor" perform +the logical operations on the quad words, "pandn" peforms also a logical +negation of the destination operand before performing the "and" operation. +"pcmpeqb", "pcmpeqw" and "pcmpeqd" compare for equality of packed bytes, +packed words or packed double words. If a pair of data elements is equal, the +corresponding data element in the destination operand is filled with bits of +value 1, otherwise it's set to 0. "pcmpgtb", "pcmpgtw" and "pcmpgtd" perform +the similar operation, but they check whether the data elements in the +destination operand are greater than the correspoding data elements in the +source operand. "packsswb" converts packed signed words into packed signed +bytes, "packssdw" converts packed signed double words into packed signed +words, using saturation to handle overflow conditions. "packuswb" converts +packed signed words into packed unsigned bytes. Converted data elements from +the source operand are stored in the low part of the destination operand, +while converted data elements from the destination operand are stored in the +high part. "punpckhbw", "punpckhwd" and "punpckhdq" interleaves the data +elements from the high parts of the source and destination operands and +stores the result into the destination operand. "punpcklbw", "punpcklwd" and +"punpckldq" perform the same operation, but the low parts of the source and +destination operand are used. + + paddsb mm0,[esi] ; add packed bytes with signed saturation + pcmpeqw mm3,mm7 ; compare packed words for equality + + "psllw", "pslld" and "psllq" perform logical shift left of the packed words, +packed double words or a single quad word in the destination operand by the +amount specified in the source operand. "psrlw", "psrld" and "psrlq" perform +logical shift right of the packed words, packed double words or a single quad +word. "psraw" and "psrad" perform arithmetic shift of the packed words or +double words. The destination operand should be a MMX register, while source +operand can be a MMX register, 64-bit memory location, or 8-bit immediate +value. + + psllw mm2,mm4 ; shift words left logically + psrad mm4,[ebx] ; shift double words right arithmetically + + "emms" makes the FPU registers usable for the FPU instructions, it must be +used before using the FPU instructions if any MMX instructions were used. + + +2.1.15 SSE instructions + +The SSE extension adds more MMX instructions and also introduces the +operations on packed single precision floating point values. The 128-bit +packed single precision format consists of four single precision floating +point values. The 128-bit SSE registers are designed for the purpose of +operations on this data type. + "movaps" and "movups" transfer a double quad word operand containing packed +single precision values from source operand to destination operand. At least +one of the operands have to be a SSE register, the second one can be also a +SSE register or 128-bit memory location. Memory operands for "movaps" +instruction must be aligned on boundary of 16 bytes, operands for "movups" +instruction don't have to be aligned. + + movups xmm0,[ebx] ; move unaligned double quad word + + "movlps" moves packed two single precision values between the memory and the +low quad word of SSE register. "movhps" moved packed two single precision +values between the memory and the high quad word of SSE register. One of the +operands must be a SSE register, and the other operand must be a 64-bit memory +location. + + movlps xmm0,[ebx] ; move memory to low quad word of xmm0 + movhps [esi],xmm7 ; move high quad word of xmm7 to memory + + "movlhps" moves packed two single precision values from the low quad word +of source register to the high quad word of destination register. "movhlps" +moves two packed single precision values from the high quad word of source +register to the low quad word of destination register. Both operands have to +be a SSE registers. + "movmskps" transfers the most significant bit of each of the four single +precision values in the SSE register into low four bits of a general register. +The source operand must be a SSE register, the destination operand must be a +general register. + "movss" transfers a single precision value between source and destination +operand (only the low double word is trasferred). At least one of the operands +have to be a SSE register, the second one can be also a SSE register or 32-bit +memory location. + + movss [edi],xmm3 ; move low double word of xmm3 to memory + + Each of the SSE arithmetic operations has two variants. When the mnemonic +ends with "ps", the source operand can be a 128-bit memory location or a SSE +register, the destination operand must be a SSE register and the operation is +performed on packed four single precision values, for each pair of the +corresponding data elements separately, the result is stored in the +destination register. When the mnemonic ends with "ss", the source operand +can be a 32-bit memory location or a SSE register, the destination operand +must be a SSE register and the operation is performed on single precision +values, only low double words of SSE registers are used in this case, the +result is stored in the low double word of destination register. "addps" and +"addss" add the values, "subps" and "subss" substract the source value from +destination value, "mulps" and "mulss" multiply the values, "divps" and +"divss" divide the destination value by the source value, "rcpps" and "rcpss" +compute the approximate reciprocal of the source value, "sqrtps" and "sqrtss" +compute the square root of the source value, "rsqrtps" and "rsqrtss" compute +the approximate reciprocal of square root of the source value, "maxps" and +"maxss" compare the source and destination values and return the greater one, +"minps" and "minss" compare the source and destination values and return the +lesser one. + + mulss xmm0,[ebx] ; multiply single precision values + addps xmm3,xmm7 ; add packed single precision values + + "andps", "andnps", "orps" and "xorps" perform the logical operations on +packed single precision values. The source operand can be a 128-bit memory +location or a SSE register, the destination operand must be a SSE register. + "cmpps" compares packed single precision values and returns a mask result +into the destination operand, which must be a SSE register. The source operand +can be a 128-bit memory location or SSE register, the third operand must be an +immediate operand selecting code of one of the eight compare conditions +(table 2.3). "cmpss" performs the same operation on single precision values, +only low double word of destination register is affected, in this case source +operand can be a 32-bit memory location or SSE register. These two +instructions have also variants with only two operands and the condition +encoded within mnemonic. Their mnemonics are obtained by attaching the +mnemonic from table 2.3 to the "cmp" mnemonic and then attaching the "ps" or +"ss" at the end. + + cmpps xmm2,xmm4,0 ; compare packed single precision values + cmpltss xmm0,[ebx] ; compare single precision values + + Table 2.3 SSE conditions + ÚÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄ¿ + ³ Code ³ Mnemonic ³ Description ³ + ÆÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍØÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍ͵ + ³ 0 ³ eq ³ equal ³ + ³ 1 ³ lt ³ less than ³ + ³ 2 ³ le ³ less than or equal ³ + ³ 3 ³ unord ³ unordered ³ + ³ 4 ³ neq ³ not equal ³ + ³ 5 ³ nlt ³ not less than ³ + ³ 6 ³ nle ³ not less than nor equal ³ + ³ 7 ³ ord ³ ordered ³ + ÀÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÁÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÙ + + "comiss" and "ucomiss" compare the single precision values and set the ZF, +PF and CF flags to show the result. The destination operand must be a SSE +register, the source operand can be a 32-bit memory location or SSE register. + "shufps" moves any two of the four single precision values from the +destination operand into the low quad word of the destination operand, and any +two of the four values from the source operand into the high quad word of the +destination operand. The destination operand must be a SSE register, the +source operand can be a 128-bit memory location or SSE register, the third +operand must be an 8-bit immediate value selecting which values will be moved +into the destination operand. Bits 0 and 1 select the value to be moved from +destination operand to the low double word of the result, bits 2 and 3 select +the value to be moved from the destination operand to the second double word, +bits 4 and 5 select the value to be moved from the source operand to the third +double word, and bits 6 and 7 select the value to be moved from the source +operand to the high double word of the result. + + shufps xmm0,xmm0,10010011b ; shuffle double words + + "unpckhps" performs an interleaved unpack of the values from the high parts +of the source and destination operands and stores the result in the +destination operand, which must be a SSE register. The source operand can be +a 128-bit memory location or a SSE register. "unpcklps" performs an +interleaved unpack of the values from the low parts of the source and +destination operand and stores the result in the destination operand, +the rules for operands are the same. + "cvtpi2ps" converts packed two double word integers into the the packed two +single precision floating point values and stores the result in the low quad +word of the destination operand, which should be a SSE register. The source +operand can be a 64-bit memory location or MMX register. + + cvtpi2ps xmm0,mm0 ; convert integers to single precision values + + "cvtsi2ss" converts a double word integer into a single precision floating +point value and stores the result in the low double word of the destination +operand, which should be a SSE register. The source operand can be a 32-bit +memory location or 32-bit general register. + + cvtsi2ss xmm0,eax ; convert integer to single precision value + + "cvtps2pi" converts packed two single precision floating point values into +packed two double word integers and stores the result in the destination +operand, which should be a MMX register. The source operand can be a 64-bit +memory location or SSE register, only low quad word of SSE register is used. +"cvttps2pi" performs the similar operation, except that truncation is used to +round a source values to integers, rules for the operands are the same. + + cvtps2pi mm0,xmm0 ; convert single precision values to integers + + "cvtss2si" convert a single precision floating point value into a double +word integer and stores the result in the destination operand, which should be +a 32-bit general register. The source operand can be a 32-bit memory location +or SSE register, only low double word of SSE register is used. "cvttss2si" +performs the similar operation, except that truncation is used to round a +source value to integer, rules for the operands are the same. + + cvtss2si eax,xmm0 ; convert single precision value to integer + + "pextrw" copies the word in the source operand specified by the third +operand to the destination operand. The source operand must be a MMX register, +the destination operand must be a 32-bit general register (but only the low +word of it is affected), the third operand must an 8-bit immediate value. + + pextrw eax,mm0,1 ; extract word into eax + + "pinsrw" inserts a word from the source operand in the destination operand +at the location specified with the third operand, which must be an 8-bit +immediate value. The destination operand must be a MMX register, the source +operand can be a 16-bit memory location or 32-bit general register (only low +word of the register is used). + + pinsrw mm1,ebx,2 ; insert word from ebx + + "pavgb" and "pavgw" compute average of packed bytes or words. "pmaxub" +return the maximum values of packed unsigned bytes, "pminub" returns the +minimum values of packed unsigned bytes, "pmaxsw" returns the maximum values +of packed signed words, "pminsw" returns the minimum values of packed signed +words. "pmulhuw" performs a unsigned multiply of the packed words and stores +the high words of the results in the destination operand. "psadbw" computes +the absolute differences of packed unsigned bytes, sums the differences, and +stores the sum in the low word of destination operand. All these instructions +follow the same rules for operands as the general MMX operations described in +previous section. + "pmovmskb" creates a mask made of the most significant bit of each byte in +the source operand and stores the result in the low byte of destination +operand. The source operand must be a MMX register, the destination operand +must a 32-bit general register. + "pshufw" inserts words from the source operand in the destination operand +from the locations specified with the third operand. The destination operand +must be a MMX register, the source operand can be a 64-bit memory location or +MMX register, third operand must an 8-bit immediate value selecting which +values will be moved into destination operand, in the similar way as the third +operand of the "shufps" instruction. + "movntq" moves the quad word from the source operand to memory using a +non-temporal hint to minimize cache pollution. The source operand should be a +MMX register, the destination operand should be a 64-bit memory location. +"movntps" stores packed single precision values from the SSE register to +memory using a non-temporal hint. The source operand should be a SSE register, +the destination operand should be a 128-bit memory location. "maskmovq" stores +selected bytes from the first operand into a 64-bit memory location using a +non-temporal hint. Both operands should be a MMX registers, the second operand +selects wich bytes from the source operand are written to memory. The +memory location is pointed by DI (or EDI) register in the segment selected +by DS. + "prefetcht0", "prefetcht1", "prefetcht2" and "prefetchnta" fetch the line +of data from memory that contains byte specified with the operand to a +specified location in hierarchy. The operand should be an 8-bit memory +location. + "sfence" performs a serializing operation on all instruction storing to +memory that were issued prior to it. This instruction has no operands. + "ldmxcsr" loads the 32-bit memory operand into the MXCSR register. "stmxcsr" +stores the contents of MXCSR into a 32-bit memory operand. + "fxsave" saves the current state of the FPU, MXCSR register, and all the FPU +and SSE registers to a 512-byte memory location specified in the destination +operand. "fxrstor" reloads data previously stored with "fxsave" instruction +from the specified 512-byte memory location. The memory operand for both those +instructions must be aligned on 16 byte boundary, it should declare operand +of no specified size. + + +2.1.16 SSE2 instructions + +The SSE2 extension introduces the operations on packed double precision +floating point values, extends the syntax of MMX instructions, and adds also +some new instructions. + "movapd" and "movupd" transfer a double quad word operand containing packed +double precision values from source operand to destination operand. These +instructions are analogous to "movaps" and "movups" and have the same rules +for operands. + "movlpd" moves double precision value between the memory and the low quad +word of SSE register. "movhpd" moved double precision value between the memory +and the high quad word of SSE register. These instructions are analogous to +"movlps" and "movhps" and have the same rules for operands. + "movmskpd" transfers the most significant bit of each of the two double +precision values in the SSE register into low two bits of a general register. +This instruction is analogous to "movmskps" and has the same rules for +operands. + "movsd" transfers a double precision value between source and destination +operand (only the low quad word is trasferred). At least one of the operands +have to be a SSE register, the second one can be also a SSE register or 64-bit +memory location. + Arithmetic operations on double precision values are: "addpd", "addsd", +"subpd", "subsd", "mulpd", "mulsd", "divpd", "divsd", "sqrtpd", "sqrtsd", +"maxpd", "maxsd", "minpd", "minsd", and they are analoguous to arithmetic +operations on single precision values described in previous section. When the +mnemonic ends with "pd" instead of "ps", the operation is performed on packed +two double precision values, but rules for operands are the same. When the +mnemonic ends with "sd" instead of "ss", the source operand can be a 64-bit +memory location or a SSE register, the destination operand must be a SSE +register and the operation is performed on double precision values, only low +quad words of SSE registers are used in this case. + "andpd", "andnpd", "orpd" and "xorpd" perform the logical operations on +packed double precision values. They are analoguous to SSE logical operations +on single prevision values and have the same rules for operands. + "cmppd" compares packed double precision values and returns and returns a +mask result into the destination operand. This instruction is analoguous to +"cmpps" and has the same rules for operands. "cmpsd" performs the same +operation on double precision values, only low quad word of destination +register is affected, in this case source operand can be a 64-bit memory or +SSE register. Variant with only two operands are obtained by attaching the +condition mnemonic from table 2.3 to the "cmp" mnemonic and then attaching +the "pd" or "sd" at the end. + "comisd" and "ucomisd" compare the double precision values and set the ZF, +PF and CF flags to show the result. The destination operand must be a SSE +register, the source operand can be a 128-bit memory location or SSE register. + "shufpd" moves any of the two double precision values from the destination +operand into the low quad word of the destination operand, and any of the two +values from the source operand into the high quad word of the destination +operand. This instruction is analoguous to "shufps" and has the same rules for +operand. Bit 0 of the third operand selects the value to be moved from the +destination operand, bit 1 selects the value to be moved from the source +operand, the rest of bits are reserved and must be zeroed. + "unpckhpd" performs an unpack of the high quad words from the source and +destination operands, "unpcklpd" performs an unpack of the low quad words from +the source and destination operands. They are analoguous to "unpckhps" and +"unpcklps", and have the same rules for operands. + "cvtps2pd" converts the packed two single precision floating point values to +two packed double precision floating point values, the destination operand +must be a SSE register, the source operand can be a 64-bit memory location or +SSE register. "cvtpd2ps" converts the packed two double precision floating +point values to packed two single precision floating point values, the +destination operand must be a SSE register, the source operand can be a +128-bit memory location or SSE register. "cvtss2sd" converts the single +precision floating point value to double precision floating point value, the +destination operand must be a SSE register, the source operand can be a 32-bit +memory location or SSE register. "cvtsd2ss" converts the double precision +floating point value to single precision floating point value, the destination +operand must be a SSE register, the source operand can be 64-bit memory +location or SSE register. + "cvtpi2pd" converts packed two double word integers into the the packed +double precision floating point values, the destination operand must be a SSE +register, the source operand can be a 64-bit memory location or MMX register. +"cvtsi2sd" converts a double word integer into a double precision floating +point value, the destination operand must be a SSE register, the source +operand can be a 32-bit memory location or 32-bit general register. "cvtpd2pi" +converts packed double precision floating point values into packed two double +word integers, the destination operand should be a MMX register, the source +operand can be a 128-bit memory location or SSE register. "cvttpd2pi" performs +the similar operation, except that truncation is used to round a source values +to integers, rules for operands are the same. "cvtsd2si" converts a double +precision floating point value into a double word integer, the destination +operand should be a 32-bit general register, the source operand can be a +64-bit memory location or SSE register. "cvttsd2si" performs the similar +operation, except that truncation is used to round a source value to integer, +rules for operands are the same. + "cvtps2dq" and "cvttps2dq" convert packed single precision floating point +values to packed four double word integers, storing them in the destination +operand. "cvtpd2dq" and "cvttpd2dq" convert packed double precision floating +point values to packed two double word integers, storing the result in the low +quad word of the destination operand. "cvtdq2ps" converts packed four +double word integers to packed single precision floating point values. +"cvtdq2pd" converts packed two double word integers from the low quad word +of the source operand to packed double precision floating point values. +For all these instruction destination operand must be a SSE register, the +source operand can be a 128-bit memory location or SSE register. + "movdqa" and "movdqu" transfer a double quad word operand containing packed +integers from source operand to destination operand. At least one of the +operands have to be a SSE register, the second one can be also a SSE register +or 128-bit memory location. Memory operands for "movdqa" instruction must be +aligned on boundary of 16 bytes, operands for "movdqu" instruction don't have +to be aligned. + "movq2dq" moves the contents of the MMX source register to the low quad word +of destination SSE register. "movdq2q" moves the low quad word from the source +SSE register to the destination MMX register. + + movq2dq xmm0,mm1 ; move from MMX register to SSE register + movdq2q mm0,xmm1 ; move from SSE register to MMX register + + All MMX instructions operating on the 64-bit packed integers (those with +mnemonics starting with "p") are extended to operate on 128-bit packed +integers located in SSE registers. Additional syntax for these instructions +needs an SSE register where MMX register was needed, and the 128-bit memory +location or SSE register where 64-bit memory location of MMX register were +needed. The exception is "pshufw" instruction, which doesn't allow extended +syntax, but has two new variants: "pshufhw" and "pshuflw", which allow only +the extended syntax, and perform the same operation as "pshufw" on the high +or low quad words of operands respectively. Also the new instruction "pshufd" +is introduced, which performs the same operation as "pshufw", but on the +double words instead of words, it allows only the extended syntax. + + psubb xmm0,[esi] ; substract 16 packed bytes + pextrw eax,xmm0,7 ; extract highest word into eax + + "paddq" performs the addition of packed quad words, "psubq" performs the +substraction of packed quad words, "pmuludq" performs an unsigned multiply +of low double words from each corresponding quad words and returns the results +in packed quad words. These instructions follow the same rules for operands as +the general MMX operations described in 2.1.14. + "pslldq" and "psrldq" perform logical shift left or right of the double +quad word in the destination operand by the amount of bits specified in the +source operand. The destination operand should be a SSE register, source +operand should be an 8-bit immediate value. + "punpckhqdq" interleaves the high quad word of the source operand and the +high quad word of the destination operand and writes them to the destination +SSE register. "punpcklqdq" interleaves the low quad word of the source operand +and the low quad word of the destination operand and writes them to the +destination SSE register. The source operand can be a 128-bit memory location +or SSE register. + "movntdq" stores packed integer data from the SSE register to memory using +non-temporal hint. The source operand should be a SSE register, the +destination operand should be a 128-bit memory location. "movntpd" stores +packed double precision values from the SSE register to memory using a +non-temporal hint. Rules for operand are the same. "movnti" stores integer +from a general register to memory using a non-temporal hint. The source +operand should be a 32-bit general register, the destination operand should +be a 32-bit memory location. "maskmovdqu" stores selected bytes from the first +operand into a 128-bit memory location using a non-temporal hint. Both +operands should be a SSE registers, the second operand selects wich bytes from +the source operand are written to memory. The memory location is pointed by DI +(or EDI) register in the segment selected by DS and does not need to be +aligned. + "clflush" writes and invalidates the cache line associated with the address +of byte specified with the operand, which should be a 8-bit memory location. + "lfence" performs a serializing operation on all instruction loading from +memory that were issued prior to it. "mfence" performs a serializing operation +on all instruction accesing memory that were issued prior to it, and so it +combines the functions of "sfence" (described in previous section) and +"lfence" instructions. These instructions have no operands. + + +2.1.17 SSE3 instructions + +Prescott technology introduced some new instructions to improve the performance +of SSE and SSE2 - this extension is called SSE3. + "fisttp" behaves like the "fistp" instruction and accepts the same operands, +the only difference is that it always used truncation, irrespective of the +rounding mode. + "movshdup" loads into destination operand the 128-bit value obtained from +the source value of the same size by filling the each quad word with the two +duplicates of the value in its high double word. "movsldup" performs the same +action, except it duplicates the values of low double words. The destination +operand should be SSE register, the source operand can be SSE register or +128-bit memory location. + "movddup" loads the 64-bit source value and duplicates it into high and low +quad word of the destination operand. The destination operand should be SSE +register, the source operand can be SSE register or 64-bit memory location. + "lddqu" is functionally equivalent to "movdqu" instruction with memory as +source operand, but it may improve performance when the source operand crosses +a cacheline boundary. The destination operand has to be SSE register, the +source operand must be 128-bit memory location. + "addsubps" performs single precision addition of second and fourth pairs and +single precision substracion of the first and third pairs of floating point +values in the operands. "addsubpd" performs double precision addition of the +second pair and double precision substraction of the first pair of floating +point values in the operand. "haddps" performs the addition of two single +precision values within the each quad word of source and destination operands, +and stores the results of such horizontal addition of values from destination +operand into low quad word of destination operand, and the results from the +source operand into high quad word of destination operand. "haddpd" performs +the addition of two double precision values within each operand, and stores +the result from destination operand into low quad word of destination operand, +and the result from source operand into high quad word of destination operand. +All these instruction need the destination operand to be SSE register, source +operand can be SSE register or 128-bit memory location. + "monitor" sets up an address range for monitoring of write-back stores. It +need its three operands to be EAX, ECX and EDX register in that order. "mwait" +waits for a write-back store to the address range set up by the "monitor" +instruction. It uses two operands with additional parameters, first being the +EAX and second the ECX register. + + +2.1.18 AMD 3DNow! instructions + +The 3DNow! extension adds a new MMX instructions to those described in 2.1.14, +and introduces operation on the 64-bit packed floating point values, each +consisting of two single precision floating point values. + These instructions follow the same rules as the general MMX operations, the +destination operand should be a MMX register, the source operand can be a MMX +register or 64-bit memory location. "pavgusb" computes the rounded averages +of packed unsigned bytes. "pmulhrw" performs a signed multiply of the packed +words, round the high word of each double word results and stores them in the +destination operand. "pi2fd" converts packed double word integers into +packed floating point values. "pf2id" converts packed floating point values +into packed double word integers using truncation. "pi2fw" converts packed +word integers into packed floating point values, only low words of each +double word in source operand are used. "pf2iw" converts packed floating +point values to packed word integers, results are extended to double words +using the sign extension. "pfadd" adds packed floating point values. "pfsub" +and "pfsubr" substracts packed floating point values, the first one substracts +source values from destination values, the second one substracts destination +values from the source values. "pfmul" multiplies packed floating point +values. "pfacc" adds the low and high floating point values of the destination +operand, storing the result in the low double word of destination, and adds +the low and high floating point values of the source operand, storing the +result in the high double word of destination. "pfnacc" substracts the high +floating point value of the destination operand from the low, storing the +result in the low double word of destination, and substracts the high floating +point value of the source operand from the low, storing the result in the high +double word of destination. "pfpnacc" substracts the high floating point value +of the destination operand from the low, storing the result in the low double +word of destination, and adds the low and high floating point values of the +source operand, storing the result in the high double word of destination. +"pfmax" and "pfmin" compute the maximum and minimum of floating point values. +"pswapd" reverses the high and low double word of the source operand. "pfrcp" +returns an estimates of the reciprocals of floating point values from the +source operand, "pfrsqrt" returns an estimates of the reciprocal square +roots of floating point values from the source operand, "pfrcpit1" performs +the first step in the Newton-Raphson iteration to refine the reciprocal +approximation produced by "pfrcp" instruction, "pfrsqit1" performs the first +step in the Newton-Raphson iteration to refine the reciprocal square root +approximation produced by "pfrsqrt" instruction, "pfrcpit2" performs the +second final step in the Newton-Raphson iteration to refine the reciprocal +approximation or the reciprocal square root approximation. "pfcmpeq", +"pfcmpge" and "pfcmpgt" compare the packed floating point values and sets +all bits or zeroes all bits of the correspoding data element in the +destination operand according to the result of comparison, first checks +whether values are equal, second checks whether destination value is greater +or equal to source value, third checks whether destination value is greater +than source value. + "prefetch" and "prefetchw" load the line of data from memory that contains +byte specified with the operand into the data cache, "prefetchw" instruction +should be used when the data in the cache line is expected to be modified, +otherwise the "prefetch" instruction should be used. The operand should be an +8-bit memory location. + "femms" performs a fast clear of MMX state. This instruction has no +operands. + + +2.1.19 The x86-64 long mode instructions + +The AMD64 and EM64T architectures (we will use the common name x86-64 for them +both) extend the x86 instruction set for the 64-bit processing. While legacy +and compatibility modes use the same set of registers and instructions, the +new long mode extends the x86 operations to 64 bits and introduces several new +registers. You can turn on generating the code for this mode with the "use64" +directive. + Each of the general purpose registers is extended to 64 bits and the eight +whole new general purpose registers and also eight new SSE registers are added. +See table 2.4 for the summary of new registers (only the ones that was not +listed in table 1.2). The general purpose registers of smallers sizes are the +low order portions of the larger ones. You can still access the "ah", "bh", +"ch" and "dh" registers in long mode, but you cannot use them in the same +instruction with any of the new registers. + + Table 2.4 New registers in long mode + ÚÄÄÄÄÄÄÂÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÂÄÄÄÄÄÄÄ¿ + ³ Type ³ General ³ SSE ³ + ÃÄÄÄÄÄÄÅÄÄÄÄÄÄÂÄÄÄÄÄÄÂÄÄÄÄÄÄÂÄÄÄÄÄÄÅÄÄÄÄÄÄÄ´ + ³ Bits ³ 8 ³ 16 ³ 32 ³ 64 ³ 128 ³ + ÆÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍØÍÍÍÍÍÍ͵ + ³ ³ ³ ³ ³ rax ³ ³ + ³ ³ ³ ³ ³ rcx ³ ³ + ³ ³ ³ ³ ³ rdx ³ ³ + ³ ³ ³ ³ ³ rbx ³ ³ + ³ ³ spl ³ ³ ³ rsp ³ ³ + ³ ³ bpl ³ ³ ³ rbp ³ ³ + ³ ³ sil ³ ³ ³ rsi ³ ³ + ³ ³ dil ³ ³ ³ rdi ³ ³ + ³ ³ r8b ³ r8w ³ r8d ³ r8 ³ xmm8 ³ + ³ ³ r9b ³ r9w ³ r9d ³ r9 ³ xmm9 ³ + ³ ³ r10b ³ r10w ³ r10d ³ r10 ³ xmm10 ³ + ³ ³ r11b ³ r11w ³ r11d ³ r11 ³ xmm11 ³ + ³ ³ r12b ³ r12w ³ r12d ³ r12 ³ xmm12 ³ + ³ ³ r13b ³ r13w ³ r13d ³ r13 ³ xmm13 ³ + ³ ³ r14b ³ r14w ³ r14d ³ r14 ³ xmm14 ³ + ³ ³ r15b ³ r15w ³ r15d ³ r15 ³ xmm15 ³ + ÀÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÁÄÄÄÄÄÄÄÙ + + In general any instruction from x86 architecture, which allowed 16-bit or +32-bit operand sizes, in long mode allows also the 64-bit operands. The 64-bit +registers should be used for addressing in long mode, the 32-bit addressing +is also allowed, but it's not possible to use the addresses based on 16-bit +registers. Below are the samples of new operations possible in long mode on the +example of "mov" instruction: + + mov rax,r8 ; transfer 64-bit general register + mov al,[rbx] ; transfer memory addressed by 64-bit register + +The long mode uses also the instruction pointer based addresses, you can +specify it manually with the special RIP register symbol, but such addressing +is also automatically generated by flat assembler, since there is no 64-bit +absolute addressing in long mode. You can still force the assembler to use the +32-bit absolute addressing by putting the "dword" size override for address +inside the square brackets. There is also one exception, where the 64-bit +absolute addressing is possible, it's the "mov" instruction with one of the +operand being accumulator register, and second being the memory operand. +To force the assembler to use the 64-bit absolute addressing there, use the +"qword" size operator for address inside the square brackets. When no size +operator is applied to address, assembler generates the optimal form +automatically. + + mov [qword 0],rax ; absolute 64-bit addressing + mov [dword 0],r15d ; absolute 32-bit addressing + mov [0],rsi ; automatic RIP-relative addressing + mov [rip+3],sil ; manual RIP-relative addressing + + Also as the immediate operands for 64-bit operations only the signed 32-bit +values are possible, with the only exception being the "mov" instruction with +destination operand being 64-bit general purpose register. Trying to force the +64-bit immediate with any other instruction will cause an error. + If any operation is performed on the 32-bit general registers in long mode, +the upper 32 bits of the 64-bit registers containing them are filled with +zeros. This is unlike the operations on 16-bit or 8-bit portions of those +registers, which preserve the upper bits. + Three new type conversion instructions are available. The "cdqe" sign extends +the double word in EAX into quad word and stores the result in RAX register. +"cqo" sign extends the quad word in RAX into double quad word and stores the +extra bits in the RDX register. These instructions have no operands. "movsxd" +sign extends the double word source operand, being either the 32-bit register +or memory, into 64-bit destination operand, which has to be register. +No analogous instruction is needed for the zero extension, since it is done +automatically by any operations on 32-bit registers, as noted in previous +paragraph. And the "movzx" and "movsx" instructions, conforming to the general +rule, can be used with 64-bit destination operand, allowing extension of byte +or word values into quad words. + All the binary arithmetic and logical instruction are promoted to allow +64-bit operands in long mode. The use of decimal arithmetic instructions in +long mode is prohibited. + The stack operations, like "push" and "pop" in long mode default to 64-bit +operands and it's not possible to use 32-bit operands with them. The "pusha" +and "popa" are disallowed in long mode. + The indirect near jumps and calls in long mode default to 64-bit operands and +it's not possible to use the 32-bit operands with them. On the other hand, the +indirect far jumps and calls allow any operands that were allowed by the x86 +architecture and also 80-bit memory operand is allowed (though only EM64T seems +to implement such variant), with the first eight bytes defining the offset and +two last bytes specifying the selector. The direct far jumps and calls are not +allowed in long mode. + The I/O instructions, "in", "out", "ins" and "outs" are the exceptional +instructions that are not extended to accept quad word operands in long mode. +But all other string operations are, and there are new short forms "movsq", +"cmpsq", "scasq", "lodsq" and "stosq" introduced for the variants of string +operations for 64-bit string elements. The RSI and RDI registers are used by +default to address the string elements. + The "lfs", "lgs" and "lss" instructions are extended to accept 80-bit source +memory operand with 64-bit destination register (though only EM64T seems to +implement such variant). The "lds" and "les" are disallowed in long mode. + The system instructions like "lgdt" which required the 48-bit memory operand, +in long mode require the 80-bit memory operand. + The "cmpxchg16b" is the 64-bit equivalent of "cmpxchg8b" instruction, it uses +the double quad word memory operand and 64-bit registers to perform the +analoguous operation. + "swapgs" is the new instruction, which swaps the contents of GS register and +the KernelGSbase model-specific register (MSR address 0C0000102h). + "syscall" and "sysret" is the pair of new instructions that provide the +functionality similar to "sysenter" and "sysexit" in long mode, where the +latter pair is disallowed. + + +2.2 Control directives + +This section describes the directives that control the assembly process, they +are processed during the assembly and may cause some blocks of instructions +to be assembled differently or not assembled at all. + + +2.2.1 Numerical constants + +The "=" directive allows to define the numerical constant. It should be +preceded by the name for the constant and followed by the numerical expression +providing the value. The value of such constants can be a number or an address, +but - unlike labels - the numerical constants are not allowed to hold the +register-based addresses. Besides this difference, in their basic variant +numerical constants behave very much like labels and you can even +forward-reference them (access their values before they actually get defined). + There is, however, a second variant of numerical constants, which is +recognized by assembler when you try to define the constant of name, under +which there already was a numerical constant defined. In such case assembler +treats that constant as an assembly-time variable and allows it to be assigned +with new value, but forbids forward-referencing it (for obvious reasons). Let's +see both the variant of numerical constants in one example: + + dd sum + x = 1 + x = x+2 + sum = x + +Here the "x" is an assembly-time variable, and every time it is accessed, the +value that was assigned to it the most recently is used. Thus if we tried to +access the "x" before it gets defined the first time, like if we wrote "dd x" +in place of the "dd sum" instruction, it would cause an error. And when it is +re-defined with the "x = x+2" directive, the previous value of "x" is used to +calculate the new one. So when the "sum" constant gets defined, the "x" has +value of 3, and this value is assigned to the "sum". Since this one is defined +only once in source, it is the standard numerical constant, and can be +forward-referenced. So the "dd sum" is assembled as "dd 3". To read more about +how the assembler is able to resolve this, see section 2.2.6. + The value of numerical constant can be preceded by size operator, which can +ensure that the value will fit in the range for the specified size, and can +affect also how some of the calculations inside the numerical expression are +performed. This example: + + c8 = byte -1 + c32 = dword -1 + +defines two different constants, the first one fits in 8 bits, the second one +fits in 32 bits. + When you need to define constant with the value of address, which may be +register-based (and thus you cannot employ numerical constant for this +purpose), you can use the extended syntax of "label" directive (already +described in section 1.2.3), like: + + label myaddr at ebp+4 + +which declares label placed at "ebp+4" address. However remember that labels, +unlike numerical constants, cannot become assembly-time variables. + + +2.2.2 Conditional assembly + +"if" directive causes come block of instructions to be assembled only under +certain condition. It should be followed by logical expression specifying the +condition, instructions in next lines will be assembled only when this +condition is met, otherwise they will be skipped. The optional "else if" +directive followed with logical expression specifying additional condition +begins the next block of instructions that will be assembled if previous +conditions were not met, and the additional condition is met. The optional +"else" directive begins the block of instructions that will be assembled if +all the conditions were not met. The "end if" directive ends the last block of +instructions. + You should note that "if" directive is processed at assembly stage and +therefore it doesn't affect any preprocessor directives, like the definitions +of symbolic constants and macroinstructions - when the assembler recognizes the +"if" directive, all the preprocessing has been already finished. + The logical expression consist of logical values and logical operators. The +logical operators are "~" for logical negation, "&" for logical and, "|" for +logical or. The negation has the highest priority. Logical value can be a +numerical expression, it will be false if it is equal to zero, otherwise it +will be true. Two numerical expression can be compared using one of the +following operators to make the logical value: "=" (equal), "<" (less), +">" (greater), "<=" (less or equal), ">=" (greater or equal), +"<>" (not equal). + The "used" operator followed by a symbol name, is the logical value that +checks whether the given symbol is used somewhere (it returns correct result +even if symbol is used only after this check). The "defined" operator can be +followed by any expression, usually just by a single symbol name; it checks +whether the given expression contains only symbols that are defined in the +source and accessible from the current position. + The following simple example uses the "count" constant that should be +defined somewhere in source: + + if count>0 + mov cx,count + rep movsb + end if + +These two assembly instructions will be assembled only if the "count" constant +is greater than 0. The next sample shows more complex conditional structure: + + if count & ~ count mod 4 + mov cx,count/4 + rep movsd + else if count>4 + mov cx,count/4 + rep movsd + mov cx,count mod 4 + rep movsb + else + mov cx,count + rep movsb + end if + +The first block of instructions gets assembled when the "count" is non zero and +divisible by four, if this condition is not met, the second logical expression, +which follows the "else if", is evaluated and if it's true, the second block +of instructions get assembled, otherwise the last block of instructions, which +follows the line containing only "else", is assembled. + There are also operators that allow comparison of values being any chains of +symbols. The "eq" compares two such values whether they are exactly the same. +The "in" operator checks whether given value is a member of the list of values +following this operator, the list should be enclosed between "<" and ">" +characters, its members should be separated with commas. The symbols are +considered the same when they have the same meaning for the assembler - for +example "pword" and "fword" for assembler are the same and thus are not +distinguished by the above operators. In the same way "16 eq 10h" is the true +condition, however "16 eq 10+4" is not. + The "eqtype" operator checks whether the two compared values have the same +structure, and whether the structural elements are of the same type. The +distinguished types include numerical expressions, individual quoted strings, +floating point numbers, address expressions (the expressions enclosed in square +brackets or preceded by "ptr" operator), instruction mnemonics, registers, size +operators, jump type and code type operators. And each of the special +characters that act as a separators, like comma or colon, is the separate type +itself. For example, two values, each one consisting of register name followed +by comma and numerical expression, will be regarded as of the same type, no +matter what kind of register and how complicated numerical expression is used; +with exception for the quoted strings and floating point values, which are the +special kinds of numerical expressions and are treated as different types. Thus +"eax,16 eqtype fs,3+7" condition is true, but "eax,16 eqtype eax,1.6" is false. + + +2.2.3 Repeating blocks of instructions + +"times" directive repeats one instruction specified number of times. It +should be followed by numerical expression specifying number of repeats and +the instruction to repeat (optionally colon can be used to separate number and +instruction). When special symbol "%" is used inside the instruction, it is +equal to the number of current repeat. For example "times 5 db %" will define +five bytes with values 1, 2, 3, 4, 5. Recursive use of "times" directive is +also allowed, so "times 3 times % db %" will define six bytes with values +1, 1, 2, 1, 2, 3. + "repeat" directive repeats the whole block of instructions. It should be +followed by numerical expression specifying number of repeats. Instructions +to repeat are expected in next lines, ended with the "end repeat" directive, +for example: + + repeat 8 + mov byte [bx],% + inc bx + end repeat + +The generated code will store byte values from one to eight in the memory +addressed by BX register. + Number of repeats can be zero, in that case the instructions are not +assembled at all. + The "break" directive allows to stop repeating earlier and continue assembly +from the first line after the "end repeat". Combined with the "if" directive it +allows to stop repeating under some special condition, like: + + s = x/2 + repeat 100 + if x/s = s + break + end if + s = (s+x/s)/2 + end repeat + + The "while" directive repeats the block of instructions as long as the +condition specified by the logical expression following it is true. The block +of instructions to be repeated should end with the "end while" directive. +Before each repetition the logical expression is evaluated and when its value +is false, the assembly is continued starting from the first line after the +"end while". Also in this case the "%" symbol holds the number of current +repeat. The "break" directive can be used to stop this kind of loop in the same +way as with "repeat" directive. The previous sample can be rewritten to use the +"while" instead of "repeat" this way: + + s = x/2 + while x/s <> s + s = (s+x/s)/2 + if % = 100 + break + end if + end while + + The blocks defined with "if", "repeat" and "while" can be nested in any +order, however they should be closed in the same order in which they were +started. The "break" directive always stops processing the block that was +started last with either the "repeat" or "while" directive. + + +2.2.4 Addressing spaces + + "org" directive sets address at which the following code is expected to +appear in memory. It should be followed by numerical expression specifying +the address. This directive begins the new addressing space, the following +code itself is not moved in any way, but all the labels defined within it +and the value of "$" symbol are affected as if it was put at the given +address. However it's the responsibility of programmer to put the code at +correct address at run-time. + The "load" directive allows to define constant with a binary value loaded +from the already assembled code. This directive should be followed by the name +of the constant, then optionally size operator, then "from" operator and a +numerical expression specifying a valid address in current addressing space. +The size operator has unusual meaning in this case - it states how many bytes +(up to 8) have to be loaded to form the binary value of constant. If no size +operator is specified, one byte is loaded (thus value is in range from 0 to +255). The loaded data cannot exceed current offset. + The "store" directive can modify the already generated code by replacing +some of the previously generated data with the value defined by given +numerical expression, which follow. The expression can be preceded by the +optional size operator to specify how large value the expression defines, and +therefore how much bytes will be stored, if there is no size operator, the +size of one byte is assumed. Then the "at" operator and the numerical +expression defining the valid address in current addressing code space, at +which the given value have to be stored should follow. This is a directive for +advanced appliances and should be used carefully. + Both "load" and "store" directives are limited to operate on places in +current addressing space. The "$$" symbol is always equal to the base address +of current addressing space, and the "$" symbol is the address of current +position in that addressing space, therefore these two values define limits +of the area, where "load" and "store" can operate. + Combining the "load" and "store" directives allows to do things like encoding +some of the already generated code. For example to encode the whole code +generated in current addressing space you can use such block of directives: + + repeat $-$$ + load a byte from $$+%-1 + store byte a xor c at $$+%-1 + end repeat + +and each byte of code will be xored with the value defined by "c" constant. + "virtual" defines virtual data at specified address. This data won't be +included in the output file, but labels defined there can be used in other +parts of source. This directive can be followed by "at" operator and the +numerical expression specifying the address for virtual data, otherwise is +uses current address, the same as "virtual at $". Instructions defining data +are expected in next lines, ended with "end virtual" directive. The block of +virtual instructions itself is an independent addressing space, after it's +ended, the context of previous addressing space is restored. + The "virtual" directive can be used to create union of some variables, for +example: + + GDTR dp ? + virtual at GDTR + GDT_limit dw ? + GDT_address dd ? + end virtual + +It defines two labels for parts of the 48-bit variable at "GDTR" address. + It can be also used to define labels for some structures addressed by a +register, for example: + + virtual at bx + LDT_limit dw ? + LDT_address dd ? + end virtual + +With such definition instruction "mov ax,[LDT_limit]" will be assembled +to "mov ax,[bx]". + Declaring defined data values or instructions inside the virtual block would +also be useful, because the "load" directive can be used to load the values +from the virtually generated code into a constants. This directive should be +used after the code it loads but before the virtual block ends, because it can +only load the values from the same addressing space. For example: + + virtual at 0 + xor eax,eax + and edx,eax + load zeroq dword from 0 + end virtual + +The above piece of code will define the "zeroq" constant containing four bytes +of the machine code of the instructions defined inside the virtual block. +This method can be also used to load some binary value from external file. +For example this code: + + virtual at 0 + file 'a.txt':10h,1 + load char from 0 + end virtual + +loads the single byte from offset 10h in file "a.txt" into the "char" +constant. + Any of the "section" directives described in 2.4 also begins a new +addressing space. + + +2.2.5 Other directives + +"align" directive aligns code or data to the specified boundary. It should +be followed by a numerical expression specifying the number of bytes, to the +multiply of which the current address has to be aligned. The boundary value +has to be the power of two. + The "align" directive fills the bytes that had to be skipped to perform the +alignment with the "nop" instructions and at the same time marks this area as +uninitialized data, so if it is placed among other uninitialized data that +wouldn't take space in the output file, the alignment bytes will act the same +way. If you need to fill the alignment area with some other values, you can +combine "align" with "virtual" to get the size of alignment needed and then +create the alignment yourself, like: + + virtual + align 16 + a = $ - $$ + end virtual + db a dup 0 + +The "a" constant is defined to be the difference between address after +alignment and address of the "virtual" block (see previous section), so it is +equal to the size of needed alignment space. + "display" directive displays the message at the assembly time. It should +be followed by the quoted strings or byte values, separated with commas. It +can be used to display values of some constants, for example: + + bits = 16 + display 'Current offset is 0x' + repeat bits/4 + d = '0' + $ shr (bits-%*4) and 0Fh + if d > '9' + d = d + 'A'-'9'-1 + end if + display d + end repeat + display 13,10 + +This block of directives calculates the four hexadecimal digits of 16-bit value +and converts them into characters for displaying. Note that this won't work if +the adresses in current addressing space are relocatable (as it might happen +with PE or object output formats), since only absolute values can be used this +way. The absolute value may be obtained by calculating the relative address, +like "$-$$", or "rva $" in case of PE format. + + +2.2.6 Multiple passes + +Because the assembler allows to reference some of the labels or constants +before they get actually defined, it has to predict the values of such labels +and if there is even a suspicion that prediction failed in at least one case, +it does one more pass, assembling the whole source, this time doing better +prediction based on the values the labels got in the previous pass. + The changing values of labels can cause some instructions to have encodings +of different length, and this can cause the change in values of labels again. +And since the labels and constants can also be used inside the expressions that +affect the behavior of control directives, the whole block of source can be +processed completely differently during the new pass. Thus the assembler does +more and more passes, each time trying to do better predictions to approach +the final solution, when all the values get predicted correctly. It uses +various method for predicting the values, which has been chosen to allow +finding in a few passes the solution of possibly smallest length for the most +of the programs. + Some of the errors, like the values not fitting in required boundaries, are +not signaled during those intermediate passes, since it may happen that when +some of the values are predicted better, these errors will disappear. However +if assembler meets some illegal syntax construction or unknown instruction, it +always stops immediately. Also defining some label more than once causes such +error, because it makes the predictions groundless. + Only the messages created with the "display" directive during the last +performed pass get actually displayed. In case when the assembly has been +stopped due to an error, these messages may reflect the predicted values that +are not yet resolved correctly. + The solution may sometimes not exist and in such cases the assembler will +never manage to make correct predictions - for this reason there is a limit for +a number of passes, and when assembler reaches this limit, it stops and +displays the message that it is not able to generate the correct output. +Consider the following example: + + if ~ defined alpha + alpha: + end if + +The "defined" operator gives the true value when the expression following it +could be calculated in this place, what in this case means that the "alpha" +label is defined somewhere. But the above block causes this label to be defined +only when the value given by "defined" operator is false, what leads to an +antynomy and makes it impossible to resolve such code. When processing the "if" +directive assembler has to predict whether the "alpha" label will be defined +somewhere (it wouldn't have to predict only if the label was already defined +earlier in this pass), and whatever the prediction is, the opposite always +happens. Thus the assembly will fail, unless the "alpha" label is defined +somewhere in source preceding the above block of instructions - in such case, +as it was already noted, the prediction is not needed and the block will just +get skipped. + The above sample might have been written as a try to define the label only +when it was not yet defined. It fails, because the "defined" operator does +check whether the label is defined anywhere, and this includes the definition +inside this conditionally processed block. However adding some additional +condition may make it possible to get it resolved: + + if ~ defined alpha | defined @f + alpha: + @@: + end if + +The "@f" is always the same label as the nearest "@@" symbol in the source +following it, so the above sample would mean the same if any unique name was +used instead of the anonymous label. When "alpha" is not defined in any other +place in source, the only possible solution is when this block gets defined, +and this time this doesn't lead to the antynomy, because of the anonymous +label which makes this block self-establishing. To better understand this, +look at the blocks that has nothing more than this self-establishing: + + if defined @f + @@: + end if + +This is an example of source that may have more than one solution, as both +cases when this block gets processed or not are equally correct. Which one of +those two solutions we get depends on the algorithm on the assembler, in case +of flat assembler - on the algorithm of predictions. Back to the previous +sample, when "alpha" is not defined anywhere else, the condition for "if" block +cannot be false, so we are left with only one possible solution, and we can +hope the assembler will arrive at it. On the other hand, when "alpha" is +defined in some other place, we've got two possible solutions again, but one of +them causes "alpha" to be defined twice, and such an error causes assembler to +abort the assembly immediately, as this is the kind of error that deeply +disturbs the process of resolving. So we can get such source either correctly +resolved or causing an error, and what we get may depend on the internal +choices made by the assembler. + However there are some facts about such choices that are certain. When +assembler has to check whether the given symbol is defined and it was already +defined in the current pass, no prediction is needed - it was already noted +above. And when the given symbol has been defined never before, including all +the already finished passes, the assembler predicts it to be not defined. +Knowing this, we can expect that the simple self-establishing block shown +above will not be assembled at all and that the previous sample will resolve +correctly when "alpha" is defined somewhere before our conditional block, +while it will itself define "alpha" when it's not already defined earlier, thus +potentially causing the error because of double definition if the "alpha" is +also defined somewhere later. + The "used" operator may be expected to behave in a similar manner in +analogous cases, however any other kinds of predictions my not be so simple and +you should never rely on them this way. + + +2.3 Preprocessor directives + +All preprocessor directives are processed before the main assembly process, +and therefore are not affected by the control directives. At this time also +all comments are stripped out. + + +2.3.1 Including source files + +"include" directive includes the specified source file at the position where +it is used. It should be followed by the quoted name of file that should be +included, for example: + + include 'macros.inc' + +The whole included file is preprocessed before preprocessing the lines next +to the line containing the "include" directive. There are no limits to the +number of included files as long as they fit in memory. + The quoted path can contain environment variables enclosed within "%" +characters, they will be replaced with their values inside the path, both the +"\" and "/" characters are allowed as a path separators. If no absolute path +is given, the file is first searched for in the directory containing file +which included it and when it's not found there, in the directory containing +the main source file (the one specified in command line). These rules concern +also paths given with the "file" directive. + + +2.3.2 Symbolic constants + +The symbolic constants are different from the numerical constants, before the +assembly process they are replaced with their values everywhere in source +lines after their definitions, and anything can become their values. + The definition of symbolic constant consists of name of the constant +followed by the "equ" directive. Everything that follows this directive will +become the value of constant. If the value of symbolic constant contains +other symbolic constants, they are replaced with their values before assigning +this value to the new constant. For example: + + d equ dword + NULL equ d 0 + d equ edx + +After these three definitions the value of "NULL" constant is "dword 0" and +the value of "d" is "edx". So, for example, "push NULL" will be assembled as +"push dword 0" and "push d" will be assembled as "push edx". And if then the +following line was put: + + d equ d,eax + +the "d" constant would get the new value of "edx,eax". This way the growing +lists of symbols can be defined. + "restore" directive allows to get back previous value of redefined symbolic +constant. It should be followed by one more names of symbolic constants, +separated with commas. So "restore d" after the above definitions will give +"d" constant back the value "edx", the second one will restore it to value +"dword", and one more will revert "d" to original meaning as if no such +constant was defined. If there was no constant defined of given name, +"restore" won't cause an error, it will be just ignored. + Symbolic constant can be used to adjust the syntax of assembler to personal +preferences. For example the following set of definitions provides the handy +shortcuts for all the size operators: + + b equ byte + w equ word + d equ dword + p equ pword + f equ fword + q equ qword + t equ tword + x equ dqword + + Because symbolic constant may also have an empty value, it can be used to +allow the syntax with "offset" word before any address value: + + offset equ + +After this definition "mov ax,offset char" will be valid construction for +copying the offset of "char" variable into "ax" register, because "offset" is +replaced with an empty value, and therefore ignored. + The "define" directive followed by the name of constant and then the value, +is the alternative way of defining symbolic constant. The only difference +between "define" and "equ" is that "define" assigns the value as it is, it does +not replace the symbolic constants with their values inside it. + Symbolic constants can also be defined with the "fix" directive, which has +the same syntax as "equ", but defines constants of high priority - they are +replaced with their symbolic values even before processing the preprocessor +directives and macroinstructions, the only exception is "fix" directive +itself, which has the highest possible priority, so it allows redefinition of +constants defined this way. + The "fix" directive can be used for syntax adjustments related to directives +of preprocessor, what cannot be done with "equ" directive. For example: + + incl fix include + +defines a short name for "include" directive, while the similar definition done +with "equ" directive wouldn't give such result, as standard symbolic constants +are replaced with their values after searching the line for preprocessor +directives. + + +2.3.3 Macroinstructions + +"macro" directive allows you to define your own complex instructions, called +macroinstructions, using which can greatly simplify the process of +programming. In its simplest form it's similar to symbolic constant +definition. For example the following definition defines a shortcut for the +"test al,0xFF" instruction: + + macro tst {test al,0xFF} + +After the "macro" directive there is a name of macroinstruction and then its +contents enclosed between the "{" and "}" characters. You can use "tst" +instruction anywhere after this definition and it will be assembled as +"test al,0xFF". Defining symbolic constant "tst" of that value would give the +similar result, but the difference is that the name of macroinstruction is +recognized only as an instruction mnemonic. Also, macroinstructions are +replaced with corresponding code even before the symbolic constants are +replaced with their values. So if you define macroinstruction and symbolic +constant of the same name, and use this name as an instruction mnemonic, it +will be replaced with the contents of macroinstruction, but it will be +replaced with value if symbolic constant if used somewhere inside the +operands. + The definition of macroinstruction can consist of many lines, because +"{" and "}" characters don't have to be in the same line as "macro" directive. +For example: + + macro stos0 + { + xor al,al + stosb + } + +The macroinstruction "stos0" will be replaced with these two assembly +instructions anywhere it's used. + Like instructions which needs some number of operands, the macroinstruction +can be defined to need some number of arguments separated with commas. The +names of needed argument should follow the name of macroinstruction in the +line of "macro" directive and should be separated with commas if there is more +than one. Anywhere one of these names occurs in the contents of +macroinstruction, it will be replaced with corresponding value, provided when +the macroinstruction is used. Here is an example of a macroinstruction that +will do data alignment for binary output format: + + macro align value { rb (value-1)-($+value-1) mod value } + +When the "align 4" instruction is found after this macroinstruction is +defined, it will be replaced with contents of this macroinstruction, and the +"value" will there become 4, so the result will be "rb (4-1)-($+4-1) mod 4". + If a macroinstruction is defined that uses an instruction with the same name +inside its definition, the previous meaning of this name is used. Useful +redefinition of macroinstructions can be done in that way, for example: + + macro mov op1,op2 + { + if op1 in & op2 in + push op2 + pop op1 + else + mov op1,op2 + end if + } + +This macroinstruction extends the syntax of "mov" instruction, allowing both +operands to be segment registers. For example "mov ds,es" will be assembled as +"push es" and "pop ds". In all other cases the standard "mov" instruction will +be used. The syntax of this "mov" can be extended further by defining next +macroinstruction of that name, which will use the previous macroinstruction: + + macro mov op1,op2,op3 + { + if op3 eq + mov op1,op2 + else + mov op1,op2 + mov op2,op3 + end if + } + +It allows "mov" instruction to have three operands, but it can still have two +operands only, because when macroinstruction is given less arguments than it +needs, the rest of arguments will have empty values. When three operands are +given, this macroinstruction will become two macroinstructions of the previous +definition, so "mov es,ds,dx" will be assembled as "push ds", "pop es" and +"mov ds,dx". + By placing the "*" after the name of argument you can mark the argument as +required - preprocessor won't allow it to have an empty value. For example the +above macroinstruction could be declared as "macro mov op1*,op2*,op3" to make +sure that first two arguments will always have to be given some non empty +values. + When it's needed to provide macroinstruction with argument that contains +some commas, such argument should be enclosed between "<" and ">" characters. +If it contains more than one "<" character, the same number of ">" should be +used to tell that the value of argument ends. + "purge" directive allows removing the last definition of specified +macroinstruction. It should be followed by one or more names of +macroinstructions, separated with commas. If such macroinstruction has not +been defined, you won't get any error. For example after having the syntax of +"mov" extended with the macroinstructions defined above, you can disable +syntax with three operands back by using "purge mov" directive. Next +"purge mov" will disable also syntax for two operands being segment registers, +and all the next such directives will do nothing. + If after the "macro" directive you enclose some group of arguments' names in +square brackets, it will allow giving more values for this group of arguments +when using that macroinstruction. Any more argument given after the last +argument of such group will begin the new group and will become the first +argument of it. That's why after closing the square bracket no more argument +names can follow. The contents of macroinstruction will be processed for each +such group of arguments separately. The simplest example is to enclose one +argument name in square brackets: + + macro stoschar [char] + { + mov al,char + stosb + } + +This macroinstruction accepts unlimited number of arguments, and each one +will be processed into these two instructions separately. For example +"stoschar 1,2,3" will be assembled as the following instructions: + + mov al,1 + stosb + mov al,2 + stosb + mov al,3 + stosb + + There are some special directives available only inside the definitions of +macroinstructions. "local" directive defines local names, which will be +replaced with unique values each time the macroinstruction is used. It should +be followed by names separated with commas. If the name given as parameter to +"local" directive begins with a dot or two dots, the unique labels generated +by each evaluation of macroinstruction will have the same properties. +This directive is usually needed for the constants or labels that +macroinstruction defines and uses internally. For example: + + macro movstr + { + local move + move: + lodsb + stosb + test al,al + jnz move + } + +Each time this macroinstruction is used, "move" will become other unique name +in its instructions, so you won't get an error you normally get when some +label is defined more than once. + "forward", "reverse" and "common" directives divide macroinstruction into +blocks, each one processed after the processing of previous is finished. They +differ in behavior only if macroinstruction allows multiple groups of +arguments. Block of instructions that follows "forward" directive is processed +for each group of arguments, from first to last - exactly like the default +block (not preceded by any of these directives). Block that follows "reverse" +directive is processed for each group of argument in reverse order - from last +to first. Block that follows "common" directive is processed only once, +commonly for all groups of arguments. Local name defined in one of the blocks +is available in all the following blocks when processing the same group of +arguments as when it was defined, and when it is defined in common block it is +available in all the following blocks not depending on which group of +arguments is processed. + Here is an example of macroinstruction that will create the table of +addresses to strings followed by these strings: + + macro strtbl name,[string] + { + common + label name dword + forward + local label + dd label + forward + label db string,0 + } + +First argument given to this macroinstruction will become the label for table +of addresses, next arguments should be the strings. First block is processed +only once and defines the label, second block for each string declares its +local name and defines the table entry holding the address to that string. +Third block defines the data of each string with the corresponding label. + The directive starting the block in macroinstruction can be followed by the +first instruction of this block in the same line, like in the following +example: + + macro stdcall proc,[arg] + { + reverse push arg + common call proc + } + +This macroinstruction can be used for calling the procedures using STDCALL +convention, arguments are pushed on stack in the reverse order. For example +"stdcall foo,1,2,3" will be assembled as: + + push 3 + push 2 + push 1 + call foo + + If some name inside macroinstruction has multiple values (it is either one +of the arguments enclosed in square brackets or local name defined in the +block following "forward" or "reverse" directive) and is used in block +following the "common" directive, it will be replaced with all of its values, +separated with commas. For example the following macroinstruction will pass +all of the additional arguments to the previously defined "stdcall" +macroinstruction: + + macro invoke proc,[arg] + { common stdcall [proc],arg } + +It can be used to call indirectly (by the pointer stored in memory) the +procedure using STDCALL convention. + Inside macroinstruction also special operator "#" can be used. This +operator causes two names to be concatenated into one name. It can be useful, +because it's done after the arguments and local names are replaced with their +values. The following macroinstruction will generate the conditional jump +according to the "cond" argument: + + macro jif op1,cond,op2,label + { + cmp op1,op2 + j#cond label + } + +For example "jif ax,ae,10h,exit" will be assembled as "cmp ax,10h" and +"jae exit" instructions. + The "#" operator can be also used to concatenate two quoted strings into one. +Also conversion of name into a quoted string is possible, with the "`" operator, +which likewise can be used inside the macroinstruction. It convert the name +that follows it into a quoted string - but note, that when it is followed by +a macro argument which is being replaced with value containing more than one +symbol, only the first of them will be converted, as the "`" operator converts +only one symbol that immediately follows it. Here's an example of utilizing +those two features: + + macro label name + { + label name + if ~ used name + display `name # " is defined but not used.",13,10 + end if + } + +When label defined with such macro is not used in the source, macro will warn +you with the message, informing to which label it applies. + To make macroinstruction behaving differently when some of the arguments are +of some special type, for example a quoted strings, you can use "eqtype" +comparison operator. Here's an example of utilizing it to distinguish a +quoted string from an other argument: + + macro message arg + { + if arg eqtype "" + local str + jmp @f + str db arg,0Dh,0Ah,24h + @@: + mov dx,str + else + mov dx,arg + end if + mov ah,9 + int 21h + } + +The above macro is designed for displaying messages in DOS programs. When the +argument of this macro is some number, label, or variable, the string from +that address is displayed, but when the argument is a quoted string, the +created code will display that string followed by the carriage return and +line feed. + It is also possible to put a declaration of macroinstruction inside another +macroinstruction, so one macro can define another, but there is a problem +with such definitions caused by the fact, that "}" character cannot occur +inside the macroinstruction, as it always means the end of definition. To +overcome this problem, the escaping of symbols inside macroinstruction can be +used. This is done by placing one or more backslashes in front of any other +symbol (even the special character). Preprocessor sees such sequence as a +single symbol, but each time it meets such symbol during the macroinstruction +processing, it cuts the backslash character from the front of it. For example +"\{" is treated as single symbol, but during processing of the macroinstruction +it becomes the "{" symbol. This allows to put one definition of +macroinstruction inside another: + + macro ext instr + { + macro instr op1,op2,op3 + \{ + if op3 eq + instr op1,op2 + else + instr op1,op2 + instr op2,op3 + end if + \} + } + + ext add + ext sub + +The macro "ext" is defined correctly, but when it is used, the "\{" and "\}" +become the "{" and "}" symbols. So when the "ext add" is processed, the +contents of macro becomes valid definition of a macroinstruction and this way +the "add" macro becomes defined. In the same way "ext sub" defines the "sub" +macro. The use of "\{" symbol wasn't really necessary here, but is done this +way to make the definition more clear. + If some directives specific to macroinstructions, like "local" or "common" +are needed inside some macro embedded this way, they can be escaped in the same +way. Escaping the symbol with more than one backslash is also allowed, which +allows multiple levels of nesting the macroinstruction definitions. + The another technique for defining one macroinstruction by another is to +use the "fix" directive, which becomes useful when some macroinstruction only +begins the definition of another one, without closing it. For example: + + macro tmacro [params] + { + common macro params { + } + + MACRO fix tmacro + ENDM fix } + +defines an alternative syntax for defining macroinstructions, which looks like: + + MACRO stoschar char + mov al,char + stosb + ENDM + +Note that symbol that has such customized definition must be defined with "fix" +directive, because only the prioritized symbolic constants are processed before +the preprocessor looks for the "}" character while defining the macro. This +might be a problem if one needed to perform some additional tasks one the end +of such definition, but there is one more feature which helps in such cases. +Namely it is possible to put any directive, instruction or macroinstruction +just after the "}" character that ends the macroinstruction and it will be +processed in the same way as if it was put in the next line. + + +2.3.4 Structures + +"struc" directive is a special variant of "macro" directive that is used to +define data structures. Macroinstruction defined using the "struc" directive +must be preceded by a label (like the data definition directive) when it's +used. This label will be also attached at the beginning of every name starting +with dot in the contents of macroinstruction. The macroinstruction defined +using the "struc" directive can have the same name as some other +macroinstruction defined using the "macro" directive, structure +macroinstruction won't prevent the standard macroinstruction being processed +when there is no label before it and vice versa. All the rules and features +concerning standard macroinstructions apply to structure macroinstructions. + Here is the sample of structure macroinstruction: + + struc point x,y + { + .x dw x + .y dw y + } + +For example "my point 7,11" will define structure labeled "my", consisting of +two variables: "my.x" with value 7 and "my.y" with value 11. + If somewhere inside the definition of structure the name consisting of a +single dot it found, it is replaced by the name of the label for the given +instance of structure and this label will not be defined automatically in +such case, allowing to completely customize the definition. The following +example utilizes this feature to extend the data definition directive "db" +with ability to calculate the size of defined data: + + struc db [data] + { + common + . db data + .size = $ - . + } + +With such definition "msg db 'Hello!',13,10" will define also "msg.size" +constant, equal to the size of defined data in bytes. + Defining data structures addressed by registers or absolute values should be +done using the "virtual" directive with structure macroinstruction +(see 2.2.4). + "restruc" directive removes the last definition of the structure, just like +"purge" does with macroinstructions and "restore" with symbolic constants. +It also has the same syntax - should be followed by one or more names of +structure macroinstructions, separated with commas. + + +2.3.5 Repeating macroinstructions + +The "rept" directive is a special kind of macroinstruction, which makes given +amount of duplicates of the block enclosed with braces. The basic syntax is +"rept" directive followed by number (it cannot be an expression, since +preprocessor doesn't do calculations, if you need repetitions based on values +calculated by assembler, use one of the code repeating directives that are +processed by assembler, see 2.2.3), and then block of source enclosed between +the "{" and "}" characters. The simplest example: + + rept 5 { in al,dx } + +will make five duplicates of the "in al,dx" line. The block of instructions +is defined in the same way as for the standard macroinstruction and any +special operators and directives which can be used only inside +macroinstructions are also allowed here. When the given count is zero, the +block is simply skipped, as if you defined macroinstruction but never used +it. The number of repetitions can be followed by the name of counter symbol, +which will get replaced symbolically with the number of duplicate currently +generated. So this: + + rept 3 counter + { + byte#counter db counter + } + +will generate lines: + + byte1 db 1 + byte2 db 2 + byte3 db 3 + +The repetition mechanism applied to "rept" blocks is the same as the one used +to process multiple groups of arguments for macroinstructions, so directives +like "forward", "common" and "reverse" can be used in their usual meaning. +Thus such macroinstruction: + + rept 7 num { reverse display `num } + +will display digits from 7 to 1 as text. The "local" directive behaves in the +same way as inside macroinstruction with multiple groups of arguments, so: + + rept 21 + { + local label + label: loop label + } + +will generate unique label for each duplicate. + The counter symbol by default counts from 1, but you can declare different +base value by placing the number preceded by colon immediately after the name +of counter. For example: + + rept 8 n:0 { pxor xmm#n,xmm#n } + +will generate code which will clear the contents of eight SSE registers. +You can define multiple counters separated with commas, and each one can have +different base. + The "irp" directive iterates the single argument through the given list of +parameters. The syntax is "irp" followed by the argument name, then the comma +and then the list of parameters. The parameters are specified in the same +way like in the invocation of standard macroinstruction, so they have to be +separated with commas and each one can be enclosed with the "<" and ">" +characters. Also the name of argument may be followed by "*" to mark that it +cannot get an empty value. Such block: + + irp value, 2,3,5 + { db value } + +will generate lines: + + db 2 + db 3 + db 5 + +The "irps" directive iterates through the given list of symbols, it should +be followed by the argument name, then the comma and then the sequence of any +symbols. Each symbol in this sequence, no matter whether it is the name +symbol, symbol character or quoted string, becomes an argument value for one +iteration. If there are no symbols following the comma, no iteration is done +at all. This example: + + irps reg, al bx ecx + { xor reg,reg } + +will generate lines: + + xor al,al + xor bx,bx + xor ecx,ecx + +The blocks defined by the "irp" and "irps" directives are also processed in +the same way as any macroinstructions, so operators and directives specific +to macroinstructions may be freely used also in this case. + + +2.3.6 Conditional preprocessing + +"match" directive causes some block of source to be preprocessed and passed +to assembler only when the given sequence of symbols matches the specified +pattern. The pattern comes first, ended with comma, then the symbols that have +to be matched with the pattern, and finally the block of source, enclosed +within braces as macroinstruction. + There are the few rules for building the expression for matching, first is +that any of symbol characters and any quoted string should be matched exactly +as is. In this example: + + match +,+ { include 'first.inc' } + match +,- { include 'second.inc' } + +the first file will get included, since "+" after comma matches the "+" in +pattern, and the second file won't be included, since there is no match. + To match any other symbol literally, it has to be preceded by "=" character +in the pattern. Also to match the "=" character itself, or the comma, the +"==" and "=," constructions have to be used. For example the "=a==" pattern +will match the "a=" sequence. + If some name symbol is placed in the pattern, it matches any sequence +consisting of at least one symbol and then this name is replaced with the +matched sequence everywhere inside the following block, analogously to the +parameters of macroinstruction. For instance: + + match a-b, 0-7 + { dw a,b-a } + +will generate the "dw 0,7-0" instruction. Each name is always matched with +as few symbols as possible, leaving the rest for the following ones, so in +this case: + + match a b, 1+2+3 { db a } + +the "a" name will match the "1" symbol, leaving the "+2+3" sequence to be +matched with "b". But in this case: + + match a b, 1 { db a } + +there will be nothing left for "b" to match, so the block won't get processed +at all. + The block of source defined by match is processed in the same way as any +macroinstruction, so any operators specific to macroinstructions can be used +also in this case. + What makes "match" directive more useful is the fact, that it replaces the +symbolic constants with their values in the matched sequence of symbols (that +is everywhere after comma up to the beginning of the source block) before +performing the match. Thanks to this it can be used for example to process +some block of source under the condition that some symbolic constant has the +given value, like: + + match =TRUE, DEBUG { include 'debug.inc' } + +which will include the file only when the symbolic constant "DEBUG" was +defined with value "TRUE". + + +2.3.7 Order of processing + +When combining various features of the preprocessor, it's important to know +the order in which they are processed. As it was already noted, the highest +priority has the "fix" directive and the replacements defined with it. This +is done completely before doing any other preprocessing, therefore this +piece of source: + + V fix { + macro empty + V + V fix } + V + +becomes a valid definition of an empty macroinstruction. It can be interpreted +that the "fix" directive and prioritized symbolic constants are processed in +a separate stage, and all other preprocessing is done after on the resulting +source. + The standard preprocessing that comes after, on each line begins with +recognition of the first symbol. It begins with checking for the preprocessor +directives, and when none of them is detected, preprocessor checks whether the +first symbol is macroinstruction. If no macroinstruction is found, it moves +to the second symbol of line, and again begins with checking for directives, +which in this case is only the "equ" directive, as this is the only one that +occurs as the second symbol in line. If there's no directive, the second +symbol is checked for the case of structure macroinstruction and when none +of those checks gives the positive result, the symbolic constants are replaced +with their values and such line is passed to the assembler. + To see it on the example, assume that there is defined the macroinstruction +called "foo" and the structure macroinstruction called "bar". Those lines: + + foo equ + foo bar + +would be then both interpreted as invocations of macroinstruction "foo", since +the meaning of the first symbol overrides the meaning of second one. + The macroinstructions generate the new lines from their definition blocks, +replacing the parameters with their values and then processing the "#" and "`" +operators. The conversion operator has the higher priority than concatenation. +After this is completed, the newly generated line goes through the standard +preprocessing, as described above. + Though the symbolic constants are usually only replaced in the lines, where +no preprocessor directives nor macroinstructions has been found, there are some +special cases where those replacements are performed in the parts of lines +containing directives. First one is the definition of symbolic constant, where +the replacements are done everywhere after the "equ" keyword and the resulting +value is then assigned to the new constant (see 2.3.2). The second such case +is the "match" directive, where the replacements are done in the symbols +following comma before matching them with pattern. These features can be used +for example to maintain the lists, like this set of definitions: + + list equ + + macro append item + { + match any, list \{ list equ list,item \} + match , list \{ list equ item \} + } + +The "list" constant is here initialized with empty value, and the "append" +macroinstruction can be used to add the new items into this list, separating +them with commas. The first match in this macroinstruction occurs only when +the value of list is not empty (see 2.3.6), in such case the new value for the +list is the previous one with the comma and the new item appended at the end. +The second match happens only when the list is still empty, and in such case +the list is defined to contain just the new item. So starting with the empty +list, the "append 1" would define "list equ 1" and the "append 2" following it +would define "list equ 1,2". One might then need to use this list as the +parameters to some macroinstruction. But it cannot be done directly - if "foo" +is the macroinstruction, then "foo list" would just pass the "list" symbol +as a parameter to macro, since symbolic constants are not unrolled at this +stage. For this purpose again "match" directive comes in handy: + + match params, list { foo params } + +The value of "list", if it's not empty, matches the "params" keyword, which is +then replaced with matched value when generating the new lines defined by the +block enclosed with braces. So if the "list" had value "1,2", the above line +would generate the line containing "foo 1,2", which would then go through the +standard preprocessing. + There is one more special case - when preprocessor goes to checking the +second symbol in the line and it happens to be the colon character (what is +then interpreted by assembler as definition of a label), it stops in this +place and finishes the preprocessing of the first symbol (so if it's the +symbolic constant it gets unrolled) and if it still appears to be the label, +it performs the standard preprocessing starting from the place after the +label. This allows to place preprocessor directives and macroinstructions +after the labels, analogously to the instructions and directives processed +by assembler, like: + + start: include 'start.inc' + +However if the label becomes broken during preprocessing (for example when +it is the symbolic constant with empty value), only replacing of the symbolic +constants is continued for the rest of line. + It should be remembered, that the jobs performed by preprocessor are the +preliminary operations on the texts symbols, that are done in a simple +single pass before the main process of assembly. The text that is the +result of preprocessing is passed to assembler, and it then does its +multiple passes on it. Thus the control directives, which are recognized and +processed only by the assembler - as they are dependent on the numerical +values that may even vary between passes - are not recognized in any way by +the preprocessor and have no effect on the preprocessing. Consider this +example source: + + if 0 + a = 1 + b equ 2 + end if + dd b + +When it is preprocessed, they only directive that is recognized by the +preprocessor is the "equ", which defines symbolic constant "b", so later +in the source the "b" symbol is replaced with the value "2". Except for this +replacement, the other lines are passes unchanged to the assembler. So +after preprocessing the above source becomes: + + if 0 + a = 1 + end if + dd 2 + +Now when assembler processes it, the condition for the "if" is false, and +the "a" constant doesn't get defined. However symbolic constant "b" was +processed normally, even though its definition was put just next to the one +of "a". So because of the possible confusion you should be very careful +every time when mixing the features of preprocessor and assembler - always +try to imagine what your source will become after the preprocessing, and +thus what the assembler will see and do its multiple passes on. + + +2.4 Formatter directives + +These directives are actually also a kind of control directives, with the +purpose of controlling the format of generated code. + "format" directive followed by the format identifier allows to select the +output format. This directive should be put at the beginning of the source. +Default output format is a flat binary file, it can also be selected by using +"format binary" directive. + "use16" and "use32" directives force the assembler to generate 16-bit or +32-bit code, omitting the default setting for selected output format. "use64" +enables generating the code for the long mode of x86-64 processors. + Below are described different output formats with the directives specific to +these formats. + + +2.4.1 MZ executable + +To select the MZ output format, use "format MZ" directive. The default code +setting for this format is 16-bit. + "segment" directive defines a new segment, it should be followed by label, +which value will be the number of defined segment, optionally "use16" or +"use32" word can follow to specify whether code in this segment should be +16-bit or 32-bit. The origin of segment is aligned to paragraph (16 bytes). +All the labels defined then will have values relative to the beginning of this +segment. + "entry" directive sets the entry point for MZ executable, it should be +followed by the far address (name of segment, colon and the offset inside +segment) of desired entry point. + "stack" directive sets up the stack for MZ executable. It can be followed by +numerical expression specifying the size of stack to be created automatically +or by the far address of initial stack frame when you want to set up the stack +manually. When no stack is defined, the stack of default size 4096 bytes will +be created. + "heap" directive should be followed by a 16-bit value defining maximum size +of additional heap in paragraphs (this is heap in addition to stack and +undefined data). Use "heap 0" to always allocate only memory program really +needs. Default size of heap is 65535. + + +2.4.2 Portable Executable + +To select the Portable Executable output format, use "format PE" directive, it +can be followed by additional format settings: use "console", "GUI" or +"native" operator selects the target subsystem (floating point value +specifying subsystem version can follow), "DLL" marks the output file as a +dynamic link library. Then can follow the "at" operator and the numerical +expression specifying the base of PE image and then optionally "on" operator +followed by the quoted string containing file name selects custom MZ stub for +PE program (when specified file is not a MZ executable, it is treated as a +flat binary executable file and converted into MZ format). The default code +setting for this format is 32-bit. The example of fully featured PE format +declaration: + + format PE GUI 4.0 DLL at 7000000h on 'stub.exe' + + To create PE file for the x86-64 architecture, use "PE64" keyword instead of +"PE" in the format declaration, in such case the long mode code is generated +by default. + "section" directive defines a new section, it should be followed by quoted +string defining the name of section, then one or more section flags can +follow. Available flags are: "code", "data", "readable", "writeable", +"executable", "shareable", "discardable", "notpageable". The origin of section +is aligned to page (4096 bytes). Example declaration of PE section: + + section '.text' code readable executable + +Among with flags also one of the special PE data identifiers can be specified +to mark the whole section as a special data, possible identifiers are +"export", "import", "resource" and "fixups". If the section is marked to +contain fixups, they are generated automatically and no more data needs to be +defined in this section. Also resource data can be generated automatically +from the resource file, it can be achieved by writing the "from" operator and +quoted file name after the "resource" identifier. Below are the examples of +sections containing some special PE data: + + section '.reloc' data discardable fixups + section '.rsrc' data readable resource from 'my.res' + + "entry" directive sets the entry point for Portable Executable, the value of +entry point should follow. + "stack" directive sets up the size of stack for Portable Executable, value +of stack reserve size should follow, optionally value of stack commit +separated with comma can follow. When stack is not defined, it's set by +default to size of 4096 bytes. + "heap" directive chooses the size of heap for Portable Executable, value of +heap reserve size should follow, optionally value of heap commit separated +with comma can follow. When no heap is defined, it is set by default to size +of 65536 bytes, when size of heap commit is unspecified, it is by default set +to zero. + "data" directive begins the definition of special PE data, it should be +followed by one of the data identifiers ("export", "import", "resource" or +"fixups") or by the number of data entry in PE header. The data should be +defined in next lines, ended with "end data" directive. When fixups data +definition is chosen, they are generated automatically and no more data needs +to be defined there. The same applies to the resource data when the "resource" +identifier is followed by "from" operator and quoted file name - in such case +data is taken from the given resource file. + The "rva" operator can be used inside the numerical expressions to obtain +the RVA of the item addressed by the value it is applied to. + + +2.4.3 Common Object File Format + +To select Common Object File Format, use "format COFF" or "format MS COFF" +directive whether you want to create classic or Microsoft's COFF file. The +default code setting for this format is 32-bit. To create the file in +Microsoft's COFF format for the x86-64 architecture, use "format MS64 COFF" +setting, in such case long mode code is generated by default. + "section" directive defines a new section, it should be followed by quoted +string defining the name of section, then one or more section flags can +follow. Section flags available for both COFF variants are "code" and "data", +while "readable", "writeable", "executable", "shareable", "discardable", +"notpageable", "linkremove" and "linkinfo" are flags available only with +Microsoft COFF variant. + By default section is aligned to double word (four bytes), in case of +Microsoft COFF variant other alignment can be specified by providing the +"align" operator followed by alignment value (any power of two up to 8192) +among the section flags. + "extrn" directive defines the external symbol, it should be followed by the +name of symbol and optionally the size operator specifying the size of data +labeled by this symbol. The name of symbol can be also preceded by quoted +string containing name of the external symbol and the "as" operator. +Some example declarations of external symbols: + + extrn exit + extrn '__imp__MessageBoxA@16' as MessageBox:dword + + "public" directive declares the existing symbol as public, it should be +followed by the name of symbol, optionally it can be followed by the "as" +operator and the quoted string containing name under which symbol should be +available as public. Some examples of public symbols declarations: + + public main + public start as '_start' + +2.4.4 Executable and Linkable Format + +To select ELF output format, use "format ELF" directive. The default code +setting for this format is 32-bit. To create ELF file for the x86-64 +architecture, use "format ELF64" directive, in such case the long mode code is +generated by default. + "section" directive defines a new section, it should be followed by quoted +string defining the name of section, then can follow one or both of the +"executable" and "writeable" flags, optionally also "align" operator followed +by the number specifying the alignment of section (it has to be the power of +two), if no alignment is specified, the default value is used, which is 4 or 8, +depending on which format variant has been chosen. + "extrn" and "public" directives have the same meaning and syntax as when the +COFF output format is selected (described in previous section). + The "rva" operator can be used also in the case of this format (however not +when target architecture is x86-64), it converts the address into the offset +relative to the GOT table, so it may be useful to create position-independent +code. + To create executable file, follow the format choice directive with the +"executable" keyword. It allows to use "entry" directive followed by the value +to set as entry point of program. On the other hand it makes "extrn" and +"public" directives unavailable, and instead of "section" there should be the +"segment" directive used, followed only by one or more segment permission +flags. The origin of segment is aligned to page (4096 bytes), and available +flags for are: "readable", "writeable" and "executable". + + +EOF \ No newline at end of file diff --git a/data/Vortex86MX-eng/docs/HOT_KEYS.TXT b/data/Vortex86MX-eng/docs/HOT_KEYS.TXT new file mode 100644 index 0000000000..ba08147e8d --- /dev/null +++ b/data/Vortex86MX-eng/docs/HOT_KEYS.TXT @@ -0,0 +1,10 @@ +The following "hot" shortcut keys are used in the system: +(Indexing on time of appearance in the system) +1) Ctrl + Alt + Del start of the application CPU (the manager of processes), is a sole combination maintained on a level of a kernel, all rest "hot" key is realized at the expense of the application @PANEL. +2) Ctrl + Shift - switching of keyboard layout. +3) Win - start of the application MENU. +4) Alt + Ctrl + F12 - start of the application END. +5) Alt + F4 - terminate the active application. +6) Alt + Tab - switch to the next (in the window stack) window +7) Alt + Shift + Tab - switch to the previous (in the window stack) window +8) Alt + Shift + NumLock - start of the application MOUSEMUL, which emulates mouse with numpad, when NumLock is on (note: mousEmul does not create window or pictures to indicate its work!) diff --git a/data/Vortex86MX-eng/docs/INI.TXT b/data/Vortex86MX-eng/docs/INI.TXT new file mode 100644 index 0000000000..f906363c7e --- /dev/null +++ b/data/Vortex86MX-eng/docs/INI.TXT @@ -0,0 +1,25 @@ +Ini-files are text files of special contents: + +[name of first section] +Key1=value1 +Key2=value2 +;comment +[name of second section] +Key3=value3 + +All lines beginning with ';' are considered as comments and ignored. + +Keyboard shortcuts are described as follows: +any number of modificators Ctrl/Alt/Shift/LCtrl/LAlt/LShift/RCtrl/RAlt/RShift, +followed by latin letter, digit or key name. The following keys have a name: +F1 - F12 +Home; End; PgUp; PgDn; Ins, equivalently, Insert; Del, equivalently, Delete; +Tab; Plus; Esc; Enter; Backspace; Space; +Left (left arrow); Right (right arrow); Up (up arrow); Down (down arrow). +The string for shortcut is case-insensitive. Parts of the string +can be written without delimiters or with '+' between parts. Examples: +Ctrl+Alt+Backspace +RCtrl+RShift +ShiftA +f10 +shiftalt5 diff --git a/data/Vortex86MX-eng/docs/KFAR_KEYS.TXT b/data/Vortex86MX-eng/docs/KFAR_KEYS.TXT new file mode 100644 index 0000000000..d21d24ce41 --- /dev/null +++ b/data/Vortex86MX-eng/docs/KFAR_KEYS.TXT @@ -0,0 +1,94 @@ +Control keys in KFar. +For panels: +arrows, Home, End - move cursor on active panel +Tab - change active panel +Enter - enter to folder or run program under cursor +F3 - view file under cursor +F5 - copy selected items or item under cursor to another panel +Shift+F5 - copy selected items or item under cursor to the same panel + (of course, you must specify another file name) +F7 - create folder +F8 - delete selected elements or element under cursor +F10 - exit +Alt+F1/Alt+F2 - change drive on left/right panel +Alt+F9 - resize window to maximum possible size and restore initial size +Ctrl+F3 - sort file/folders on active panel by name +Ctrl+F4 - sort by extension +Ctrl+F5 - sort by date/time of last modification +Ctrl+F6 - sort by size +Ctrl+F7 - don't sort (display in order as on disk) +Ctrl+F8 - sort by date/time of creation +Ctrl+F9 - sort by date/time of last access +F12 - display screens menu +Ctrl+R - refresh active panel +Menu - display context menu for file under cursor +LeftCtrl+1/2/3/4 - select panel mode (brief/medium/full/wide) +RightCtrl+0..9 - go to folder specified in the section [FolderShortcuts] + of ini-file as Shortcut0..9 accordingly +Insert - select/deselect current element +Grey[+] - select files and folders with mask +Grey[-] - deselect files and folders with mask +The mask is like "*.asm,*.inc|template.asm" (which selects all files with +extensions ASM and INC except for template.asm): one or more elementary +including masks with standard mean of '*' and '?', delimited by ',' or ';', +optionally followed by '|' and one or more elementary excluding masks. +The mask "*.*" specifies all files having '.' in name (i.e. files with +any non-empty extension); to specify all files use "*". +Grey[*] - invert selection +Alt+ - position cursor on name of file/folder, +beginning from selected letter or digit; it shows fast find window, +in which one can enter subsequent symbols of file/folder name to more precise +selection, and also Ctrl+Enter/Shift+Ctrl+Enter to move to the next/previous +panel item, whose name starts with specified letters + +For viewer: +Esc = F3 = F10 = Numpad5 - exit +Down - line down +PgDn - page down +Up - line up +PgUp - page up +Home - to begin of file +End - to end of file +Left - character left +Right - character right +Ctrl+Left - in Text-mode 20 characters left; + in Hex-mode 1 byte left +Ctrl+Right - in Text-mode 20 characters right; + in Hex-mode 1 byte right +Ctrl+Shift+Left - start of lines on the screen +Ctrl+Shift+Right - end of lines on the screen +F2 - toggle line wrap +F4 - toggle Text <-> Hex mode +F8 - toggle encoding cp866 (DOS) <-> cp1251 (Win) +Shift+F8 - encoding tables menu +F12 - display screens menu +F7 - search a string from the current position in the file + (the string and settings are set in the following dialog) +Shift+F7 - continue to search a string + (use the string and settings from last search by F7) +Alt+F9 - resize window to maximum possible size and restore initial size + +For editor: +Esc = F10 - exit; if the file was modified, the question about save necessity + will follow +Shift+F10 - save and exit +F2 - save the file +Down - move cursor down to one line +PgDn - move cursor down to one page +Up - move cursor up to one line +PgUp - move cursor up to one page +Left - move cursor left to one symbol +Right - move cursor right to one symbol +Home - move cursor to the beginning of the current line +End - move cursor to the end of the current line +Backspace - delete the symbol before the cursor +Del - delete the symbol under the cursor +Ins - toggle insert/replace mode when entering symbols +F12 - display screens menu +Alt+F9 - resize window to maximum possible size and restore initial size +F7 - search a string starting from the position next to the cursor + (the string and search settings are prompted in the following dialog) +Shift+F7 - continue to search a string (same as F7 without settings dialog) + + diamond + mailto:diamondz@land.ru diff --git a/data/Vortex86MX-eng/docs/MTDBG.TXT b/data/Vortex86MX-eng/docs/MTDBG.TXT new file mode 100644 index 0000000000..975bbefb8e --- /dev/null +++ b/data/Vortex86MX-eng/docs/MTDBG.TXT @@ -0,0 +1,214 @@ +Introduction. + +mtdbg is a debugger for Kolibri operating system. This documentation describes +debugger features and work with it. If you need some features which are +not presented yet, either write to the forum meos.sysbin.com (if you can +read russian texts) or mail me to address given in the end of this file. + +General description. + +In each moment of time mtdbg can debug only one program. I will call it +loaded program. If no program is loaded, overwhelming majority of debugging +actions is disabled. + +mtdbg is controlled by command line, entering from keyboard. Command line +is drawn in the bottom part of debugger window. Debugger handles standard +input keys Backspace,Delete,Home,End,left/right arrows. +Commands are case-insensitive. Delimiter is arbitrary nonzero number of spaces. + +At any moment mtdbg can be terminated by command "quit" (without arguments). +You can also simply press to close button in the right upper corner of window. + +When debugger is started without command string parameters, no program is +loaded. Also mtdbg can be started with command string, in this case it tries +to load program with the name pointed to in first parameter in command string +and parameters pointed to following (if present). + +If no program is loaded, you can load a program with the command +load [] +Examples: +load /rd/1/example +LOAD /rd/1/aclock w200 h200 + LoaD /hd0/1/menuetos/dosbox/dosbox +All that stays after first space after executable file name, is exactly passed +to program as command string. +The command "load" reports result in the messages window (a little higher +than command line window). If program was loaded successfully, there will +be the appropriate message; otherwise the message will contain error reason. +Most probable error is "file not found" if wrong file name is given. + +The debugger can load files with information on symbols in the program +(labels, global variables) - text files, each line of which has format +0x +(lines, which do not have such format, are ignored). Such file can be created +by hand or generated automatically by fasm. Evident load can be done by command +load-symbols +Furthermore, when the debugger executes the command "load", it checks for +presence of file with name as of loading binary and extension '.dbg' +(/rd/1/example.dbg in the first of examples above), and if such file exists, +the debugger loads it automatically (with the message "Symbols loaded", if +all is OK). + +It can happen so that loaded program is packed. General principle of +program packing is following: at first input file is packed (by some +pack algorithm), then is appended small code which gets control at program +start, unpacks input code in the memory and then passes control to it. +If program is packed, it "real" code is not visible and for debugging it is +needed previously to pass through unpacker code. +mtdbg determines most of existing packers (mxp,mxp_lzo,mxp_nrv,mtappack) +and in this case suggests to automatically go to "real" code. It is recommended +to accept (press 'y' or ), but you can refuse too. At refusal and if +program is packed by something unknown the command "unpack" (without arguments) +can be used. Call it only in the case when you are sure that program is packed +and control has not already went to main code! [Starting from Kolibri 0.6.5.0, +this paragraph is no more actual, because one can pack applications as all +binary files with kpack and the unpacker code in this case is located in the +kernel and is transparent for debug.] + +Loaded program can be terminated by the command "terminate" (without +arguments). The command "detach" (without arguments) detaches from program, +after that program continues execution normally, as if there was no debugger. +After both this commands program stops to be debugged. + +It is possible to anew load program for debugging by the command "reload" +(without arguments). If there is already loaded program, it is terminated +and new instance is started (from the beginning) (with the same command +string), in this case the command is similar to the commands +terminate +load +Otherwise is loaded anew latest program, which was debugged (in the current +seance of work with mtdbg) (with the same command string), i.e. is similar to +load , +but the command "reload" in both cases is shorter and more convenient; +moreover, "load" thinks that new program is loaded and moves data window +(see below) to zero address, and "reload" keeps current address. + +The command "help", which can be shorten to "h", is always available. +All commands are divided on groups. +"help" without arguments displays the list of command groups. +"help" with group name displays the list of commands in this group with short +comments. +"help" with command name displays information about given command. +Examples: +help +help control +h LoaD + +The debugger window consists from the following items enumerated from up +to down: +- status string. If there is loaded program, shows its name and state + ("Running/Paused"), otherwise reports "No program loaded". +- registers window - shows values of general-purpose registers, register eip + and states of single flags: CF,PF,AF,ZF,SF,DF,OF: if flag is cleared, then + is displayed lower-case letter, if flag is set, then upper-case one. + Registers which are changed from previous moment are highlighted in green. +- data window (dump window) - shows memory contains of loaded program +- code window (disassembler window) - shows program code as disassembled + instructions +- messages window +- command line window + +Dump window can display data starting from any address, to this serves +the command +d +The command "d" without arguments flicks dump window down. +The same is for code window and the command +u +or simply "u". +Examples: +d esi - displays data at address esi (e.g. is useful before execution of + instruction rep movsb) +d esp - displays stack +u eip - disassembles instruction starting from the current + +Expressions in mtdbg can include +- hexadecimal constants +- names of all general-purpose registers (8 32-bits, 8 16-bits and + 8 8-bits) and register eip; values of 16- and 8-bits registers are padded + with zeroes to 32 bits +- four arithmetic operations +,-,*,/ (with standard priorities) and + brackets +- [if symbols information was loaded] names, loaded from dbg-file +All calculations are realized modulo 2^32. +Examples of expressions: +eax +eip+2 +ecx-esi-1F +al+AH*bl +ax + 2* bH*(eip+a73) +3*esi*di/EAX +The command +? +calculates value of specified expression. + +Values of registers in loaded program can be changed by the command "r", which +has two absolutely equivalent forms: +r +r = +(in both cases you can place spaces as you want). Register can be any of +above-mentioned - 24 general-purpose registers and eip. + + +Let us assume that the command "load" was successfully load program for +debugging. +Immediately after loading program is suspended and does not execute. +Press Ctrl+F7 (command-line analog is the command "s") to make one step +in loaded program, after that control returns to debugger which displays +new contains of registers and memory. The system call "int 40h" is considered +as one step. +Pressing Ctrl+F8 (command-line analog is the command "p") also makes step in +loaded program, but procedure calls, string operations with prefix +rep/repz/repnz and 'loop' cycles are executed as one step. +The one-step commands are used usually on single program sections, +when it is needed, for example, to regularly trace registers value and/or +some variables in memory. +The command +g +resumes program execution and waits until control goes to eip=given address, +and in this moment suspends program. The command "g" without arguments +simply resumes execution. + +To suspend program use the command "stop" (without arguments). + +In the typical situation it is required that program is executed normally, +but when some conditions are satisfied, program suspends and debugger receives +control. The corresponding conditions are called breakpoints or simply breaks. +Primary type of breakpoints is to concrete address, i.e. stop execution at +eip=. Such breakpoints are set by the command +bp +Note that if there is only one such breakpoint, there is more convenient to use +the command "g" with argument instead. + +Other type of breakpoints is on access to given memory area. Maximum +numbers of such breakpoints is 4 (because hardware features of x86 processors +are used and they allows only 4). +bpm - breaks at any access to byte at given address +bpm w - breaks at write to byte at given address +bpmb,bpmw,bpmd - breaks to access correspondingly to byte, word +or dword at given address. bpm ¨ bpmb are synonyms. When bpmw,bpmd are used, +address must be aligned according to correspondingly word bound (i.e. be even) +or dword bound (i.e. be divisible by 4). +bpmb,bpmw,bpmd w - similar to break on write. + +To see the list of set breakpoints use the command "bl", to obtain information +on concrete breakpoint use "bl ". Unnecessary breakpoints can be +deleted with the command "bc ", temporarily unnecessary can be +disabled by the command "bd ", when they will be needed again, +use the command "be ". + +Remarks. + +1. When debugging your own programs you can put in code instructions + int3 (pay attention to absence of space!). Such instruction causes + exception at normal run, which leads to process termination, but + at work under debugger it is simply activated (with the message + "int3 command at xxx"). This feature allows to not think about addresses + to use in the commands g and/or bp. +2. All output and all input is oriented on hexadecimal scale of notation. +3. When program is executed, registers and data window shows information + regarding to moment before resume; you can not set registers value in this + mode. Nevertheless the command "d" in this mode shows information that + was true in the moment of command delivery. + + diamond + mailto:diamondz@land.ru diff --git a/data/Vortex86MX-eng/docs/README.TXT b/data/Vortex86MX-eng/docs/README.TXT new file mode 100644 index 0000000000..d8d770e76c --- /dev/null +++ b/data/Vortex86MX-eng/docs/README.TXT @@ -0,0 +1,268 @@ + ************************ + * Kolibri OS 0.7.7.0+ * + * February 2010 * + ************************ + + The latest release of the OS is available on the official site: + http://kolibrios.org + + If you have questions - look for support on our forum: + http://board.kolibrios.org (rus+eng) + + *********************************** + * What is new in this release? * + *********************************** + + The following changes, revisions, fixes in the kernel have been made: + + From Evgeny Grechnikov (Diamond) - Russian Federation + 1) Improvement of drives detection using BIOS service (V86) + 2) Kernel bugfixes. + + From Sergey Semyonov (Serge) - Russian Federation + 1) Driver for ATI videocards updated. + 2) Linux-like kernel mutexes + + From Mihail Semenyako (mike.dld) - Republic of Belarus + 1) Refactoring of window subsystem. + + From + 1) Processing API functions in order to completely remove the shift-register-call + 2) Refactoring, optimization, bugfixes of some places in the kernel. + + From A.Jerdev (art_zh) - United Kingdom + 1) Memory-mapped I/O (MMIO) access from the userworld. + 2) PCIe Extended configuration space access (auto-adjust for AMD-NPT since Athlon64). + + From turbanoff + 1) Read from ext2fs/ext3fs. + + From Marat Zakiyanov (Mario79) - Russian Federation + 1) Improvements in the processing of mouse clicks. + + From hidnplayr + 1) Rewriting of the entire network subsystem. + + From Asper + 1) Drivers for the sound cards VT823(X) and EMU10K1X. + + From tsdima + 1) Driver for the sound card ForteMedia fm801. + + From Maxis + 1) changes in free memory checks. + + + + + + The following changes, revisions, fixes in applications have been made: + + * New versions of applications and new applications: + + FTPS - tsdima, some improvements + VIEW3DS - macgub, version 0.054 + FASM - Pavel Rymovski (Heavyiron), updated to version 1.69.11 + IgorA, use the library box_lib, russification, + Marat Zakiyanov (Mario79) fix bugs encountered + Evgeny Grechnikov (Diamond), fix of window wrapping + PCIDEV - art_zh, MMIO sample dumps added; vendors database + trimmed to reduce the distro size. + BOARD - Evgeny Grechnikov (Diamond), do not throw out existing + messages at the program start + UNVWATER - Asper, demo ported from OctaOS + (the author is Octavio Vega Fernandez). + HEED - staper, version 0.14: use the library box_lib; + Ctrl+C/X/V, Ctrl+B to select a block + Marat Zakiyanov (Mario79), using of OpenDialog component, + little optimization of the code + SHELL - Albom, version 0.4.2 + CPU - Evgeny Grechnikov (Diamond) at the suggestion of + Kirill Lipatov (Leency), do not show system processes + by default + HTMLV - Kirill Lipatov (Leency), version 0.62a + EOLITE - Kirill Lipatov (Leency), version 0.98.7a + RTFREAD - Sorcerer, cosmetic fix + dunkaist, menu_bar and scroll_bar from box_lib, 'end' hotkey + E80 - Albom, version 0.5.1 + KIV - Evgeny Grechnikov (Diamond), file name in the window + title, configurable keyboard shortcuts for next/prev + images in the current folder + SUDOKU - staper, port of Sudoku game - that is a puzzle with digits, where you + have to fill free cells with digits from 1 to 9 so that every row, + every column and every small square 3x3 contain each digit just one time. + There are 9 levels in the game. + REVERSI - staper, port of strategy game Reversi (Othello) + MSQUARE - staper, math puzzle "magic square": sum of the numbers in rows, columns + (less often in diagonals) should be equal + FINDN-S - Artemonische, a simple game in which you have to collect all the numbers + in the order of 10 to 90 + PANEL - Evgeny Grechnikov (Diamond), a little change in the panel clock + and reanimation of backlight on the Alt+[Shift+]Tab press. + AC97SND - Asper, support of playlists in m3u format. + @NOTIFY - SoUrcerer, program for popup text messages + DOSBOX - Evgeny Grechnikov (Diamond), version 0.74 + ASCIIVJU - Konstantin Dutkevich (Nazarus), program shows ASCII table + PIPETKA - Rock_maniak_forever, program to get color of a pixel on the screen + SNAKE - dunkaist, yet another implementation of classic game + + + + + * New versions of dynamic libraries and new dynamic libraries: + libini - Evgeny Grechnikov (Diamond), added function to read + keyboard shortcuts + box_lib - IgorA, update component tree_list, new component + text_editor, documentation on the library + Marat Zakiyanov (Mario79) refinement of ŽpenDialog component, rewriting + of some applications to use it, new component PathShow + + + +/-----------------------------------------------\ +* Dates of publication of the distribution kits * +\-----------------------------------------------/ + +RE N1 30.08.2003 +RE N2 07.10.2003 +RE N3 26.11.2003 +RE N4 23.12.2003 +RE N5 15.02.2004 +RE N6 27.03.2004 +KOLIBRI N1 16.05.2004 +RE N7 11.06.2004 +KOLIBRI N2 28.08.2004 +RE N8 01.12.2004 +KOLIBRI N3 22.02.2005 + Beta 2: 20.03.2005 +KOLIBRI N4 07.06.2005 +KOLIBRI 0.5.0.0 04.10.2005 + 0.5.1.0 12.10.2005 + 0.5.2.0 02.12.2005 + 0.5.3.0 18.03.2006 + 0.5.8.0 09.07.2006 + 0.5.8.1 25.07.2006 + + 0.6.0.0 04.09.2006 + 0.6.3.0 31.10.2006 + 0.6.5.0 14.02.2007 + + 0.7.0.0 07.06.2007 + 0.7.1.0 23.09.2007 + 0.7.5.0 31.01.2009 + 0.7.7.0 13.12.2009 + +/----------------\ +* KolibriOS TEAM * +\----------------/ + +This list contains all, who has actively helped to creation and development +of KolibriOS, whoever possible. + (people are enumerated in the order by time of participation in the project, + from bottom to top - from past to future, through present) + +* Trans \ +* VaStaNi | +* Ivan Poddubny | +* Marat Zakiyanov (Mario79) | +* Mihail Semenyako (mike.dld) | system programming +* Sergey Kuzmin (Wildwest) | +* Andrey Halyavin (halyavin) | loaders, +* Mihail Lisovin (Mihasik) | kernel improvements and so on +* Andrey Ignatiev (andrew_programmer) | +* NoName | +* Evgeny Grechnikov (Diamond) | +* Iliya Mihailov (Ghost) | +* Sergey Semyonov (Serge) | +* Johnny_B | +* kasTIgar | +* SPraid | +* Rus | +* Alver | +* Maxis | +* Galkov | +* CleverMouse | +* tsdima | +* turbanoff | +* Asper | +* art_zh / + +* Mihail Lisovin (Mihasik) \ +* Andrey Ivushkin (Willow) | +* Mihail Semenyako (mike.dld) | +* Pavlushin Evgeny (Exis) | +* Ivan Poddubny | application programming +* Marat Zakiyanov (Mario79) | +* Sergey Kuzmin (Wildwest) | +* Andrey Halyavin (halyavin) | creation of new, +* Hex | port of existing +* Andrey Ignatiev (andrew_programmer) | or revisions of old +* ealex | applications for Kolibri +* Olaf | +* Evgeny Grechnikov (Diamond) | +* Navanax | +* Johnny_B | +* Pavel Rymovski (Heavyiron) | +* Vitaly Bendik (mistifi(ator) | +* Iliya Mihailov (Ghost) | +* Maxim Evtihov (Maxxxx32) | +* Vladimir Zaitsev (Rabid Rabbit) | +* vectoroc | +* Alexey Teplov () | +* Sergey Semyonov (Serge) | +* YELLOW | +* iadn | +* Maciej Guba (macgub) | +* Mario Birkner (cYfleXX) | +* hidden player (hidnplayr) | +* trolly | +* nilgui | +* kaitz | +* DedOk | +* SPraid | +* Rus | +* Alver | +* Dron2004 | +* Gluk | +* Aleksandr Bogomaz (Albom) | +* Kirill Lipatov (Leency) | +* Vasiliy Kosenko (vkos) | +* IgorA | +* staper | +* chaykin | +* Alexander Meshcheryakov | + (Self-Perfection) | +* CleverMouse | +* tsdima | +* art_zh | +* Asper | +* Pterox | +* Artemonische | +* dunkaist / + +* Hex \ +* Diamond / documentation + +* CodeWorld \ forum http://meos.sysbin.com +* mike.dld / site http://kolibrios.org; svn-server + +* Alexey Teplov () \ (KolibriOS logo) +* goglus | design (KolibriOS background) +* Kirill Lipatov (Leency) / (KolibriOS icons) + +* Pavel Rymovski (Heavyiron) \ +* Vitaly Bendik (mistifi(ator) | +* vectoroc | +* Veliant | testing, +* AqwAS | countenance +* Mike | +* camper | +* Dmitry the Sorcerer | +* Ataualpa | +* Maxis | +* Galkov | +* ChE / + +and others... + + KolibriOS team diff --git a/data/Vortex86MX-eng/docs/STACK.TXT b/data/Vortex86MX-eng/docs/STACK.TXT new file mode 100644 index 0000000000..9b2f1c7184 --- /dev/null +++ b/data/Vortex86MX-eng/docs/STACK.TXT @@ -0,0 +1,387 @@ +What is implemented +=================== + +The following features are present in the TCP/IP stack code: + + IP layer. + ICMP. + TCP layer. + UDP layer. + local loopback. + Realtek 8029 PCI ethernet interface. + Realtek 8139 PCI ethernet interface. + Intel i8255x PCI ethernet interface. + Dynamic ARP table. + PPP dialer + +And the following internet applcations are implemented + + HTTP Server + Telnet + POP Client + DNS Name resolver + MP3 Server + TFTP Client + IRC Client + +There are also a number of experimental applications for streaming music +and performing interprocess communication via sockets. A Web broswer is in +development + + +What is not implemented +======================= + +The IP layer does not process header options. +The IP layer does not support routing. +Packet fragmentation is not supported. + + +How to configure Kolibri for PPP +=============================== + +See ppp.txt + + +How to configure Kolibri for Ethernet +==================================== + +First, you need to have a supported ethernet card fitted, or present +on your motherboard. If you are uncertain what type of hardware you +have, try to configue the stack. If you have supported hardware it +will be found, and enabled. + +Setting Up the ARP Table +------------------------ + +Kolibri's ARP table is dynamically created and maintained; You can see what +hosts Kolibri has communicated with by running the ARPSTAT application. + +Enabling Ethernet +----------------- + +Boot Kolibri, then select STACKCFG from the NET menu. +Press the 'Read' Button, then select 'Packet Driver'. +Press 'Change' next to the IP address, and enter the IP address you want +to use. Make sure it is on the same sub-net as the LAN to which you are +connected. +Press 'Apply' to action the changes. +Close the program. + + +The stack is now running, which you can test by pinging Kolibri from a +remote host. + + +The simplest way to connect two PC's together is using a 'Null Modem' +Ethernet cable. These simply cross certain wires over. They can be +purchased from PC stores, but are simple to make. Details can be found +on the web. Look on google for 'ethernet cross over cable' or similar. + + +How to use TCP/IP locally, with no Network +========================================== + +Kolibri supports a form of local loopback that means applications on the +same PC can communicate with each other via sockets as though they +were on separate hosts. To connect to an application on the same machine, +specify the local IP address as the destination address. You do not even +need to configure the stack for ethernet; local loopback will work without +any network hardware. It's great for development and testing. + + +Application Programming Interface +================================= + +The developer can access the stack through interrupt 0x40, function 53. +The file TFTPC.ASM gives a good example of how to use the programming +interface ( at least, for UDP), but as network communication is complex +I'll give an overview. + + +Sockets +======= + +Applications connect to each other and pass information between themselves +through a mechanism called a 'socket'. Sockets are end-points for +communication; You need one at each application to communicate. + +Using sockets is a little like using files on an OS; You open them, read +and write to them, then close them. The only thing that makes life slightly +more complicated is that unlike with a file, you have something intelligent +at the other end ( which for example may not want to close when you do! ) + +Lets deal with the terminology before we go any further. + +socket A unique identifier used by the application for communication. +local port A number that identifies this application on the local host. + Ports are a way to allow multiple applications to communicate + with other hosts without the data becoming mixed up. ( The + technical term is 'multiplex' ). Port numbers are 16 bit. +remote port A number that identifies the application on the remote host + to which we are communicating with. To the remote host, this is + it's 'local port'. Port numbers are 16 bit. +IP Address A 32 bit number that identifies the remote host PC that we are + communicating with. +Passive Refers to the mode by which a socket is opened; When opening in + passive mode, the local PC is awaiting an incoming connection. +Active Refers to the mode by which a socket is opened; When opening in + active mode, the local PC will attempt to connect to a remote + PC. + +When you connect to a socket on a remote PC, you need to specify more than +just the IP address, otherwise the remote stack will not know to which +application it should send your data. You must fully qualify the address, +which means you specify the IP address and the port number. This would be +written like this + +192.168.1.10:80 ; Connect to port 80 on the machine 192.168.1.10 + +Port numbers are important. Some are 'well known' and provide access to +common applications. For example port 80 is used by HTTP servers; That +way I can connect to a webserver on a host without having to find out +what port number the application is listening on. + +This brings me to the way in which you open a socket; As I said earlier, +there are two modes, Passive and Active. A webserver would open a passive +socket, as it is waiting for incoming connection requests. A web browser +would open an active socket because it is attempting to connect to a +specified remote host. + + +Access to programming interface +=============================== +The developer accesses the stack functions through interrupt 0x40, +function 53. Some functions may be accessed through function 52, but these +are mainly for stack configuration. +Here is a summary of the functions that you may use and the parameter +definitions. + + +Get Local IP Address +-------------------- +eax = 52 +ebx = 1 + +IP address returned in eax ( in internet byte order ) + + +Write to stack input queue +-------------------------- +eax = 52 +ebx = 6 +edx = number of bytes to write +esi = pointer to data ( in application space ) + +On return, eax holds 0 for OK, or 0xFFFFFFFF for error. +This interface is for slow network drivers only ( PPP, SLIP ) + + +Read data from network output queue +----------------------------------- +eax = 52 +ebx = 8 +esi = pointer to data ( in application space ) + +On return, eax holds number of bytes transferred. +This interface is for slow network drivers only ( PPP, SLIP ) + + +Open a UDP socket +----------------- +eax = 53 +ebx = 0 +ecx = local port +edx = remote port +esi = remote ip address ( in internet byte order ) + +The socket number allocated is returned in eax. +A return value of 0xFFFFFFFF means no socket could be opened. + + +Open a TCP socket +----------------- +eax = 53 +ebx = 5 +ecx = local port +edx = remote port +esi = remote ip address ( in internet byte order ) +edi = mode : SOCKET_PASSIVE or SOCKET_ACTIVE ( defined in stack.inc ) + +The socket number allocated is returned in eax. +A return value of 0xFFFFFFFF means no socket could be opened. + + +Close a socket (UDP Only ) +-------------------------- +eax = 53 +ebx = 1 +ecx = socket number + +On return, eax holds 0 for OK, or 0xFFFFFFFF for error. + + +Close a socket (TCP Only ) +-------------------------- +eax = 53 +ebx = 8 +ecx = socket number + +On return, eax holds 0 for OK, or 0xFFFFFFFF for error. + + +Poll socket +----------- +eax = 53 +ebx = 2 +ecx = socket number + +On return, eax holds the number of bytes in the receive buffer. + + +Read socket data +---------------- +eax = 53 +ebx = 3 +ecx = socket number + +On return, eax holds the number of bytes remaining, bl holds a data byte. + + +Write to socket ( UDP only ) +---------------------------- +eax = 53 +ebx = 4 +ecx = socket number +edx = number of bytes to write +esi = pointer to data ( in application space ) + +On return, eax holds 0 for OK, or 0xFFFFFFFF for error. + + +Return socket status ( TCP only ) +--------------------------------- +eax = 53 +ebx = 6 +ecx = socket number + +On return, eax holds the sockets TCP status. +This function can be used to determine when a socket has actually connected +to another socket - data cannot be written to a socket until the connection +is established (TCB_ESTABLISHED). The states a socket can be in are defined +in stack.inc as TCB_ + + +Write to socket ( TCP only ) +---------------------------- +eax = 53 +ebx = 7 +ecx = socket number +edx = number of bytes to write +esi = pointer to data ( in application space ) + +On return, eax holds 0 for OK, or 0xFFFFFFFF for error. + + +Check port number +----------------- +eax = 53 +ebx = 9 +ecx = port number + +This function is used to determine if a port number +is in use by any sockets as a local port number. Local +port numbers are normally unique. + +On return, eax is 1 for port number not in use, 0 otherwise. + + +Opening a TCP socket in Kolibri +=============================== + +There are two ways to open a socket - Passive or Active. + +In a Passive connection your application 'listens' for incoming +requests from remote applications. Typically this will be done when +you are implementing a server application that allows any other +application to connect to it. You would specify a 'known' local +port number, such as 80 for a web server. You would leave the +remote IP and remote port number as 0, which indicates any +remote application may connect. + +Once the socket has been opened you would wait for an incoming +connection before doing anything. This can be by either checking +the socket status for TCB_ESTABLISHED, or waiting for data in the +receive buffer. + +In an Active connection, you are making a connection to a specified +remote port. The remote IP and remote port parameters must be filled +in with non-zero values ( otherwise, what are you connecting to? ). +You also specify a unique local port number so the remote application +can uniquely identify you - after all, there may be several applications +on your machine connected to the same remote host. See below for finding +a unique port number. + + +How to find an unused local port number +======================================= + +Typically when you are creating an active connection to a remote +socket you will want to choose a unique local port number. Local +port numbers normally start from 1000; The following code may +be used to obtain an unused port number prior to making the +open socket call. + + mov ecx, 1000 ; local port starting at 1000 + +getlp: + inc ecx + push ecx + mov eax, 53 + mov ebx, 9 + int 0x40 + pop ecx + cmp eax, 0 ; is this local port in use? + jz getlp ; yes - so try next + + ; ecx contains a free local port number + + + +Writing data to a socket +======================== + +There are two functions available depending on whether the socket +was opened for TCP or UDP protocol; The call parameters are the +same however. When the socket is being opened for TCP, use the +status function to poll for a connection - data cannot be written +to a socket until another socket has connected to it, and the +state of the socket is TCB_ESTABLISHED. + +When you write data, the call results in a single IP packet being +created and transmitted. Thus the user application is responsible for +the size of transmitted packets. Keep the packet sizes under 768 bytes. +If you are writing a terminal program like telnet, you may want to send +a packet for each keystroke ( inefficient ) or use a timer to send data +periodically ( say, every second ). + + +Reading data from a socket +========================== + +There is one function to read data from a sockets receive buffer. This +function retrieves one byte at a time. You can use the poll function to +test the receive buffer for data. + + +Closing a socket +================ + +Simply call the appropriate function - there is one for TCP, and another +for UDP. When closing a TCP socket, don't forget that the other end +may continue to send data, so the socket may remain active for a +few seconds after your call. + + +If you have any questions or have suggestions for improving this +document please contact me at mikeh@oceanfree.net. diff --git a/data/Vortex86MX-eng/docs/VRR_ENG.TXT b/data/Vortex86MX-eng/docs/VRR_ENG.TXT new file mode 100644 index 0000000000..8a2e9ec850 --- /dev/null +++ b/data/Vortex86MX-eng/docs/VRR_ENG.TXT @@ -0,0 +1,104 @@ +Vertical Refresh Rater + +Version 2.0 + +Copyright (C) 2003, Trans + + +Text Version 1.1 (02.08.03) + +Win text (cp1251). (DOS codepage text - see down.) +------------------------------------------------------------------------------- + +Contents: +1. Why it need? +2. Installation. +3. Using. +4. FAQ. +5. Support. + +1. Why it need? +--------------------- +The problem of "60 Hz" is falling stand before of users of MeOS in modern condisions. +As a rule, most modern computers consist of 17" monitor (all written later is not actual +for owners of LCD monitors). If on 14" or 15" monitors the problem of "60 Hz" not a +main, but with 17" monitor it's a most pantfull. And with more size monitors I have no +words for discusion: it's a slade-show. Of couse, all of the upper correlated with +standart interface of VESA. As for VESA 3.0 - yes, interface have more rich features, +but it have no possiblity of change videomode in protect mode (the Virtual86 not realized +in MeOS !!!!!). + +The MeOS not known as a detected devices on boot, it setting of standard VESA videomode +with 60 Hz vertical refrash rate ! + +This programm is a FreeWare. And distribute "AS IS ...". Author not +carreing responsibility for probable damage :) . + +!!!!!_Warning_!!!!!: +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +! On this time programm have a EXPERIMENTAL status (!). And this reason you have a ! +! chance destroy own device (monitor). Espesialy this taking attantionall users with ! +! monitor without of rate protection. ! +! If you decide using this util I have a suggestion: fill of information form and ! +! send me. ! +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +2. Installation. +----------------- +Extract file VRR (it's ordinary executed MeOS file) from archive and situated it on +C:\ root or MeOS floppy. In main, VRR may situated on any directory (you must have +possibility run this file under MeOS). + + +3. Using. +---------- +The VRR is a standard executed file of Menuet Operation System. You may send on +execute this file by SYSTREE or MASH. + +After redraw of programm window will be present of current vertical refrash rate +and table with possibiling videoregimes. It's sorrably, table have VERY small +videomode (the programm is experimental). + + Change of videomode + ~~~~~~~~~~~~~~~~~~~~~ +You may select interesting videomode using _ONLY_ numerical keys: 1,2,3,4 and 5. +In a first step you must select resolution of videoregime. In a second step - need +select of vertical refresh rate. All changes are indicated on screen in a the +programm window. After select videomode, to set mode you must press "Enter" or +button "Ok". Notification: in this time all executing MeOS programs will be +killing. It this needed for minimize artefacts of the screen. After change videomode +you have a two way. First way: you can not any doing and after 13 seconds waiting +return last videomode. Second way: press two-three time any key or some time mouse +click on artefacts of VRR (or this plase) and fixing selected mode. Also you have +possibility modification of horizontal screen size by button "Left"\"Right" or keys +"+\-". For correcting your select you may use button "Cancel". + +Also in programm realized return at initial videomode with 60 Hz vertical refresh +by button "Default". And you may return in last videomode by button "Return" or +key "r" + +Note: +~~~~~~ +In this time programm may change vertical refresh rate _ONLY_ by lowing screen +resolution, because this method will be using at most part videocard +(VGA, SVGA or modern) + +Example: +If you have videomode 1024x768x60Hz and if you want select 800x600x95Hz, you must +press key "3" and key "1". After that key "Enter" or button "Ok". And after redraw +screen two time click on last program window position. If need using button +"Left\Right" for correcting horizontal size. + +4. FAQ. +---------- + +5. Supports. +---------------- +All questions, notes and wishs you may send to author by following e-mail: + + transafe@rambler.ru + transafe@chat.ru + trans397@yahoo.com + +Using with enjoy! +Trans. diff --git a/data/Vortex86MX-eng/doexe2.asm b/data/Vortex86MX-eng/doexe2.asm new file mode 100644 index 0000000000..eaebd8aaf8 --- /dev/null +++ b/data/Vortex86MX-eng/doexe2.asm @@ -0,0 +1,68 @@ +filename equ '%EXENAME%' + +virtual at 0 +file filename:3Ch,4 +load pehea dword from 0 +file filename:pehea,0F8h+28h*3 +load NumberOfSections word from 4+6 +load SizeOfOptionalHeader word from 4+14h +if NumberOfSections<>3 +error Expected three sections, .text, .bss and .reloc +end if +if SizeOfOptionalHeader<>0E0h +error Nonstandard PE header +end if +load RelocsRVA dword from 4+0A0h +load RelocsSize dword from 4+0A4h +load ImageBase dword from 4+34h +load TextRVA dword from 4+0F8h+0Ch +load TextSize dword from 4+0F8h+8 +load TextOffs dword from 4+0F8h+14h +load BSSSize dword from 4+0F8h+28h+10h +load RelocRVA dword from 4+0F8h+28h*2+0Ch +load RelocOffs dword from 4+0F8h+28h*2+14h +if BSSSize +error Second section expected to be .bss +end if +if RelocRVA<>RelocsRVA +error Third section expected to be .reloc +end if +;file 'test.exe':pehea+0F8h,28h +;load physofs dword from 4+14h +;load mem dword from 4+8 +;file 'test.exe':physofs+16,4 +;load sz dword from $-4 +end virtual + +file filename:TextOffs,TextSize + +while RelocsSize>8 +virtual at 0 +file filename:RelocOffs,8 +load CurRelocPage dword from 0 +load CurRelocChunkSize dword from 4 +end virtual +RelocsSize=RelocsSize-CurRelocChunkSize +CurRelocChunkSize = CurRelocChunkSize-8 +RelocOffs=RelocOffs+8 +while CurRelocChunkSize +virtual at 0 +file filename:RelocOffs,2 +RelocOffs=RelocOffs+2 +CurRelocChunkSize=CurRelocChunkSize-2 +load s word from 0 +end virtual +CurRelocType = s shr 12 +RelocItem = CurRelocPage + (s and 0xFFF) +if CurRelocType=0 +else if CurRelocType=3 +load z dword from RelocItem-TextRVA +store dword z-(TextRVA+ImageBase) at RelocItem-TextRVA +else +error Unexpected relocation type +end if +end while +end while + +store dword TextSize at 10h +store dword RelocRVA-TextRVA at 14h diff --git a/data/Vortex86MX-eng/drivers/sound.obj b/data/Vortex86MX-eng/drivers/sound.obj new file mode 100644 index 0000000000000000000000000000000000000000..af4de0f6e22454596c6699ad931fa9f336f1bfa8 GIT binary patch literal 7761 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 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/fonts/char.mt b/data/Vortex86MX-eng/fonts/char.mt new file mode 100644 index 0000000000000000000000000000000000000000..df1cbd9a5700890d92cbb14d4ce320cee0d73f82 GIT binary patch literal 2304 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 ZXu00|d6RcFA?xl+0Flt9Ccgjx00CJ5gp&XO literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/games/reversi b/data/Vortex86MX-eng/games/reversi new file mode 100644 index 0000000000000000000000000000000000000000..2dcc36a151eec86ce5096d41d89866d48c5b42bd GIT binary patch literal 3294 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 c8s0f8OUx@y~yOL{NR-v8v- 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 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/hdread b/data/Vortex86MX-eng/hdread new file mode 100644 index 0000000000000000000000000000000000000000..dc749323277172b0f76d18ffa63c380f7bb3be70 GIT binary patch literal 1287 zcmV+i1^D_)P(w@Z3IG6s00001Mv*2LLXK;4&&M{gp_a5w91nD}-HPHytKd%&SVZOe z=2J`}<4jPj!blANTP7mp0us~Ct-JGC#y?-$h_O9J`MuOlp9Ji39xlkMxOB9cR z9HX{qx96!4x>u_ls`g!V=2aE`VhBd(LQuo?_*G-NCUR>DmWjEp*5hgO*H<6rdYTv? zw;%)5n)9_tCHV+_Id0$e;_!&ngAQi_T?5P2V#!c(nEq+ZG7ic#X$90TcHCls++Blj#|pe4RfHPOZok{kRdVh=ETK}Rx7U($afpL zSjSB}1I)@-_Nc||o23ab(TjJuA+=^z!#B3MGzc0ytrrW$P0DX}d1&mNN_h8vwYgD}RIDxM-~o!5N)D`1D-C0#V@I+z6~=aH3s*}WsSN%s;^ zB>4;tyV&Womvr_VZW`Fp{h&X?BTZx;Aa3asu_Tj6cR758uGxt&i$?Lqh_f)}-l^zz zdHlID$mLoMqS$66Wq{#~;+Y?Or#Wr9xCrA4KG>4fCjE1kzQBt5AQtw;_5M_kBc}^! zx4DP?&ysi7$(o(MHvpK?nH=N_&h-y7Od{wJ8a)`fhm$uSL_Wu2#~4GeMXRT8UfD?P zBHbu(6N{cIDEpT$Fi2^IojHCYPPi&=_ZNBrLF4llEoe-H$}-Tofqp&^|yA#YXzej5z_?lp_qEL?Cu+w zCPO(lX?{<)_0-?AZ4?~hvTrwy2h@|!ZDijdV%Z`SCaPS=f+f%KZ?a5Tr)G4Z>UXZB zIx4;S0-Nd&W1!PGd8aE_r6cBCXa}s6=>JS9O`P)Yu)>R-T!v@C%Ho%=Jy8E&hX@i; zG25o$3t&d&;gY4(!4G6opggRP6NZ@ty#A8dMde{Ug-di^mSK$dxC3SehVB#7E#%|g z=;Q}%AR~y!(cTI22qwCH(Yz3?K_Q@W%91|+k?_96%gei^+e}y5{$;~&F{!COQL$r) zmss3nCdNG%JWRN)L%#85AeyImRwrX;Qum1VW#AZi9NyD#x-agqJ)d&th;?d}!S?XM z#{#3KLDnqdNVpIz-7uG=vVgi+U)+fB@8!K5ATt3epBvXgz(oRdnJ&t#$`k;VplLwk zo#r`u>HiUx3+Z`PN7Ts&xU#gi0eiS=75HEoR8*ILvNv;_Nbj0G!BA2AJ*ocU`9q$h x^|S<3_*61;)6WpgI1A~^c`rl((*l*KKYpi>n{;c+`p+W349RCscSHaH00P3kkD34g literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/htmlv b/data/Vortex86MX-eng/htmlv new file mode 100644 index 0000000000000000000000000000000000000000..bb1ba6f79c82a96be757bd8b98025ba04ca29906 GIT binary patch literal 9915 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 A{r~^~ literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/index_htm b/data/Vortex86MX-eng/index_htm new file mode 100644 index 0000000000..c88fcc52bb --- /dev/null +++ b/data/Vortex86MX-eng/index_htm @@ -0,0 +1,30 @@ + + + + + KolibriOS web server - default message + + +

Welcome to KolibriOS server

+

+ If you can read this with an external html-browser then Kolibri + networking is correctly set up. +

This file: /rd/1/index.htm +

+ + + + + + + + + + + + + diff --git a/data/Vortex86MX-eng/kerpack b/data/Vortex86MX-eng/kerpack new file mode 100644 index 0000000000000000000000000000000000000000..511e23d2daab0a765ccd64373f1aee2768090f8f GIT binary patch literal 6421 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 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/keymap.key b/data/Vortex86MX-eng/keymap.key new file mode 100644 index 0000000000000000000000000000000000000000..f6f2a5d8a7c5d4ee9dc1db5ee573fc521604329e GIT binary patch literal 2688 zcmXq$HZ(FeF*P%{ur$!M<=`wVPc15`EX~X>h>qp0ODs-FOV7y4&aqZcV2G)zNG?mt z%hl1-XD~5UaDeLrny_Wl4zmsBn=Q6(+`e<0qmzxxe>ZmzPcLsDUqAnVz@Xre(6I1` z$S6lAXBSr#88c}`2W1u2I5jN|&3J7N&cJZjppeK=Pyc}GTHZRxU>BfjpfOfTbqqC8 z5zb*we!ez#_Jr)WBieq30S0DB;jbNy9R3IDki!4aK|=<0c=+oQ@;^!8ucX|ss-~}@ zX=@*g9R4SO_QS*f)Ja1IEok^#Tg4Nye`tokJuLjIK|K4=d{UPt-Z}NX0}hA#mg{dc2h(Dgud>Uwz(g4W9Cnv z*wZm-PUAcsLiP`(^sjbSNnJztT>Rw=n!xZ+tb&#QaVorZg|PBJcM=1GRyjER>sVVU z63YLils}02M;2KAJ4V6E|EW`W>jGirzptt&!?bX4`nT897bRpr@!@YKEmNml9bGdc zCe9(Yc3}Oly#=}a|ML~8{QvgEkimv#<^K|B`JaGX{@=NZRQ_K(V#r`O+{=Ho@&_3H cPcmWU&*ucXmp@;4>!x_Z%AZel!?XMW0KQF=u>b%7 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/kuzkina.mid b/data/Vortex86MX-eng/kuzkina.mid new file mode 100644 index 0000000000000000000000000000000000000000..01f4ecb91dd19f1d5fea7ca9a75c61af185942e2 GIT binary patch literal 456 zcmXv~-%G+^6uoMQ{g8xSiVTD-A%f~Df-yGc+FTAbr88VgbRiRu@=Nv7(0Z0G~sU$s*XwtOtN}Kzb<4_!OZ{ z7Qk}OW*8N5XaX%#hn6Aax=_2r&gy+69B49v>7Ro7DmoT*>a!EbYao5L{U$~W>@4BK zfe$N?6_D()F_392sfqbh%y?{t@(Pg8=D3Z6dA4TJ5{(VkynpkJ5#&;0ejg)GiOL(W ybXXs@Av@2;JgT5^&&nLJD2PSzN2tVh5||B(xKjn~0M0rf*+haLNrLh+KBHgJ7Lb?# literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/lang.inc b/data/Vortex86MX-eng/lang.inc new file mode 100644 index 0000000000..dc151ef654 --- /dev/null +++ b/data/Vortex86MX-eng/lang.inc @@ -0,0 +1 @@ +lang fix en \ No newline at end of file diff --git a/data/Vortex86MX-eng/lang.ini b/data/Vortex86MX-eng/lang.ini new file mode 100644 index 0000000000..c03a291d7d --- /dev/null +++ b/data/Vortex86MX-eng/lang.ini @@ -0,0 +1,28 @@ +[start] +startlng = 1 + +[comkey] +ccomkey1 = 1 +ccomkey2 = 4 +ccomkey3 = 7 + +[altkey] +altkey1 = 1 +altkey2 = 4 +altkey3 = 7 +altkey4 = 3 +altkey5 = 5 +altkey6 = 6 +altkey7 = 2 +altkey8 = 0 +altkey9 = 0 +altkey0 = 0 + +[langs] +1 = En +2 = Fi +3 = Ge +4 = Ru +5 = Fr +6 = Et +7 = Ua \ No newline at end of file diff --git a/data/Vortex86MX-eng/lib/cnv_png.obj b/data/Vortex86MX-eng/lib/cnv_png.obj new file mode 100644 index 0000000000000000000000000000000000000000..29a750c5458b6c8460011e9e81414529ef0b6574 GIT binary patch literal 3182 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 U9034}#-OztrC1m0d;kCd0Xth53;+NC literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/lib/msgbox.obj b/data/Vortex86MX-eng/lib/msgbox.obj new file mode 100644 index 0000000000000000000000000000000000000000..655d3dee72dac7a6768090ab954fdcbb25803a39 GIT binary patch literal 981 zcmV;`11kJWP(w@L3jhFt00001Yyc*tx23KZ}i}hoGk;$ydEkAq*6X zXOG`h6w4qI&^mc#98#AWFx|54#7&QxPf%Jy3V0+1t}krDAC12bO|jGVL-&4sXf}z6 zZGK-zO=HpLd=eZAQD5hVWYRV%P(2KxzLXE(jWD>g*8+NZdMH&+_1LoOKQ+v2p=?4P zD{Ockn{I(~rhGTJFG~Uw;Eq7Y9-c)EeyvV>N7di*ynr(K`^|jtbD3{Vw7Hz!1EGTJ zAQu9l_S>w#VF+|xddkD|^Imtf>#N(9LQm`1{^(m_D8UMD`nLM}QRB5*8X`b){h47+ zs({qy#E6h8T6m}8>0WwF;q4&TO9aS+trr*%&UZEyj=y$WJ5oN~DcLE08>tG6xaCax z_JC=^S=7&voO4aaM>^A05U^C%UX>TtmD0}VVk^+Q**FoLQ^)sL6GmK{-UZ5f8|Z2<2YV5U5kFrNL?M9x2rLE&!ns-7=a|%Gs^m=K zW&3BiYYRy;vs_ZkL@VUAv!J2)Ah~PUNQV1_jR^0E%-FaAoJU1#Ngpti7ndC*_-Xy` zFwdHX7uIV5`L*}w-rbU<=K93_<$EI+#(y6HeeictYUyFZ*Eii@ZHa$@A>t^&VNrYt zI?)39J1rXpqjGl7jEsvg80U6$s-d!J@j`q^R-rSvSCMd8sR$;!Aj62HQ7UAGL=;E% zhqN#sy37$g5|-swq=C#l1+!7K1o5aMfOBYLV!j@M`Y%iIR3j;nls%ap2-8Pd$Up`yc#2A{w3;J%f|9gFvVPKdINtmu-NF}GP~BjlcTo@Z1?`a*j2Ch zN#RGStnzURFS-sSg#TyHdz-(D^ZtsQ5ME zviya!3B(H115k6Ms-$6bngFP(bI;!7Iua@%v;1#(7AJG;J*kenaVlw-n;!rU00000 D`?cCd literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/lib/pixlib.obj b/data/Vortex86MX-eng/lib/pixlib.obj new file mode 100644 index 0000000000000000000000000000000000000000..ca2e94a7780dc586f691d3d46566dac759043422 GIT binary patch literal 4620 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 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/lib/sort.obj b/data/Vortex86MX-eng/lib/sort.obj new file mode 100644 index 0000000000000000000000000000000000000000..063da99799ee64d7114d1db4bda89769864ef138 GIT binary patch literal 851 zcmV-Z1FZZ@P(w?c1^@to0000#JOC#DVV(`3k}CVWm6ntCICt?Tk}=*NFrT_^ZEz}h zSmGB!i#s2uPNz$M7QruMM9xH}X#*fRElTrnv}+S_wepB6e6aoemB;F}6J`Q~y;TR0 zm@+!WK0h4t1)rn=ti!}rg`UCG8~9>jRt0VQ9887Hn6g^kC;7bV*b^qSXQPDnLoQ;J zVl*np5oflR;81(9cPMtjDZYr|z)@W@$I=0k!X8N`<=@L_PBR|P%C+C3X!b;=nem{~ zF=Qmx*YR>CyP>Tk2|z5ZrE0LTUcFtdW-i&cXz%S<)C^DR@Yy*n_`F|BB?q#CU5=+Y z)30eqRxPAdzlAH62*IIth~dwZ2?I5Md1@UW8YIC83Isw3=WwyBmN5)iq{3jfD1cPa zBZmBi$$rXe25}7vIK!3M&F_k+I&;G|a;u0Lli2HJ5nMX3r<7$d;wu|9DY}CSCO;B@ z=aXVT`$lW5^s5N*z*4<4W_=^T!hWvqxnhB*>BzKVTXa2c>L6{eUx@hLnY@ z1R~rIblVF{J_GjQkrvz-80sqTqEf3#hjC#_ApEh}n2-x4a|9Z&+L)VfXHnp%H`Pe1 z>=JP5;e(TzWEkte!6d(MCEG8M6>BSuzv^N;YYbYF)J)KNbmbPWhcd-t5LrkgvR2YG zd1pIq@y$l-_*X4hpP2{a&V1`O$vIf-P~qtXLdA9#oA9$j1X6K(Y7#H_sF*JnN}g#*_WP)P41%jJ10e z /@1 +Demos > /@4 +Graphics > /@6 +Sound and music > /@7 +Development > /@8 +System > /@10 +Data processing > /@14 +Network > /@15 +Other > /@18 +Help /rd/1/docpak +Run application /rd/1/run +Shutdown /rd/1/end +#1 **** GAMES **** +Logical games > /@2 +Arcades > /@3 +Spectrum emulator /rd/1/e80 +Memory Blocks /rd/1/games/mblocks +FreeCell /rd/1/games/freecell +Pipes /rd/1/games/pipes +Kosilka /rd/1/games/kosilka +RockeT ForceS /rd/1/games/rforces +Find Numbers /rd/1/games/FindNumbers +#2 **** LOGICAL GAMES **** +C4 /rd/1/games/c4 +15 /rd/1/games/15 +Mine /rd/1/games/mine +Just Clicks /rd/1/games/clicks +Checkers /rd/1/games/checkers +SQ_GAME /rd/1/games/sq_game +Color Lines /rd/1/games/lines +Lights /rd/1/games/lights +Criss-Cross /rd/1/games/kox +Bulls and cows /rd/1/games/bnc +MegaMaze /rd/1/games/megamaze +Sea Fight /rd/1/games/sw +Sudoku /rd/1/games/sudoku +Go-moku /rd/1/games/gomoku +Reversi /rd/1/games/reversi +#3 **** ARCADES **** +Tetris /rd/1/games/tetris +Pong /rd/1/games/pong +New Pong /rd/1/games/pong3 +Red Square /rd/1/games/rsquare +XONIX /rd/1/games/xonix +ArcanII /rd/1/games/arcanii +Phenix /rd/1/games/phenix +Snake /rd/1/games/snake +#4 **** DEMOS **** +3D > /@5 +Fire /rd/1/demos/fire +Circle /rd/1/demos/circle +Fractal /rd/1/demos/tinyfrac +Color demo /rd/1/demos/colorref +Eyes /rd/1/demos/eyes +Tube /rd/1/demos/tube +Plasma /rd/1/demos/plasma +Moveback /rd/1/demos/movback +Life /rd/1/demos/life2 +TranTest /rd/1/demos/trantest +WEB /rd/1/demos/web +FireWork /rd/1/demos/firework +UnvWater /rd/1/demos/unvwater +#5 **** 3D demos **** +ScreenSaver /rd/1/3d/crownscr +3D-cube /rd/1/3d/3dcube2 +3D-labyrinth /rd/1/3d/free3d04 +3D-textured cube /rd/1/3d/3dtcub10 +3DSHeart /rd/1/3d/3dsheart +View3DS /rd/1/3d/view3ds +CubeLine /rd/1/3d/cubeline +3D-textured cube 2 /rd/1/3d/cubetext +Gears /rd/1/3d/gears +FlatWave /rd/1/3d/flatwav +3D-spiral /rd/1/3d/3dspiral +#6 **** GRAPHICS **** +Image viewer /rd/1/media/kiv +Animage /rd/1/media/animage +#7 **** AUDIO **** +MidAMP /rd/1/media/midamp +CD player /rd/1/media/cdp +#8 **** PROGRAMMING **** +Examples > /@9 +Tools > /@20 +#9 **** EXAMPLES **** +Threads /rd/1/develop/thread +IPC /rd/1/develop/ipc +Color slider /rd/1/demos/cslide +Console example 1 /rd/1/develop/testcon2 +Console example 2 /rd/1/develop/test_gets +Message Boxes example /rd/1/demos/use_mb +#10 **** SYSTEM **** +Settings > /@11 +System sensors > /@12 +Work with files > /@13 +Testing > /@19 +Accessibility opt. > /@21 +Debug board /rd/1/develop/board +#11 **** SETTINGS **** +Devices /rd/1/setup +Background generator /rd/1/pic4 +Colors & Skin /rd/1/desktop +Panel /rd/1/spanel +Icons manager /rd/1/icon +VRR /rd/1/vrr +MyKey /rd/1/mykey +Video mode for ATI /rd/1/vmode +#12 **** SYSTEM SENSORS **** +Process manager /rd/1/cpu +PCI devices /rd/1/pcidev +Test graphics speed /rd/1/mgb +CPUID /rd/1/cpuid +Ghost Monitor /rd/1/gmon +K. Bus disconnected /rd/1/kbd +HDD informer /rd/1/hdd_info +Read HDD /rd/1/hdread +#13 **** WORK WITH FILES **** +KFAR /rd/1/File Managers/kfar +KFM /rd/1/File Managers/kfm +Eolite /rd/1/File Managers/Eolite +SHELL console /rd/1/shell +SysXTree /rd/1/sysxtree +Save RD image /rd/1/rdsave +#14 **** DATA PROCESSING **** +Calculator /rd/1/calc +TinyPad /rd/1/tinypad +Table Processor /rd/1/table +Graph builder /rd/1/graph +Hex-Editor /rd/1/develop/heed +#15 **** NET **** +Servers > /@16 +Clients > /@17 +Configuration /rd/1/network/stackcfg +Zero-Config /rd/1/network/zeroconf +Network status /rd/1/network/ethstat +ARP status /rd/1/network/arpstat +#16 **** SERVERS **** +SMTPS /rd/1/network/smtps +HTTPS /rd/1/network/https +FTPS /rd/1/network/ftps +#17 **** CLIENTS **** +TFTP client /rd/1/network/tftpc +Internet-chess /rd/1/network/chess +Simple HTTP client /rd/1/network/httpc +HTML+HTTP viewer /rd/1/htmlv +NNTP-NewsGroups /rd/1/network/nntpc +TELNET /rd/1/network/telnet +POP - MAIL /rd/1/network/popc +IRC client /rd/1/network/airc +YAHOO messenger (demo) /rd/1/network/ym +JMail /rd/1/network/jmail +VNC client /rd/1/network/vncclient +DNS resolver /rd/1/network/nslookup +#18 **** OTHER **** +Analogue clock /rd/1/demos/aclock +Binary clock /rd/1/demos/bcdclk +Timer /rd/1/demos/timer +ScrShoot /rd/1/scrshoot +Calendar /rd/1/calendar +BGI Font demo /rd/1/fonts/bgitest +RTF reader /rd/1/rtfread +#19 **** SYSTEM TESTS **** +Protection test /rd/1/test +Monitor test /rd/1/disptest +#20 **** PROGRAMMING TOOLS **** +Archiver KPack /rd/1/kpack +Flat Assembler /rd/1/develop/fasm +ASCII-codes /rd/1/develop/keyascii +SCAN-codes /rd/1/develop/scancode +Hex2Dec2Bin /rd/1/develop/h2d2b +Debug Board /rd/1/develop/board +Debugger /rd/1/develop/mtdbg +#21 **** SYSTEM SPECIAL **** +Screen magnifier /rd/1/magnify +Screen keyboard /rd/1/zkey +Character table /rd/1/ASCIIVju +## diff --git a/data/Vortex86MX-eng/network/jmail b/data/Vortex86MX-eng/network/jmail new file mode 100644 index 0000000000000000000000000000000000000000..c6091335c207a041a600dbb0cfcafc3cd4776506 GIT binary patch literal 1976 zcmV;p2S@lzP(w?16aWB$00001Mv*2LLXK;4&&M{gp_R3rW|Cw@0?q9aY);Gm2C|;_ zPHAGBd!PRSk6e$7>f{hp0fBQ&bfyFFVZbyu6p|Zo#3SqdIH?3h0uC(IkxYfxW)4l z5f_nv3d4MzJBi=Q=e_0=!MjLIYw)syS~#3@`uSo38-1jzCEFaypUAbkJB-TtNT5-% zWD#x6$H>AApr^K^Bf@uVhEaTYvhefH0XgwJs^=6;tdL56^D1<{ss;b-%$=LtLU{I{ zA0yHthYy68&4ZD}=$71E12~a48F+pFTcFD2MSh2xN*@kW4;I6~iwA(D4OQhVMfuXg z6j{0FnkI}NZWT~r6Ew$(4iW=8_zkLS3yv6>0BV^0kdBHkI?~bFe)PxdE@*u%f(iz) z=JghmAcSGc3xwQxKCAw0PCP=Pk=kJwlF+N5kz_uiay7XjEdUm$;0#mB3Qd!f7vf|z zW6kK{N8j~gQHal{>mUkkY9{_V4hfS^-TQq#n%DAB;RGGI6lre0<(h~p!nNETWHnKy zKD5u$m(dYa9&ijIQ$xi^B>F+dF@{>fX&nGPAv8|s2>@?WsgF>24bhjQ*Y5Ywb{O{L zt?&SVBWS@jPYPO+{pSj2XwNek0wfv~r<#1w2;Bt>FIbmIJ=R(0Hrlrb~7sA{K*w5@(Af%jE63M|GPz<#V1duvDK{zp=deH<&#t%)C017^4(ZTS zr@HGvA@1dPJ$RF^C!#ieVw!jqJp~e7iqTY=wq*Cvm9H!(@|)Gn1$0VIA>X|d>!TbK zC3BLTh-0_B+){bXY}tk_D6YDL|Luw`%kh^%|EGI9rw?b`(7n|Jh7fn zM9|72f7Aj-GB%j**BShSGhsg0`tm$3P_*JP`MM<2#)OGc9dnXd3wJecHBmqMm7%|| z&+*4pG2HN5=zZOS5fMNEB#lB?oTSF0xcU1v5HFI|1Kezs({-7OUGdp@XB_Gm5Gdy* zzK+Xq!DP?os}tqp-LN2w8w6Lxg(fS7J0uWxj~p@e7AaV6{y@c&6tCYmyNXUy=Eb0% zc^@PNq?$57i=0fRlyh`5Ygh0BOb}J%4Ovdklv6f%cP&9*(M_Q?5mXBKS2w!WB#S>rQuA;QN9ppzj#UvBgMrD zW?de+$(@>!32m$lyjuyN zFj32V@;TgzG>dG5iN0P6hZZ6$H#;?Jr<-j|CsoNa*4y~_3b{O!{R$D=((gq45-nf& zBO^}{*{-b8L>32Zd6J_#J?=m9$+X$l*?Vep1%L?zW_hNKU=Ju4TOtbwRuURSQ`T&y zzNs^?K+L+1q{FpAz3re1P{c!xnCLR`fE(Q*i3qCY%^ygR@*7SxwDt; zLW|rLDlZ|6V_47qfY}EgfGY)^VGjS|6g)8 +;port = +; If proxy requires authentification, uncomment following lines too +; (otherwise, leave them commented): +;user = +;password= + diff --git a/data/Vortex86MX-eng/panel.dat b/data/Vortex86MX-eng/panel.dat new file mode 100644 index 0000000000..fc97f062a7 --- /dev/null +++ b/data/Vortex86MX-eng/panel.dat @@ -0,0 +1 @@ +0000;0000;0001;0001;0001;0001;0100;0001;0001;0001;0001;0001;x \ No newline at end of file diff --git a/data/Vortex86MX-eng/setup.dat b/data/Vortex86MX-eng/setup.dat new file mode 100644 index 0000000000000000000000000000000000000000..c94ae3ec5bde3b9d0f59c17f39a7eee748cf4b6d GIT binary patch literal 48 gcmZQzU|>*SW?%p!1_dSt1{NUAhy??s7`T8K01S%&UH||9 literal 0 HcmV?d00001 diff --git a/data/Vortex86MX-eng/vmode b/data/Vortex86MX-eng/vmode new file mode 100644 index 0000000000000000000000000000000000000000..0c964ece6a940ffc395fcad0f296c9b6ef8eb006 GIT binary patch literal 8628 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 G0000SwA^6; literal 0 HcmV?d00001