1
0
mirror of synced 2024-11-21 20:44:23 +01:00

Fix a lot of spurious whitespace

This commit is contained in:
Christian Dietrich 2014-10-09 17:30:00 +02:00
parent 51e2a244bb
commit cea45e869f
8 changed files with 67 additions and 46 deletions

View File

@ -1,5 +1,8 @@
export TEXINPUTS := $(shell pwd)//:${TEXINPUTS} export TEXINPUTS := $(shell pwd)//:${TEXINPUTS}
doc:
cd source; latexmk -pdf -shell-escape avremu
test: test-simple test: test-simple
cd source/test-suite; ./test-suite cd source/test-suite; ./test-suite
@ -9,4 +12,4 @@ test-simple: source/simple-testsuite.tex
test-%: source/test-suite/%.c test-%: source/test-suite/%.c
cd source/test-suite; ./test-suite single $(shell basename $<) cd source/test-suite; ./test-suite single $(shell basename $<)
.PHONY: test-simple .PHONY: test-simple doc

View File

@ -23,10 +23,8 @@
\newcount\avr@ihex@count \newcount\avr@ihex@count
\newcount\avr@ihex@instrs \newcount\avr@ihex@instrs
\def\avr@ihex@load#1{% \def\avr@ihex@load#1{%
\newread\avr@input% \newread\avr@input%
\avr@ihex@instrs=0\relax% \avr@ihex@instrs=0\relax%
\openin\avr@input=#1\relax% \openin\avr@input=#1\relax%
\@whilesw\unless\ifeof\avr@input\fi{% \@whilesw\unless\ifeof\avr@input\fi{%
@ -46,9 +44,7 @@
%\avr@debug{=\avr@ihex@opcode}% %\avr@debug{=\avr@ihex@opcode}%
\advance \avr@ihex@count by -1\relax% \advance \avr@ihex@count by -1\relax%
\advance \avr@ihex@addr by 1\relax% \advance \avr@ihex@addr by 1\relax%
\repeat \repeat%
}{}% }{}%
}% }%
}% }%

View File

@ -104,7 +104,7 @@
}% }%
\edef\@tmpb{#1}% \edef\@tmpb{#1}%
\expandafter\avr@bin@setbit@helper\@tmpb\@nnil% \expandafter\avr@bin@setbit@helper\@tmpb\@nnil%
\edef#4{\@tempa} \edef#4{\@tempa}%
} }
% \avr@bin@btw bs:byte, \result -> \result = 00000000+bs % \avr@bin@btw bs:byte, \result -> \result = 00000000+bs
@ -178,7 +178,7 @@
}% }%
\edef\@tempa{#1}% \edef\@tempa{#1}%
\def#2{}% \def#2{}%
\expandafter\avr@bin@lsb@del@helper\@tempa\@nnil \expandafter\avr@bin@lsb@del@helper\@tempa\@nnil%
} }
% Get LSB: bs, \result % Get LSB: bs, \result
@ -191,7 +191,7 @@
\fi% \fi%
}% }%
\edef\@tempa{#1}% \edef\@tempa{#1}%
\expandafter\avr@bin@lsb@get@helper\@tempa\@nnil \expandafter\avr@bin@lsb@get@helper\@tempa\@nnil%
} }
% Delete MSB: bs, \result,\carry % Delete MSB: bs, \result,\carry

View File

