src/share/tools/hsdis/hsdis.h

Thu, 26 Jul 2018 17:38:44 -0400

author
dbuck
date
Thu, 26 Jul 2018 17:38:44 -0400
changeset 9473
d0613fb2fc3b
parent 4244
3d701c802d01
child 9476
9a18c71dbd25
permissions
-rw-r--r--

8208183: update HSDIS plugin license to UPL
Reviewed-by: simonis, adinn, jrose

     1 /*
     2  * Copyright (c) 2008, 2012, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     5  * The Universal Permissive License (UPL), Version 1.0
     6  *
     7  * Subject to the condition set forth below, permission is hereby granted to
     8  * any person obtaining a copy of this software, associated documentation
     9  * and/or data (collectively the "Software"), free of charge and under any
    10  * and all copyright rights in the Software, and any and all patent rights
    11  * owned or freely licensable by each licensor hereunder covering either (i)
    12  * the unmodified Software as contributed to or provided by such licensor,
    13  * or (ii) the Larger Works (as defined below), to deal in both
    14  *
    15  * (a) the Software, and
    16  *
    17  * (b) any piece of software and/or hardware listed in the lrgrwrks.txt file
    18  * if one is included with the Software (each a “Larger Work” to which the
    19  * Software is contributed by such licensors),
    20  *
    21  * without restriction, including without limitation the rights to copy,
    22  * create derivative works of, display, perform, and distribute the Software
    23  * and make, use, sell, offer for sale, import, export, have made, and have
    24  * sold the Software and the Larger Work(s), and to sublicense the foregoing
    25  * rights on either these or other terms.
    26  *
    27  * This license is subject to the following condition:
    28  *
    29  * The above copyright notice and either this complete permission notice or
    30  * at a minimum a reference to the UPL must be included in all copies or
    31  * substantial portions of the Software.
    32  *
    33  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
    34  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
    35  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
    36  * NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
    37  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
    38  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
    39  * USE OR OTHER DEALINGS IN THE SOFTWARE.
    40  *
    41  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    42  * or visit www.oracle.com if you need additional information or have any
    43  * questions.
    44  *
    45  */
    47 /* decode_instructions -- dump a range of addresses as native instructions
    48    This implements the protocol required by the HotSpot PrintAssembly option.
    50    The start_va, end_va is the virtual address the region of memory to
    51    disasemble and buffer contains the instructions to decode,
    52    Disassembling instructions in the current address space is done by
    53    having start_va == buffer.
    55    The option string, if not empty, is interpreted by the disassembler implementation.
    57    The printf callback is 'fprintf' or any other workalike.
    58    It is called as (*printf_callback)(printf_stream, "some format...", some, format, args).
    60    The event callback receives an event tag (a string) and an argument (a void*).
    61    It is called as (*event_callback)(event_stream, "tag", arg).
    63    Events:
    64      <insn pc='%p'>             begin an instruction, at a given location
    65      </insn pc='%d'>            end an instruction, at a given location
    66      <addr value='%p'/>         emit the symbolic value of an address
    68    A tag format is one of three basic forms: "tag", "/tag", "tag/",
    69    where tag is a simple identifier, signifying (as in XML) a element start,
    70    element end, and standalone element.  (To render as XML, add angle brackets.)
    71 */
    72 #ifndef SHARED_TOOLS_HSDIS_H
    73 #define SHARED_TOOLS_HSDIS_H
    75 extern
    76 #ifdef DLL_EXPORT
    77   DLL_EXPORT
    78 #endif
    79 void* decode_instructions_virtual(uintptr_t start_va, uintptr_t end_va,
    80                                   unsigned char* buffer, uintptr_t length,
    81                                   void* (*event_callback)(void*, const char*, void*),
    82                                   void* event_stream,
    83                                   int (*printf_callback)(void*, const char*, ...),
    84                                   void* printf_stream,
    85                                   const char* options,
    86                                   int newline /* bool value for nice new line */);
    88 /* This is the compatability interface for older versions of hotspot */
    89 extern
    90 #ifdef DLL_ENTRY
    91   DLL_ENTRY
    92 #endif
    93 void* decode_instructions(void* start_pv, void* end_pv,
    94                     void* (*event_callback)(void*, const char*, void*),
    95                     void* event_stream,
    96                     int   (*printf_callback)(void*, const char*, ...),
    97                     void* printf_stream,
    98                     const char* options);
   100 /* convenience typedefs */
   102 typedef void* (*decode_instructions_event_callback_ftype)  (void*, const char*, void*);
   103 typedef int   (*decode_instructions_printf_callback_ftype) (void*, const char*, ...);
   104 typedef void* (*decode_func_vtype) (uintptr_t start_va, uintptr_t end_va,
   105                                     unsigned char* buffer, uintptr_t length,
   106                                     decode_instructions_event_callback_ftype event_callback,
   107                                     void* event_stream,
   108                                     decode_instructions_printf_callback_ftype printf_callback,
   109                                     void* printf_stream,
   110                                     const char* options,
   111                                     int newline);
   112 typedef void* (*decode_func_stype) (void* start_pv, void* end_pv,
   113                                     decode_instructions_event_callback_ftype event_callback,
   114                                     void* event_stream,
   115                                     decode_instructions_printf_callback_ftype printf_callback,
   116                                     void* printf_stream,
   117                                     const char* options);
   118 #endif /* SHARED_TOOLS_HSDIS_H */

mercurial