hotspot/src/os/windows/vm/decoder_windows.hpp
author sla
Wed, 04 Dec 2013 14:43:50 +0100
changeset 22216 888245fbd0a5
parent 19952 bc974e92f881
child 22234 da823d78ad65
permissions -rw-r--r--
8029395: SA: jstack throws WrongTypeException Summary: SA missed some TLABs Reviewed-by: dsamersoff, mgerdin, brutisso
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     1
/*
13963
e5b53c306fb5 7197424: update copyright year to match last edit in jdk8 hotspot repository
mikael
parents: 13340
diff changeset
     2
 * Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     4
 *
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     7
 * published by the Free Software Foundation.
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     8
 *
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    13
 * accompanied this code).
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    14
 *
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    18
 *
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    21
 * questions.
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    22
 *
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    23
 */
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    24
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    25
#ifndef OS_WINDOWS_VM_DECODER_WINDOWS_HPP
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    26
#define OS_WINDOWS_VM_DECIDER_WINDOWS_HPP
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    27
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    28
#include <windows.h>
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    29
#include <imagehlp.h>
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    30
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    31
#include "utilities/decoder.hpp"
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    32
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    33
// functions needed for decoding symbols
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    34
typedef DWORD (WINAPI *pfn_SymSetOptions)(DWORD);
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    35
typedef BOOL  (WINAPI *pfn_SymInitialize)(HANDLE, PCTSTR, BOOL);
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    36
typedef BOOL  (WINAPI *pfn_SymGetSymFromAddr64)(HANDLE, DWORD64, PDWORD64, PIMAGEHLP_SYMBOL64);
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    37
typedef DWORD (WINAPI *pfn_UndecorateSymbolName)(const char*, char*, DWORD, DWORD);
15186
1a255c84cf6a 7152671: RFE: Windows decoder should add some std dirs to the symbol search path
zgu
parents: 13963
diff changeset
    38
typedef BOOL  (WINAPI *pfn_SymSetSearchPath)(HANDLE, PCTSTR);
1a255c84cf6a 7152671: RFE: Windows decoder should add some std dirs to the symbol search path
zgu
parents: 13963
diff changeset
    39
typedef BOOL  (WINAPI *pfn_SymGetSearchPath)(HANDLE, PTSTR, int);
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    40
19952
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    41
#ifdef AMD64
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    42
typedef BOOL  (WINAPI *pfn_StackWalk64)(DWORD MachineType,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    43
                                        HANDLE hProcess,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    44
                                        HANDLE hThread,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    45
                                        LPSTACKFRAME64 StackFrame,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    46
                                        PVOID ContextRecord,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    47
                                        PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    48
                                        PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    49
                                        PGET_MODULE_BASE_ROUTINE64 GetModuleBaseRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    50
                                        PTRANSLATE_ADDRESS_ROUTINE64 TranslateAddress);
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    51
typedef PVOID (WINAPI *pfn_SymFunctionTableAccess64)(HANDLE hProcess, DWORD64 AddrBase);
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    52
typedef DWORD64 (WINAPI *pfn_SymGetModuleBase64)(HANDLE hProcess, DWORD64 dwAddr);
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    53
#endif
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    54
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    55
class WindowsDecoder : public AbstractDecoder {
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    56
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    57
public:
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    58
  WindowsDecoder();
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    59
  ~WindowsDecoder() { uninitialize(); };
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    60
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    61
  bool can_decode_C_frame_in_vm() const;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    62
  bool demangle(const char* symbol, char *buf, int buflen);
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    63
  bool decode(address addr, char *buf, int buflen, int* offset, const char* modulepath = NULL);
13340
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 11761
diff changeset
    64
  bool decode(address addr, char *buf, int buflen, int* offset, const void* base) {
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 11761
diff changeset
    65
    ShouldNotReachHere();
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 11761
diff changeset
    66
    return false;
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 11761
diff changeset
    67
  }
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    68
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    69
private:
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    70
  void initialize();
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    71
  void uninitialize();
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    72
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    73
private:
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    74
  HMODULE                   _dbghelp_handle;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    75
  bool                      _can_decode_in_vm;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    76
  pfn_SymGetSymFromAddr64   _pfnSymGetSymFromAddr64;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    77
  pfn_UndecorateSymbolName  _pfnUndecorateSymbolName;
19952
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    78
#ifdef AMD64
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    79
  pfn_StackWalk64              _pfnStackWalk64;
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    80
  pfn_SymFunctionTableAccess64 _pfnSymFunctionTableAccess64;
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    81
  pfn_SymGetModuleBase64       _pfnSymGetModuleBase64;
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    82
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    83
  friend class WindowsDbgHelp;
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    84
#endif
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    85
};
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
    86
19952
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    87
#ifdef AMD64
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    88
// TODO: refactor and move the handling of dbghelp.dll outside of Decoder
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    89
class WindowsDbgHelp : public Decoder {
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    90
public:
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    91
  static BOOL StackWalk64(DWORD MachineType,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    92
                          HANDLE hProcess,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    93
                          HANDLE hThread,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    94
                          LPSTACKFRAME64 StackFrame,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    95
                          PVOID ContextRecord,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    96
                          PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    97
                          PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    98
                          PGET_MODULE_BASE_ROUTINE64 GetModuleBaseRoutine,
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
    99
                          PTRANSLATE_ADDRESS_ROUTINE64 TranslateAddress);
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   100
  static PVOID SymFunctionTableAccess64(HANDLE hProcess, DWORD64 AddrBase);
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   101
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   102
  static pfn_SymFunctionTableAccess64 pfnSymFunctionTableAccess64();
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   103
  static pfn_SymGetModuleBase64       pfnSymGetModuleBase64();
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   104
};
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   105
#endif
bc974e92f881 8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents: 15186
diff changeset
   106
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
   107
#endif // OS_WINDOWS_VM_DECODER_WINDOWS_HPP
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents:
diff changeset
   108