| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 336 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 347 __ fmulp(3); | 347 __ fmulp(3); |
| 348 __ fdivp(3); | 348 __ fdivp(3); |
| 349 __ fcompp(); | 349 __ fcompp(); |
| 350 __ fwait(); | 350 __ fwait(); |
| 351 __ nop(); | 351 __ nop(); |
| 352 { | 352 { |
| 353 if (CpuFeatures::IsSupported(SSE2)) { | 353 if (CpuFeatures::IsSupported(SSE2)) { |
| 354 CpuFeatureScope fscope(&assm, SSE2); | 354 CpuFeatureScope fscope(&assm, SSE2); |
| 355 __ cvttss2si(edx, Operand(ebx, ecx, times_4, 10000)); | 355 __ cvttss2si(edx, Operand(ebx, ecx, times_4, 10000)); |
| 356 __ cvtsi2sd(xmm1, Operand(ebx, ecx, times_4, 10000)); | 356 __ cvtsi2sd(xmm1, Operand(ebx, ecx, times_4, 10000)); |
| 357 __ addsd(xmm1, xmm0); | |
| 358 __ mulsd(xmm1, xmm0); | |
| 359 __ subsd(xmm1, xmm0); | |
| 360 __ divsd(xmm1, xmm0); | |
| 361 __ movsd(xmm1, Operand(ebx, ecx, times_4, 10000)); | 357 __ movsd(xmm1, Operand(ebx, ecx, times_4, 10000)); |
| 362 __ movsd(Operand(ebx, ecx, times_4, 10000), xmm1); | 358 __ movsd(Operand(ebx, ecx, times_4, 10000), xmm1); |
| 363 __ ucomisd(xmm0, xmm1); | 359 __ movaps(xmm0, xmm1); |
| 364 | |
| 365 // 128 bit move instructions. | 360 // 128 bit move instructions. |
| 366 __ movdqa(xmm0, Operand(ebx, ecx, times_4, 10000)); | 361 __ movdqa(xmm0, Operand(ebx, ecx, times_4, 10000)); |
| 367 __ movdqa(Operand(ebx, ecx, times_4, 10000), xmm0); | 362 __ movdqa(Operand(ebx, ecx, times_4, 10000), xmm0); |
| 368 __ movdqu(xmm0, Operand(ebx, ecx, times_4, 10000)); | 363 __ movdqu(xmm0, Operand(ebx, ecx, times_4, 10000)); |
| 369 __ movdqu(Operand(ebx, ecx, times_4, 10000), xmm0); | 364 __ movdqu(Operand(ebx, ecx, times_4, 10000), xmm0); |
| 365 |
| 366 __ addsd(xmm1, xmm0); |
| 367 __ mulsd(xmm1, xmm0); |
| 368 __ subsd(xmm1, xmm0); |
| 369 __ divsd(xmm1, xmm0); |
| 370 __ ucomisd(xmm0, xmm1); |
| 371 __ cmpltsd(xmm0, xmm1); |
| 372 |
| 373 __ andps(xmm0, xmm1); |
| 374 __ andpd(xmm0, xmm1); |
| 375 __ psllq(xmm0, 17); |
| 376 __ psllq(xmm0, xmm1); |
| 377 __ psrlq(xmm0, 17); |
| 378 __ psrlq(xmm0, xmm1); |
| 379 __ por(xmm0, xmm1); |
| 370 } | 380 } |
| 371 } | 381 } |
| 372 | 382 |
| 373 // cmov. | 383 // cmov. |
| 374 { | 384 { |
| 375 if (CpuFeatures::IsSupported(CMOV)) { | 385 if (CpuFeatures::IsSupported(CMOV)) { |
| 376 CpuFeatureScope use_cmov(&assm, CMOV); | 386 CpuFeatureScope use_cmov(&assm, CMOV); |
| 377 __ cmov(overflow, eax, Operand(eax, 0)); | 387 __ cmov(overflow, eax, Operand(eax, 0)); |
| 378 __ cmov(no_overflow, eax, Operand(eax, 1)); | 388 __ cmov(no_overflow, eax, Operand(eax, 1)); |
| 379 __ cmov(below, eax, Operand(eax, 2)); | 389 __ cmov(below, eax, Operand(eax, 2)); |
| 380 __ cmov(above_equal, eax, Operand(eax, 3)); | 390 __ cmov(above_equal, eax, Operand(eax, 3)); |
| 381 __ cmov(equal, eax, Operand(ebx, 0)); | 391 __ cmov(equal, eax, Operand(ebx, 0)); |
| 382 __ cmov(not_equal, eax, Operand(ebx, 1)); | 392 __ cmov(not_equal, eax, Operand(ebx, 1)); |
| 383 __ cmov(below_equal, eax, Operand(ebx, 2)); | 393 __ cmov(below_equal, eax, Operand(ebx, 2)); |
| 384 __ cmov(above, eax, Operand(ebx, 3)); | 394 __ cmov(above, eax, Operand(ebx, 3)); |
| 385 __ cmov(sign, eax, Operand(ecx, 0)); | 395 __ cmov(sign, eax, Operand(ecx, 0)); |
| 386 __ cmov(not_sign, eax, Operand(ecx, 1)); | 396 __ cmov(not_sign, eax, Operand(ecx, 1)); |
| 387 __ cmov(parity_even, eax, Operand(ecx, 2)); | 397 __ cmov(parity_even, eax, Operand(ecx, 2)); |
| 388 __ cmov(parity_odd, eax, Operand(ecx, 3)); | 398 __ cmov(parity_odd, eax, Operand(ecx, 3)); |
| 389 __ cmov(less, eax, Operand(edx, 0)); | 399 __ cmov(less, eax, Operand(edx, 0)); |
| 390 __ cmov(greater_equal, eax, Operand(edx, 1)); | 400 __ cmov(greater_equal, eax, Operand(edx, 1)); |
| 391 __ cmov(less_equal, eax, Operand(edx, 2)); | 401 __ cmov(less_equal, eax, Operand(edx, 2)); |
| 392 __ cmov(greater, eax, Operand(edx, 3)); | 402 __ cmov(greater, eax, Operand(edx, 3)); |
| 393 } | 403 } |
| 394 } | 404 } |
| 395 | 405 |
| 396 // andpd, cmpltsd, movaps, psllq, psrlq, por. | |
| 397 { | |
| 398 if (CpuFeatures::IsSupported(SSE2)) { | |
| 399 CpuFeatureScope fscope(&assm, SSE2); | |
| 400 __ andpd(xmm0, xmm1); | |
| 401 __ andpd(xmm1, xmm2); | |
| 402 | |
| 403 __ cmpltsd(xmm0, xmm1); | |
| 404 __ cmpltsd(xmm1, xmm2); | |
| 405 | |
| 406 __ movaps(xmm0, xmm1); | |
| 407 __ movaps(xmm1, xmm2); | |
| 408 | |
| 409 __ psllq(xmm0, 17); | |
| 410 __ psllq(xmm1, 42); | |
| 411 | |
| 412 __ psllq(xmm0, xmm1); | |
| 413 __ psllq(xmm1, xmm2); | |
| 414 | |
| 415 __ psrlq(xmm0, 17); | |
| 416 __ psrlq(xmm1, 42); | |
| 417 | |
| 418 __ psrlq(xmm0, xmm1); | |
| 419 __ psrlq(xmm1, xmm2); | |
| 420 | |
| 421 __ por(xmm0, xmm1); | |
| 422 __ por(xmm1, xmm2); | |
| 423 } | |
| 424 } | |
| 425 | |
| 426 { | 406 { |
| 427 if (CpuFeatures::IsSupported(SSE2) && | 407 if (CpuFeatures::IsSupported(SSE2) && |
| 428 CpuFeatures::IsSupported(SSE4_1)) { | 408 CpuFeatures::IsSupported(SSE4_1)) { |
| 429 CpuFeatureScope scope(&assm, SSE4_1); | 409 CpuFeatureScope scope(&assm, SSE4_1); |
| 430 __ pextrd(eax, xmm0, 1); | 410 __ pextrd(eax, xmm0, 1); |
| 431 __ pinsrd(xmm1, eax, 0); | 411 __ pinsrd(xmm1, eax, 0); |
| 432 __ extractps(eax, xmm1, 0); | 412 __ extractps(eax, xmm1, 0); |
| 433 } | 413 } |
| 434 } | 414 } |
| 435 | 415 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 449 CHECK(code->IsCode()); | 429 CHECK(code->IsCode()); |
| 450 #ifdef OBJECT_PRINT | 430 #ifdef OBJECT_PRINT |
| 451 Code::cast(code)->Print(); | 431 Code::cast(code)->Print(); |
| 452 byte* begin = Code::cast(code)->instruction_start(); | 432 byte* begin = Code::cast(code)->instruction_start(); |
| 453 byte* end = begin + Code::cast(code)->instruction_size(); | 433 byte* end = begin + Code::cast(code)->instruction_size(); |
| 454 disasm::Disassembler::Disassemble(stdout, begin, end); | 434 disasm::Disassembler::Disassemble(stdout, begin, end); |
| 455 #endif | 435 #endif |
| 456 } | 436 } |
| 457 | 437 |
| 458 #undef __ | 438 #undef __ |
| OLD | NEW |