[Bug 1355530] [NEW] Valgrind is not supported on PPC64 Little Endian (LE) platforms

Launchpad Bug Tracker 1355530 at bugs.launchpad.net
Tue Aug 12 02:04:53 UTC 2014


You have been subscribed to a public bug:

---Problem Description---
Valgrind is not supported on PPC64 Little Endian (LE) platforms.  The LE support has recently been added to Valgrind.  Would like to get the support included in the Ubuntu 14.10 release.
 
---Additional Hardware Info---
PPC64 LE system 
 
Machine Type = PPC64 Little Endian 
  
---Steps to Reproduce---
 The valgrind support for PPC64 does not exist.  So starting the tool on the platform just fails.
 
Userspace tool common name: valgrind 
 
The userspace tool has the following bit modes: 64-bit 

The needed support for Valgrind on PPC64 LE was added upstream.  The
description of the added support can be found in the Valgrind bugzillas:

   https://bugs.kde.org/show_bug.cgi?id=334384     Patch 1  Valgrind commit 14238
   https://bugs.kde.org/show_bug.cgi?id=334834     Patch 2  Valgrind commit 14239, vex commit 2914
   https://bugs.kde.org/show_bug.cgi?id=334836     Patch 3  Valgrind commit 14240

   fix for the performance regerssion fix Valgrind commit 14246 on Friday July 8, 2014
 
Note, patch 2 is depended on some newly added support for passing the Endianess of the host and the guest to the VEX code.  The valgrind commit for this dependent support is as follows:

Valgrind repository

   r14184 | sewardj | 2014-07-24 07:45:24 -0500 (Thu, 24 Jul 2014) | 8
lines

   Track vex r2910 (infrastructural improvements in representation of
   endianness in VEX).

   In short: in m_machine.c, VG_(machine_get_hwcaps), get the endianness
   of the host, and pass it through to all places (in VEX) where it is
   required.

VEX repository

   r2910 | sewardj | 2014-07-24 07:42:03 -0500 (Thu, 24 Jul 2014) | 22
lines

   Improve infrastructure for dealing with endianness in VEX.  This patch
   removes all decisions about endianness from VEX.  Instead, it requires
   that the LibVEX_* calls pass in information about the guest or host
   endianness (depending on context) and in turn it passes that info
   through to all the places that need it:

   * the front ends (xx_toIR.c)
   * the back ends (xx_isel.c)
   * the patcher functions (Chain, UnChain, PatchProfInc)

   Mostly it is boring and ugly plumbing.  As far as types go, there is a
   new type "VexEndness" that carries the endianness.  This also makes it
   possible to stop using Bools to indicate endianness.  VexArchInfo has
   a new field of type VexEndness.  Apart from that, no other changes in
   types.

   Followups: MIPS front and back ends have not yet been fixed up to use
   the passed-in endianness information.  Currently they assume that the
   endianness of both host and guest is the same as the endianness of the
   target for which VEX is being compiled.

** Affects: valgrind (Ubuntu)
     Importance: Undecided
         Status: Confirmed


** Tags: architecture-ppc64le bugnameltc-114508 severity-medium targetmilestone-inin1410
-- 
Valgrind is not supported on PPC64 Little Endian (LE) platforms
https://bugs.launchpad.net/bugs/1355530
You received this bug notification because you are a member of Ubuntu Foundations Bugs, which is subscribed to valgrind in Ubuntu.



More information about the foundations-bugs mailing list