intel: tools: dump: protect against multiple calls on destructor
authorLionel Landwerlin <lionel.g.landwerlin@intel.com>
Fri, 20 Jul 2018 10:20:41 +0000 (11:20 +0100)
committerLionel Landwerlin <lionel.g.landwerlin@intel.com>
Fri, 20 Jul 2018 16:36:56 +0000 (17:36 +0100)
When running gdb, make sure to pass the LD_PRELOAD variable only to
the executed program, not the debugger. Otherwise the debugger will
run the preloaded constructor/destructor too and bad things will
happen.

Suggested-by: Rafael Antognolli <rafael.antognolli@intel.com>
Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Reviewed-by: Rafael Antognolli <rafael.antognolli@intel.com>
src/intel/tools/intel_dump_gpu.in

index 0454cff25da45a31ed7df5d822d2577b1b7e6695..aa187ba86146c7afcc7bef6c231be8d8d75106ff 100755 (executable)
@@ -23,8 +23,10 @@ EOF
     exit 0
 }
 
+ld_preload="@install_libexecdir@/libintel_dump_gpu.so${LD_PPRELOAD:+:$LD_PRELOAD}"
 args=""
 file=""
+gdb=""
 
 function add_arg() {
     arg=$1
@@ -60,6 +62,14 @@ while true; do
             add_arg "device=${1##--device=}"
             shift
             ;;
+        --gdb)
+            gdb=1
+            shift
+            ;;
+        -g)
+            gdb=1
+            shift
+            ;;
         --help)
             show_help
             ;;
@@ -85,9 +95,12 @@ done
 tmp_file=`mktemp`
 echo -e $args > $tmp_file
 
-LD_PRELOAD="@install_libexecdir@/libintel_dump_gpu.so${LD_PPRELOAD:+:$LD_PRELOAD}" \
-          INTEL_DUMP_GPU_CONFIG=$tmp_file \
-          $@
+if [ -z $gdb ]; then
+    LD_PRELOAD="$ld_preload" INTEL_DUMP_GPU_CONFIG=$tmp_file $@
+else
+    gdb -iex "set exec-wrapper env LD_PRELOAD=$ld_preload INTEL_DUMP_GPU_CONFIG=$tmp_file" --args $@
+fi
+
 ret=$?
 rm $tmp_file
 exit $ret