src/cpu/zero/vm/stack_zero.hpp

Mon, 14 Jun 2010 00:52:15 -0700

author
twisti
date
Mon, 14 Jun 2010 00:52:15 -0700
changeset 1960
d179e225c164
parent 1907
c18cbe5936b8
child 2314
f95d63e2154a
permissions
-rw-r--r--

6960550: Missing semicolon in Zero
Summary: There is a missing semicolon in cppInterpreter_zero.cpp.
Reviewed-by: twisti
Contributed-by: Gary Benson <gbenson@redhat.com>

     1 /*
     2  * Copyright (c) 2003, 2007, Oracle and/or its affiliates. All rights reserved.
     3  * Copyright 2008, 2009, 2010 Red Hat, Inc.
     4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     5  *
     6  * This code is free software; you can redistribute it and/or modify it
     7  * under the terms of the GNU General Public License version 2 only, as
     8  * published by the Free Software Foundation.
     9  *
    10  * This code is distributed in the hope that it will be useful, but WITHOUT
    11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    12  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    13  * version 2 for more details (a copy is included in the LICENSE file that
    14  * accompanied this code).
    15  *
    16  * You should have received a copy of the GNU General Public License version
    17  * 2 along with this work; if not, write to the Free Software Foundation,
    18  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    19  *
    20  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    21  * or visit www.oracle.com if you need additional information or have any
    22  * questions.
    23  *
    24  */
    26 class ZeroStack {
    27  private:
    28   intptr_t *_base; // the last available word
    29   intptr_t *_top;  // the word past the end of the stack
    30   intptr_t *_sp;   // the top word on the stack
    32  private:
    33   int _shadow_pages_size; // how much ABI stack must we keep free?
    35  public:
    36   ZeroStack()
    37     : _base(NULL), _top(NULL), _sp(NULL) {
    38     _shadow_pages_size = StackShadowPages * os::vm_page_size();
    39   }
    41   bool needs_setup() const {
    42     return _base == NULL;
    43   }
    45   int suggest_size(Thread *thread) const;
    47   void setup(void *mem, size_t size) {
    48     assert(needs_setup(), "already set up");
    49     assert(!(size & WordAlignmentMask), "unaligned");
    51     _base = (intptr_t *) mem;
    52     _top  = _base + (size >> LogBytesPerWord);
    53     _sp   = _top;
    54   }
    55   void teardown() {
    56     assert(!needs_setup(), "not set up");
    57     assert(_sp == _top, "stuff on stack at teardown");
    59     _base = NULL;
    60     _top  = NULL;
    61     _sp   = NULL;
    62   }
    64   intptr_t *sp() const {
    65     return _sp;
    66   }
    67   void set_sp(intptr_t *new_sp) {
    68     assert(_top >= new_sp && new_sp >= _base, "bad stack pointer");
    69     _sp = new_sp;
    70   }
    72   int total_words() const {
    73     return _top - _base;
    74   }
    75   int available_words() const {
    76     return _sp - _base;
    77   }
    79   void push(intptr_t value) {
    80     assert(_sp > _base, "stack overflow");
    81     *(--_sp) = value;
    82   }
    83   intptr_t pop() {
    84     assert(_sp < _top, "stack underflow");
    85     return *(_sp++);
    86   }
    88   void *alloc(size_t size) {
    89     int count = align_size_up(size, wordSize) >> LogBytesPerWord;
    90     assert(count <= available_words(), "stack overflow");
    91     return _sp -= count;
    92   }
    94   int shadow_pages_size() const {
    95     return _shadow_pages_size;
    96   }
    97   int abi_stack_available(Thread *thread) const;
    99  public:
   100   void overflow_check(int required_words, TRAPS);
   101   static void handle_overflow(TRAPS);
   103  public:
   104   void zap(int c) PRODUCT_RETURN;
   106  public:
   107   static ByteSize base_offset() {
   108     return byte_offset_of(ZeroStack, _base);
   109   }
   110   static ByteSize top_offset() {
   111     return byte_offset_of(ZeroStack, _top);
   112   }
   113   static ByteSize sp_offset() {
   114     return byte_offset_of(ZeroStack, _sp);
   115   }
   116 };
   119 class EntryFrame;
   120 class InterpreterFrame;
   121 class SharkFrame;
   122 class FakeStubFrame;
   124 //
   125 // |  ...               |
   126 // +--------------------+  ------------------
   127 // |  ...               |       low addresses
   128 // | frame_type         |
   129 // | next_frame         |      high addresses
   130 // +--------------------+  ------------------
   131 // |  ...               |
   133 class ZeroFrame {
   134   friend class frame;
   135   friend class ZeroStackPrinter;
   137  protected:
   138   ZeroFrame() {
   139     ShouldNotCallThis();
   140   }
   142   enum Layout {
   143     next_frame_off,
   144     frame_type_off,
   145     jf_header_words
   146   };
   148   enum FrameType {
   149     ENTRY_FRAME = 1,
   150     INTERPRETER_FRAME,
   151     SHARK_FRAME,
   152     FAKE_STUB_FRAME
   153   };
   155  protected:
   156   intptr_t *addr_of_word(int offset) const {
   157     return (intptr_t *) this - offset;
   158   }
   159   intptr_t value_of_word(int offset) const {
   160     return *addr_of_word(offset);
   161   }
   163  public:
   164   ZeroFrame *next() const {
   165     return (ZeroFrame *) value_of_word(next_frame_off);
   166   }
   168  protected:
   169   FrameType type() const {
   170     return (FrameType) value_of_word(frame_type_off);
   171   }
   173  public:
   174   bool is_entry_frame() const {
   175     return type() == ENTRY_FRAME;
   176   }
   177   bool is_interpreter_frame() const {
   178     return type() == INTERPRETER_FRAME;
   179   }
   180   bool is_shark_frame() const {
   181     return type() == SHARK_FRAME;
   182   }
   183   bool is_fake_stub_frame() const {
   184     return type() == FAKE_STUB_FRAME;
   185   }
   187  public:
   188   EntryFrame *as_entry_frame() const {
   189     assert(is_entry_frame(), "should be");
   190     return (EntryFrame *) this;
   191   }
   192   InterpreterFrame *as_interpreter_frame() const {
   193     assert(is_interpreter_frame(), "should be");
   194     return (InterpreterFrame *) this;
   195   }
   196   SharkFrame *as_shark_frame() const {
   197     assert(is_shark_frame(), "should be");
   198     return (SharkFrame *) this;
   199   }
   200   FakeStubFrame *as_fake_stub_frame() const {
   201     assert(is_fake_stub_frame(), "should be");
   202     return (FakeStubFrame *) this;
   203   }
   205  public:
   206   void identify_word(int   frame_index,
   207                      int   offset,
   208                      char* fieldbuf,
   209                      char* valuebuf,
   210                      int   buflen) const;
   212  protected:
   213   void identify_vp_word(int       frame_index,
   214                         intptr_t* addr,
   215                         intptr_t* monitor_base,
   216                         intptr_t* stack_base,
   217                         char*     fieldbuf,
   218                         int       buflen) const;
   219 };

mercurial