hotspot/src/share/vm/prims/jniFastGetField.hpp
author ysr
Thu, 03 Dec 2009 15:01:57 -0800
changeset 4461 c17c526d36ef
parent 1 489c9b5090e2
child 5547 f4b087cbb361
permissions -rw-r--r--
6906727: UseCompressedOops: some card-marking fixes related to object arrays Summary: Introduced a new write_ref_array(HeapWords* start, size_t count) method that does the requisite MemRegion range calculation so (some of the) clients of the erstwhile write_ref_array(MemRegion mr) do not need to worry. This removed all external uses of array_size(), which was also simplified and made private. Asserts were added to catch other possible issues. Further, less essential, fixes stemming from this investigation are deferred to CR 6904516 (to follow shortly in hs17). Reviewed-by: kvn, coleenp, jmasa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
     2
 * Copyright 2004 Sun Microsystems, Inc.  All Rights Reserved.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
 * CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
 * have any questions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
// Basic logic of a fast version of jni_Get<Primitive>Field:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
// (See safepoint.hpp for a description of _safepoint_counter)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
// load _safepoint_counter into old_counter
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
// IF old_counter is odd THEN
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
//   a safepoint is going on, return jni_GetXXXField
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
// ELSE
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
//   load the primitive field value into result (speculatively)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
//   load _safepoint_counter into new_counter
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
//   IF (old_counter == new_counter) THEN
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
//     no safepoint happened during the field access, return result
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
//   ELSE
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
//     a safepoint might have happened in-between, return jni_GetXXXField()
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
//   ENDIF
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
// ENDIF
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
// LoadLoad membars to maintain the load order may be necessary
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
// for some platforms.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
// The fast versions don't check for pending suspension request.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
// This is fine since it's totally read-only and doesn't create new race.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
// There is a hypothetical safepoint counter wraparound. But it's not
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
// a practical concern.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
class JNI_FastGetField : AllStatic {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  enum { LIST_CAPACITY = 40 };      // a conservative number for the number of
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
                                    // speculative loads on all the platforms
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
  static address speculative_load_pclist [];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
  static address slowcase_entry_pclist   [];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
  static int     count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
  static address generate_fast_get_int_field0(BasicType type);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
  static address generate_fast_get_float_field0(BasicType type);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
#if defined(_WINDOWS) && !defined(_WIN64)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
  static GetBooleanField_t jni_fast_GetBooleanField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  static GetByteField_t    jni_fast_GetByteField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  static GetCharField_t    jni_fast_GetCharField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
  static GetShortField_t   jni_fast_GetShortField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
  static GetIntField_t     jni_fast_GetIntField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
  static GetLongField_t    jni_fast_GetLongField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
  static GetFloatField_t   jni_fast_GetFloatField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
  static GetDoubleField_t  jni_fast_GetDoubleField_fp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
  static address generate_fast_get_boolean_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  static address generate_fast_get_byte_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  static address generate_fast_get_char_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
  static address generate_fast_get_short_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
  static address generate_fast_get_int_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  static address generate_fast_get_long_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  static address generate_fast_get_float_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  static address generate_fast_get_double_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  // If pc is in speculative_load_pclist, return the corresponding
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  // slow case entry pc. Otherwise, return -1.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  // This is used by signal/exception handler to handle such case:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
  // After an even safepoint counter is loaded and a fast field access
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
  // is about to begin, a GC kicks in and shrinks the heap. Then the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
  // field access may fault. The signal/exception handler needs to
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
  // return to the slow case.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
  // The GC may decide to temporarily stuff some bad values into handles,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
  // for example, for debugging purpose, in which case we need the mapping also.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
  static address find_slowcase_pc(address pc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
};