templateInterpreterGenerator.hpp revision 605:98cb887364d3
1/*
2 * Copyright 1997-2007 Sun Microsystems, Inc.  All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
20 * CA 95054 USA or visit www.sun.com if you need additional information or
21 * have any questions.
22 *
23 */
24
25// This file contains the platform-independent parts
26// of the template interpreter generator.
27
28#ifndef CC_INTERP
29
30class TemplateInterpreterGenerator: public AbstractInterpreterGenerator {
31 protected:
32
33  // entry points for shared code sequence
34  address _unimplemented_bytecode;
35  address _illegal_bytecode_sequence;
36
37  // shared code sequences
38  // Converter for native abi result to tosca result
39  address generate_result_handler_for(BasicType type);
40  address generate_slow_signature_handler();
41  address generate_error_exit(const char* msg);
42  address generate_StackOverflowError_handler();
43  address generate_exception_handler(const char* name, const char* message) {
44    return generate_exception_handler_common(name, message, false);
45  }
46  address generate_klass_exception_handler(const char* name) {
47    return generate_exception_handler_common(name, NULL, true);
48  }
49  address generate_exception_handler_common(const char* name, const char* message, bool pass_oop);
50  address generate_ClassCastException_handler();
51  address generate_ArrayIndexOutOfBounds_handler(const char* name);
52  address generate_continuation_for(TosState state);
53  address generate_return_entry_for(TosState state, int step);
54  address generate_earlyret_entry_for(TosState state);
55  address generate_deopt_entry_for(TosState state, int step);
56  address generate_safept_entry_for(TosState state, address runtime_entry);
57  void    generate_throw_exception();
58
59  // entry point generator
60//   address generate_method_entry(AbstractInterpreter::MethodKind kind);
61
62  // Instruction generation
63  void generate_and_dispatch (Template* t, TosState tos_out = ilgl);
64  void set_vtos_entry_points (Template* t, address& bep, address& cep, address& sep, address& aep, address& iep, address& lep, address& fep, address& dep, address& vep);
65  void set_short_entry_points(Template* t, address& bep, address& cep, address& sep, address& aep, address& iep, address& lep, address& fep, address& dep, address& vep);
66  void set_wide_entry_point  (Template* t, address& wep);
67
68  void set_entry_points(Bytecodes::Code code);
69  void set_unimplemented(int i);
70  void set_entry_points_for_all_bytes();
71  void set_safepoints_for_all_bytes();
72
73  // Helpers for generate_and_dispatch
74  address generate_trace_code(TosState state)   PRODUCT_RETURN0;
75  void count_bytecode()                         PRODUCT_RETURN;
76  void histogram_bytecode(Template* t)          PRODUCT_RETURN;
77  void histogram_bytecode_pair(Template* t)     PRODUCT_RETURN;
78  void trace_bytecode(Template* t)              PRODUCT_RETURN;
79  void stop_interpreter_at()                    PRODUCT_RETURN;
80
81  void generate_all();
82
83 public:
84  TemplateInterpreterGenerator(StubQueue* _code);
85
86  #include "incls/_templateInterpreterGenerator_pd.hpp.incl"
87
88};
89
90#endif // !CC_INTERP
91