src/hotspot/cpu/sparc/vm_version_ext_sparc.cpp
author egahlin
Tue, 15 May 2018 20:24:34 +0200
changeset 50113 caf115bb98ad
child 50538 f36d08a3e700
permissions -rw-r--r--
8199712: Flight Recorder Reviewed-by: coleenp, ihse, erikj, dsamersoff, mseledtsov, egahlin, mgronlun Contributed-by: erik.gahlin@oracle.com, markus.gronlund@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     2
 * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     4
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
#include "jvm.h"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
#include "memory/allocation.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
#include "memory/allocation.inline.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
#include "vm_version_ext_sparc.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
// VM_Version_Ext statics
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
int   VM_Version_Ext::_no_of_threads = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
int   VM_Version_Ext::_no_of_cores = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
int   VM_Version_Ext::_no_of_sockets = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
kid_t VM_Version_Ext::_kcid = -1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
char  VM_Version_Ext::_cpu_name[CPU_TYPE_DESC_BUF_SIZE] = {0};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
char  VM_Version_Ext::_cpu_desc[CPU_DETAILED_DESC_BUF_SIZE] = {0};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
// get cpu information. It takes into account if the kstat chain id
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
// has been changed and update the info if necessary.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
bool VM_Version_Ext::initialize_cpu_information(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
  int core_id = -1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
  int chip_id = -1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
  int len = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
  char* src_string = NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
  kstat_ctl_t* kc = kstat_open();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
  if (!kc) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
    return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
  // check if kstat chain has been updated
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
  kid_t kcid = kstat_chain_update(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
  if (kcid == -1) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
    kstat_close(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
    return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
  bool updated = ((kcid > 0) && (kcid != _kcid)) ||
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
                 ((kcid == 0) && (_kcid == -1));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
  if (!updated) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
    kstat_close(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
    return true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
  // update the cached _kcid
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
  _kcid = kcid;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
  // find the number of online processors
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    69
  // for modern processsors, it is also known as the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
  // hardware threads.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    71
  _no_of_threads  = sysconf(_SC_NPROCESSORS_ONLN);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
  if (_no_of_threads <= 0 ) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    74
    kstat_close(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
    return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
  _no_of_cores = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    79
  _no_of_sockets = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    81
  // loop through the kstat chain
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    82
  kstat_t* ksp = NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    83
  for (ksp = kc->kc_chain; ksp != NULL; ksp = ksp->ks_next) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    84
    // only interested in "cpu_info"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    85
    if (strcmp(ksp->ks_module, (char*)CPU_INFO) == 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    86
      if (kstat_read(kc, ksp, NULL) == -1) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    87
        kstat_close(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
        return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
      }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
      if (ksp->ks_data != NULL) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
        kstat_named_t* knm = (kstat_named_t *)ksp->ks_data;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
        // loop through the number of fields in each record
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
        for (int i = 0; i < ksp->ks_ndata; i++) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
          // set cpu type if it hasn't been already set
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
          if ((strcmp((const char*)&(knm[i].name), CPU_TYPE) == 0) &&
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
                     (_cpu_name[0] == '\0')) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
            if (knm[i].data_type == KSTAT_DATA_STRING) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
              src_string = (char*)KSTAT_NAMED_STR_PTR(&knm[i]);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
            } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
              src_string = (char*)&(knm[i].value.c[0]);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
            len = strlen(src_string);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
            if (len < CPU_TYPE_DESC_BUF_SIZE) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
              jio_snprintf(_cpu_name, CPU_TYPE_DESC_BUF_SIZE,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
                                         "%s", src_string);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
          }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
          // set cpu description if it hasn't been already set
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
          if ((strcmp((const char*)&(knm[i].name), CPU_DESCRIPTION) == 0) &&
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
                      (_cpu_desc[0] == '\0')) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
            if (knm[i].data_type == KSTAT_DATA_STRING) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
              src_string = (char*)KSTAT_NAMED_STR_PTR(&knm[i]);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
            } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
              src_string = (char*)&(knm[i].value.c[0]);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
            len = strlen(src_string);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
            if (len < CPU_DETAILED_DESC_BUF_SIZE) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
              jio_snprintf(_cpu_desc, CPU_DETAILED_DESC_BUF_SIZE,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
                                         "%s", src_string);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
          }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
          // count the number of sockets based on the chip id
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
          if (strcmp((const char*)&(knm[i].name), CHIP_ID) == 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
            if (chip_id != knm[i].value.l) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
              chip_id = knm[i].value.l;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
              _no_of_sockets++;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
          }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
          // count the number of cores based on the core id
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
          if (strcmp((const char*)&(knm[i].name), CORE_ID) == 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
            if (core_id != knm[i].value.l) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
              core_id = knm[i].value.l;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
              _no_of_cores++;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
          }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
      }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
  kstat_close(kc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
  return true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
int VM_Version_Ext::number_of_threads(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
  initialize_cpu_information();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
  return _no_of_threads;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
int VM_Version_Ext::number_of_cores(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
  initialize_cpu_information();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
  return _no_of_cores;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
int VM_Version_Ext::number_of_sockets(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
  initialize_cpu_information();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
  return _no_of_sockets;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
const char* VM_Version_Ext::cpu_name(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
  if (!initialize_cpu_information()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
    return NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
  char* tmp = NEW_C_HEAP_ARRAY_RETURN_NULL(char, CPU_TYPE_DESC_BUF_SIZE, mtTracing);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
  if (NULL == tmp) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
    return NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
  strncpy(tmp, _cpu_name, CPU_TYPE_DESC_BUF_SIZE);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
  return tmp;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   174
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
const char* VM_Version_Ext::cpu_description(void) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
  if (!initialize_cpu_information()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
    return NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
  char* tmp = NEW_C_HEAP_ARRAY_RETURN_NULL(char, CPU_DETAILED_DESC_BUF_SIZE, mtTracing);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
  if (NULL == tmp) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
    return NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
  strncpy(tmp, _cpu_desc, CPU_DETAILED_DESC_BUF_SIZE);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
  return tmp;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
}