** Description changed:

+ ## DRAFT ###
+ [Impact]
+ valgrind on bionic coredump and errors out as follows:
+ 
+ ARM64 front end: branch_etc
+ disInstr(arm64): unhandled instruction 0xD5380000
+ disInstr(arm64): 1101'0101 0011'1000 0000'0000 0000'0000
+ ==11950== valgrind: Unrecognised instruction at address 0x4014c90.
+ ==11950==    at 0x4014C90: init_cpu_features (cpu-features.c:72)
+ ==11950==    by 0x4014C90: dl_platform_init (dl-machine.h:208)
+ ==11950==    by 0x4014C90: _dl_sysdep_start (dl-sysdep.c:231)
+ ==11950==    by 0x40018C3: _dl_start_final (rtld.c:414)
+ ==11950==    by 0x4001B47: _dl_start (rtld.c:523)
+ ==11950==    by 0x40011C7: ??? (in /lib/aarch64-linux-gnu/ld-2.27.so)
+ ==11950== Your program just tried to execute an instruction that Valgrind
+ ==11950== did not recognise.  There are two possible reasons for this.
+ ==11950== 1. Your program has a bug and erroneously jumped to a non-code
+ ==11950==    location.  If you are running Memcheck and you just saw a
+ ==11950==    warning about a bad jump, it's probably your program's fault.
+ ==11950== 2. The instruction is legitimate but Valgrind doesn't handle it,
+ ==11950==    i.e. it's Valgrind's fault.  If you think this is the case or
+ ==11950==    you are not sure, please let us know and we'll try to fix it.
+ ==11950== Either way, Valgrind will now raise a SIGILL signal which will
+ ==11950== probably kill your program.
+ ==11950== 
+ ==11950== Process terminating with default action of signal 4 (SIGILL)
+ ==11950==  Illegal opcode at address 0x4014C90
+ ==11950==    at 0x4014C90: init_cpu_features (cpu-features.c:72)
+ ==11950==    by 0x4014C90: dl_platform_init (dl-machine.h:208)
+ ==11950==    by 0x4014C90: _dl_sysdep_start (dl-sysdep.c:231)
+ ==11950==    by 0x40018C3: _dl_start_final (rtld.c:414)
+ ==11950==    by 0x4001B47: _dl_start (rtld.c:523)
+ ==11950==    by 0x40011C7: ??? (in /lib/aarch64-linux-gnu/ld-2.27.so)
+ 
+ 
+ [Test Case]
+ 
+ 1) Write a 'Hello World' program:
+ ----
+ #include <stdio.h>
+ 
+ void main(void) {
+ printf("Hello World!\n");
+ };
+ ----
+ 
+ 2) Build it:
+ $ cc -o hello hello.c
+ 
+ 3) Then run valgrind on it:
+ $ valgrind ./hello
+ 
+ [Regression Potential]
+ 
+ [Other information]
+ 
+ Upstream fix: 
+ 
https://sourceware.org/git/?p=valgrind.git;a=commit;h=fbbb696c5d1e93d4ac6cb548c68bb3f443ceef42
+ 
+ * Only affecting Bionic:
+ 
+ # git describe --contains fbbb696c5d1e93d4ac6cb548c68bb3f443ceef42
+ VALGRIND_3_14_0~96
+ 
+ # rmadison valgrind
+ => valgrind | 1:3.13.0-2ubuntu2.1      | bionic-updates  
+    valgrind | 1:3.14.0-2ubuntu6        | disco                      
+    valgrind | 1:3.15.0-1ubuntu3.1      | eoan-updates    
+    valgrind | 1:3.15.0-1ubuntu5        | focal          
+ 
+ 
+ [Original Description]
+ 
  I'm performing Valgrind testing on an ElPotato running Ubuntu Bionic
  Aarch64 image. My program is dying like in
  https://bugs.kde.org/show_bug.cgi?id=381556 :
- 
  
  ```
  $ valgrind --track-origins=yes --suppressions=cryptopp.supp ./cryptest.exe v
  ==12969== Memcheck, a memory error detector
  ==12969== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
  ==12969== Using Valgrind-3.13.0 and LibVEX; rerun with -h for copyright info
  ==12969== Command: ./cryptest.exe v
  ==12969==
  ARM64 front end: branch_etc
  disInstr(arm64): unhandled instruction 0xD5380000
  disInstr(arm64): 1101'0101 0011'1000 0000'0000 0000'0000
  ==12969== valgrind: Unrecognised instruction at address 0x4014c90.
  ==12969==    at 0x4014C90: init_cpu_features (cpu-features.c:72)
  ==12969==    by 0x4014C90: dl_platform_init (dl-machine.h:208)
  ==12969==    by 0x4014C90: _dl_sysdep_start (dl-sysdep.c:231)
  ==12969==    by 0x40018C3: _dl_start_final (rtld.c:414)
  ==12969==    by 0x4001B47: _dl_start (rtld.c:523)
  ==12969==    by 0x40011C7: ??? (in /lib/aarch64-linux-gnu/ld-2.27.so)
  ...
  ```
  
  Here's a similar Red Hat issue report:
  https://bugzilla.redhat.com/show_bug.cgi?id=1467952 .
  
  Please pickup the patch in the 381556 bug report.
  
  -----
  
  $ lsb_release -rd
  Description:    Ubuntu 18.04.2 LTS
  Release:        18.04
  
  $ apt-cache policy valgrind
  valgrind:
-   Installed: 1:3.13.0-2ubuntu2.1
-   Candidate: 1:3.13.0-2ubuntu2.1
-   Version table:
-  *** 1:3.13.0-2ubuntu2.1 500
-         500 http://ports.ubuntu.com bionic-updates/main arm64 Packages
-         100 /var/lib/dpkg/status
-      1:3.13.0-2ubuntu2 500
-         500 http://ports.ubuntu.com bionic/main arm64 Packages
+   Installed: 1:3.13.0-2ubuntu2.1
+   Candidate: 1:3.13.0-2ubuntu2.1
+   Version table:
+  *** 1:3.13.0-2ubuntu2.1 500
+         500 http://ports.ubuntu.com bionic-updates/main arm64 Packages
+         100 /var/lib/dpkg/status
+      1:3.13.0-2ubuntu2 500
+         500 http://ports.ubuntu.com bionic/main arm64 Packages

-- 
You received this bug notification because you are a member of Ubuntu
Bugs, which is subscribed to Ubuntu.
https://bugs.launchpad.net/bugs/1826811

Title:
  Valgrind unhandled instruction 0xD5380000 on Aarch64

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/valgrind/+bug/1826811/+subscriptions

-- 
ubuntu-bugs mailing list
ubuntu-bugs@lists.ubuntu.com
https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs

Reply via email to