123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278 |
- // Precalculate constants
- // MD 0 = PI
- // MD 4 = -PI
- // MD 8 = PI/2
- // MD 12 = -PI/2
- // MD 16 = PI/4
- // MD 20 = -PI/4
- L __CNST_PI
- T MD 0
- NEGR
- T MD 4
- L __CNST_PI
- L 2.0
- /R
- T MD 8
- NEGR
- T MD 12
- L __CNST_PI
- L 4.0
- /R
- T MD 16
- NEGR
- T MD 20
- // Run tests
- __STWRST
- L 1.0
- L 1.0
- +R
- __ASSERT== __ACCU 1, 2.0
- __ASSERT== __ACCU 1, DW#16#40000000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 1.0
- L -1.0
- +R
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L -1.0
- L -1.0
- +R
- __ASSERT== __ACCU 1, -2.0
- __ASSERT== __ACCU 1, DW#16#C0000000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 1.0
- L 1.0
- -R
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __ACCU 1, DW#16#00000000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 1.0
- L -1.0
- -R
- __ASSERT== __ACCU 1, 2.0
- __ASSERT== __ACCU 1, DW#16#40000000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L -1.0
- L -1.0
- -R
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __ACCU 1, DW#16#00000000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 3.0
- L 2.0
- *R
- __ASSERT== __ACCU 1, 6.0
- __ASSERT== __ACCU 1, DW#16#40C00000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 3.0
- L -2.0
- *R
- __ASSERT== __ACCU 1, -6.0
- __ASSERT== __ACCU 1, DW#16#C0C00000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L -3.0
- L -2.0
- *R
- __ASSERT== __ACCU 1, 6.0
- __ASSERT== __ACCU 1, DW#16#40C00000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 3.0
- L 2.0
- /R
- __ASSERT== __ACCU 1, 1.5
- __ASSERT== __ACCU 1, DW#16#3FC00000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L 3.0
- L -2.0
- /R
- __ASSERT== __ACCU 1, -1.5
- __ASSERT== __ACCU 1, DW#16#BFC00000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- __STWRST
- L -3.0
- L -2.0
- /R
- __ASSERT== __ACCU 1, 1.5
- __ASSERT== __ACCU 1, DW#16#3FC00000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: Inf * 0.0 = NaN
- __STWRST
- L __CNST_PINF
- L 0.0
- *R
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: -Inf * 0.0 = NaN
- __STWRST
- L __CNST_NINF
- L 0.0
- *R
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: denormalized
- __STWRST
- L DW#16#00000001
- L 2.0
- /R
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: pos / 0.0 = +inf
- __STWRST
- L 1.5
- L 0.0
- /R
- __ASSERT== __ACCU 1, __CNST_PINF
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: neg / 0.0 = -inf
- __STWRST
- L -1.5
- L 0.0
- /R
- __ASSERT== __ACCU 1, __CNST_NINF
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: -pos
- __STWRST
- L 1.5
- NEGR
- __ASSERT== __ACCU 1, -1.5
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: -neg
- __STWRST
- L -1.5
- NEGR
- __ASSERT== __ACCU 1, 1.5
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: abs(pos)
- __STWRST
- L 1.5
- ABS
- __ASSERT== __ACCU 1, 1.5
- // Test: abs(neg)
- __STWRST
- L -1.5
- ABS
- __ASSERT== __ACCU 1, 1.5
- // Test: pos^2
- __STWRST
- L 1.5
- SQR
- __ASSERT== __ACCU 1, 2.25
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: neg^2
- __STWRST
- L -1.5
- SQR
- __ASSERT== __ACCU 1, 2.25
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sqrt(pos)
- __STWRST
- L 9.0
- SQRT
- __ASSERT== __ACCU 1, 3.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sqrt(-0.0)
- __STWRST
- L -0.0
- SQRT
- __ASSERT== __ACCU 1, -0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sqrt(-0.5)
- __STWRST
- L -0.5
- SQRT
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: sqrt(-1.5)
- __STWRST
- L -1.5
- SQRT
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: exp(0.0)
- __STWRST
- L 0.0
- EXP
- __ASSERT== __ACCU 1, 1.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: exp(1.5)
- __STWRST
- L 1.5
- EXP
- __ASSERT== __ACCU 1, DW#16#408F69FF
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: exp(-1.5)
- __STWRST
- L -1.5
- EXP
- __ASSERT== __ACCU 1, DW#16#3E647C3C
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: ln(0.0)
- __STWRST
- L 0.0
- LN
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: ln(-0.0)
- __STWRST
- L -0.0
- LN
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: ln(1.5)
- __STWRST
- L 1.5
- LN
- __ASSERT== __ACCU 1, DW#16#3ECF991F
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: ln(-1.5)
- __STWRST
- L -1.5
- LN
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: sin(0.0 deg)
- __STWRST
- L 0.0
- SIN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(-0.0 deg)
- __STWRST
- L -0.0
- SIN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(90.0 deg)
- __STWRST
- L MD 8 // PI/2
- SIN
- __ASSERT== __ACCU 1, 1.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(180.0 deg)
- __STWRST
- L MD 0 // PI
- SIN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(-90.0 deg)
- __STWRST
- L MD 12 // -PI/2
- SIN
- __ASSERT== __ACCU 1, -1.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(-180.0 deg)
- __STWRST
- L MD 4 // -PI
- SIN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(0.0 deg)
- __STWRST
- L 0.0
- COS
- __ASSERT== __ACCU 1, 1.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(-0.0 deg)
- __STWRST
- L -0.0
- COS
- __ASSERT== __ACCU 1, 1.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(90.0 deg)
- __STWRST
- L MD 8 // PI/2
- COS
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(180.0 deg)
- __STWRST
- L MD 0 // PI
- COS
- __ASSERT== __ACCU 1, -1.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(-90.0 deg)
- __STWRST
- L MD 12 // -PI/2
- COS
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: cos(-180.0 deg)
- __STWRST
- L MD 4 // -PI
- COS
- __ASSERT== __ACCU 1, -1.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(0.0 deg)
- __STWRST
- L 0.0
- TAN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(-0.0 deg)
- __STWRST
- L -0.0
- TAN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(45.0 deg)
- __STWRST
- L MD 16 // PI/4
- TAN
- __ASSERT== __ACCU 1, 1.0
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(90.0 deg)
- __STWRST
- L MD 8 // PI/2
- TAN
- __ASSERT== __ACCU 1, DW#16#7F800000
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: tan(180.0 deg)
- __STWRST
- L MD 0 // PI
- TAN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(-45.0 deg)
- __STWRST
- L MD 20 // -PI/4
- TAN
- __ASSERT== __ACCU 1, -1.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: tan(-90.0 deg)
- __STWRST
- L MD 12 // -PI/2
- TAN
- __ASSERT== __ACCU 1, DW#16#FF800000
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: tan(-180.0 deg)
- __STWRST
- L MD 4 // -PI
- TAN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: asin(0.0)
- __STWRST
- L 0.0
- ASIN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: asin(-0.0)
- __STWRST
- L -0.0
- ASIN
- __ASSERT== __ACCU 1, -0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: asin(1.0)
- __STWRST
- L 1.0
- ASIN
- __ASSERT== __ACCU 1, MD 8 // PI/2
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: sin(-1.0)
- __STWRST
- L -1.0
- ASIN
- __ASSERT== __ACCU 1, MD 12 // -PI/2
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: acos(1.0)
- __STWRST
- L 1.0
- ACOS
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: acos(0.0)
- __STWRST
- L 0.0
- ACOS
- __ASSERT== __ACCU 1, MD 8 // PI/2
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: acos(-1.0)
- __STWRST
- L -1.0
- ACOS
- __ASSERT== __ACCU 1, MD 0 // PI
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(0.0)
- __STWRST
- L 0.0
- ATAN
- __ASSERT== __ACCU 1, 0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(-0.0)
- __STWRST
- L -0.0
- ATAN
- __ASSERT== __ACCU 1, -0.0
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(1.0)
- __STWRST
- L 1.0
- ATAN
- __ASSERT== __ACCU 1, MD 16 // PI/4
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(inf)
- __STWRST
- L DW#16#7F800000
- ATAN
- __ASSERT== __ACCU 1, MD 8 // PI/2
- __ASSERT== __STW A1, 1
- __ASSERT== __STW A0, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(-inf)
- __STWRST
- L DW#16#FF800000
- ATAN
- __ASSERT== __ACCU 1, MD 12 // -PI/2
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: atan(-1.0)
- __STWRST
- L -1.0
- ATAN
- __ASSERT== __ACCU 1, MD 20 // -PI/4
- __ASSERT== __STW A1, 0
- __ASSERT== __STW A0, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: 1 -> 1.0
- __STWRST
- L 1
- DTR
- __ASSERT== __ACCU 1, 1.0
- // Test: -1 -> -1.0
- __STWRST
- L L#-1
- DTR
- __ASSERT== __ACCU 1, -1.0
- // Test: RND(1.1)
- __STWRST
- L 1.1
- RND
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(1.5)
- __STWRST
- L 1.5
- RND
- __ASSERT== __ACCU 1, 2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(2.5)
- __STWRST
- L 2.5
- RND
- __ASSERT== __ACCU 1, 2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(-1.1)
- __STWRST
- L -1.1
- RND
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(-1.5)
- __STWRST
- L -1.5
- RND
- __ASSERT== __ACCU 1, L#-2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(-2.5)
- __STWRST
- L -2.5
- RND
- __ASSERT== __ACCU 1, L#-2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND(3000000000.0)
- __STWRST
- L 3000000000.0
- RND
- __ASSERT== __ACCU 1, 3000000000.0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND(nNAN)
- __STWRST
- L __CNST_NNAN
- RND
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND(pNAN)
- __STWRST
- L __CNST_PNAN
- RND
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND(nINF)
- __STWRST
- L __CNST_NINF
- RND
- __ASSERT== __ACCU 1, __CNST_NINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND(pINF)
- __STWRST
- L __CNST_PINF
- RND
- __ASSERT== __ACCU 1, __CNST_PINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: TRUNC(1.1)
- __STWRST
- L 1.1
- TRUNC
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(1.5)
- __STWRST
- L 1.5
- TRUNC
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(2.5)
- __STWRST
- L 2.5
- TRUNC
- __ASSERT== __ACCU 1, 2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(-1.1)
- __STWRST
- L -1.1
- TRUNC
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(-1.5)
- __STWRST
- L -1.5
- TRUNC
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(-2.5)
- __STWRST
- L -2.5
- TRUNC
- __ASSERT== __ACCU 1, L#-2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: TRUNC(3000000000.0)
- __STWRST
- L 3000000000.0
- TRUNC
- __ASSERT== __ACCU 1, 3000000000.0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: TRUNC(nNAN)
- __STWRST
- L __CNST_NNAN
- TRUNC
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: TRUNC(pNAN)
- __STWRST
- L __CNST_PNAN
- TRUNC
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: TRUNC(nINF)
- __STWRST
- L __CNST_NINF
- TRUNC
- __ASSERT== __ACCU 1, __CNST_NINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: TRUNC(pINF)
- __STWRST
- L __CNST_PINF
- TRUNC
- __ASSERT== __ACCU 1, __CNST_PINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND+(0.0)
- __STWRST
- L 0.0
- RND+
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(0.1)
- __STWRST
- L 0.1
- RND+
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(0.5)
- __STWRST
- L 0.5
- RND+
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(1.0)
- __STWRST
- L 1.0
- RND+
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(1.5)
- __STWRST
- L 1.5
- RND+
- __ASSERT== __ACCU 1, 2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(2.5)
- __STWRST
- L 2.5
- RND+
- __ASSERT== __ACCU 1, 3
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(-0.1)
- __STWRST
- L -0.1
- RND+
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(-0.5)
- __STWRST
- L -0.5
- RND+
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(-1.0)
- __STWRST
- L -1.0
- RND+
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(-1.5)
- __STWRST
- L -1.5
- RND+
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(-2.5)
- __STWRST
- L -2.5
- RND+
- __ASSERT== __ACCU 1, L#-2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND+(3000000000.0)
- __STWRST
- L 3000000000.0
- RND+
- __ASSERT== __ACCU 1, 3000000000.0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND+(nNAN)
- __STWRST
- L __CNST_NNAN
- RND+
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND+(pNAN)
- __STWRST
- L __CNST_PNAN
- RND+
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND+(nINF)
- __STWRST
- L __CNST_NINF
- RND+
- __ASSERT== __ACCU 1, __CNST_NINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND+(pINF)
- __STWRST
- L __CNST_PINF
- RND+
- __ASSERT== __ACCU 1, __CNST_PINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND-(0.0)
- __STWRST
- L 0.0
- RND-
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(0.1)
- __STWRST
- L 0.1
- RND-
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(0.5)
- __STWRST
- L 0.5
- RND-
- __ASSERT== __ACCU 1, 0
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(1.0)
- __STWRST
- L 1.0
- RND-
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(1.5)
- __STWRST
- L 1.5
- RND-
- __ASSERT== __ACCU 1, 1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(2.5)
- __STWRST
- L 2.5
- RND-
- __ASSERT== __ACCU 1, 2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(-0.1)
- __STWRST
- L -0.1
- RND-
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(-0.5)
- __STWRST
- L -0.5
- RND-
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(-1.0)
- __STWRST
- L -1.0
- RND-
- __ASSERT== __ACCU 1, L#-1
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(-1.5)
- __STWRST
- L -1.5
- RND-
- __ASSERT== __ACCU 1, L#-2
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(-2.5)
- __STWRST
- L -2.5
- RND-
- __ASSERT== __ACCU 1, L#-3
- __ASSERT== __STW OV, 0
- __ASSERT== __STW OS, 0
- // Test: RND-(3000000000.0)
- __STWRST
- L 3000000000.0
- RND-
- __ASSERT== __ACCU 1, 3000000000.0
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND-(nNAN)
- __STWRST
- L __CNST_NNAN
- RND-
- __ASSERT== __ACCU 1, __CNST_NNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND-(pNAN)
- __STWRST
- L __CNST_PNAN
- RND-
- __ASSERT== __ACCU 1, __CNST_PNAN
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND-(nINF)
- __STWRST
- L __CNST_NINF
- RND-
- __ASSERT== __ACCU 1, __CNST_NINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- // Test: RND-(pINF)
- __STWRST
- L __CNST_PINF
- RND-
- __ASSERT== __ACCU 1, __CNST_PINF
- __ASSERT== __STW OV, 1
- __ASSERT== __STW OS, 1
- CALL SFC 46 // STOP CPU
|