< prev index next >

src/hotspot/cpu/x86/vm_version_x86.cpp

Print this page
@@ -36,20 +36,21 @@
  #include "runtime/java.hpp"
  #include "runtime/os.inline.hpp"
  #include "runtime/stubCodeGenerator.hpp"
  #include "runtime/vm_version.hpp"
  #include "utilities/checkedCast.hpp"
+ #include "utilities/ostream.hpp"
  #include "utilities/powerOfTwo.hpp"
  #include "utilities/virtualizationSupport.hpp"
  
  int VM_Version::_cpu;
  int VM_Version::_model;
  int VM_Version::_stepping;
  bool VM_Version::_has_intel_jcc_erratum;
  VM_Version::CpuidInfo VM_Version::_cpuid_info = { 0, };
  
- #define DECLARE_CPU_FEATURE_NAME(id, name, bit) name,
+ #define DECLARE_CPU_FEATURE_NAME(id, name, bit) XSTR(name),
  const char* VM_Version::_features_names[] = { CPU_FEATURE_FLAGS(DECLARE_CPU_FEATURE_NAME)};
  #undef DECLARE_CPU_FEATURE_FLAG
  
  // Address of instruction which causes SEGV
  address VM_Version::_cpuinfo_segv_addr = nullptr;

@@ -1098,25 +1099,20 @@
      if ((X86ICacheSync == 5) && !supports_serialize()) {
        vm_exit_during_initialization("CPU does not support SERIALIZE, unable to use X86ICacheSync=5");
      }
    }
  
-   char buf[2048];
-   size_t cpu_info_size = jio_snprintf(
-               buf, sizeof(buf),
-               "(%u cores per cpu, %u threads per core) family %d model %d stepping %d microcode 0x%x",
-               cores_per_cpu(), threads_per_core(),
-               cpu_family(), _model, _stepping, os::cpu_microcode_revision());
-   assert(cpu_info_size > 0, "not enough temporary space allocated");
+   stringStream ss(2048);
+   ss.print("(%u cores per cpu, %u threads per core) family %d model %d stepping %d microcode 0x%x",
+            cores_per_cpu(), threads_per_core(),
+            cpu_family(), _model, _stepping, os::cpu_microcode_revision());
+   ss.print(", ");
+   int features_offset = (int)ss.size();
+   insert_features_names(_features, ss);
  
-   insert_features_names(_features, buf + cpu_info_size, sizeof(buf) - cpu_info_size);
- 
-   _cpu_info_string = os::strdup(buf);
- 
-   _features_string = extract_features_string(_cpu_info_string,
-                                              strnlen(_cpu_info_string, sizeof(buf)),
-                                              cpu_info_size);
+   _cpu_info_string = ss.as_string(true);
+   _features_string = _cpu_info_string + features_offset;
  
    // Use AES instructions if available.
    if (supports_aes()) {
      if (FLAG_IS_DEFAULT(UseAES)) {
        FLAG_SET_DEFAULT(UseAES, true);

@@ -3294,15 +3290,54 @@
      break;
    }
    return true;
  }
  
- void VM_Version::insert_features_names(VM_Version::VM_Features features, char* buf, size_t buflen) {
-   for (int i = 0; i < MAX_CPU_FEATURES; i++) {
-     if (features.supports_feature((VM_Version::Feature_Flag)i)) {
-       int res = jio_snprintf(buf, buflen, ", %s", _features_names[i]);
-       assert(res > 0, "not enough temporary space allocated");
-       buf += res;
-       buflen -= res;
+ void VM_Version::insert_features_names(VM_Version::VM_Features features, stringStream& ss) {
+   int i = 0;
+   ss.join([&]() {
+     const char* str = nullptr;
+     while ((i < MAX_CPU_FEATURES) && (str == nullptr)) {
+       if (features.supports_feature((VM_Version::Feature_Flag)i)) {
+         str = _features_names[i];
+       }
+       i += 1;
      }
-   }
+     return str;
+   }, ", ");
+ }
+ 
+ void VM_Version::get_cpu_features_name(void* features_buffer, stringStream& ss) {
+   VM_Features* features = (VM_Features*)features_buffer;
+   insert_features_names(*features, ss);
+ }
+ 
+ void VM_Version::get_missing_features_name(void* features_buffer, stringStream& ss) {
+   VM_Features* features_to_test = (VM_Features*)features_buffer;
+   int i = 0;
+   ss.join([&]() {
+     const char* str = nullptr;
+     while ((i < MAX_CPU_FEATURES) && (str == nullptr)) {
+       Feature_Flag flag = (Feature_Flag)i;
+       if (features_to_test->supports_feature(flag) && !_features.supports_feature(flag)) {
+         str = _features_names[i];
+       }
+       i += 1;
+     }
+     return str;
+   }, ", ");
+ }
+ 
+ int VM_Version::cpu_features_size() {
+   return sizeof(VM_Features);
+ }
+ 
+ void VM_Version::store_cpu_features(void* buf) {
+   VM_Features copy = _features;
+   copy.clear_feature(CPU_HT); // HT does not result in incompatibility of aot code cache
+   memcpy(buf, &copy, sizeof(VM_Features));
+ }
+ 
+ bool VM_Version::supports_features(void* features_buffer) {
+   VM_Features* features_to_test = (VM_Features*)features_buffer;
+   return _features.supports_features(features_to_test);
  }
< prev index next >