1 2 /*---------------------------------------------------------------*/ 3 /*--- begin host_ppc_defs.h ---*/ 4 /*---------------------------------------------------------------*/ 5 6 /* 7 This file is part of Valgrind, a dynamic binary instrumentation 8 framework. 9 10 Copyright (C) 2004-2012 OpenWorks LLP 11 info@open-works.net 12 13 This program is free software; you can redistribute it and/or 14 modify it under the terms of the GNU General Public License as 15 published by the Free Software Foundation; either version 2 of the 16 License, or (at your option) any later version. 17 18 This program is distributed in the hope that it will be useful, but 19 WITHOUT ANY WARRANTY; without even the implied warranty of 20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 21 General Public License for more details. 22 23 You should have received a copy of the GNU General Public License 24 along with this program; if not, write to the Free Software 25 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 26 02110-1301, USA. 27 28 The GNU General Public License is contained in the file COPYING. 29 30 Neither the names of the U.S. Department of Energy nor the 31 University of California nor the names of its contributors may be 32 used to endorse or promote products derived from this software 33 without prior written permission. 34 */ 35 36 #ifndef __VEX_HOST_PPC_DEFS_H 37 #define __VEX_HOST_PPC_DEFS_H 38 39 /* Num registers used for function calls */ 40 #define PPC_N_REGPARMS 8 41 42 43 /* --------- Registers. --------- */ 44 45 /* The usual HReg abstraction. There are 32 real int regs, 46 32 real float regs, and 32 real vector regs. 47 */ 48 49 extern void ppHRegPPC ( HReg ); 50 51 extern HReg hregPPC_GPR0 ( Bool mode64 ); // scratch reg / zero reg 52 extern HReg hregPPC_GPR1 ( Bool mode64 ); // Stack Frame Pointer 53 extern HReg hregPPC_GPR2 ( Bool mode64 ); // not used: TOC pointer 54 extern HReg hregPPC_GPR3 ( Bool mode64 ); 55 extern HReg hregPPC_GPR4 ( Bool mode64 ); 56 extern HReg hregPPC_GPR5 ( Bool mode64 ); 57 extern HReg hregPPC_GPR6 ( Bool mode64 ); 58 extern HReg hregPPC_GPR7 ( Bool mode64 ); 59 extern HReg hregPPC_GPR8 ( Bool mode64 ); 60 extern HReg hregPPC_GPR9 ( Bool mode64 ); 61 extern HReg hregPPC_GPR10 ( Bool mode64 ); 62 extern HReg hregPPC_GPR11 ( Bool mode64 ); 63 extern HReg hregPPC_GPR12 ( Bool mode64 ); 64 extern HReg hregPPC_GPR13 ( Bool mode64 ); 65 extern HReg hregPPC_GPR14 ( Bool mode64 ); 66 extern HReg hregPPC_GPR15 ( Bool mode64 ); 67 extern HReg hregPPC_GPR16 ( Bool mode64 ); 68 extern HReg hregPPC_GPR17 ( Bool mode64 ); 69 extern HReg hregPPC_GPR18 ( Bool mode64 ); 70 extern HReg hregPPC_GPR19 ( Bool mode64 ); 71 extern HReg hregPPC_GPR20 ( Bool mode64 ); 72 extern HReg hregPPC_GPR21 ( Bool mode64 ); 73 extern HReg hregPPC_GPR22 ( Bool mode64 ); 74 extern HReg hregPPC_GPR23 ( Bool mode64 ); 75 extern HReg hregPPC_GPR24 ( Bool mode64 ); 76 extern HReg hregPPC_GPR25 ( Bool mode64 ); 77 extern HReg hregPPC_GPR26 ( Bool mode64 ); 78 extern HReg hregPPC_GPR27 ( Bool mode64 ); 79 extern HReg hregPPC_GPR28 ( Bool mode64 ); 80 extern HReg hregPPC_GPR29 ( Bool mode64 ); // reserved for dispatcher 81 extern HReg hregPPC_GPR30 ( Bool mode64 ); // used as VMX spill temp 82 extern HReg hregPPC_GPR31 ( Bool mode64 ); // GuestStatePtr (callee-saved) 83 84 extern HReg hregPPC_FPR0 ( void ); 85 extern HReg hregPPC_FPR1 ( void ); 86 extern HReg hregPPC_FPR2 ( void ); 87 extern HReg hregPPC_FPR3 ( void ); 88 extern HReg hregPPC_FPR4 ( void ); 89 extern HReg hregPPC_FPR5 ( void ); 90 extern HReg hregPPC_FPR6 ( void ); 91 extern HReg hregPPC_FPR7 ( void ); 92 extern HReg hregPPC_FPR8 ( void ); 93 extern HReg hregPPC_FPR9 ( void ); 94 extern HReg hregPPC_FPR10 ( void ); 95 extern HReg hregPPC_FPR11 ( void ); 96 extern HReg hregPPC_FPR12 ( void ); 97 extern HReg hregPPC_FPR13 ( void ); 98 extern HReg hregPPC_FPR14 ( void ); 99 extern HReg hregPPC_FPR15 ( void ); 100 extern HReg hregPPC_FPR16 ( void ); 101 extern HReg hregPPC_FPR17 ( void ); 102 extern HReg hregPPC_FPR18 ( void ); 103 extern HReg hregPPC_FPR19 ( void ); 104 extern HReg hregPPC_FPR20 ( void ); 105 extern HReg hregPPC_FPR21 ( void ); 106 extern HReg hregPPC_FPR22 ( void ); 107 extern HReg hregPPC_FPR23 ( void ); 108 extern HReg hregPPC_FPR24 ( void ); 109 extern HReg hregPPC_FPR25 ( void ); 110 extern HReg hregPPC_FPR26 ( void ); 111 extern HReg hregPPC_FPR27 ( void ); 112 extern HReg hregPPC_FPR28 ( void ); 113 extern HReg hregPPC_FPR29 ( void ); 114 extern HReg hregPPC_FPR30 ( void ); 115 extern HReg hregPPC_FPR31 ( void ); 116 117 extern HReg hregPPC_VR0 ( void ); 118 extern HReg hregPPC_VR1 ( void ); 119 extern HReg hregPPC_VR2 ( void ); 120 extern HReg hregPPC_VR3 ( void ); 121 extern HReg hregPPC_VR4 ( void ); 122 extern HReg hregPPC_VR5 ( void ); 123 extern HReg hregPPC_VR6 ( void ); 124 extern HReg hregPPC_VR7 ( void ); 125 extern HReg hregPPC_VR8 ( void ); 126 extern HReg hregPPC_VR9 ( void ); 127 extern HReg hregPPC_VR10 ( void ); 128 extern HReg hregPPC_VR11 ( void ); 129 extern HReg hregPPC_VR12 ( void ); 130 extern HReg hregPPC_VR13 ( void ); 131 extern HReg hregPPC_VR14 ( void ); 132 extern HReg hregPPC_VR15 ( void ); 133 extern HReg hregPPC_VR16 ( void ); 134 extern HReg hregPPC_VR17 ( void ); 135 extern HReg hregPPC_VR18 ( void ); 136 extern HReg hregPPC_VR19 ( void ); 137 extern HReg hregPPC_VR20 ( void ); 138 extern HReg hregPPC_VR21 ( void ); 139 extern HReg hregPPC_VR22 ( void ); 140 extern HReg hregPPC_VR23 ( void ); 141 extern HReg hregPPC_VR24 ( void ); 142 extern HReg hregPPC_VR25 ( void ); 143 extern HReg hregPPC_VR26 ( void ); 144 extern HReg hregPPC_VR27 ( void ); 145 extern HReg hregPPC_VR28 ( void ); 146 extern HReg hregPPC_VR29 ( void ); 147 extern HReg hregPPC_VR30 ( void ); 148 extern HReg hregPPC_VR31 ( void ); 149 150 #define StackFramePtr(_mode64) hregPPC_GPR1(_mode64) 151 #define GuestStatePtr(_mode64) hregPPC_GPR31(_mode64) 152 153 154 155 /* --------- Condition codes --------- */ 156 157 /* This gives names from bitfields in CR; hence it names BI numbers */ 158 /* Using IBM/hardware indexing convention */ 159 typedef 160 enum { 161 // CR7, which we use for integer compares 162 Pcf_7LT = 28, /* neg | lt */ 163 Pcf_7GT = 29, /* pos | gt */ 164 Pcf_7EQ = 30, /* zero | equal */ 165 Pcf_7SO = 31, /* summary overflow */ 166 Pcf_NONE = 32 /* no condition; used with Pct_ALWAYS */ 167 } 168 PPCCondFlag; 169 170 typedef 171 enum { /* Maps bc bitfield BO */ 172 Pct_FALSE = 0x4, /* associated PPCCondFlag must not be Pcf_NONE */ 173 Pct_TRUE = 0xC, /* associated PPCCondFlag must not be Pcf_NONE */ 174 Pct_ALWAYS = 0x14 /* associated PPCCondFlag must be Pcf_NONE */ 175 } 176 PPCCondTest; 177 178 typedef 179 struct { 180 PPCCondFlag flag; 181 PPCCondTest test; 182 } 183 PPCCondCode; 184 185 extern HChar* showPPCCondCode ( PPCCondCode ); 186 187 /* constructor */ 188 extern PPCCondCode mk_PPCCondCode ( PPCCondTest, PPCCondFlag ); 189 190 /* false->true, true->false */ 191 extern PPCCondTest invertCondTest ( PPCCondTest ); 192 193 194 195 196 /* --------- Memory address expressions (amodes). --------- */ 197 198 typedef 199 enum { 200 Pam_IR=1, /* Immediate (signed 16-bit) + Reg */ 201 Pam_RR=2 /* Reg1 + Reg2 */ 202 } 203 PPCAModeTag; 204 205 typedef 206 struct { 207 PPCAModeTag tag; 208 union { 209 struct { 210 HReg base; 211 Int index; 212 } IR; 213 struct { 214 HReg base; 215 HReg index; 216 } RR; 217 } Pam; 218 } 219 PPCAMode; 220 221 extern PPCAMode* PPCAMode_IR ( Int, HReg ); 222 extern PPCAMode* PPCAMode_RR ( HReg, HReg ); 223 224 extern PPCAMode* dopyPPCAMode ( PPCAMode* ); 225 226 extern void ppPPCAMode ( PPCAMode* ); 227 228 229 /* --------- Operand, which can be a reg or a u16/s16. --------- */ 230 /* ("RH" == "Register or Halfword immediate") */ 231 typedef 232 enum { 233 Prh_Imm=3, 234 Prh_Reg=4 235 } 236 PPCRHTag; 237 238 typedef 239 struct { 240 PPCRHTag tag; 241 union { 242 struct { 243 Bool syned; 244 UShort imm16; 245 } Imm; 246 struct { 247 HReg reg; 248 } Reg; 249 } 250 Prh; 251 } 252 PPCRH; 253 254 extern PPCRH* PPCRH_Imm ( Bool, UShort ); 255 extern PPCRH* PPCRH_Reg ( HReg ); 256 257 extern void ppPPCRH ( PPCRH* ); 258 259 260 /* --------- Operand, which can be a reg or a u32/64. --------- */ 261 262 typedef 263 enum { 264 Pri_Imm=5, 265 Pri_Reg=6 266 } 267 PPCRITag; 268 269 typedef 270 struct { 271 PPCRITag tag; 272 union { 273 ULong Imm; 274 HReg Reg; 275 } 276 Pri; 277 } 278 PPCRI; 279 280 extern PPCRI* PPCRI_Imm ( ULong ); 281 extern PPCRI* PPCRI_Reg( HReg ); 282 283 extern void ppPPCRI ( PPCRI* ); 284 285 286 /* --------- Operand, which can be a vector reg or a s6. --------- */ 287 /* ("VI" == "Vector Register or Immediate") */ 288 typedef 289 enum { 290 Pvi_Imm=7, 291 Pvi_Reg=8 292 } 293 PPCVI5sTag; 294 295 typedef 296 struct { 297 PPCVI5sTag tag; 298 union { 299 Char Imm5s; 300 HReg Reg; 301 } 302 Pvi; 303 } 304 PPCVI5s; 305 306 extern PPCVI5s* PPCVI5s_Imm ( Char ); 307 extern PPCVI5s* PPCVI5s_Reg ( HReg ); 308 309 extern void ppPPCVI5s ( PPCVI5s* ); 310 311 312 /* --------- Instructions. --------- */ 313 314 /* --------- */ 315 typedef 316 enum { 317 Pun_NEG, 318 Pun_NOT, 319 Pun_CLZ32, 320 Pun_CLZ64, 321 Pun_EXTSW 322 } 323 PPCUnaryOp; 324 325 extern HChar* showPPCUnaryOp ( PPCUnaryOp ); 326 327 328 /* --------- */ 329 typedef 330 enum { 331 Palu_INVALID, 332 Palu_ADD, Palu_SUB, 333 Palu_AND, Palu_OR, Palu_XOR, 334 } 335 PPCAluOp; 336 337 extern 338 HChar* showPPCAluOp ( PPCAluOp, 339 Bool /* is the 2nd operand an immediate? */); 340 341 342 /* --------- */ 343 typedef 344 enum { 345 Pshft_INVALID, 346 Pshft_SHL, Pshft_SHR, Pshft_SAR, 347 } 348 PPCShftOp; 349 350 extern 351 HChar* showPPCShftOp ( PPCShftOp, 352 Bool /* is the 2nd operand an immediate? */, 353 Bool /* is this a 32bit or 64bit op? */ ); 354 355 356 /* --------- */ 357 typedef 358 enum { 359 Pfp_INVALID, 360 361 /* Ternary */ 362 Pfp_MADDD, Pfp_MSUBD, 363 Pfp_MADDS, Pfp_MSUBS, 364 Pfp_DFPADD, Pfp_DFPADDQ, 365 Pfp_DFPSUB, Pfp_DFPSUBQ, 366 Pfp_DFPMUL, Pfp_DFPMULQ, 367 Pfp_DFPDIV, Pfp_DFPDIVQ, 368 Pfp_DQUAQ, Pfp_DRRNDQ, 369 370 /* Binary */ 371 Pfp_ADDD, Pfp_SUBD, Pfp_MULD, Pfp_DIVD, 372 Pfp_ADDS, Pfp_SUBS, Pfp_MULS, Pfp_DIVS, 373 Pfp_DRSP, Pfp_DRDPQ, Pfp_DCTFIX, Pfp_DCTFIXQ, Pfp_DCFFIX, 374 Pfp_DQUA, Pfp_RRDTR, Pfp_DIEX, Pfp_DIEXQ, 375 376 /* Unary */ 377 Pfp_SQRT, Pfp_ABS, Pfp_NEG, Pfp_MOV, Pfp_RES, Pfp_RSQRTE, 378 Pfp_FRIN, Pfp_FRIM, Pfp_FRIP, Pfp_FRIZ, 379 Pfp_DSCLI, Pfp_DSCRI, Pfp_DSCLIQ, Pfp_DSCRIQ, Pfp_DCTDP, 380 Pfp_DCTQPQ, Pfp_DCFFIXQ, Pfp_DXEX, Pfp_DXEXQ, 381 382 } 383 PPCFpOp; 384 385 extern HChar* showPPCFpOp ( PPCFpOp ); 386 387 388 /* --------- */ 389 typedef 390 enum { 391 Pav_INVALID, 392 393 /* Integer Unary */ 394 Pav_MOV, /* Mov */ 395 Pav_NOT, /* Bitwise */ 396 Pav_UNPCKH8S, Pav_UNPCKH16S, /* Unpack */ 397 Pav_UNPCKL8S, Pav_UNPCKL16S, 398 Pav_UNPCKHPIX, Pav_UNPCKLPIX, 399 400 /* Integer Binary */ 401 Pav_AND, Pav_OR, Pav_XOR, /* Bitwise */ 402 Pav_ADDU, Pav_QADDU, Pav_QADDS, 403 Pav_SUBU, Pav_QSUBU, Pav_QSUBS, 404 Pav_OMULU, Pav_OMULS, Pav_EMULU, Pav_EMULS, 405 Pav_AVGU, Pav_AVGS, 406 Pav_MAXU, Pav_MAXS, 407 Pav_MINU, Pav_MINS, 408 409 /* Compare (always affects CR field 6) */ 410 Pav_CMPEQU, Pav_CMPGTU, Pav_CMPGTS, 411 412 /* Shift */ 413 Pav_SHL, Pav_SHR, Pav_SAR, Pav_ROTL, 414 415 /* Pack */ 416 Pav_PACKUU, Pav_QPACKUU, Pav_QPACKSU, Pav_QPACKSS, 417 Pav_PACKPXL, 418 419 /* Merge */ 420 Pav_MRGHI, Pav_MRGLO, 421 } 422 PPCAvOp; 423 424 extern HChar* showPPCAvOp ( PPCAvOp ); 425 426 427 /* --------- */ 428 typedef 429 enum { 430 Pavfp_INVALID, 431 432 /* Floating point binary */ 433 Pavfp_ADDF, Pavfp_SUBF, Pavfp_MULF, 434 Pavfp_MAXF, Pavfp_MINF, 435 Pavfp_CMPEQF, Pavfp_CMPGTF, Pavfp_CMPGEF, 436 437 /* Floating point unary */ 438 Pavfp_RCPF, Pavfp_RSQRTF, 439 Pavfp_CVTU2F, Pavfp_CVTS2F, Pavfp_QCVTF2U, Pavfp_QCVTF2S, 440 Pavfp_ROUNDM, Pavfp_ROUNDP, Pavfp_ROUNDN, Pavfp_ROUNDZ, 441 } 442 PPCAvFpOp; 443 444 extern HChar* showPPCAvFpOp ( PPCAvFpOp ); 445 446 447 /* --------- */ 448 typedef 449 enum { 450 Pin_LI, /* load word (32/64-bit) immediate (fake insn) */ 451 Pin_Alu, /* word add/sub/and/or/xor */ 452 Pin_Shft, /* word shl/shr/sar */ 453 Pin_AddSubC, /* add/sub with read/write carry */ 454 Pin_Cmp, /* word compare */ 455 Pin_Unary, /* not, neg, clz */ 456 Pin_MulL, /* widening multiply */ 457 Pin_Div, /* div */ 458 Pin_Call, /* call to address in register */ 459 Pin_XDirect, /* direct transfer to GA */ 460 Pin_XIndir, /* indirect transfer to GA */ 461 Pin_XAssisted, /* assisted transfer to GA */ 462 Pin_CMov, /* conditional move */ 463 Pin_Load, /* zero-extending load a 8|16|32|64 bit value from mem */ 464 Pin_LoadL, /* load-linked (lwarx/ldarx) 32|64 bit value from mem */ 465 Pin_Store, /* store a 8|16|32|64 bit value to mem */ 466 Pin_StoreC, /* store-conditional (stwcx./stdcx.) 32|64 bit val */ 467 Pin_Set, /* convert condition code to value 0 or 1 */ 468 Pin_MfCR, /* move from condition register to GPR */ 469 Pin_MFence, /* mem fence */ 470 471 Pin_FpUnary, /* FP unary op */ 472 Pin_FpBinary, /* FP binary op */ 473 Pin_FpMulAcc, /* FP multipy-accumulate style op */ 474 Pin_FpLdSt, /* FP load/store */ 475 Pin_FpSTFIW, /* stfiwx */ 476 Pin_FpRSP, /* FP round IEEE754 double to IEEE754 single */ 477 Pin_FpCftI, /* fcfid[u,s,us]/fctid[u]/fctiw[u] */ 478 Pin_FpCMov, /* FP floating point conditional move */ 479 Pin_FpLdFPSCR, /* mtfsf */ 480 Pin_FpCmp, /* FP compare, generating value into int reg */ 481 482 Pin_RdWrLR, /* Read/Write Link Register */ 483 484 Pin_AvLdSt, /* AV load/store (kludging for AMode_IR) */ 485 Pin_AvUnary, /* AV unary general reg=>reg */ 486 487 Pin_AvBinary, /* AV binary general reg,reg=>reg */ 488 Pin_AvBin8x16, /* AV binary, 8x4 */ 489 Pin_AvBin16x8, /* AV binary, 16x4 */ 490 Pin_AvBin32x4, /* AV binary, 32x4 */ 491 492 Pin_AvBin32Fx4, /* AV FP binary, 32Fx4 */ 493 Pin_AvUn32Fx4, /* AV FP unary, 32Fx4 */ 494 495 Pin_AvPerm, /* AV permute (shuffle) */ 496 Pin_AvSel, /* AV select */ 497 Pin_AvShlDbl, /* AV shift-left double by imm */ 498 Pin_AvSplat, /* One elem repeated throughout dst */ 499 Pin_AvLdVSCR, /* mtvscr */ 500 Pin_AvCMov, /* AV conditional move */ 501 Pin_Dfp64Unary, /* DFP64 unary op */ 502 Pin_Dfp128Unary, /* DFP128 unary op */ 503 Pin_DfpShift, /* Decimal floating point shift by immediate value */ 504 Pin_Dfp64Binary, /* DFP64 binary op */ 505 Pin_Dfp128Binary, /* DFP128 binary op */ 506 Pin_DfpShift128, /* 128-bit Decimal floating point shift by 507 * immediate value */ 508 Pin_DfpD128toD64, /* DFP 128 to DFP 64 op */ 509 Pin_DfpI64StoD128, /* DFP signed integer to DFP 128 */ 510 Pin_DfpRound, /* D64 round to D64 */ 511 Pin_DfpRound128, /* D128 round to D128 */ 512 Pin_ExtractExpD128, /* DFP, extract 64 bit exponent */ 513 Pin_InsertExpD128, /* DFP, insert 64 bit exponent and 128 bit binary 514 * significand into a DFP 128-bit value*/ 515 Pin_Dfp64Cmp, /* DFP 64-bit compare, generating value into 516 * int reg */ 517 Pin_Dfp128Cmp, /* DFP 128-bit compare, generating value into 518 * int reg */ 519 Pin_DfpQuantize, /* D64 quantize using register value, significance 520 * round */ 521 Pin_DfpQuantize128, /* D128 quantize using register value, significance 522 * round */ 523 Pin_EvCheck, /* Event check */ 524 Pin_ProfInc /* 64-bit profile counter increment */ 525 } 526 PPCInstrTag; 527 528 /* Destinations are on the LEFT (first operand) */ 529 530 typedef 531 struct { 532 PPCInstrTag tag; 533 union { 534 /* Get a 32/64-bit literal into a register. 535 May turn into a number of real insns. */ 536 struct { 537 HReg dst; 538 ULong imm64; 539 } LI; 540 /* Integer add/sub/and/or/xor. Limitations: 541 - For add, the immediate, if it exists, is a signed 16. 542 - For sub, the immediate, if it exists, is a signed 16 543 which may not be -32768, since no such instruction 544 exists, and so we have to emit addi with +32768, but 545 that is not possible. 546 - For and/or/xor, the immediate, if it exists, 547 is an unsigned 16. 548 */ 549 struct { 550 PPCAluOp op; 551 HReg dst; 552 HReg srcL; 553 PPCRH* srcR; 554 } Alu; 555 /* Integer shl/shr/sar. 556 Limitations: the immediate, if it exists, 557 is a signed 5-bit value between 1 and 31 inclusive. 558 */ 559 struct { 560 PPCShftOp op; 561 Bool sz32; /* mode64 has both 32 and 64bit shft */ 562 HReg dst; 563 HReg srcL; 564 PPCRH* srcR; 565 } Shft; 566 /* */ 567 struct { 568 Bool isAdd; /* else sub */ 569 Bool setC; /* else read carry */ 570 HReg dst; 571 HReg srcL; 572 HReg srcR; 573 } AddSubC; 574 /* If signed, the immediate, if it exists, is a signed 16, 575 else it is an unsigned 16. */ 576 struct { 577 Bool syned; 578 Bool sz32; /* mode64 has both 32 and 64bit cmp */ 579 UInt crfD; 580 HReg srcL; 581 PPCRH* srcR; 582 } Cmp; 583 /* Not, Neg, Clz32/64, Extsw */ 584 struct { 585 PPCUnaryOp op; 586 HReg dst; 587 HReg src; 588 } Unary; 589 struct { 590 Bool syned; /* meaningless if hi32==False */ 591 Bool hi; /* False=>low, True=>high */ 592 Bool sz32; /* mode64 has both 32 & 64bit mull */ 593 HReg dst; 594 HReg srcL; 595 HReg srcR; 596 } MulL; 597 /* ppc32 div/divu instruction. */ 598 struct { 599 Bool extended; 600 Bool syned; 601 Bool sz32; /* mode64 has both 32 & 64bit div */ 602 HReg dst; 603 HReg srcL; 604 HReg srcR; 605 } Div; 606 /* Pseudo-insn. Call target (an absolute address), on given 607 condition (which could be Pct_ALWAYS). argiregs indicates 608 which of r3 .. r10 carries argument values for this call, 609 using a bit mask (1<<N is set if rN holds an arg, for N in 610 3 .. 10 inclusive). */ 611 struct { 612 PPCCondCode cond; 613 Addr64 target; 614 UInt argiregs; 615 } Call; 616 /* Update the guest CIA value, then exit requesting to chain 617 to it. May be conditional. Use of Addr64 in order to cope 618 with 64-bit hosts. */ 619 struct { 620 Addr64 dstGA; /* next guest address */ 621 PPCAMode* amCIA; /* amode in guest state for CIA */ 622 PPCCondCode cond; /* can be ALWAYS */ 623 Bool toFastEP; /* chain to the slow or fast point? */ 624 } XDirect; 625 /* Boring transfer to a guest address not known at JIT time. 626 Not chainable. May be conditional. */ 627 struct { 628 HReg dstGA; 629 PPCAMode* amCIA; 630 PPCCondCode cond; /* can be ALWAYS */ 631 } XIndir; 632 /* Assisted transfer to a guest address, most general case. 633 Not chainable. May be conditional. */ 634 struct { 635 HReg dstGA; 636 PPCAMode* amCIA; 637 PPCCondCode cond; /* can be ALWAYS */ 638 IRJumpKind jk; 639 } XAssisted; 640 /* Mov src to dst on the given condition, which may not 641 be the bogus Pct_ALWAYS. */ 642 struct { 643 PPCCondCode cond; 644 HReg dst; 645 PPCRI* src; 646 } CMov; 647 /* Zero extending loads. Dst size is host word size */ 648 struct { 649 UChar sz; /* 1|2|4|8 */ 650 HReg dst; 651 PPCAMode* src; 652 } Load; 653 /* Load-and-reserve (lwarx, ldarx) */ 654 struct { 655 UChar sz; /* 4|8 */ 656 HReg dst; 657 HReg src; 658 } LoadL; 659 /* 64/32/16/8 bit stores */ 660 struct { 661 UChar sz; /* 1|2|4|8 */ 662 PPCAMode* dst; 663 HReg src; 664 } Store; 665 /* Store-conditional (stwcx., stdcx.) */ 666 struct { 667 UChar sz; /* 4|8 */ 668 HReg dst; 669 HReg src; 670 } StoreC; 671 /* Convert a ppc condition code to value 0 or 1. */ 672 struct { 673 PPCCondCode cond; 674 HReg dst; 675 } Set; 676 /* Move the entire CR to a GPR */ 677 struct { 678 HReg dst; 679 } MfCR; 680 /* Mem fence. In short, an insn which flushes all preceding 681 loads and stores as much as possible before continuing. 682 On PPC we emit a "sync". */ 683 struct { 684 } MFence; 685 686 /* PPC Floating point */ 687 struct { 688 PPCFpOp op; 689 HReg dst; 690 HReg src; 691 } FpUnary; 692 struct { 693 PPCFpOp op; 694 HReg dst; 695 HReg srcL; 696 HReg srcR; 697 } FpBinary; 698 struct { 699 PPCFpOp op; 700 HReg dst; 701 HReg srcML; 702 HReg srcMR; 703 HReg srcAcc; 704 } FpMulAcc; 705 struct { 706 Bool isLoad; 707 UChar sz; /* only 4 (IEEE single) or 8 (IEEE double) */ 708 HReg reg; 709 PPCAMode* addr; 710 } FpLdSt; 711 struct { 712 HReg addr; /* int reg */ 713 HReg data; /* float reg */ 714 } FpSTFIW; 715 /* Round 64-bit FP value to 32-bit FP value in an FP reg. */ 716 struct { 717 HReg src; 718 HReg dst; 719 } FpRSP; 720 /* fcfid[u,s,us]/fctid[u]/fctiw[u]. Only some combinations 721 of the various fields are allowed. This is asserted for 722 and documented in the code for the constructor, 723 PPCInstr_FpCftI, in host_ppc_defs.c. */ 724 struct { 725 Bool fromI; /* True== I->F, False== F->I */ 726 Bool int32; /* True== I is 32, False== I is 64 */ 727 Bool syned; 728 Bool flt64; /* True== F is 64, False== F is 32 */ 729 HReg src; 730 HReg dst; 731 } FpCftI; 732 /* FP mov src to dst on the given condition. */ 733 struct { 734 PPCCondCode cond; 735 HReg dst; 736 HReg src; 737 } FpCMov; 738 /* Load FP Status & Control Register */ 739 struct { 740 HReg src; 741 UInt dfp_rm; 742 } FpLdFPSCR; 743 /* Do a compare, generating result into an int register. */ 744 struct { 745 UChar crfD; 746 HReg dst; 747 HReg srcL; 748 HReg srcR; 749 } FpCmp; 750 751 /* Read/Write Link Register */ 752 struct { 753 Bool wrLR; 754 HReg gpr; 755 } RdWrLR; 756 757 /* Simplistic AltiVec */ 758 struct { 759 Bool isLoad; 760 UChar sz; /* 8|16|32|128 */ 761 HReg reg; 762 PPCAMode* addr; 763 } AvLdSt; 764 struct { 765 PPCAvOp op; 766 HReg dst; 767 HReg src; 768 } AvUnary; 769 struct { 770 PPCAvOp op; 771 HReg dst; 772 HReg srcL; 773 HReg srcR; 774 } AvBinary; 775 struct { 776 PPCAvOp op; 777 HReg dst; 778 HReg srcL; 779 HReg srcR; 780 } AvBin8x16; 781 struct { 782 PPCAvOp op; 783 HReg dst; 784 HReg srcL; 785 HReg srcR; 786 } AvBin16x8; 787 struct { 788 PPCAvOp op; 789 HReg dst; 790 HReg srcL; 791 HReg srcR; 792 } AvBin32x4; 793 struct { 794 PPCAvFpOp op; 795 HReg dst; 796 HReg srcL; 797 HReg srcR; 798 } AvBin32Fx4; 799 struct { 800 PPCAvFpOp op; 801 HReg dst; 802 HReg src; 803 } AvUn32Fx4; 804 /* Perm,Sel,SlDbl,Splat are all weird AV permutations */ 805 struct { 806 HReg dst; 807 HReg srcL; 808 HReg srcR; 809 HReg ctl; 810 } AvPerm; 811 struct { 812 HReg dst; 813 HReg srcL; 814 HReg srcR; 815 HReg ctl; 816 } AvSel; 817 struct { 818 UChar shift; 819 HReg dst; 820 HReg srcL; 821 HReg srcR; 822 } AvShlDbl; 823 struct { 824 UChar sz; /* 8,16,32 */ 825 HReg dst; 826 PPCVI5s* src; 827 } AvSplat; 828 /* Mov src to dst on the given condition, which may not 829 be the bogus Xcc_ALWAYS. */ 830 struct { 831 PPCCondCode cond; 832 HReg dst; 833 HReg src; 834 } AvCMov; 835 /* Load AltiVec Status & Control Register */ 836 struct { 837 HReg src; 838 } AvLdVSCR; 839 struct { 840 PPCFpOp op; 841 HReg dst; 842 HReg src; 843 } Dfp64Unary; 844 struct { 845 PPCFpOp op; 846 HReg dst; 847 HReg srcL; 848 HReg srcR; 849 } Dfp64Binary; 850 struct { 851 PPCFpOp op; 852 HReg dst; 853 HReg src; 854 PPCRI* shift; 855 } DfpShift; 856 struct { 857 PPCFpOp op; 858 HReg dst_hi; 859 HReg dst_lo; 860 HReg src_hi; 861 HReg src_lo; 862 } Dfp128Unary; 863 struct { 864 /* The dst is used to pass the left source operand in and return 865 * the result. 866 */ 867 PPCFpOp op; 868 HReg dst_hi; 869 HReg dst_lo; 870 HReg srcR_hi; 871 HReg srcR_lo; 872 } Dfp128Binary; 873 struct { 874 PPCFpOp op; 875 HReg dst_hi; 876 HReg dst_lo; 877 HReg src_hi; 878 HReg src_lo; 879 PPCRI* shift; 880 } DfpShift128; 881 struct { 882 HReg dst; 883 HReg src; 884 PPCRI* r_rmc; 885 } DfpRound; 886 struct { 887 HReg dst_hi; 888 HReg dst_lo; 889 HReg src_hi; 890 HReg src_lo; 891 PPCRI* r_rmc; 892 } DfpRound128; 893 struct { 894 PPCFpOp op; 895 HReg dst; 896 HReg srcL; 897 HReg srcR; 898 PPCRI* rmc; 899 } DfpQuantize; 900 struct { 901 PPCFpOp op; 902 HReg dst_hi; 903 HReg dst_lo; 904 HReg src_hi; 905 HReg src_lo; 906 PPCRI* rmc; 907 } DfpQuantize128; 908 struct { 909 PPCFpOp op; 910 HReg dst; 911 HReg src_hi; 912 HReg src_lo; 913 } ExtractExpD128; 914 struct { 915 PPCFpOp op; 916 HReg dst_hi; 917 HReg dst_lo; 918 HReg srcL; 919 HReg srcR_hi; 920 HReg srcR_lo; 921 } InsertExpD128; 922 struct { 923 PPCFpOp op; 924 HReg dst; 925 HReg src_hi; 926 HReg src_lo; 927 } DfpD128toD64; 928 struct { 929 PPCFpOp op; 930 HReg dst_hi; 931 HReg dst_lo; 932 HReg src; 933 } DfpI64StoD128; 934 struct { 935 UChar crfD; 936 HReg dst; 937 HReg srcL; 938 HReg srcR; 939 } Dfp64Cmp; 940 struct { 941 UChar crfD; 942 HReg dst; 943 HReg srcL_hi; 944 HReg srcL_lo; 945 HReg srcR_hi; 946 HReg srcR_lo; 947 } Dfp128Cmp; 948 struct { 949 PPCAMode* amCounter; 950 PPCAMode* amFailAddr; 951 } EvCheck; 952 struct { 953 /* No fields. The address of the counter to inc is 954 installed later, post-translation, by patching it in, 955 as it is not known at translation time. */ 956 } ProfInc; 957 } Pin; 958 } 959 PPCInstr; 960 961 962 extern PPCInstr* PPCInstr_LI ( HReg, ULong, Bool ); 963 extern PPCInstr* PPCInstr_Alu ( PPCAluOp, HReg, HReg, PPCRH* ); 964 extern PPCInstr* PPCInstr_Shft ( PPCShftOp, Bool sz32, HReg, HReg, PPCRH* ); 965 extern PPCInstr* PPCInstr_AddSubC ( Bool, Bool, HReg, HReg, HReg ); 966 extern PPCInstr* PPCInstr_Cmp ( Bool, Bool, UInt, HReg, PPCRH* ); 967 extern PPCInstr* PPCInstr_Unary ( PPCUnaryOp op, HReg dst, HReg src ); 968 extern PPCInstr* PPCInstr_MulL ( Bool syned, Bool hi32, Bool sz32, HReg, HReg, HReg ); 969 extern PPCInstr* PPCInstr_Div ( Bool extended, Bool syned, Bool sz32, HReg dst, HReg srcL, HReg srcR ); 970 extern PPCInstr* PPCInstr_Call ( PPCCondCode, Addr64, UInt ); 971 extern PPCInstr* PPCInstr_XDirect ( Addr64 dstGA, PPCAMode* amCIA, 972 PPCCondCode cond, Bool toFastEP ); 973 extern PPCInstr* PPCInstr_XIndir ( HReg dstGA, PPCAMode* amCIA, 974 PPCCondCode cond ); 975 extern PPCInstr* PPCInstr_XAssisted ( HReg dstGA, PPCAMode* amCIA, 976 PPCCondCode cond, IRJumpKind jk ); 977 extern PPCInstr* PPCInstr_CMov ( PPCCondCode, HReg dst, PPCRI* src ); 978 extern PPCInstr* PPCInstr_Load ( UChar sz, 979 HReg dst, PPCAMode* src, Bool mode64 ); 980 extern PPCInstr* PPCInstr_LoadL ( UChar sz, 981 HReg dst, HReg src, Bool mode64 ); 982 extern PPCInstr* PPCInstr_Store ( UChar sz, PPCAMode* dst, 983 HReg src, Bool mode64 ); 984 extern PPCInstr* PPCInstr_StoreC ( UChar sz, HReg dst, HReg src, 985 Bool mode64 ); 986 extern PPCInstr* PPCInstr_Set ( PPCCondCode cond, HReg dst ); 987 extern PPCInstr* PPCInstr_MfCR ( HReg dst ); 988 extern PPCInstr* PPCInstr_MFence ( void ); 989 990 extern PPCInstr* PPCInstr_FpUnary ( PPCFpOp op, HReg dst, HReg src ); 991 extern PPCInstr* PPCInstr_FpBinary ( PPCFpOp op, HReg dst, HReg srcL, HReg srcR ); 992 extern PPCInstr* PPCInstr_FpMulAcc ( PPCFpOp op, HReg dst, HReg srcML, 993 HReg srcMR, HReg srcAcc ); 994 extern PPCInstr* PPCInstr_FpLdSt ( Bool isLoad, UChar sz, HReg, PPCAMode* ); 995 extern PPCInstr* PPCInstr_FpSTFIW ( HReg addr, HReg data ); 996 extern PPCInstr* PPCInstr_FpRSP ( HReg dst, HReg src ); 997 extern PPCInstr* PPCInstr_FpCftI ( Bool fromI, Bool int32, Bool syned, 998 Bool dst64, HReg dst, HReg src ); 999 extern PPCInstr* PPCInstr_FpCMov ( PPCCondCode, HReg dst, HReg src ); 1000 extern PPCInstr* PPCInstr_FpLdFPSCR ( HReg src, Bool dfp_rm ); 1001 extern PPCInstr* PPCInstr_FpCmp ( HReg dst, HReg srcL, HReg srcR ); 1002 1003 extern PPCInstr* PPCInstr_RdWrLR ( Bool wrLR, HReg gpr ); 1004 1005 extern PPCInstr* PPCInstr_AvLdSt ( Bool isLoad, UChar sz, HReg, PPCAMode* ); 1006 extern PPCInstr* PPCInstr_AvUnary ( PPCAvOp op, HReg dst, HReg src ); 1007 extern PPCInstr* PPCInstr_AvBinary ( PPCAvOp op, HReg dst, HReg srcL, HReg srcR ); 1008 extern PPCInstr* PPCInstr_AvBin8x16 ( PPCAvOp op, HReg dst, HReg srcL, HReg srcR ); 1009 extern PPCInstr* PPCInstr_AvBin16x8 ( PPCAvOp op, HReg dst, HReg srcL, HReg srcR ); 1010 extern PPCInstr* PPCInstr_AvBin32x4 ( PPCAvOp op, HReg dst, HReg srcL, HReg srcR ); 1011 extern PPCInstr* PPCInstr_AvBin32Fx4 ( PPCAvFpOp op, HReg dst, HReg srcL, HReg srcR ); 1012 extern PPCInstr* PPCInstr_AvUn32Fx4 ( PPCAvFpOp op, HReg dst, HReg src ); 1013 extern PPCInstr* PPCInstr_AvPerm ( HReg dst, HReg srcL, HReg srcR, HReg ctl ); 1014 extern PPCInstr* PPCInstr_AvSel ( HReg ctl, HReg dst, HReg srcL, HReg srcR ); 1015 extern PPCInstr* PPCInstr_AvShlDbl ( UChar shift, HReg dst, HReg srcL, HReg srcR ); 1016 extern PPCInstr* PPCInstr_AvSplat ( UChar sz, HReg dst, PPCVI5s* src ); 1017 extern PPCInstr* PPCInstr_AvCMov ( PPCCondCode, HReg dst, HReg src ); 1018 extern PPCInstr* PPCInstr_AvLdVSCR ( HReg src ); 1019 1020 extern PPCInstr* PPCInstr_Dfp64Unary ( PPCFpOp op, HReg dst, HReg src ); 1021 extern PPCInstr* PPCInstr_Dfp64Binary ( PPCFpOp op, HReg dst, HReg srcL, 1022 HReg srcR ); 1023 extern PPCInstr* PPCInstr_DfpShift ( PPCFpOp op, HReg dst, HReg src, 1024 PPCRI* shift ); 1025 extern PPCInstr* PPCInstr_Dfp128Unary ( PPCFpOp op, HReg dst_hi, HReg dst_lo, 1026 HReg srcR_hi, HReg srcR_lo ); 1027 extern PPCInstr* PPCInstr_Dfp128Binary ( PPCFpOp op, HReg dst_hi, HReg dst_lo, 1028 HReg srcR_hi, HReg srcR_lo ); 1029 extern PPCInstr* PPCInstr_DfpShift128 ( PPCFpOp op, HReg dst_hi, HReg src_hi, 1030 HReg dst_lo, HReg src_lo, 1031 PPCRI* shift ); 1032 extern PPCInstr* PPCInstr_DfpD128toD64 ( PPCFpOp op, HReg dst, 1033 HReg dst_lo, HReg src_lo); 1034 extern PPCInstr* PPCInstr_DfpI64StoD128 ( PPCFpOp op, HReg dst_hi, 1035 HReg dst_lo, HReg src); 1036 extern PPCInstr* PPCInstr_DfpRound ( HReg dst, HReg src, PPCRI* r_rmc ); 1037 extern PPCInstr* PPCInstr_DfpRound128 ( HReg dst_hi, HReg dst_lo, HReg src_hi, 1038 HReg src_lo, PPCRI* r_rmc ); 1039 extern PPCInstr* PPCInstr_DfpQuantize ( PPCFpOp op, HReg dst, HReg srcL, 1040 HReg srcR, PPCRI* rmc ); 1041 extern PPCInstr* PPCInstr_DfpQuantize128 ( PPCFpOp op, HReg dst_hi, 1042 HReg dst_lo, 1043 HReg src_hi, 1044 HReg src_lo, PPCRI* rmc ); 1045 extern PPCInstr* PPCInstr_ExtractExpD128 ( PPCFpOp op, HReg dst, 1046 HReg src_hi, HReg src_lo ); 1047 extern PPCInstr* PPCInstr_InsertExpD128 ( PPCFpOp op, HReg dst_hi, 1048 HReg dst_lo, HReg srcL, 1049 HReg srcR_hi, HReg srcR_lo ); 1050 extern PPCInstr* PPCInstr_Dfp64Cmp ( HReg dst, HReg srcL, HReg srcR ); 1051 extern PPCInstr* PPCInstr_Dfp128Cmp ( HReg dst, HReg srcL_hi, HReg srcL_lo, 1052 HReg srcR_hi, HReg srcR_lo ); 1053 extern PPCInstr* PPCInstr_EvCheck ( PPCAMode* amCounter, 1054 PPCAMode* amFailAddr ); 1055 extern PPCInstr* PPCInstr_ProfInc ( void ); 1056 1057 extern void ppPPCInstr(PPCInstr*, Bool mode64); 1058 1059 1060 /* Some functions that insulate the register allocator from details 1061 of the underlying instruction set. */ 1062 extern void getRegUsage_PPCInstr ( HRegUsage*, PPCInstr*, Bool mode64 ); 1063 extern void mapRegs_PPCInstr ( HRegRemap*, PPCInstr* , Bool mode64); 1064 extern Bool isMove_PPCInstr ( PPCInstr*, HReg*, HReg* ); 1065 extern Int emit_PPCInstr ( /*MB_MOD*/Bool* is_profInc, 1066 UChar* buf, Int nbuf, PPCInstr* i, 1067 Bool mode64, 1068 void* disp_cp_chain_me_to_slowEP, 1069 void* disp_cp_chain_me_to_fastEP, 1070 void* disp_cp_xindir, 1071 void* disp_cp_xassisted ); 1072 1073 extern void genSpill_PPC ( /*OUT*/HInstr** i1, /*OUT*/HInstr** i2, 1074 HReg rreg, Int offsetB, Bool mode64 ); 1075 extern void genReload_PPC ( /*OUT*/HInstr** i1, /*OUT*/HInstr** i2, 1076 HReg rreg, Int offsetB, Bool mode64 ); 1077 1078 extern void getAllocableRegs_PPC ( Int*, HReg**, Bool mode64 ); 1079 extern HInstrArray* iselSB_PPC ( IRSB*, 1080 VexArch, 1081 VexArchInfo*, 1082 VexAbiInfo*, 1083 Int offs_Host_EvC_Counter, 1084 Int offs_Host_EvC_FailAddr, 1085 Bool chainingAllowed, 1086 Bool addProfInc, 1087 Addr64 max_ga ); 1088 1089 /* How big is an event check? This is kind of a kludge because it 1090 depends on the offsets of host_EvC_FAILADDR and 1091 host_EvC_COUNTER. */ 1092 extern Int evCheckSzB_PPC ( void ); 1093 1094 /* Perform a chaining and unchaining of an XDirect jump. */ 1095 extern VexInvalRange chainXDirect_PPC ( void* place_to_chain, 1096 void* disp_cp_chain_me_EXPECTED, 1097 void* place_to_jump_to, 1098 Bool mode64 ); 1099 1100 extern VexInvalRange unchainXDirect_PPC ( void* place_to_unchain, 1101 void* place_to_jump_to_EXPECTED, 1102 void* disp_cp_chain_me, 1103 Bool mode64 ); 1104 1105 /* Patch the counter location into an existing ProfInc point. */ 1106 extern VexInvalRange patchProfInc_PPC ( void* place_to_patch, 1107 ULong* location_of_counter, 1108 Bool mode64 ); 1109 1110 1111 #endif /* ndef __VEX_HOST_PPC_DEFS_H */ 1112 1113 /*---------------------------------------------------------------*/ 1114 /*--- end host_ppc_defs.h ---*/ 1115 /*---------------------------------------------------------------*/ 1116