Fix byte table access

This commit is contained in:
drmortalwombat 2021-11-01 21:22:02 +01:00
parent 2cd7956736
commit 40f82ba6ec
7 changed files with 342 additions and 15 deletions

View File

@ -48,6 +48,9 @@ if %errorlevel% neq 0 goto :error
call :test testint16cmp.c call :test testint16cmp.c
if %errorlevel% neq 0 goto :error if %errorlevel% neq 0 goto :error
call :test testint8cmp.c
if %errorlevel% neq 0 goto :error
call :test testint32cmp.c call :test testint32cmp.c
if %errorlevel% neq 0 goto :error if %errorlevel% neq 0 goto :error

316
autotest/testint8cmp.c Normal file
View File

@ -0,0 +1,316 @@
#include <stdio.h>
#include <assert.h>
typedef signed char int8;
bool beq(int8 a, int8 b)
{
return a == b;
}
bool blt(int8 a, int8 b)
{
return a < b;
}
bool bgt(int8 a, int8 b)
{
return a > b;
}
bool ble(int8 a, int8 b)
{
return a <= b;
}
bool bge(int8 a, int8 b)
{
return a >= b;
}
bool neq(int8 a, int8 b)
{
return a == b;
}
#pragma native(neq)
bool nlt(int8 a, int8 b)
{
return a < b;
}
#pragma native(nlt)
bool ngt(int8 a, int8 b)
{
return a > b;
}
#pragma native(ngt)
bool nle(int8 a, int8 b)
{
return a <= b;
}
#pragma native(nle)
bool nge(int8 a, int8 b)
{
return a >= b;
}
#pragma native(nge)
bool beqz(int8 a)
{
return a == 0;
}
bool bltz(int8 a)
{
return a < 0;
}
bool bgtz(int8 a)
{
return a > 0;
}
bool blez(int8 a)
{
return a <= 0;
}
bool bgez(int8 a)
{
return a >= 0;
}
bool neqz(int8 a)
{
return a == 0;
}
#pragma native(neqz)
bool nltz(int8 a)
{
return a < 0;
}
#pragma native(nltz)
bool ngtz(int8 a)
{
return a > 0;
}
#pragma native(ngtz)
bool nlez(int8 a)
{
return a <= 0;
}
#pragma native(nlez)
bool ngez(int8 a)
{
return a >= 0;
}
#pragma native(ngez)
bool beq1(int8 a)
{
return a == 1;
}
bool blt1(int8 a)
{
return a < 1;
}
bool bgt1(int8 a)
{
return a > 1;
}
bool ble1(int8 a)
{
return a <= 1;
}
bool bge1(int8 a)
{
return a >= 1;
}
bool neq1(int8 a)
{
return a == 1;
}
#pragma native(neq1)
bool nlt1(int8 a)
{
return a < 1;
}
#pragma native(nlt1)
bool ngt1(int8 a)
{
return a > 1;
}
#pragma native(ngt1)
bool nle1(int8 a)
{
return a <= 1;
}
#pragma native(nle1)
bool nge1(int8 a)
{
return a >= 1;
}
#pragma native(nge1)
void cmp(int8 a, int8 b)
{
bool beqf = beq(a, b), bltf = blt(a, b), bgtf = bgt(a, b), blef = ble(a, b), bgef = bge(a, b);
bool neqf = neq(a, b), nltf = nlt(a, b), ngtf = ngt(a, b), nlef = nle(a, b), ngef = nge(a, b);
printf("BYTE %d, %d : EQ %d LT %d GT %d\r", a, b, beqf, bltf, bgtf);
printf("NATIVE %d, %d : EQ %d LT %d GT %d\r", a, b, neqf, nltf, ngtf);
assert(beqf == neqf);
assert(bltf == nltf);
assert(bgtf == ngtf);
assert(blef == nlef);
assert(bgef == ngef);
}
void cmpz(int8 a)
{
bool beqf = beqz(a), bltf = bltz(a), bgtf = bgtz(a), blef = blez(a), bgef = bgez(a);
bool neqf = neqz(a), nltf = nltz(a), ngtf = ngtz(a), nlef = nlez(a), ngef = ngez(a);
printf("BYTE %d, 0 : EQ %d LT %d GT %d\r", a, beqf, bltf, bgtf);
printf("NATIVE %d, 0 : EQ %d LT %d GT %d\r", a, neqf, nltf, ngtf);
assert(beqf == neqf);
assert(bltf == nltf);
assert(bgtf == ngtf);
assert(blef == nlef);
assert(bgef == ngef);
}
void cmp1(int8 a)
{
bool beqf = beq1(a), bltf = blt1(a), bgtf = bgt1(a), blef = ble1(a), bgef = bge1(a);
bool neqf = neq1(a), nltf = nlt1(a), ngtf = ngt1(a), nlef = nle1(a), ngef = nge1(a);
printf("BYTE %d, 1 : EQ %d LT %d GT %d LE %d GE %d\r", a, beqf, bltf, bgtf, blef, bgef);
printf("NATIVE %d, 1 : EQ %d LT %d GT %d LE %d GE %d\r", a, neqf, nltf, ngtf, nlef, ngef);
assert(beqf == neqf);
assert(bltf == nltf);
assert(bgtf == ngtf);
assert(blef == nlef);
assert(bgef == ngef);
}
int main(void)
{
cmp( 0, 1);
cmp( 0, -1);
cmp( 1, 0);
cmp(-1, 0);
cmp(1, 1);
cmp(1, 2);
cmp(2, 1);
cmp(-1, -1);
cmp(-1, -2);
cmp(-2, -1);
cmp( 1, -1);
cmp( 1, -2);
cmp( 2, -1);
cmp(-1, 1);
cmp(-1, 2);
cmp(-2, 1);
cmp( 0, 100);
cmp( 0, -100);
cmp( 100, 0);
cmp(-100, 0);
cmp(10, 10);
cmp(10, 20);
cmp(20, 10);
cmp(-10, -10);
cmp(-10, -20);
cmp(-20, -10);
cmp( 10, -10);
cmp( 10, -20);
cmp( 20, -10);
cmp(-10, 10);
cmp(-10, 20);
cmp(-20, 10);
cmp(-30, 30);
cmp(-30, -30);
cmp( 30, 30);
cmp( 30, -30);
cmp( 0, 127);
cmp( 0, -128);
cmp( 127, 0);
cmp(-128, 0);
cmp( 127, 127);
cmp( 127, -128);
cmp(-128, 127);
cmp(-128, -128);
cmpz(0);
cmpz(1);
cmpz(127);
cmpz(-1);
cmpz(-128);
cmp1(0);
cmp1(1);
cmp1(2);
cmp1(3);
cmp1(127);
cmp1(-1);
cmp1(-2);
cmp1(-3);
cmp1(-128);
return 0;
}

