]> git.ipfire.org Git - thirdparty/valgrind.git/log
thirdparty/valgrind.git
18 years agox86 front end: Implement MASKMOVQ (MMX class insn, introduced in SSE1)
Julian Seward [Wed, 27 Dec 2006 01:15:29 +0000 (01:15 +0000)] 
x86 front end: Implement MASKMOVQ (MMX class insn, introduced in SSE1)
and MASKMOVDQU (SSE class insn, introduced in SSE2).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1702

18 years agoA large but non-functional commit: as suggested by Nick, rename some
Julian Seward [Sun, 24 Dec 2006 02:20:24 +0000 (02:20 +0000)] 
A large but non-functional commit: as suggested by Nick, rename some
IR types, structure fields and functions to make IR a bit easier to
understand.  Specifically:

  dopyIR* -> deepCopyIR*

  sopyIR* -> shallowCopyIR*

  The presence of a .Tmp union in both IRExpr and IRStmt is
  confusing.  It has been renamed to RdTmp in IRExpr, reflecting
  the fact that here we are getting the value of an IRTemp, and to
  WrTmp in IRStmt, reflecting the fact that here we are assigning
  to an IRTemp.

  IRBB (IR Basic Block) is renamed to IRSB (IR SuperBlock),
  reflecting the reality that Vex does not really operate in terms
  of basic blocks, but in terms of superblocks - single entry,
  multiple exit sequences.

  IRArray is renamed to IRRegArray, to make it clearer it refers
  to arrays of guest registers and not arrays in memory.

  VexMiscInfo is renamed to VexAbiInfo, since that's what it is
  -- relevant facts about the ABI (calling conventions, etc) for
  both the guest and host platforms.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1689

18 years agoMake compilable again.
Julian Seward [Sun, 17 Dec 2006 17:40:36 +0000 (17:40 +0000)] 
Make compilable again.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1688

18 years agoMake this compilable again.
Julian Seward [Sun, 17 Dec 2006 14:24:05 +0000 (14:24 +0000)] 
Make this compilable again.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1687

18 years agoChange a stupid algorithm that deals with real register live
Julian Seward [Fri, 1 Dec 2006 02:59:17 +0000 (02:59 +0000)] 
Change a stupid algorithm that deals with real register live
ranges into a less stupid one.  Prior to this change, the complexity
of reg-alloc included an expensive term

