diff options
Diffstat (limited to 'desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java')
-rw-r--r-- | desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java | 279 |
1 files changed, 272 insertions, 7 deletions
diff --git a/desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java b/desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java index 1ce5f5697bcb..684b8224d2af 100644 --- a/desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java +++ b/desktop/source/registration/com/sun/star/servicetag/SolarisSystemEnvironment.java @@ -6,9 +6,8 @@ * * OpenOffice.org - a multi-platform office productivity suite * - * $RCSfile: SolarisSystemEnvironment.java,v $ - * - * $Revision: 1.2 $ + * $RCSfile: Registration.java,v $ + * $Revision: 1.3 $ * * This file is part of OpenOffice.org. * @@ -40,17 +39,180 @@ package com.sun.star.servicetag; // (e.g. NetBeans and SunStudio) will use the version in JDK. import java.io.*; +import java.util.Set; +import java.util.HashSet; /** * Solaris implementation of the SystemEnvironment class. */ class SolarisSystemEnvironment extends SystemEnvironment { + private static final int SN = 1; + private static final int SYS = 2; + private static final int CPU = 3; + private static final int MODEL = 4; + private String kstatCpuInfo = null; + SolarisSystemEnvironment() { setHostId(getCommandOutput("/usr/bin/hostid")); - setSystemModel(getCommandOutput("/usr/bin/uname", "-i")); + setSystemModel(getSolarisModel()); setSystemManufacturer(getSolarisSystemManufacturer()); setCpuManufacturer(getSolarisCpuManufacturer()); setSerialNumber(getSolarisSN()); + setPhysMem(getSolarisPhysMem()); + setSockets(getSolarisSockets()); + setCores(getSolarisCores()); + setVirtCpus(getSolarisVirtCpus()); + setCpuName(getSolarisCpuName()); + setClockRate(getSolarisClockRate()); + } + + private String getSolarisClockRate() { + String data = getSolarisKstatCpuInfo(); + + String lines[] = data.split("\n"); + String token = "clock_MHz"; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.startsWith(token)) { + return line.substring(line.indexOf(token) + token.length()).trim(); + } + } + return ""; + } + + private String getSolarisCpuName() { + String data = getSolarisKstatCpuInfo(); + + String lines[] = data.split("\n"); + String token = "brand"; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.startsWith(token)) { + return line.substring(line.indexOf(token) + token.length()).trim(); + } + } + return ""; + } + + private String getSolarisVirtCpus() { + String data = getSolarisKstatCpuInfo(); + + int cnt = 0; + String lines[] = data.split("\n"); + String token = " cpu_info "; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.indexOf(token) != -1) { + cnt++; + } + } + return "" + cnt; + } + + private String getSolarisCores() { + String data = getSolarisKstatCpuInfo(); + + Set<String> set = new HashSet<String>(); + String lines[] = data.split("\n"); + String coreIdToken = "core_id"; + String coreId = ""; + String chipIdToken = "chip_id"; + String chipId = ""; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.startsWith(chipIdToken)) { + chipId = line.substring(line.indexOf(chipIdToken) + chipIdToken.length()).trim(); + } + if (line.startsWith(coreIdToken)) { + coreId = line.substring(line.indexOf(coreIdToken) + coreIdToken.length()).trim(); + set.add(chipId + "," + coreId); + } + } + return "" + set.size(); + } + + private String getSolarisPhysMem() { + String data = getCommandOutput("/usr/sbin/prtconf"); + + int cnt = 0; + String lines[] = data.split("\n"); + String token = "Memory size:"; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.startsWith(token)) { + line = line.substring(line.indexOf(token) + token.length()).trim(); + if (line.indexOf(" ") != -1) { + return line.substring(0, line.indexOf(" ")).trim(); + } + } + } + return ""; + } + + private String getSolarisSockets() { + String data = getSolarisKstatCpuInfo(); + + Set<String> set = new HashSet<String>(); + String lines[] = data.split("\n"); + String token = "chip_id"; + for (int i=0; i<lines.length; i++) { + String line = lines[i].trim(); + if (line.startsWith(token)) { + String id = line.substring(line.indexOf(token) + token.length()).trim(); + set.add(id); + } + } + return "" + set.size(); + } + + private synchronized String getSolarisKstatCpuInfo() { + // only try to get kstat cpu_info information once, after that, we can + // reuse the output + if (kstatCpuInfo == null) { + Thread thread = new Thread() { + public void run() { + kstatCpuInfo = getCommandOutput("/usr/bin/kstat", "cpu_info"); + } + }; + thread.start(); + + try { + thread.join(2000); + if (thread.isAlive()) { + thread.interrupt(); + kstatCpuInfo = ""; + } + } catch (InterruptedException ie) { + thread.interrupt(); + } + } + return kstatCpuInfo; + } + + private String getSolarisModel() { + String tmp = getFileContent("/var/run/psn"); + if (tmp.length() > 0) { + String[] lines = tmp.split("\n"); + if (MODEL <= lines.length) { + return lines[MODEL-1] + "::" + + getCommandOutput("/usr/bin/uname", "-v"); + } + } + + if ("sparc".equalsIgnoreCase(System.getProperty("os.arch"))) { + return getCommandOutput("/usr/bin/uname", "-i") + "::" + + getCommandOutput("/usr/bin/uname", "-v"); + } else { + String model = getSmbiosData("1", "Product: "); + if (model == null || model.trim().equals("")) { + model = getCommandOutput("/usr/bin/uname", "-i"); + } + if (model == null) { + model = ""; + } + return model.trim() + "::" + + getCommandOutput("/usr/bin/uname", "-v"); + } } /** @@ -58,13 +220,21 @@ class SolarisSystemEnvironment extends SystemEnvironment { * @return The cpu manufacturer (an empty string if not found or an error occurred) */ private String getSolarisCpuManufacturer() { + String tmp = getFileContent("/var/run/psn"); + if (tmp.length() > 0) { + String[] lines = tmp.split("\n"); + if (CPU <= lines.length) { + return lines[CPU-1]; + } + } + // not fully accurate, this could be another manufacturer (fujitsu for example) if ("sparc".equalsIgnoreCase(System.getProperty("os.arch"))) { return "Sun Microsystems, Inc"; } - // if we're here, then we'll try smbios (type 3) - return getSmbiosData("3", "Manufacturer: "); + // if we're here, then we'll try smbios (type 4) + return getSmbiosData("4", "Manufacturer: "); } /** @@ -72,8 +242,19 @@ class SolarisSystemEnvironment extends SystemEnvironment { * @return The system manufacturer (an empty string if not found or an error occurred) */ private String getSolarisSystemManufacturer() { + String tmp = getFileContent("/var/run/psn"); + if (tmp.length() > 0) { + String[] lines = tmp.split("\n"); + if (SYS <= lines.length) { + return lines[SYS-1]; + } + } + // not fully accurate, this could be another manufacturer (fujitsu for example) if ("sparc".equalsIgnoreCase(System.getProperty("os.arch"))) { + if (getCommandOutput("/usr/bin/uname", "-m").equals("sun4us")) { + return "Fujitsu"; + } return "Sun Microsystems, Inc"; } @@ -89,7 +270,10 @@ class SolarisSystemEnvironment extends SystemEnvironment { // try to read from the psn file if it exists String tmp = getFileContent("/var/run/psn"); if (tmp.length() > 0) { - return tmp.trim(); + String[] lines = tmp.split("\n"); + if (SN <= lines.length) { + return lines[SN-1]; + } } // if we're here, then we'll try sneep @@ -110,6 +294,17 @@ class SolarisSystemEnvironment extends SystemEnvironment { return tmpSN; } + if ("sparc".equalsIgnoreCase(System.getProperty("os.arch"))) { + tmpSN = getSNViaPrtfruX(); + if (tmpSN.length() > 0) { + return tmpSN; + } + tmpSN = getSNViaPrtfru(); + if (tmpSN.length() > 0) { + return tmpSN; + } + } + // give up and return return ""; } @@ -156,4 +351,74 @@ class SolarisSystemEnvironment extends SystemEnvironment { } } + private String getSNViaPrtfruX() { + String data = getCommandOutput("/usr/sbin/prtfru", "-x"); + + boolean FRUTREE_FLAG = false; + boolean FRUNAME_FLAG = false; + boolean MB_LABEL_FLAG = false; + boolean SYSTEM_BOARD_FLAG = false; + + String lines[] = data.split("\n"); + for (int i=0; i<lines.length; i++) { + String line = lines[i]; + if (SYSTEM_BOARD_FLAG) { + String tok = "<Sun_Serial_No value=\""; + int index = line.indexOf(tok); + if (index != -1) { + String val = line.substring(index+tok.length()); + String vals[] = val.split("\""); + if (vals.length > 0) { + return vals[0].trim(); + } + break; + } + } + + if (line.indexOf("</ContainerData>") != -1) { + FRUTREE_FLAG = false; + FRUNAME_FLAG = false; + SYSTEM_BOARD_FLAG = false; + } + + if (FRUNAME_FLAG && line.indexOf("<Container name=\"system-board\">") != -1 ) { + SYSTEM_BOARD_FLAG = true; + } + + if (FRUTREE_FLAG && line.indexOf("<Fru name=\"chassis\">") != -1 ) { + FRUNAME_FLAG = true; + } + + if (line.indexOf("<Location name=\"frutree\">") != -1) { + FRUTREE_FLAG = true; + } + } + + return ""; + } + + private String getSNViaPrtfru() { + String data = getCommandOutput("/usr/sbin/prtfru"); + boolean CHASSIS_FLAG = false; + + String lines[] = data.split("\n"); + for (int i=0; i<lines.length; i++) { + String line = lines[i]; + if (CHASSIS_FLAG) { + String tok = "/ManR/Sun_Serial_No:"; + int index = line.indexOf(tok); + if (index != -1) { + String val = line.substring(index+tok.length()); + return val.trim(); + } + } + + if (line.indexOf("/frutree/chassis/system-board (container)") != -1) { + CHASSIS_FLAG = true; + } else if (line.indexOf("/frutree/chassis/MB?Label=MB/system-board (container)") != -1) { + CHASSIS_FLAG = true; + } + } + return ""; + } } |