View File

@ -38,6 +38,9 @@ void keyb_poll(void)
if (cia1.prb != 0xff) if (cia1.prb != 0xff)
{ {
keyb_matrix[6] &= 0xef;
keyb_matrix[1] &= 0x7f;
byte a = 0xfe; byte a = 0xfe;
for(byte i=0; i<8; i++) for(byte i=0; i<8; i++)
{ {

View File

@ -5,4 +5,6 @@ typedef unsigned char byte;
typedef unsigned short word; typedef unsigned short word;
typedef unsigned long dword; typedef unsigned long dword;
typedef signed char sbyte;
#endif #endif

View File

@ -5,3 +5,13 @@ void vic_setbank(char bank)
{ {
cia2.pra = (cia2.pra & 0xfc) | (bank ^ 0x03); cia2.pra = (cia2.pra & 0xfc) | (bank ^ 0x03);
} }
void vic_sprxy(byte s, int x, int y)
{
vic.spr_pos[0].y = y;
vic.spr_pos[0].x = x & 0xff;
if (x & 0x100)
vic.spr_msbx |= 1 << s;
else
vic.spr_msbx &= ~(1 << s);
}

View File

@ -75,6 +75,9 @@ struct VIC
void vic_setbank(char bank); void vic_setbank(char bank);
inline void vic_sprxy(byte s, int x, int y);
#define vic (*((struct VIC *)0xd000)) #define vic (*((struct VIC *)0xd000))
#pragma compile("vic.c") #pragma compile("vic.c")

View File

@ -2571,17 +2571,16 @@ void NativeCodeBasicBlock::CheckFrameIndex(int& reg, int& index, int size, int t
{ {
if (index < 0 || index + size > 256) if (index < 0 || index + size > 256)
{ {
if (treg == 0)
treg = BC_REG_ADDR;
mIns.Push(NativeCodeInstruction(ASMIT_CLC, ASMIM_IMPLIED)); mIns.Push(NativeCodeInstruction(ASMIT_CLC, ASMIM_IMPLIED));
mIns.Push(NativeCodeInstruction(ASMIT_LDA, ASMIM_ZERO_PAGE, reg)); mIns.Push(NativeCodeInstruction(ASMIT_LDA, ASMIM_ZERO_PAGE, reg));
mIns.Push(NativeCodeInstruction(ASMIT_ADC, ASMIM_IMMEDIATE, index & 0xff)); mIns.Push(NativeCodeInstruction(ASMIT_ADC, ASMIM_IMMEDIATE, index & 0xff));
mIns.Push(NativeCodeInstruction(ASMIT_STA, ASMIM_ZERO_PAGE, BC_REG_ADDR)); mIns.Push(NativeCodeInstruction(ASMIT_STA, ASMIM_ZERO_PAGE, treg));
mIns.Push(NativeCodeInstruction(ASMIT_LDA, ASMIM_ZERO_PAGE, reg + 1)); mIns.Push(NativeCodeInstruction(ASMIT_LDA, ASMIM_ZERO_PAGE, reg + 1));
mIns.Push(NativeCodeInstruction(ASMIT_ADC, ASMIM_IMMEDIATE, (index >> 8) & 0xff)); mIns.Push(NativeCodeInstruction(ASMIT_ADC, ASMIM_IMMEDIATE, (index >> 8) & 0xff));
mIns.Push(NativeCodeInstruction(ASMIT_STA, ASMIM_ZERO_PAGE, BC_REG_ADDR + 1)); mIns.Push(NativeCodeInstruction(ASMIT_STA, ASMIM_ZERO_PAGE, treg + 1));
index = 0; index = 0;
if (treg == 0)
reg = BC_REG_ADDR;
else
reg = treg; reg = treg;
} }
} }
@ -10667,15 +10666,6 @@ void NativeCodeProcedure::CompileInterBlock(InterCodeProcedure* iproc, InterCode
break; break;
case IC_LOAD: case IC_LOAD:
if (i + 1 < iblock->mInstructions.Size() && if (i + 1 < iblock->mInstructions.Size() &&
iblock->mInstructions[i + 1]->mCode == IC_STORE &&
iblock->mInstructions[i + 1]->mSrc[0].mTemp == ins->mDst.mTemp &&
iblock->mInstructions[i + 1]->mSrc[0].mFinal &&
InterTypeSize[ins->mDst.mType] == 1)
{
block->LoadStoreValue(iproc, ins, iblock->mInstructions[i + 1]);
i++;
}
else if (i + 1 < iblock->mInstructions.Size() &&
iblock->mInstructions[i + 1]->mCode == IC_STORE && iblock->mInstructions[i + 1]->mCode == IC_STORE &&
iblock->mInstructions[i + 1]->mSrc[0].mTemp == ins->mDst.mTemp && iblock->mInstructions[i + 1]->mSrc[0].mTemp == ins->mDst.mTemp &&
iblock->mInstructions[i + 1]->mSrc[0].mFinal) iblock->mInstructions[i + 1]->mSrc[0].mFinal)