O(#instrs in code sequence x #real-register live ranges in code sequence)

This commit changes that term to essentially

O(#instrs in code sequence) + O(time to sort real-reg-L-R array)

On amd64 this nearly halves the cost of register allocation and means
Valgrind performs better in translation-intensive situations (a.k.a
starting programs).  Eg, firefox start/exit falls from 119 to 113
seconds.  The effect will be larger on ppc32/64 as there are more real
registers and hence real-reg live ranges to consider, and will be
smaller on x86 for the same reason.

The actual code the JIT produces should be unchanged.  This commit
merely modifies how the register allocator handles one of its
important data structures.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1686

18 years agoAdd a couple of %rflags spec rules which improve performance of amd64
Julian Seward [Mon, 27 Nov 2006 04:09:52 +0000 (04:09 +0000)] 
Add a couple of %rflags spec rules which improve performance of amd64
FP comparisons.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1685

18 years agoNew function dopyIRBBExceptStmts which makes it a bit easier to write
Julian Seward [Fri, 24 Nov 2006 23:32:55 +0000 (23:32 +0000)] 
New function dopyIRBBExceptStmts which makes it a bit easier to write
tools.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1684

18 years agoSpecialise computation of carry flag after ADDL.
Julian Seward [Wed, 22 Nov 2006 23:31:37 +0000 (23:31 +0000)] 
Specialise computation of carry flag after ADDL.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1683

18 years agoEven more flag-spec rules: SUBL-CondNL, SUBL-CondNBE, SUBL-NB and redo
Julian Seward [Wed, 22 Nov 2006 17:39:51 +0000 (17:39 +0000)] 
Even more flag-spec rules: SUBL-CondNL, SUBL-CondNBE, SUBL-NB and redo
SUBL-CondNS.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1682

18 years agoA couple more x86 spec rules: COPY-CondNZ and SUBL-CondNS.
Julian Seward [Wed, 22 Nov 2006 16:01:45 +0000 (16:01 +0000)] 
A couple more x86 spec rules: COPY-CondNZ and SUBL-CondNS.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1681

18 years agoOn amd64, allow the register allocator to use %r10 which it previously
Julian Seward [Sun, 19 Nov 2006 02:05:47 +0000 (02:05 +0000)] 
On amd64, allow the register allocator to use %r10 which it previously
did not.  This gives a 0%-3% speedup, mostly closer to the 0% end.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1680

18 years agoHandle long-form encoding of 'push{l,w} %reg'.
Julian Seward [Sat, 18 Nov 2006 22:56:46 +0000 (22:56 +0000)] 
Handle long-form encoding of 'push{l,w} %reg'.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1679

18 years agoHandle JCXZ.
Julian Seward [Thu, 16 Nov 2006 10:42:02 +0000 (10:42 +0000)] 
Handle JCXZ.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1678

18 years agoAdd many extra comments describing the IR.
Julian Seward [Wed, 15 Nov 2006 02:57:05 +0000 (02:57 +0000)] 
Add many extra comments describing the IR.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1677

18 years agoHandle 'ret imm16'. Fixes #136650.
Julian Seward [Tue, 14 Nov 2006 17:50:16 +0000 (17:50 +0000)] 
Handle 'ret imm16'.  Fixes #136650.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1676

18 years agoAdd an %eflags rule for COPY-CondP.
Julian Seward [Tue, 14 Nov 2006 17:46:12 +0000 (17:46 +0000)] 
Add an %eflags rule for COPY-CondP.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1675

18 years agoRe-enable 'repne movs' (fix for original bug in #126147).
Julian Seward [Tue, 14 Nov 2006 15:33:05 +0000 (15:33 +0000)] 
Re-enable 'repne movs' (fix for original bug in #126147).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1674

18 years agoRe-enable 'repne stos' (fix for Gernot Tenchio's part of #126147).
Julian Seward [Tue, 14 Nov 2006 15:13:55 +0000 (15:13 +0000)] 
Re-enable 'repne stos' (fix for Gernot Tenchio's part of #126147).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1673

18 years agoImplement 'xlat' (fixes #125959 and #135012).
Julian Seward [Sun, 12 Nov 2006 22:25:21 +0000 (22:25 +0000)] 
Implement 'xlat' (fixes #125959 and #135012).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1672

19 years agoWhen doing rlwinm in 64-bit mode, bind the intermediate 32-bit result
Julian Seward [Thu, 19 Oct 2006 03:01:09 +0000 (03:01 +0000)] 
When doing rlwinm in 64-bit mode, bind the intermediate 32-bit result
to a temporary so it is only computed once.  What's there currently
causes it to be computed twice.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1671

19 years agoppc64: detect rldicl/rldicr which are simply 64-bit shifts left/right
Julian Seward [Thu, 19 Oct 2006 00:15:25 +0000 (00:15 +0000)] 
ppc64: detect rldicl/rldicr which are simply 64-bit shifts left/right
and emit IR directly as such.  Improves performance of 64-bit code (a
bit).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1670

19 years agoMerge r1663-r1666:
Julian Seward [Tue, 17 Oct 2006 00:28:22 +0000 (00:28 +0000)] 
Merge r1663-r1666:

- AIX5 build changes

- genoffsets.c: print the offsets of a few more ppc registers

- Get rid of a bunch of ad-hoc hacks which hardwire in certain
  assumptions about guest and host ABIs.  Instead pass that info
  in a VexMiscInfo structure.  This cleans up various grotty bits.

- Add to ppc32 guest state, redirection-stack stuff already present
  in ppc64 guest state.  This is to enable function redirection/
  wrapping in the presence of TOC pointers in 32-bit mode.

- Add to both ppc32 and ppc64 guest states, a new pseudo-register
  LR_AT_SC.  This holds the link register value at the most recent
  'sc', so that AIX can back up to restart a syscall if needed.

- Add to both ppc32 and ppc64 guest states, a SPRG3 register.

- Use VexMiscInfo to handle 'sc' on AIX differently from Linux:
  on AIX, 'sc' continues at the location stated in the link
  register, not at the next insn.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1669

19 years agoReinstate support for 'mcrfs'.
Julian Seward [Wed, 4 Oct 2006 17:46:11 +0000 (17:46 +0000)] 
Reinstate support for 'mcrfs'.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1667

19 years agoAnother day, another %eflags reduction rule.
Julian Seward [Sun, 17 Sep 2006 10:02:35 +0000 (10:02 +0000)] 
Another day, another %eflags reduction rule.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1660

19 years agoSupport pextrw when the destination register is 64 bits too. Fixes
Julian Seward [Mon, 11 Sep 2006 14:37:27 +0000 (14:37 +0000)] 
Support pextrw when the destination register is 64 bits too.  Fixes
#133678.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1656

19 years agoAdd support for amd64 'fprem' (fixes bug 132918). This isn't exactly
Julian Seward [Mon, 11 Sep 2006 11:07:34 +0000 (11:07 +0000)] 
Add support for amd64 'fprem' (fixes bug 132918).  This isn't exactly
right; the C3/2/1/0 FPU flags sometimes don't get set the same as
natively, and I can't figure out why.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1655

19 years ago64-bit counterpart to v1652 (Stop mkU16 asserting if d32 is a negative
Julian Seward [Mon, 28 Aug 2006 18:54:18 +0000 (18:54 +0000)] 
64-bit counterpart to v1652 (Stop mkU16 asserting if d32 is a negative
16-bit number (bug #132813)).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1653

19 years agoStop mkU16 asserting if d32 is a negative 16-bit number (bug #132813).
Julian Seward [Mon, 28 Aug 2006 18:04:33 +0000 (18:04 +0000)] 
Stop mkU16 asserting if d32 is a negative 16-bit number (bug #132813).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1652

19 years agoMore reduction rules, which further reduce memcheck's false error
Julian Seward [Fri, 25 Aug 2006 12:52:19 +0000 (12:52 +0000)] 
More reduction rules, which further reduce memcheck's false error
rate on optimised x86 and amd64 code.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1642

19 years agoFix previous commit (r1640?) so that it's actually correct :-)
Julian Seward [Sat, 19 Aug 2006 22:18:53 +0000 (22:18 +0000)] 
Fix previous commit (r1640?) so that it's actually correct :-)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1641

19 years agoComparing a reg with itself produces a result which doesn't depend on
Julian Seward [Sat, 19 Aug 2006 18:31:53 +0000 (18:31 +0000)] 
Comparing a reg with itself produces a result which doesn't depend on
the contents of the reg.  Therefore remove the false dependency, which
has been known to cause memcheck to produce false errors for
xlc-compiled code.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1640

19 years agoImplement amd64 insns cmpxchg8b and cmpxchg16b. Fixes #127521.
Julian Seward [Thu, 17 Aug 2006 01:20:01 +0000 (01:20 +0000)] 
Implement amd64 insns cmpxchg8b and cmpxchg16b.  Fixes #127521.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1639

19 years agoGenerate less verbose IR for amd64 'bswapq'. Fixes #132146.
Julian Seward [Wed, 16 Aug 2006 00:25:28 +0000 (00:25 +0000)] 
Generate less verbose IR for amd64 'bswapq'.  Fixes #132146.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1638

19 years agoamd64 insn printing fix.
Julian Seward [Wed, 16 Aug 2006 00:23:21 +0000 (00:23 +0000)] 
amd64 insn printing fix.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1637

19 years ago64-bit equivalent to r1635: handle all SSE3 instructions except
Julian Seward [Fri, 4 Aug 2006 14:51:19 +0000 (14:51 +0000)] 
64-bit equivalent to r1635: handle all SSE3 instructions except
monitor and mwait in 64-bit mode.  Regression tests to follow soon.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1636

19 years agoHandle all SSE3 instructions except monitor and mwait. 64-bit
Julian Seward [Thu, 3 Aug 2006 15:03:19 +0000 (15:03 +0000)] 
Handle all SSE3 instructions except monitor and mwait.  64-bit
equivalents to follow soon.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1635

19 years agoHandle nop-with-an-amode (sheesh. Mutancy. whatever next?) for x86 and
Julian Seward [Tue, 1 Aug 2006 18:36:25 +0000 (18:36 +0000)] 
Handle nop-with-an-amode (sheesh. Mutancy. whatever next?) for x86 and
amd64.  Fixes #131481 and #131298.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1634

19 years agoAllow a redundant REX prefix for pushfq. Fixes #130785.
Julian Seward [Mon, 24 Jul 2006 09:09:36 +0000 (09:09 +0000)] 
Allow a redundant REX prefix for pushfq.  Fixes #130785.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1633

19 years agoImplement SSE2 'psadbw'. Fixes #128917.
Julian Seward [Mon, 24 Jul 2006 08:51:16 +0000 (08:51 +0000)] 
Implement SSE2 'psadbw'.  Fixes #128917.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1632

19 years agoMore copyright updates.
Julian Seward [Mon, 5 Jun 2006 23:26:23 +0000 (23:26 +0000)] 
More copyright updates.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1628

19 years agoUpdate copyright dates.
Julian Seward [Mon, 5 Jun 2006 23:13:19 +0000 (23:13 +0000)] 
Update copyright dates.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1627

19 years agoSpecialisation rule which reduces memcheck false error rate for
Julian Seward [Thu, 25 May 2006 18:48:12 +0000 (18:48 +0000)] 
Specialisation rule which reduces memcheck false error rate for
KDE on SuSE 10.1 (amd64).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1626

19 years agoComment-only change.
Julian Seward [Thu, 25 May 2006 17:08:03 +0000 (17:08 +0000)] 
Comment-only change.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1625

19 years agoYet another %eflags folding rule - this one for performance reasons.
Julian Seward [Thu, 25 May 2006 01:04:05 +0000 (01:04 +0000)] 
Yet another %eflags folding rule - this one for performance reasons.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1624

19 years agoppc backend: handle vector constant of zero.
Cerion Armour-Brown [Mon, 22 May 2006 12:41:19 +0000 (12:41 +0000)] 
ppc backend: handle vector constant of zero.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1623

19 years agoGet rid of assertion getting in the way of handling 'sbbb G,E' where E
Julian Seward [Sun, 21 May 2006 15:38:38 +0000 (15:38 +0000)] 
Get rid of assertion getting in the way of handling 'sbbb G,E' where E
is memory.  Fixes #127631.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1622

19 years agoGot a sudden attach of the implicit-type-casting paranoias whilst
Julian Seward [Sun, 21 May 2006 12:02:44 +0000 (12:02 +0000)] 
Got a sudden attach of the implicit-type-casting paranoias whilst
looking for (non-) bug in running Python.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1621

19 years agoA couple of IR simplification hacks for the amd64 front end, so as to
Julian Seward [Sun, 21 May 2006 01:02:31 +0000 (01:02 +0000)] 
A couple of IR simplification hacks for the amd64 front end, so as to
avoid false errors from memcheck.  Analogous to some of the recent
bunch of commits to x86 front end.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1620

19 years agoClear up yet another gcc-4.1.0 stunt leading to false uninitialised
Julian Seward [Fri, 19 May 2006 23:09:03 +0000 (23:09 +0000)] 
Clear up yet another gcc-4.1.0 stunt leading to false uninitialised
value errors on SuSE 10.1 (x86) running konqueror.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1619

19 years agoA few more x86 eflags-helper rewrite cases, which further reduce the
Julian Seward [Mon, 15 May 2006 12:23:17 +0000 (12:23 +0000)] 
A few more x86 eflags-helper rewrite cases, which further reduce the
false error rate of memcheck on optimised code.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1618

19 years agoAdd an IR folding rule to convert Add32(x,x) into Shl32(x,1). This
Julian Seward [Sun, 14 May 2006 18:46:55 +0000 (18:46 +0000)] 
Add an IR folding rule to convert Add32(x,x) into Shl32(x,1).  This
fixes #118466 and it also gets rid of a bunch of false positives for
KDE 3.5.2 built by gcc-4.0.2 on x86, of the form shown below.

  Use of uninitialised value of size 4
    at 0x4BFC342: QIconSet::pixmap(QIconSet::Size, QIconSet::Mode,
                                   QIconSet::State) const (qiconset.cpp:530)
    by 0x4555BE7: KToolBarButton::drawButton(QPainter*)
                  (ktoolbarbutton.cpp:536)
    by 0x4CB8A0A: QButton::paintEvent(QPaintEvent*) (qbutton.cpp:887)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1617

19 years agoAdd specialisation rules to simplify the IR for 'testl .. ; js ..',
Julian Seward [Sat, 13 May 2006 23:08:06 +0000 (23:08 +0000)] 
Add specialisation rules to simplify the IR for 'testl .. ; js ..',
'testw .. ; js ..' and 'testb .. ; js ..'.  This gets rid of a bunch of
false errors in Memcheck of the form

==2398== Conditional jump or move depends on uninitialised value(s)
==2398==    at 0x6C51B61: KHTMLPart::clear() (khtml_part.cpp:1370)
==2398==    by 0x6C61A72: KHTMLPart::begin(KURL const&, int, int)
                          (khtml_part.cpp:1881)

(KDE 3.5.2 compiled by gcc-4.0.2, -g -O).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1616

19 years agoEnable 'SHLDv imm8,Gv,Ev'. Fixes #126583.
Julian Seward [Fri, 12 May 2006 21:03:48 +0000 (21:03 +0000)] 
Enable 'SHLDv imm8,Gv,Ev'.  Fixes #126583.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1615

19 years agoEnable 'sbb $imm,%al'. Fixes #126668.
Julian Seward [Fri, 12 May 2006 20:45:59 +0000 (20:45 +0000)] 
Enable 'sbb $imm,%al'.  Fixes #126668.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1614

19 years agoImplement CLC/STC/CMC. Fixes #125651.
Julian Seward [Fri, 12 May 2006 20:15:33 +0000 (20:15 +0000)] 
Implement CLC/STC/CMC.  Fixes #125651.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1613

19 years ago(1) Fix longstanding bug causing erroneous register zeroing for 'btl'.
Julian Seward [Fri, 12 May 2006 17:47:21 +0000 (17:47 +0000)] 
(1) Fix longstanding bug causing erroneous register zeroing for 'btl'.
(2) Implement 16-bit versions of bt/bts/btr/btc.  (Fixes #125607)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1612

19 years agoSupport 'popw m16'. Fixes #126243.
Julian Seward [Fri, 12 May 2006 14:04:48 +0000 (14:04 +0000)] 
Support 'popw m16'.  Fixes #126243.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1611

19 years agoFix for 32-bit mode, as per comment.
Julian Seward [Sat, 6 May 2006 14:40:40 +0000 (14:40 +0000)] 
Fix for 32-bit mode, as per comment.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1610

19 years agoImplement sthbrx.
Julian Seward [Fri, 5 May 2006 13:44:17 +0000 (13:44 +0000)] 
Implement sthbrx.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1609

19 years agoImplement lhbrx.
Julian Seward [Fri, 5 May 2006 13:26:14 +0000 (13:26 +0000)] 
Implement lhbrx.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1608

19 years agoFix incorrect behaviour of mov{s,z}bw (#126253).
Julian Seward [Wed, 3 May 2006 17:57:15 +0000 (17:57 +0000)] 
Fix incorrect behaviour of mov{s,z}bw (#126253).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1607

19 years agoCounterpart to r1605: in the ppc insn selector, don't use the bits
Julian Seward [Mon, 1 May 2006 02:14:17 +0000 (02:14 +0000)] 
Counterpart to r1605: in the ppc insn selector, don't use the bits
VexArchInfo.hwcaps to distinguish ppc32 and ppc64.  Instead pass
the host arch around.  And associated plumbing.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1606

19 years agoDon't use the bits VexArchInfo.hwcaps to distinguish ppc32 and ppc64,
Julian Seward [Sun, 30 Apr 2006 23:37:32 +0000 (23:37 +0000)] 
Don't use the bits VexArchInfo.hwcaps to distinguish ppc32 and ppc64,
since that doesn't work properly.  Instead pass the guest arch around
too.  Small change with lots of associated plumbing.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1605

19 years agoFix for instruction-decoding failures reported in #124499.
Julian Seward [Thu, 13 Apr 2006 22:06:35 +0000 (22:06 +0000)] 
Fix for instruction-decoding failures reported in #124499.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1604

19 years agoAllow 'repe scas' (possible fix for #124892).
Julian Seward [Wed, 12 Apr 2006 17:30:46 +0000 (17:30 +0000)] 
Allow 'repe scas' (possible fix for #124892).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1603

19 years agoImplement amd64 pmaddwd for SSE2.
Julian Seward [Sat, 8 Apr 2006 16:15:53 +0000 (16:15 +0000)] 
Implement amd64 pmaddwd for SSE2.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1602

19 years agoAdd a function to set/clear the x86 carry flag. (untested)
Julian Seward [Mon, 20 Mar 2006 12:05:42 +0000 (12:05 +0000)] 
Add a function to set/clear the x86 carry flag.  (untested)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1601

19 years agoFix some segment register pushes/pops.
Julian Seward [Sat, 18 Mar 2006 11:29:25 +0000 (11:29 +0000)] 
Fix some segment register pushes/pops.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1600

19 years agoupmerge r1597 (ppc32 needs a lot of spill slots sometimes)
Julian Seward [Thu, 16 Mar 2006 11:29:13 +0000 (11:29 +0000)] 
upmerge r1597 (ppc32 needs a lot of spill slots sometimes)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1599

19 years agoMove the helper function for x86 'fxtract' to g_generic_x87.c so
Julian Seward [Tue, 7 Mar 2006 01:15:50 +0000 (01:15 +0000)] 
Move the helper function for x86 'fxtract' to g_generic_x87.c so
it can be shared by the x86 and amd64 front ends, then use it to
implement fxtract on amd64.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1593

19 years agoImplement fnstsw.
Julian Seward [Tue, 7 Mar 2006 00:22:02 +0000 (00:22 +0000)] 
Implement fnstsw.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1591

19 years agoFix debug printing.
Julian Seward [Mon, 6 Mar 2006 19:17:17 +0000 (19:17 +0000)] 
Fix debug printing.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1588

19 years agoImplement fcmovnu.
Julian Seward [Mon, 6 Mar 2006 19:05:07 +0000 (19:05 +0000)] 
Implement fcmovnu.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1587

19 years agoImplement 3DNow! prefetch insn (prefetch, prefetchw). Fixes #120410.
Julian Seward [Mon, 6 Mar 2006 14:07:58 +0000 (14:07 +0000)] 
Implement 3DNow! prefetch insn (prefetch, prefetchw).  Fixes #120410.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1585

19 years agoHandle byte-size 'xadd reg,mem'. Also, don't bomb out for the
Julian Seward [Mon, 6 Mar 2006 13:35:42 +0000 (13:35 +0000)] 
Handle byte-size 'xadd reg,mem'.  Also, don't bomb out for the
unhandled 'xadd reg,reg' case; instead synth a SIGILL in the usual
way.  Fixes #121662.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1583

19 years agoImplement mtocrf/mfocrf.
Julian Seward [Wed, 1 Mar 2006 18:58:39 +0000 (18:58 +0000)] 
Implement mtocrf/mfocrf.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1579

19 years agoOops, stuff that should have been part of r1573 (4-arg primop change).
Julian Seward [Thu, 9 Feb 2006 02:54:03 +0000 (02:54 +0000)] 
Oops, stuff that should have been part of r1573 (4-arg primop change).

git-svn-id: svn://svn.valgrind.org/vex/trunk@1574

19 years agoRedo the way FP multiply-accumulate insns are done on ppc32/64.
Julian Seward [Wed, 8 Feb 2006 19:30:46 +0000 (19:30 +0000)] 
Redo the way FP multiply-accumulate insns are done on ppc32/64.
Instead of splitting them up into a multiply and an add/sub, add 4 new
primops which keeps the operation as a single unit.  Then, in the back
end, re-emit the as a single instruction.

Reason for this is that so-called fused-multiply-accumulate -- which
is what ppc does -- generates a double-double length intermediate
result (of the multiply, 112 mantissa bits) before doing the add, and
so it is impossible to do a bit-accurate simulation of it using AddF64
and MulF64.

Unfortunately the new primops unavoidably take 4 args (a rounding mode
+ 3 FP args) and so there is a new IRExpr expression type, IRExpr_Qop
and associated supporting junk.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1573

19 years agoWord size fixes for twi/tdi (is trickier than it looks :-). Also add
Julian Seward [Tue, 7 Feb 2006 20:55:08 +0000 (20:55 +0000)] 
Word size fixes for twi/tdi (is trickier than it looks :-).  Also add
missing DIP macros.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1572

19 years agoppc32/64: handle twi/tdi (conditional trap) instructions
Julian Seward [Tue, 7 Feb 2006 16:42:39 +0000 (16:42 +0000)] 
ppc32/64: handle twi/tdi (conditional trap) instructions

git-svn-id: svn://svn.valgrind.org/vex/trunk@1571

19 years agofre: observe the current rounding mode
Julian Seward [Mon, 6 Feb 2006 22:19:17 +0000 (22:19 +0000)] 
fre: observe the current rounding mode

git-svn-id: svn://svn.valgrind.org/vex/trunk@1570

19 years agoRedo x86g_calculate_FXTRACT to only use integer arithmetic.
Julian Seward [Mon, 6 Feb 2006 22:18:38 +0000 (22:18 +0000)] 
Redo x86g_calculate_FXTRACT to only use integer arithmetic.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1569

19 years agoComment-only changes
Julian Seward [Mon, 6 Feb 2006 03:58:31 +0000 (03:58 +0000)] 
Comment-only changes

git-svn-id: svn://svn.valgrind.org/vex/trunk@1568

19 years agoFixups following recent FP rounding mode changes.
Julian Seward [Sun, 5 Feb 2006 16:06:26 +0000 (16:06 +0000)] 
Fixups following recent FP rounding mode changes.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1567

19 years agoMake the CSE pass more aggressive. It now commons up Mux0X and GetI
Julian Seward [Sat, 4 Feb 2006 15:24:00 +0000 (15:24 +0000)] 
Make the CSE pass more aggressive.  It now commons up Mux0X and GetI
expressions too.  This generates somewhat better FP code on x86 since
it removes more redundant artefacts from the x87 FP stack simulation.
Unfortunately commoning up GetIs complicates CSEs, since it is now
possible that "available expressions" collected by the CSEr will
become invalidated by writes to the guest state as we work through the
block.  So there is additional code to check for this case.

Some supporting functions (getAliasingRelation_IC and
getAliasingRelation_II) have been moved earlier in the file.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1566

19 years agoMore x86 tidying up following rounding changes.
Julian Seward [Sat, 4 Feb 2006 15:20:13 +0000 (15:20 +0000)] 
More x86 tidying up following rounding changes.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1565

19 years agoFollowup to r1562: fixes for x86
Julian Seward [Fri, 3 Feb 2006 22:54:17 +0000 (22:54 +0000)] 
Followup to r1562: fixes for x86

git-svn-id: svn://svn.valgrind.org/vex/trunk@1564

19 years agoFollowup to r1562: fixes for ppc64
Julian Seward [Fri, 3 Feb 2006 19:12:17 +0000 (19:12 +0000)] 
Followup to r1562: fixes for ppc64

git-svn-id: svn://svn.valgrind.org/vex/trunk@1563

19 years agoAn overhaul of VEX's floating point handling, to facilitate correct
Julian Seward [Fri, 3 Feb 2006 16:08:03 +0000 (16:08 +0000)] 
An overhaul of VEX's floating point handling, to facilitate correct
simulation of IEEE rounding modes in all FP operations.

The fundamental change is to add a third argument to the basic
floating point primops, eg AddF64, MulF64, etc, indicating the
(IR-encoded) rounding mode to be used for that operation.

Unfortunately IR did not have any way to support three-argument
primops, which means a new kind of IRExpr has been added: a ternary
op, IRExpr_Triop, which is simply a 3-argument form of the existing IR
binary operation node.  The unfortunate side effect is that the size
of the union type IRExpr has increased from 16 to 20 bytes on 32-bit
platforms, and hence the JIT chews through more memory, but this does
not appear to have a measurable effect on the JIT's performance, at
least as measured by Valgrind's perf suite.

* Add IRExpr_Triop, and add handling code to dozens of places which
  examine IRExprs.

* Rename/retype a bunch of floating point IR primops to take a 3rd
  rounding mode argument (which is always the first arg).

* Add extra primops AddF64r32 et al, which do double-precision FP
  operations and then round to single precision, still within a 64-bit
  type.  This is needed to simulate PPC's fadds et al without double
  rounding.

* Adjust the PPC->IR front end, to generate these new primops and
  rounding modes.

* Cause the IR optimiser to do a CSE pass on blocks containing any
  floating point operations.  This commons up the IR rounding mode
  computations, which is important for generating efficient code from
  the backend.

* Adjust the IR->PPC back end, so as to emit instructions to set the
  rounding mode before each FP operation.  Well, at least in
  principle.  In practice there is a bit of cleverness to avoid
  repeatedly setting it to the same value.  This depends on both the
  abovementioned CSE pass, and on the SSA property of IR (cool stuff,
  SSA!).  The effect is that for most blocks containing FP code, the
  rounding mode is set just once, at the start of the block, and the
  resulting overhead is minimal.  See comment on
  set_FPU_rounding_mode().

This change requires followup changes in memcheck.  Also, the
x86/amd64 front/back ends are temporarily broken.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1562

19 years agoDo fre/fres in a way which makes minimal demands on the backend.
Julian Seward [Tue, 31 Jan 2006 16:32:25 +0000 (16:32 +0000)] 
Do fre/fres in a way which makes minimal demands on the backend.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1561

19 years agoF64i isel fix.
Julian Seward [Tue, 31 Jan 2006 16:31:44 +0000 (16:31 +0000)] 
F64i isel fix.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1560

19 years agoHandle fre and frsqrtes. Even though the IBM docs manage to
Julian Seward [Sun, 29 Jan 2006 17:07:57 +0000 (17:07 +0000)] 
Handle fre and frsqrtes.  Even though the IBM docs manage to
contradict themselves about whether these insns exist or not.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1559

19 years agoMake lsw work in 64-bit mode.
Julian Seward [Sat, 28 Jan 2006 17:07:19 +0000 (17:07 +0000)] 
Make lsw work in 64-bit mode.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1558

19 years agoUn-break ppc64 following recent hw-capabilities hackery. (sigh)
Julian Seward [Fri, 27 Jan 2006 22:05:55 +0000 (22:05 +0000)] 
Un-break ppc64 following recent hw-capabilities hackery.  (sigh)

git-svn-id: svn://svn.valgrind.org/vex/trunk@1557

19 years agoUnbreak ppc32 following recent hw-capabilities hackery.
Julian Seward [Fri, 27 Jan 2006 21:52:19 +0000 (21:52 +0000)] 
Unbreak ppc32 following recent hw-capabilities hackery.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1556

19 years agoChange the way Vex represents architecture variants into something
Julian Seward [Fri, 27 Jan 2006 21:20:15 +0000 (21:20 +0000)] 
Change the way Vex represents architecture variants into something
more flexible.  Prior to this change, the type VexSubArch effectively
imposed a total ordering on subarchitecture capabilities, which was
overly restrictive.  This change moves to effectively using a bit-set,
allowing some features (instruction groups) to be supported or not
supported independently of each other.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1555

19 years agoRe-enable stfiwx.
Julian Seward [Fri, 27 Jan 2006 16:05:49 +0000 (16:05 +0000)] 
Re-enable stfiwx.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1554

19 years agoHandle ppc32/64 fres, frsqrte.
Julian Seward [Fri, 27 Jan 2006 15:09:35 +0000 (15:09 +0000)] 
Handle ppc32/64 fres, frsqrte.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1553

19 years agoIn 32-bit mode, handle F64toI64 and I64toF64.
Julian Seward [Thu, 26 Jan 2006 03:02:26 +0000 (03:02 +0000)] 
In 32-bit mode, handle F64toI64 and I64toF64.

git-svn-id: svn://svn.valgrind.org/vex/trunk@1552

19 years agoA bit more backend tidying:
Julian Seward [Thu, 26 Jan 2006 02:24:17 +0000 (02:24 +0000)] 
A bit more backend tidying:
- fix up more float-integer conversions
- remove unused signedness field on PPCInstr_Load

git-svn-id: svn://svn.valgrind.org/vex/trunk@1551