Changeset 228 in dev for trunk/abdev/BasicCompiler64


Ignore:
Timestamp:
Jul 23, 2007, 3:24:20 AM (17 years ago)
Author:
dai_9181
Message:
 
Location:
trunk/abdev/BasicCompiler64
Files:
10 edited

Legend:

Unmodified
Added
Removed
  • trunk/abdev/BasicCompiler64/CodeGenerator.cpp

    r226 r228  
    7979#define INDEX_NON   0x04
    8080
    81 void CodeGenerator::set_mod_rm_sib_disp(char mod,int reg,int scale,int index_reg,int base_reg,long disp){
     81void CodeGenerator::set_mod_rm_sib_disp(char mod,int reg,int scale,int index_reg,int base_reg,long disp, Schedule::Type scheduleType ){
    8282    if(mod==MOD_DISP32){
    8383        //ModR/Mバイト
     
    115115    if(mod==MOD_BASE_DISP8) pNativeCode->Put( (char)disp );
    116116    else{
    117         pNativeCode->Put( disp );
    118     }
    119 }
    120 
    121 
    122 
    123 void CodeGenerator::__op_format(int op_size,char op_prefix,char opcode1,char opcode2,int reg,int base_reg,long offset,char mod){
     117        pNativeCode->Put( disp, scheduleType );
     118    }
     119}
     120
     121
     122
     123void CodeGenerator::__op_format(int op_size,char op_prefix,char opcode1,char opcode2,int reg,int base_reg,long offset,char mod, Schedule::Type scheduleType ){
    124124    //命令プリフィックス
    125125    if(op_prefix) pNativeCode->Put( op_prefix );
     
    133133
    134134    //ModR/M, SIB, disp
    135     set_mod_rm_sib_disp(mod,reg,SCALE_NON,INDEX_NON,base_reg,offset);
     135    set_mod_rm_sib_disp(mod,reg,SCALE_NON,INDEX_NON,base_reg,offset, scheduleType );
     136}
     137
     138void CodeGenerator::__jmp_op_format( char opcode, long offset, int op_size )
     139{
     140    pNativeCode->Put( opcode );
     141    if( op_size == sizeof(char) )
     142    {
     143        pNativeCode->Put( (char)offset );
     144    }
     145    else if( op_size == sizeof(long) )
     146    {
     147        SetError();
     148        pNativeCode->Put( offset );
     149    }
     150    else
     151    {
     152        SetError();
     153    }
    136154}
    137155
     
    175193    pNativeCode->Put( i64data );
    176194}
    177 void CodeGenerator::op_mov_RM(int op_size,int reg,int base_reg,long offset,char mod){
     195void CodeGenerator::op_mov_RM(int op_size,int reg,int base_reg,long offset,char mod, Schedule::Type scheduleType ){
    178196    //mov reg64,qword ptr[base_reg+offset]
    179197    //mov reg32,dword ptr[base_reg+offset]
     
    190208    else opcode=(char)0x8B;
    191209
    192     __op_format(op_size,op_prefix,opcode,0,reg,base_reg,offset,mod);
    193 }
    194 void CodeGenerator::op_mov_RM_ex(int op_size,int reg,int base_reg1,int base_reg2,long offset,BOOL bUseOffset){
     210    __op_format(op_size,op_prefix,opcode,0,reg,base_reg,offset,mod, scheduleType);
     211}
     212void CodeGenerator::op_mov_RM_ex(int op_size,int reg,int base_reg1,int base_reg2,long offset,BOOL bUseOffset, Schedule::Type scheduleType ){
    195213    //mov reg64,qword ptr[base_reg1+base_reg2+offset]
    196214    //mov reg32,dword ptr[base_reg1+base_reg2+offset]
     
    226244
    227245        //オフセット値
    228         pNativeCode->Put( offset );
     246        pNativeCode->Put( offset, scheduleType );
    229247    }
    230248    else{
     
    561579
    562580//////////////////////////////////
     581// ビット拡張
     582//////////////////////////////////
     583
     584void CodeGenerator::op_cqo()
     585{
     586    pNativeCode->Put( (char)0x48 );
     587    pNativeCode->Put( (char)0x99 );
     588}
     589
     590
     591
     592//////////////////////////////////
    563593// インクリメント・デクリメント
    564594//////////////////////////////////
     
    593623/////////////////////
    594624
    595 void CodeGenerator::op_add_RM(int op_size,int reg,int base_reg,int offset,char mod){
     625void CodeGenerator::op_add_RM(int op_size,int reg,int base_reg,int offset,char mod, Schedule::Type scheduleType ){
    596626    //add reg64,qword ptr[base_reg+offset]
    597627    //add reg32,dword ptr[base_reg+offset]
     
    608638    else opcode=(char)0x03;
    609639
    610     __op_format(op_size,op_prefix,opcode,0,reg,base_reg,offset,mod);
     640    __op_format(op_size,op_prefix,opcode,0,reg,base_reg,offset,mod, scheduleType );
    611641}
    612642
     
    638668    }
    639669}
    640 void CodeGenerator::op_add64_reg(int reg1,int reg2){
     670void CodeGenerator::op_add_RR(int reg1,int reg2){
    641671    //add reg1,reg2
    642672    char RexByte=-1;
     
    17041734
    17051735/////////////////////////////
     1736// 分岐
     1737/////////////////////////////
     1738
     1739void CodeGenerator::op_jle( long offset, int op_size )
     1740{
     1741    __jmp_op_format( (char)0x7E, offset, op_size );
     1742}
     1743void CodeGenerator::op_jbe( long offset, int op_size )
     1744{
     1745    __jmp_op_format( (char)0x76, offset, op_size );
     1746}
     1747void CodeGenerator::op_jge( long offset, int op_size )
     1748{
     1749    __jmp_op_format( (char)0x7D, offset, op_size );
     1750}
     1751void CodeGenerator::op_jae( long offset, int op_size )
     1752{
     1753    __jmp_op_format( (char)0x73, offset, op_size );
     1754}
     1755void CodeGenerator::op_jl( long offset, int op_size )
     1756{
     1757    __jmp_op_format( (char)0x7C, offset, op_size );
     1758}
     1759void CodeGenerator::op_jb( long offset, int op_size )
     1760{
     1761    __jmp_op_format( (char)0x72, offset, op_size );
     1762}
     1763void CodeGenerator::op_jg( long offset, int op_size )
     1764{
     1765    __jmp_op_format( (char)0x7F, offset, op_size );
     1766}
     1767void CodeGenerator::op_ja( long offset, int op_size )
     1768{
     1769    __jmp_op_format( (char)0x77, offset, op_size );
     1770}
     1771void CodeGenerator::op_jne( long offset, int op_size )
     1772{
     1773    __jmp_op_format( (char)0x75, offset, op_size );
     1774}
     1775void CodeGenerator::op_je( long offset, int op_size )
     1776{
     1777    __jmp_op_format( (char)0x74, offset, op_size );
     1778}
     1779void CodeGenerator::op_jmp( long offset, int op_size )
     1780{
     1781    __jmp_op_format( (char)0xEB, offset, op_size );
     1782}
     1783
     1784
     1785
     1786/////////////////////////////
    17061787// 関数呼び出し
    17071788/////////////////////////////
  • trunk/abdev/BasicCompiler64/Compile_Calc_PushVar.cpp

    r226 r228  
    185185        if(pRelativeVar->bOffsetOffset){
    186186            //mov reg, ptr[r11+offset]
    187             compiler.codeGenerator.op_mov_RM(varSize,reg,REG_R11,(int)pRelativeVar->offset,MOD_BASE_DISP32);
    188             obp-=sizeof(long);
    189             pobj_GlobalVarSchedule->add();
    190             obp+=sizeof(long);
     187            compiler.codeGenerator.op_mov_RM(varSize,reg,REG_R11,(int)pRelativeVar->offset,MOD_BASE_DISP32, Schedule::GlobalVar );
    191188        }
    192189        else{
    193190            //mov reg, ptr[offset]
    194             compiler.codeGenerator.op_mov_RM(varSize,reg,0,(int)pRelativeVar->offset,MOD_DISP32);
    195             obp-=sizeof(long);
    196             pobj_GlobalVarSchedule->add();
    197             obp+=sizeof(long);
     191            compiler.codeGenerator.op_mov_RM(varSize,reg,0,(int)pRelativeVar->offset,MOD_DISP32, Schedule::GlobalVar );
    198192        }
    199193    }
     
    201195        if(pRelativeVar->bOffsetOffset){
    202196            //add r11,qword ptr[offset]
    203             compiler.codeGenerator.op_add_RM(sizeof(_int64),REG_R11,REG_NON,(int)pRelativeVar->offset,MOD_DISP32);
    204             obp-=sizeof(long);
    205             pobj_GlobalVarSchedule->add();
    206             obp+=sizeof(long);
     197            compiler.codeGenerator.op_add_RM(sizeof(_int64),REG_R11,REG_NON,(int)pRelativeVar->offset,MOD_DISP32, Schedule::GlobalVar );
    207198        }
    208199        else{
    209200            //mov r11,qword ptr[offset]
    210             compiler.codeGenerator.op_mov_RM(sizeof(_int64),REG_R11,REG_NON,(int)pRelativeVar->offset,MOD_DISP32);
    211             obp-=sizeof(long);
    212             pobj_GlobalVarSchedule->add();
    213             obp+=sizeof(long);
     201            compiler.codeGenerator.op_mov_RM(sizeof(_int64),REG_R11,REG_NON,(int)pRelativeVar->offset,MOD_DISP32, Schedule::GlobalVar );
    214202        }
    215203
     
    219207        if(pRelativeVar->bOffsetOffset){
    220208            //mov reg, ptr[rsp+r11+offset]
    221             compiler.codeGenerator.op_mov_RM_ex(varSize,reg,REG_RSP,REG_R11,(int)pRelativeVar->offset,USE_OFFSET);
    222             obp-=sizeof(long);
    223             AddLocalVarAddrSchedule();
    224             obp+=sizeof(long);
     209            compiler.codeGenerator.op_mov_RM_ex(varSize,reg,REG_RSP,REG_R11,(int)pRelativeVar->offset,USE_OFFSET, Schedule::LocalVar );
    225210        }
    226211        else{
    227212            //mov reg, ptr[rsp+offset]
    228             compiler.codeGenerator.op_mov_RM(varSize,reg,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32);
    229             obp-=sizeof(long);
    230             AddLocalVarAddrSchedule();
    231             obp+=sizeof(long);
     213            compiler.codeGenerator.op_mov_RM(varSize,reg,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32, Schedule::LocalVar );
    232214        }
    233215    }
     
    235217        if(pRelativeVar->bOffsetOffset){
    236218            //add r11,qword ptr[rsp+offset]
    237             compiler.codeGenerator.op_add_RM(sizeof(_int64),REG_R11,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32);
    238             obp-=sizeof(long);
    239             AddLocalVarAddrSchedule();
    240             obp+=sizeof(long);
     219            compiler.codeGenerator.op_add_RM(sizeof(_int64),REG_R11,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32, Schedule::LocalVar );
    241220        }
    242221        else{
    243222            //mov r11,qword ptr[rsp+offset]
    244             compiler.codeGenerator.op_mov_RM(sizeof(_int64),REG_R11,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32);
    245             obp-=sizeof(long);
    246             AddLocalVarAddrSchedule();
    247             obp+=sizeof(long);
     223            compiler.codeGenerator.op_mov_RM(sizeof(_int64),REG_R11,REG_RSP,(int)pRelativeVar->offset,MOD_BASE_DISP32, Schedule::LocalVar );
    248224        }
    249225
  • trunk/abdev/BasicCompiler64/Compile_CallProc.cpp

    r226 r228  
    8282
    8383    //call rax
    84     OpBuffer[obp++]=(char)0xFF;
    85     OpBuffer[obp++]=(char)0xD0;
     84    compiler.codeGenerator.PutOld(
     85        (char)0xFF,
     86        (char)0xD0
     87    );
    8688
    8789
     
    361363        //call qword ptr[r11+func_index]
    362364        if(i2*PTR_SIZE<=0x7F){
    363             OpBuffer[obp++]=(char)0x41;
    364             OpBuffer[obp++]=(char)0xFF;
    365             OpBuffer[obp++]=(char)0x53;
    366             OpBuffer[obp++]=(char)(i2*PTR_SIZE);
     365            compiler.codeGenerator.PutOld(
     366                (char)0x41,
     367                (char)0xFF,
     368                (char)0x53,
     369                (char)(i2*PTR_SIZE)
     370            );
    367371        }
    368372        else{
    369             OpBuffer[obp++]=(char)0x41;
    370             OpBuffer[obp++]=(char)0xFF;
    371             OpBuffer[obp++]=(char)0x93;
    372             *((long *)(OpBuffer+obp))=i2*PTR_SIZE;
    373             obp+=sizeof(long);
     373            compiler.codeGenerator.PutOld(
     374                (char)0x41,
     375                (char)0xFF,
     376                (char)0x93,
     377                (long)(i2*PTR_SIZE)
     378            );
    374379        }
    375380    }
  • trunk/abdev/BasicCompiler64/Compile_Object.cpp

    r226 r228  
    7979        pobj_sf->pop(REG_RBX);
    8080
    81         //add eax,TypeSize
    82         OpBuffer[obp++]=(char)0x05;
    83         *((long *)(OpBuffer+obp))=ObjectSize;
    84         obp+=sizeof(long);
    85 
    86         //sub ebx,1
    87         OpBuffer[obp++]=(char)0x83;
    88         OpBuffer[obp++]=(char)0xEB;
    89         OpBuffer[obp++]=(char)0x01;
     81        //add rax,TypeSize
     82        compiler.codeGenerator.op_add_RV( REG_RAX, ObjectSize );
     83
     84        //sub rbx,1
     85        compiler.codeGenerator.op_sub_RV( sizeof(_int64), REG_RBX, 1 );
    9086
    9187        //jnz ↑
     
    275271
    276272    //call rdi
    277     OpBuffer[obp++]=(char)0xFF;
    278     OpBuffer[obp++]=(char)0xD7;
     273    compiler.codeGenerator.PutOld(
     274        (char)0xFF,
     275        (char)0xD7
     276    );
    279277
    280278    //mov rcx,qword ptr[rsp+offset]     ※スタックフレームを利用
     
    282280
    283281    //add rcx,rsi
    284     compiler.codeGenerator.op_add64_reg(REG_RCX,REG_RSI);
     282    compiler.codeGenerator.op_add_RR(REG_RCX,REG_RSI);
    285283
    286284    //sub rbx,1
  • trunk/abdev/BasicCompiler64/Compile_Set_Var.cpp

    r226 r228  
    178178directmem:
    179179        //movsd qword ptr[r11],xmm0
    180         OpBuffer[obp++]=(char)0xF2;
    181         OpBuffer[obp++]=(char)0x41;
    182         OpBuffer[obp++]=(char)0x0F;
    183         OpBuffer[obp++]=(char)0x11;
    184         OpBuffer[obp++]=(char)0x03;
     180        compiler.codeGenerator.op_movsd_MR( REG_XMM0, REG_R11, 0, MOD_BASE );
    185181    }
    186182}
     
    269265directmem:
    270266        //movss dword ptr[r11],xmm0
    271         OpBuffer[obp++]=(char)0xF3;
    272         OpBuffer[obp++]=(char)0x41;
    273         OpBuffer[obp++]=(char)0x0F;
    274         OpBuffer[obp++]=(char)0x11;
    275         OpBuffer[obp++]=(char)0x03;
     267        compiler.codeGenerator.op_movss_MR( REG_XMM0, REG_R11, 0, MOD_BASE );
    276268    }
    277269}
  • trunk/abdev/BasicCompiler64/Compile_Var.cpp

    r226 r228  
    7272
    7373    //add r11,reg
    74     compiler.codeGenerator.op_add64_reg(REG_R11,reg);
     74    compiler.codeGenerator.op_add_RR(REG_R11,reg);
    7575}
    7676void SetRelativeOffset( RELATIVE_VAR &relativeVar ){
     
    176176
    177177        //add r12,reg
    178         compiler.codeGenerator.op_add64_reg(REG_R12,reg);
     178        compiler.codeGenerator.op_add_RR(REG_R12,reg);
    179179
    180180        HeapDefaultFree(pParm[i]);
     
    182182
    183183    //imul r12,TypeSize
    184     OpBuffer[obp++]=(char)0x4D;
    185     OpBuffer[obp++]=(char)0x69;
    186     OpBuffer[obp++]=(char)0xE4;
    187     *((long *)(OpBuffer+obp))=type.GetSize();
    188     obp+=sizeof(long);
     184    compiler.codeGenerator.op_imul_RV( sizeof(_int64), REG_R12, type.GetSize() );
    189185
    190186    //mov r11,qword ptr[rsp+offset]     ※スタックフレームを利用
     
    192188
    193189    //add r11,r12
    194     OpBuffer[obp++]=(char)0x4D;
    195     OpBuffer[obp++]=(char)0x03;
    196     OpBuffer[obp++]=(char)0xDC;
     190    compiler.codeGenerator.op_add_RR( REG_R11, REG_R12 );
    197191
    198192    return true;
     
    275269    if(offset){
    276270        //add r11,offset
    277         OpBuffer[obp++]=(char)0x49;
    278         OpBuffer[obp++]=(char)0x81;
    279         OpBuffer[obp++]=(char)0xC3;
    280         *((long *)(OpBuffer+obp))=offset;
    281         obp+=sizeof(long);
     271        compiler.codeGenerator.op_add_RV( REG_R11, offset );
    282272    }
    283273
     
    12791269
    12801270            //add r11,rsp
    1281             compiler.codeGenerator.op_add64_reg(REG_R11,REG_RSP);
     1271            compiler.codeGenerator.op_add_RR(REG_R11,REG_RSP);
    12821272
    12831273            //mov reg,r11
  • trunk/abdev/BasicCompiler64/NumOpe_Arithmetic.cpp

    r226 r228  
    3737            if(idCalc==CALC_ADDITION){
    3838                //addsd xmm_reg1,xmm_reg2
    39                 OpBuffer[obp++]=(char)0xF2;
    40                 OpBuffer[obp++]=(char)0x0F;
    41                 OpBuffer[obp++]=(char)0x58;
    42                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     39                compiler.codeGenerator.PutOld(
     40                    (char)0xF2,
     41                    (char)0x0F,
     42                    (char)0x58,
     43                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     44                );
    4345            }
    4446            else if(idCalc==CALC_SUBTRACTION){
    4547                //subsd xmm_reg1,xmm_reg2
    46                 OpBuffer[obp++]=(char)0xF2;
    47                 OpBuffer[obp++]=(char)0x0F;
    48                 OpBuffer[obp++]=(char)0x5C;
    49                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     48                compiler.codeGenerator.PutOld(
     49                    (char)0xF2,
     50                    (char)0x0F,
     51                    (char)0x5C,
     52                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     53                );
    5054            }
    5155            else if(idCalc==CALC_PRODUCT){
    5256                //mulsd xmm_reg1,xmm_reg2
    53                 OpBuffer[obp++]=(char)0xF2;
    54                 OpBuffer[obp++]=(char)0x0F;
    55                 OpBuffer[obp++]=(char)0x59;
    56                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     57                compiler.codeGenerator.PutOld(
     58                    (char)0xF2,
     59                    (char)0x0F,
     60                    (char)0x59,
     61                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     62                );
    5763            }
    5864
     
    6975            if(idCalc==CALC_ADDITION){
    7076                //addss xmm_reg1,xmm_reg2
    71                 OpBuffer[obp++]=(char)0xF3;
    72                 OpBuffer[obp++]=(char)0x0F;
    73                 OpBuffer[obp++]=(char)0x58;
    74                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     77                compiler.codeGenerator.PutOld(
     78                    (char)0xF3,
     79                    (char)0x0F,
     80                    (char)0x58,
     81                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     82                );
    7583            }
    7684            else if(idCalc==CALC_SUBTRACTION){
    7785                //subss xmm_reg1,xmm_reg2
    78                 OpBuffer[obp++]=(char)0xF3;
    79                 OpBuffer[obp++]=(char)0x0F;
    80                 OpBuffer[obp++]=(char)0x5C;
    81                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     86                compiler.codeGenerator.PutOld(
     87                    (char)0xF3,
     88                    (char)0x0F,
     89                    (char)0x5C,
     90                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     91                );
    8292            }
    8393            else if(idCalc==CALC_PRODUCT){
    8494                //mulss xmm_reg1,xmm_reg2
    85                 OpBuffer[obp++]=(char)0xF3;
    86                 OpBuffer[obp++]=(char)0x0F;
    87                 OpBuffer[obp++]=(char)0x59;
    88                 OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     95                compiler.codeGenerator.PutOld(
     96                    (char)0xF3,
     97                    (char)0x0F,
     98                    (char)0x59,
     99                    (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     100                );
    89101            }
    90102
     
    104116        if(idCalc==CALC_ADDITION){
    105117            //add reg1,reg2
    106             compiler.codeGenerator.op_add64_reg(reg1,reg2);
     118            compiler.codeGenerator.op_add_RR(reg1,reg2);
    107119        }
    108120        else if(idCalc==CALC_SUBTRACTION){
     
    214226
    215227            //cqo
    216             OpBuffer[obp++]=(char)0x48;
    217             OpBuffer[obp++]=(char)0x99;
     228            compiler.codeGenerator.op_cqo();
    218229        }
    219230        else{
     
    294305
    295306        //divsd xmm_reg1,xmm_reg2
    296         OpBuffer[obp++]=(char)0xF2;
    297         OpBuffer[obp++]=(char)0x0F;
    298         OpBuffer[obp++]=(char)0x5E;
    299         OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     307        compiler.codeGenerator.PutOld(
     308            (char)0xF2,
     309            (char)0x0F,
     310            (char)0x5E,
     311            (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     312        );
    300313
    301314        if(xmm_reg1==REG_XMM4){
     
    310323
    311324        //divss xmm_reg1,xmm_reg2
    312         OpBuffer[obp++]=(char)0xF3;
    313         OpBuffer[obp++]=(char)0x0F;
    314         OpBuffer[obp++]=(char)0x5E;
    315         OpBuffer[obp++]=(char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2));
     325        compiler.codeGenerator.PutOld(
     326            (char)0xF3,
     327            (char)0x0F,
     328            (char)0x5E,
     329            (char)(0xC0 | REGISTER_OPERAND(xmm_reg1)<<3 | REGISTER_OPERAND(xmm_reg2))
     330        );
    316331
    317332        if(xmm_reg1==REG_XMM4){
     
    390405
    391406            //cqo
    392             OpBuffer[obp++]=(char)0x48;
    393             OpBuffer[obp++]=(char)0x99;
     407            compiler.codeGenerator.op_cqo();
    394408        }
    395409        else{
  • trunk/abdev/BasicCompiler64/NumOpe_Relation.cpp

    r226 r228  
    6767    ////////////////////
    6868
     69    int jmpOffset = 5;
     70
    6971    if(idCalc==CALC_PE){
    7072        //  reg1 <= reg2
     
    7274            //符号あり演算
    7375            //jle
    74             OpBuffer[obp++]=(char)0x7E;
     76            compiler.codeGenerator.op_jle( jmpOffset );
    7577        }
    7678        else{
    7779            //符号なし演算
    7880            //jbe
    79             OpBuffer[obp++]=(char)0x76;
     81            compiler.codeGenerator.op_jbe( jmpOffset );
    8082        }
    8183    }
     
    8587            //符号あり演算
    8688            //jge
    87             OpBuffer[obp++]=(char)0x7D;
     89            compiler.codeGenerator.op_jge( jmpOffset );
    8890        }
    8991        else{
    9092            //符号なし演算
    9193            //jae
    92             OpBuffer[obp++]=(char)0x73;
     94            compiler.codeGenerator.op_jae( jmpOffset );
    9395        }
    9496    }
     
    98100            //符号あり演算
    99101            //jl
    100             OpBuffer[obp++]=(char)0x7C;
     102            compiler.codeGenerator.op_jl( jmpOffset );
    101103        }
    102104        else{
    103105            //符号なし演算
    104106            //jb
    105             OpBuffer[obp++]=(char)0x72;
     107            compiler.codeGenerator.op_jb( jmpOffset );
    106108        }
    107109    }
     
    111113            //符号あり演算
    112114            //jg
    113             OpBuffer[obp++]=(char)0x7F;
     115            compiler.codeGenerator.op_jg( jmpOffset );
    114116        }
    115117        else{
    116118            //符号なし演算
    117119            //ja
    118             OpBuffer[obp++]=(char)0x77;
     120            compiler.codeGenerator.op_ja( jmpOffset );
    119121        }
    120122    }
     
    123125
    124126        //jne
    125         OpBuffer[obp++]=(char)0x75;
     127        compiler.codeGenerator.op_jne( jmpOffset );
    126128    }
    127129    else if(idCalc==CALC_EQUAL){
     
    129131
    130132        //je
    131         OpBuffer[obp++]=(char)0x74;
     133        compiler.codeGenerator.op_je( jmpOffset );
    132134    }
    133     OpBuffer[obp++]=(char)0x05;
    134135
    135136
     
    142143
    143144    //jmp 7(次のmovを飛び越す)
    144     OpBuffer[obp++]=(char)0xEB;
    145     OpBuffer[obp++]=(char)0x07;
     145    compiler.codeGenerator.op_jge( 7 );
    146146
    147147
  • trunk/abdev/BasicCompiler64/NumOpe_TypeOperation.cpp

    r226 r228  
    8585
    8686            //jge 9
    87             OpBuffer[obp++]=(char)0x7D;
    88             OpBuffer[obp++]=(char)0x09;
     87            compiler.codeGenerator.op_jge( 9 );
    8988
    9089            //addsd xmm_reg,qword ptr[offset]   ※offset value:43f0000000000000
     
    144143
    145144            //jge 9
    146             OpBuffer[obp++]=(char)0x7D;
    147             OpBuffer[obp++]=(char)0x09;
     145            compiler.codeGenerator.op_jge( 9 );
    148146
    149147            //addss xmm_reg,dword ptr[offset]   ※offset value:5f800000
     
    315313                if(type[sp-1]==DEF_DOUBLE){
    316314                    //movsd xmm5,xmm_reg
    317                     OpBuffer[obp++]=(char)0xF2;
    318                     OpBuffer[obp++]=(char)0x0F;
    319                     OpBuffer[obp++]=(char)0x10;
    320                     OpBuffer[obp++]=(char)(0xE8 | REGISTER_OPERAND(xmm_reg2));
     315                    compiler.codeGenerator.op_movsd_RR( REG_XMM5, xmm_reg2 );
    321316                }
    322317                if(type[sp-1]==DEF_SINGLE){
    323318                    //movss xmm5,xmm_reg
    324                     OpBuffer[obp++]=(char)0xF3;
    325                     OpBuffer[obp++]=(char)0x0F;
    326                     OpBuffer[obp++]=(char)0x10;
    327                     OpBuffer[obp++]=(char)(0xE8 | REGISTER_OPERAND(xmm_reg2));
     319                    compiler.codeGenerator.op_movss_RR( REG_XMM5, xmm_reg2 );
    328320                }
    329321
  • trunk/abdev/BasicCompiler64/stack_frame.cpp

    r226 r228  
    8080    if(varSize==sizeof(float)){
    8181        //movss dword ptr[rsp+offset],xmm_reg
    82         OpBuffer[obp++]=(char)0xF3;
    83         OpBuffer[obp++]=(char)0x0F;
    84         OpBuffer[obp++]=(char)0x11;
    85         OpBuffer[obp++]=(char)(0x84| REGISTER_OPERAND(xmm_reg)<<3 );
    86         OpBuffer[obp++]=(char)0x24;
    87         *((long *)(OpBuffer+obp))=now_sp;
    88         obp+=sizeof(long);
     82        compiler.codeGenerator.op_movss_MR( xmm_reg, REG_RSP, now_sp, MOD_BASE_DISP32 );
    8983    }
    9084
     
    113107    if(varSize==sizeof(float)){
    114108        //movss xmm_reg,dword ptr[rsp+offset]
    115         OpBuffer[obp++]=(char)0xF3;
    116         OpBuffer[obp++]=(char)0x0F;
    117         OpBuffer[obp++]=(char)0x10;
    118         OpBuffer[obp++]=(char)(0x84| REGISTER_OPERAND(xmm_reg)<<3 );
    119         OpBuffer[obp++]=(char)0x24;
    120         *((long *)(OpBuffer+obp))=now_sp;
    121         obp+=sizeof(long);
     109        compiler.codeGenerator.op_movss_MR( xmm_reg, REG_RSP, now_sp, MOD_BASE_DISP32 );
    122110    }
    123111
Note: See TracChangeset for help on using the changeset viewer.