@ -19,14 +19,14 @@
\avr@bin@tocount{#1}{\avr@accA}% \avr@bin@tocount{#1}{\avr@accA}%
\avr@log{DRAW CMD: \the\avr@accA}% \avr@log{DRAW CMD: \the\avr@accA}%
\avr@draw@command{\the\avr@accA}% \avr@draw@command{\the\avr@accA}%
\avr@draw@argc = 0\relax \avr@draw@argc = 0\relax%
} }
\csdef{avr@io@000011@set}#1{% \csdef{avr@io@000011@set}#1{%
\avr@bin@tocount{#1}{\avr@accA}% \avr@bin@tocount{#1}{\avr@accA}%
\avr@debug{AVR DRAW PUSH: \the\avr@accA}% \avr@debug{AVR DRAW PUSH: \the\avr@accA}%
\csxdef{avr@draw@stack@\the\avr@draw@argc}{\the\avr@accA}% \csxdef{avr@draw@stack@\the\avr@draw@argc}{\the\avr@accA}%
\advance\avr@draw@argc by 1\relax \advance\avr@draw@argc by 1\relax%
} }
\def\avr@draw@stack#1{\csuse{avr@draw@stack@#1}} \def\avr@draw@stack#1{\csuse{avr@draw@stack@#1}}
@ -111,7 +111,7 @@
\newwrite\avr@file% \newwrite\avr@file%
\newcommand{\avrdrawppm}[1]{ \newcommand{\avrdrawppm}[1]{%
% Dump to .ppm file % Dump to .ppm file
\immediate\openout\avr@file=#1% \immediate\openout\avr@file=#1%
\immediate\write\avr@file{P3}% \immediate\write\avr@file{P3}%

View File

@ -34,10 +34,12 @@
\avr@instr@run% \avr@instr@run%
} }
\newcommand{\avrsinglestep}{ \newcommand{\avrsinglestep}{%
\avr@instr@singlestep% \avr@instr@singlestep%
} }
\newcommand{\avrinstrcount}{\the\avr@instr@executed}
\def\avr@instr@step{% \def\avr@instr@step{%
\avr@code@get{\avr@instr@current}% \avr@code@get{\avr@instr@current}%
%\avr@reg@get{\csuse{avr@r24}}{\@@A}% %\avr@reg@get{\csuse{avr@r24}}{\@@A}%
@ -60,7 +62,7 @@
\newcount\avr@instr@steps \newcount\avr@instr@steps
\def\avr@instr@stepn#1{% \def\avr@instr@stepn#1{%
\avr@instr@steps=#1% \avr@instr@steps=#1%
\def\avr@instr@stepn@helper{ \def\avr@instr@stepn@helper{%
\ifnum \avr@instr@steps > 0% \ifnum \avr@instr@steps > 0%
\advance \avr@instr@steps by -1\relax% \advance \avr@instr@steps by -1\relax%
\avr@instr@step% \avr@instr@step%
@ -73,9 +75,9 @@
} }
% Run Forever % Run Forever
\def\avr@instr@run{ \def\avr@instr@run{%
\avr@instr@steps=1% \avr@instr@steps=1%
\def\avr@instr@stepn@helper{ \def\avr@instr@stepn@helper{%
\ifnum \avr@instr@steps > 0% \ifnum \avr@instr@steps > 0%
\avr@instr@step% \avr@instr@step%
\else% \else%
@ -154,7 +156,7 @@
\def#2{2}% \def#2{2}%
}{% }{%
\def#2{1}% \def#2{1}%
} }%
} }
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Match also from end for these prefixes % Match also from end for these prefixes
@ -523,7 +525,7 @@
\advance \avr@count@tmpa by 1\relax% \advance \avr@count@tmpa by 1\relax%
\fi% \fi%
\avr@count@tobin@b{\avr@count@tmpa}{\@@res}% \avr@count@tobin@b{\avr@count@tmpa}{\@@res}%
\avr@bin@msb@del{\@@res}{#2}{\@tempa} \avr@bin@msb@del{\@@res}{#2}{\@tempa}%
} }
\def\avr@instr@jump@dec#1#2{% \def\avr@instr@jump@dec#1#2{%
\avr@bin@tocount{0#1}{\avr@count@tmpa}% \avr@bin@tocount{0#1}{\avr@count@tmpa}%
@ -635,7 +637,7 @@
} }
% #1 = Value to be reached % #1 = Value to be reached
\csdef{avr@instr@11110}#1#2#3#4#5#6#7#8#9\@nnil{ \csdef{avr@instr@11110}#1#2#3#4#5#6#7#8#9\@nnil{%
\edef\@@required{\avr@bit@negate #1}% \edef\@@required{\avr@bit@negate #1}%
\def\@@offset{#2#3#4#5#6#7#8}% \def\@@offset{#2#3#4#5#6#7#8}%
\def\@@bit{00000#9}% \def\@@bit{00000#9}%
@ -645,7 +647,7 @@
\avr@bin@getbit{\@@sreg}{\@@bit}{\@@found}% \avr@bin@getbit{\@@sreg}{\@@bit}{\@@found}%
\avr@count@tmpa=\@@required% \avr@count@tmpa=\@@required%
\avr@count@tmpb=\@@found\relax% \avr@count@tmpb=\@@found\relax%
\avr@debug{BRB{CS} - (\@@sreg[\@@bit] == \@@required) ? +\@@offset : +0} \avr@debug{BRB{CS} - (\@@sreg[\@@bit] == \@@required) ? +\@@offset : +0}%
\ifnum \avr@count@tmpa = \avr@count@tmpb% \ifnum \avr@count@tmpa = \avr@count@tmpb%
\avr@instr@jump@dec{\@@offset}{\avr@count@tmpa}% \avr@instr@jump@dec{\@@offset}{\avr@count@tmpa}%
\avr@debug{BRB -- JUMP \the\avr@count@tmpa}% \avr@debug{BRB -- JUMP \the\avr@count@tmpa}%
@ -657,7 +659,7 @@
% RJMP % RJMP
% #1 = Offset % #1 = Offset
% FIXME latex assembler % FIXME latex assembler
\csdef{avr@instr@1100}#1\@nnil{ \csdef{avr@instr@1100}#1\@nnil{%
\avr@instr@rjump@dec{#1}{\avr@count@tmpa}% \avr@instr@rjump@dec{#1}{\avr@count@tmpa}%
\avr@debug{RJMP \the\avr@count@tmpa}% \avr@debug{RJMP \the\avr@count@tmpa}%
\avr@pc@add{\avr@count@tmpa}% \avr@pc@add{\avr@count@tmpa}%
@ -676,7 +678,7 @@
\avr@pc@inc% \avr@pc@inc%
\avr@debug{ done}% \avr@debug{ done}%
} }
\csdef{avr@instr@1101}#1\@nnil{ \csdef{avr@instr@1101}#1\@nnil{%
\avr@count@tobin@w{\the\avr@pc}{\@@pc}% \avr@count@tobin@w{\the\avr@pc}{\@@pc}%
\avr@instr@rjump@dec{#1}{\avr@count@tmpa}% \avr@instr@rjump@dec{#1}{\avr@count@tmpa}%
\avr@reg@get{\csuse{avr@r24}}{\@@A}% \avr@reg@get{\csuse{avr@r24}}{\@@A}%
@ -688,28 +690,28 @@
} }
\def\avr@instr@ICALL#1{\avr@code@set{1001010100001001}{#1}} \def\avr@instr@ICALL#1{\avr@code@set{1001010100001001}{#1}}
\csdef{avr@instr@1001010100001001}\@nnil{ \csdef{avr@instr@1001010100001001}\@nnil{%
\avr@count@tobin@w{\the\avr@pc}{\@@pc}% \avr@count@tobin@w{\the\avr@pc}{\@@pc}%
\avr@regw@get{\csuse{avr@Z}}{\@@addr} \avr@regw@get{\csuse{avr@Z}}{\@@addr}%
\avr@bin@tocount{\@@addr}{\avr@addr}% \avr@bin@tocount{\@@addr}{\avr@addr}%
\avr@reg@get{\csuse{avr@r24}}{\@@A}% \avr@reg@get{\csuse{avr@r24}}{\@@A}%
\avr@reg@get{\csuse{avr@r25}}{\@@B}% \avr@reg@get{\csuse{avr@r25}}{\@@B}%
\avr@reg@get{\csuse{avr@r26}}{\@@C}% \avr@reg@get{\csuse{avr@r26}}{\@@C}%
\avr@debug{ICALL \the\avr@addr {r24:\@@A} {r25:\@@B} {r26:\@@C}}% \avr@debug{ICALL \the\avr@addr {r24:\@@A} {r25:\@@B} {r26:\@@C}}%
\avr@CALL@helper{\@@pc}% \avr@CALL@helper{\@@pc}%
\avr@pc=\avr@addr \avr@pc=\avr@addr%
} }
\def\avr@instr@IJMP#1{\avr@code@set{1001010000001001}{#1}} \def\avr@instr@IJMP#1{\avr@code@set{1001010000001001}{#1}}
\csdef{avr@instr@1001010000001001}\@nnil{ \csdef{avr@instr@1001010000001001}\@nnil{%
\avr@count@tobin@w{\the\avr@pc}{\@@pc}% \avr@count@tobin@w{\the\avr@pc}{\@@pc}%
\avr@regw@get{\csuse{avr@Z}}{\@@addr} \avr@regw@get{\csuse{avr@Z}}{\@@addr}%
\avr@bin@tocount{\@@addr}{\avr@addr}% \avr@bin@tocount{\@@addr}{\avr@addr}%
\avr@reg@get{\csuse{avr@r24}}{\@@a}% \avr@reg@get{\csuse{avr@r24}}{\@@a}%
\avr@reg@get{\csuse{avr@r25}}{\@@b}% \avr@reg@get{\csuse{avr@r25}}{\@@b}%
\avr@reg@get{\csuse{avr@r26}}{\@@c}% \avr@reg@get{\csuse{avr@r26}}{\@@c}%
\avr@debug{IJMP \the\avr@addr {r24:\@@a} {r25:\@@b} {r26:\@@c}}% \avr@debug{IJMP \the\avr@addr {r24:\@@a} {r25:\@@b} {r26:\@@c}}%
\avr@pc=\avr@addr \avr@pc=\avr@addr%
} }
% RET % RET
@ -719,9 +721,9 @@
\csdef{avr@instr@1001010100001000}\@nnil{% \csdef{avr@instr@1001010100001000}\@nnil{%
\avr@reg@get{\csuse{avr@r24}}{\@@X}% \avr@reg@get{\csuse{avr@r24}}{\@@X}%
\avr@debug{RET (r24=\@@X)}% \avr@debug{RET (r24=\@@X)}%
\advance\avr@stackptr by 1\relax \advance\avr@stackptr by 1\relax%
\avr@mem@get{\the\avr@stackptr}{\@@high}% \avr@mem@get{\the\avr@stackptr}{\@@high}%
\advance\avr@stackptr by 1\relax \advance\avr@stackptr by 1\relax%
\avr@mem@get{\the\avr@stackptr}{\@@low}% \avr@mem@get{\the\avr@stackptr}{\@@low}%
\avr@bin@tocount{\@@high \@@low}{\avr@pc}% \avr@bin@tocount{\@@high \@@low}{\avr@pc}%
\avr@pc@inc\relax% \avr@pc@inc\relax%
@ -737,7 +739,7 @@
\csdef{avr@instr@001011}#1#2#3#4#5#6#7\@nnil{% \csdef{avr@instr@001011}#1#2#3#4#5#6#7\@nnil{%
\avr@reg@get{#1#7}{\avr@Rr}% \avr@reg@get{#1#7}{\avr@Rr}%
\avr@reg@set{\avr@Rr}{#2#3#4#5#6}% \avr@reg@set{\avr@Rr}{#2#3#4#5#6}%
\avr@debug{MOV - #2#3#4#5#6 <- #1#7(=\avr@Rr)} \avr@debug{MOV - #2#3#4#5#6 <- #1#7(=\avr@Rr)}%
\avr@pc@inc% \avr@pc@inc%
} }
@ -752,7 +754,7 @@
\avr@reg@set{\avr@Rr}{#1#2#3#40}% \avr@reg@set{\avr@Rr}{#1#2#3#40}%
\avr@reg@get{#51}{\avr@Rd}% \avr@reg@get{#51}{\avr@Rd}%
\avr@reg@set{\avr@Rd}{#1#2#3#41}% \avr@reg@set{\avr@Rd}{#1#2#3#41}%
\avr@debug{MOV - #1#2#3#4[01] <- #5[01](=\avr@Rr:\avr@Rd)} \avr@debug{MOV - #1#2#3#4[01] <- #5[01](=\avr@Rr:\avr@Rd)}%
\avr@pc@inc% \avr@pc@inc%
} }
@ -993,14 +995,14 @@
\def\avr@instr@LDS#1#2#3{% \def\avr@instr@LDS#1#2#3{%
\avr@code@set{1001000#20000}{#1}% \avr@code@set{1001000#20000}{#1}%
\avr@count@tmpa=#1% \avr@count@tmpa=#1%
\advance \avr@count@tmpa by 1\relax \advance \avr@count@tmpa by 1\relax%
\avr@code@set{#3}{\the\avr@count@tmpa}% \avr@code@set{#3}{\the\avr@count@tmpa}%
} }
\def\avr@instr@STS#1#2#3{% \def\avr@instr@STS#1#2#3{%
\avr@code@set{1001001#20000}{#1}% \avr@code@set{1001001#20000}{#1}%
\avr@count@tmpa=#1% \avr@count@tmpa=#1%
\advance \avr@count@tmpa by 1\relax \advance \avr@count@tmpa by 1\relax%
\avr@code@set{#3}{\the\avr@count@tmpa}% \avr@code@set{#3}{\the\avr@count@tmpa}%
} }
@ -1263,7 +1265,7 @@
\def\avr@skip@instr@eq#1#2{% \def\avr@skip@instr@eq#1#2{%
\ifdefstrequal{#1}{#2}{% \ifdefstrequal{#1}{#2}{%
\avr@pc@inc% \avr@pc@inc%
\avr@instr@length{\the\avr@pc}{\@@length} \avr@instr@length{\the\avr@pc}{\@@length}%
\avr@debug{SKIP (\@@length) instruction}% \avr@debug{SKIP (\@@length) instruction}%
\avr@pc@add{\@@length}% \avr@pc@add{\@@length}%
}{% }{%
@ -1375,8 +1377,8 @@
\csdef{avr@instr@100111}#1#2#3#4#5#6#7\@nnil{% \csdef{avr@instr@100111}#1#2#3#4#5#6#7\@nnil{%
\avr@reg@get{#1#7}{\avr@Rr}% \avr@reg@get{#1#7}{\avr@Rr}%
\avr@reg@get{#2#3#4#5#6}{\avr@Rd}% \avr@reg@get{#2#3#4#5#6}{\avr@Rd}%
\avr@bin@tocount{\avr@Rr}{\avr@MUL@A} \avr@bin@tocount{\avr@Rr}{\avr@MUL@A}%
\avr@bin@tocount{\avr@Rd}{\avr@MUL@B} \avr@bin@tocount{\avr@Rd}{\avr@MUL@B}%
\avr@debug{MUL - \the\avr@MUL@A * \the\avr@MUL@B}% \avr@debug{MUL - \the\avr@MUL@A * \the\avr@MUL@B}%
\multiply \avr@MUL@A by \avr@MUL@B\relax% \multiply \avr@MUL@A by \avr@MUL@B\relax%
\avr@count@tobin@w{\avr@MUL@A}{\avr@Rx}% \avr@count@tobin@w{\avr@MUL@A}{\avr@Rx}%

View File

@ -2,13 +2,20 @@
%% The IO Subsystem %% The IO Subsystem
%% %%
\newcommand{\avrUDR}{%
\avr@UDR%
}
\newcommand{\avrUDRclear}{%
\def\avr@UDR{}%
}
\def\avr@io@init{% \def\avr@io@init{%
\def\avr@UDR{}% \def\avr@UDR{}%
} }
% OUT % OUT
\def\avr@instr@OUT#1#2#3{% A, R \def\avr@instr@OUT#1#2#3{% A, R
\def\@@A{#2} \def\@@A{#2}%
\avr@bin@msb@del{\@@A}{\@@A}{\@@a}% \avr@bin@msb@del{\@@A}{\@@A}{\@@a}%
\avr@bin@msb@del{\@@A}{\@@A}{\@@b}% \avr@bin@msb@del{\@@A}{\@@A}{\@@b}%
\avr@code@set{10111\@@a\@@b#3\@@A}{#1}% \avr@code@set{10111\@@a\@@b#3\@@A}{#1}%
@ -24,10 +31,10 @@
% IN % IN
\def\avr@instr@IN#1#2#3{% A, R \def\avr@instr@IN#1#2#3{% A, R
\def\@@A{#2} \def\@@A{#2}%
\avr@bin@msb@del{\@@A}{\@@A}{\@@a}% \avr@bin@msb@del{\@@A}{\@@A}{\@@a}%
\avr@bin@msb@del{\@@A}{\@@A}{\@@b}% \avr@bin@msb@del{\@@A}{\@@A}{\@@b}%
\avr@code@set{10110\@@a\@@b#3\@@A}{#1}% \avr@code@set{10110\@@a\@@b#3\@@A}{#1}%
} }
\csdef{avr@instr@10110}#1#2#3#4#5#6#7#8\@nnil{% \csdef{avr@instr@10110}#1#2#3#4#5#6#7#8\@nnil{%

View File

@ -266,7 +266,7 @@
} }
%% RAM %% RAM
\newcount\avr@stackptr \newcount\avr@stackptr
\def\avr@stack@init{ \def\avr@stack@init{%
\avr@stackptr=0% \avr@stackptr=0%
} }
@ -283,20 +283,20 @@
\avr@count@tobin@w{\avr@stackptr}{\@@stack}% \avr@count@tobin@w{\avr@stackptr}{\@@stack}%
\avr@bin@word@high{\@@stack}{\@@high}% \avr@bin@word@high{\@@stack}{\@@high}%
\avr@bin@tocount{\@@high #1}{\avr@stackptr}% \avr@bin@tocount{\@@high #1}{\avr@stackptr}%
\avr@debug{ SP=\the\avr@stackptr} \avr@debug{ SP=\the\avr@stackptr}%
} }
\def\avr@stack@SPH@set#1{% \def\avr@stack@SPH@set#1{%
\avr@count@tobin@w{\avr@stackptr}{\@@stack}% \avr@count@tobin@w{\avr@stackptr}{\@@stack}%
\avr@bin@word@low{\@@stack}{\@@low}% \avr@bin@word@low{\@@stack}{\@@low}%
\avr@bin@tocount{#1\@@low}{\avr@stackptr}% \avr@bin@tocount{#1\@@low}{\avr@stackptr}%
\avr@debug{ SP=\the\avr@stackptr} \avr@debug{ SP=\the\avr@stackptr}%
} }
\def\avr@mem@init#1{% \def\avr@mem@init#1{%
\avr@count@tmpa = #1\relax \avr@count@tmpa = #1\relax
\def\avr@mem@init@helper{% \def\avr@mem@init@helper{%
\ifnum \avr@count@tmpa > 0 \ifnum \avr@count@tmpa > 0%
\csxdef{avr@mem@\the\avr@count@tmpa}{00000000}% \csxdef{avr@mem@\the\avr@count@tmpa}{00000000}%
\advance \avr@count@tmpa by -1\relax% \advance \avr@count@tmpa by -1\relax%
\else% \else%

View File

@ -2,6 +2,14 @@
\ProvidesPackage{avremu} [2014/10/09 v0.1 avremu] \ProvidesPackage{avremu} [2014/10/09 v0.1 avremu]
\RequirePackage{etoolbox} \RequirePackage{etoolbox}
\RequirePackage{tabularx} \RequirePackage{tabularx}
\RequirePackage{kvoptions}
\SetupKeyvalOptions{
family=avr,
prefix=avr@
}
\DeclareBoolOption{debug}
\ProcessKeyvalOptions*
\input{avr.numbers} \input{avr.numbers}
\input{avr.binary} \input{avr.binary}
@ -11,6 +19,11 @@
\input{avr.io} \input{avr.io}
\input{avr.testsuite} \input{avr.testsuite}
\ifavr@debug
\relax
\else
\def\avr@debug#1{}
\fi
\newcommand{\useavremulibrary}[1]{ \newcommand{\useavremulibrary}[1]{
\def\do##1{% \def\do##1{%