提交 f26aea9a 编写于 作者: K kevinw

8165482: java in ldoms, with cpu-arch=generic has problems

Reviewed-by: dholmes, alanbur
上级 6ba047d5
...@@ -236,7 +236,7 @@ void VM_Version::initialize() { ...@@ -236,7 +236,7 @@ void VM_Version::initialize() {
assert((OptoLoopAlignment % relocInfo::addr_unit()) == 0, "alignment is not a multiple of NOP size"); assert((OptoLoopAlignment % relocInfo::addr_unit()) == 0, "alignment is not a multiple of NOP size");
char buf[512]; char buf[512];
jio_snprintf(buf, sizeof(buf), "%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s", jio_snprintf(buf, sizeof(buf), "%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s",
(has_v9() ? ", v9" : (has_v8() ? ", v8" : "")), (has_v9() ? ", v9" : (has_v8() ? ", v8" : "")),
(has_hardware_popc() ? ", popc" : ""), (has_hardware_popc() ? ", popc" : ""),
(has_vis1() ? ", vis1" : ""), (has_vis1() ? ", vis1" : ""),
...@@ -249,6 +249,7 @@ void VM_Version::initialize() { ...@@ -249,6 +249,7 @@ void VM_Version::initialize() {
(has_sha256() ? ", sha256" : ""), (has_sha256() ? ", sha256" : ""),
(has_sha512() ? ", sha512" : ""), (has_sha512() ? ", sha512" : ""),
(is_ultra3() ? ", ultra3" : ""), (is_ultra3() ? ", ultra3" : ""),
(has_sparc5_instr() ? ", sparc5" : ""),
(is_sun4v() ? ", sun4v" : ""), (is_sun4v() ? ", sun4v" : ""),
(is_niagara_plus() ? ", niagara_plus" : (is_niagara() ? ", niagara" : "")), (is_niagara_plus() ? ", niagara_plus" : (is_niagara() ? ", niagara" : "")),
(is_sparc64() ? ", sparc64" : ""), (is_sparc64() ? ", sparc64" : ""),
...@@ -479,17 +480,14 @@ int VM_Version::parse_features(const char* implementation) { ...@@ -479,17 +480,14 @@ int VM_Version::parse_features(const char* implementation) {
if (strstr(impl, "SPARC-T1") != NULL) { if (strstr(impl, "SPARC-T1") != NULL) {
features |= T1_model_m; features |= T1_model_m;
} }
} else if (strstr(impl, "SUN4V-CPU") != NULL) {
// Generic or migration class LDOM
features |= T_family_m;
} else { } else {
if (strstr(impl, "SPARC") == NULL) {
#ifndef PRODUCT #ifndef PRODUCT
// kstat on Solaris 8 virtual machines (branded zones) warning("Failed to parse CPU implementation = '%s'", impl);
// returns "(unsupported)" implementation. Solaris 8 is not
// supported anymore, but include this check to be on the
// safe side.
warning("Can't parse CPU implementation = '%s', assume generic SPARC", impl);
#endif #endif
} }
}
os::free((void*)impl); os::free((void*)impl);
return features; return features;
} }
...@@ -438,40 +438,47 @@ int VM_Version::platform_features(int features) { ...@@ -438,40 +438,47 @@ int VM_Version::platform_features(int features) {
features |= sun4v_m; features |= sun4v_m;
} }
bool use_solaris_12_api = false;
Sysinfo impl(SI_CPUBRAND);
if (impl.valid()) {
// If SI_CPUBRAND works, that means Solaris 12 API to get the cache line sizes // If SI_CPUBRAND works, that means Solaris 12 API to get the cache line sizes
// is available to us as well // is available to us as well
use_solaris_12_api = true; Sysinfo cpu_info(SI_CPUBRAND);
features |= parse_features(impl.value()); bool use_solaris_12_api = cpu_info.valid();
const char* impl;
int impl_m = 0;
if (use_solaris_12_api) {
impl = cpu_info.value();
#ifndef PRODUCT
if (PrintMiscellaneous && Verbose) {
tty->print_cr("Parsing CPU implementation from %s", impl);
}
#endif
impl_m = parse_features(impl);
} else { } else {
// Otherwise use kstat to determine the machine type. // Otherwise use kstat to determine the machine type.
kstat_ctl_t* kc = kstat_open(); kstat_ctl_t* kc = kstat_open();
if (kc != NULL) {
kstat_t* ksp = kstat_lookup(kc, (char*)"cpu_info", -1, NULL); kstat_t* ksp = kstat_lookup(kc, (char*)"cpu_info", -1, NULL);
const char* implementation;
bool has_implementation = false;
if (ksp != NULL) { if (ksp != NULL) {
if (kstat_read(kc, ksp, NULL) != -1 && ksp->ks_data != NULL) { if (kstat_read(kc, ksp, NULL) != -1 && ksp->ks_data != NULL) {
kstat_named_t* knm = (kstat_named_t *)ksp->ks_data; kstat_named_t* knm = (kstat_named_t *)ksp->ks_data;
for (int i = 0; i < ksp->ks_ndata; i++) { for (int i = 0; i < ksp->ks_ndata; i++) {
if (strcmp((const char*)&(knm[i].name),"implementation") == 0) { if (strcmp((const char*)&(knm[i].name), "implementation") == 0) {
implementation = KSTAT_NAMED_STR_PTR(&knm[i]); impl = KSTAT_NAMED_STR_PTR(&knm[i]);
has_implementation = true;
#ifndef PRODUCT #ifndef PRODUCT
if (PrintMiscellaneous && Verbose) { if (PrintMiscellaneous && Verbose) {
tty->print_cr("cpu_info.implementation: %s", implementation); tty->print_cr("Parsing CPU implementation from %s", impl);
} }
#endif #endif
features |= parse_features(implementation); impl_m = parse_features(impl);
break; break;
} }
} // for(
} }
} }
assert(has_implementation, "unknown cpu info (changed kstat interface?)"); }
kstat_close(kc); kstat_close(kc);
} }
}
assert(impl_m != 0, err_msg("Unknown CPU implementation %s", impl));
features |= impl_m;
bool is_sun4v = (features & sun4v_m) != 0; bool is_sun4v = (features & sun4v_m) != 0;
if (use_solaris_12_api && is_sun4v) { if (use_solaris_12_api && is_sun4v) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册