2002-04-30 22:22:54 +00:00
|
|
|
// The contents of this file are subject to the Mozilla Public License
|
|
|
|
// Version 1.0 (the "License"); you may not use this file except in
|
|
|
|
// compliance with the License. You may obtain a copy of the License at
|
|
|
|
// http://www.mozilla.org/MPL/
|
|
|
|
//
|
|
|
|
// Software distributed under the License is distributed on an "AS IS"
|
|
|
|
// basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing rights and limitations
|
|
|
|
// under the License.
|
|
|
|
//
|
|
|
|
// The Original Code is the Berkeley Open Infrastructure for Network Computing.
|
|
|
|
//
|
|
|
|
// The Initial Developer of the Original Code is the SETI@home project.
|
|
|
|
// Portions created by the SETI@home project are Copyright (C) 2002
|
|
|
|
// University of California at Berkeley. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Contributor(s):
|
|
|
|
//
|
|
|
|
|
2002-07-22 23:07:14 +00:00
|
|
|
#include "windows_cpp.h"
|
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2002-06-06 18:50:12 +00:00
|
|
|
#include <time.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
|
|
|
|
#if HAVE_SYS_TYPES_H
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <sys/types.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
#if HAVE_SYS_STATVFS_H
|
|
|
|
#include <sys/statvfs.h>
|
|
|
|
#endif
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#if HAVE_SYS_SWAP_H
|
|
|
|
#include <sys/swap.h>
|
|
|
|
#endif
|
2002-07-03 22:37:24 +00:00
|
|
|
|
2002-06-06 18:50:12 +00:00
|
|
|
#ifdef _WIN32
|
|
|
|
#include <windows.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
|
2002-06-10 06:14:18 +00:00
|
|
|
#if HAVE_SYS_SYSTEMINFO_H
|
2002-06-06 22:39:21 +00:00
|
|
|
#include <sys/systeminfo.h>
|
2002-06-10 06:14:18 +00:00
|
|
|
#endif
|
2002-07-03 22:37:24 +00:00
|
|
|
#if HAVE_SYS_UTSNAME_H
|
2002-06-06 18:50:12 +00:00
|
|
|
#include <sys/utsname.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
#if HAVE_UNISTD_H
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <unistd.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
#if HAVE_NETDB_H
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <netdb.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
#if HAVE_ARPA_INET_H
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <arpa/inet.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
#if HAVE_NETINET_IN_H
|
2002-04-30 22:22:54 +00:00
|
|
|
#include <netinet/in.h>
|
2002-06-06 18:50:12 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2002-06-01 20:26:21 +00:00
|
|
|
#include "client_types.h"
|
2002-07-11 01:09:53 +00:00
|
|
|
#include "error_numbers.h"
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
// functions to get name/addr of local host
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Returns the domain of the local host
|
|
|
|
// TODO: Should the 256 be MAXHOSTNAMELEN instead?
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
int get_local_domain_name(char* p) {
|
|
|
|
char buf[256];
|
2002-08-14 23:02:32 +00:00
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
gethostname(buf, 256);
|
|
|
|
struct hostent* he = gethostbyname(buf);
|
2002-08-14 23:02:32 +00:00
|
|
|
if (!he) return -1;
|
2002-04-30 22:22:54 +00:00
|
|
|
strcpy(p, he->h_name);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Gets the ip address of the local host
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
int get_local_ip_addr(int& p) {
|
2002-07-22 23:07:14 +00:00
|
|
|
p = 0;
|
|
|
|
|
2002-07-03 22:59:40 +00:00
|
|
|
#if HAVE_NETDB_H
|
2002-08-14 23:02:32 +00:00
|
|
|
char buf[256];
|
|
|
|
struct in_addr addr;
|
2002-04-30 22:22:54 +00:00
|
|
|
gethostname(buf, 256);
|
|
|
|
struct hostent* he = gethostbyname(buf);
|
|
|
|
memcpy(&addr, he->h_addr_list[0], sizeof(addr));
|
|
|
|
p = addr.s_addr;
|
2002-07-03 22:59:40 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Returns the name of the local host
|
|
|
|
// TODO: Should the 256 be MAXHOSTNAMELEN instead?
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
int get_local_ip_addr_str(char* p) {
|
2002-07-22 23:07:14 +00:00
|
|
|
strcpy( p,"" );
|
2002-07-03 22:59:40 +00:00
|
|
|
#if HAVE_NETDB_H
|
2002-08-14 23:02:32 +00:00
|
|
|
char buf[256];
|
2002-04-30 22:22:54 +00:00
|
|
|
struct in_addr addr;
|
|
|
|
gethostname(buf, 256);
|
|
|
|
struct hostent* he = gethostbyname(buf);
|
|
|
|
memcpy(&addr, he->h_addr_list[0], sizeof(addr));
|
|
|
|
strcpy(p, inet_ntoa(addr));
|
2002-07-03 22:59:40 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Converts a int ip address to a string representation (i.e. "66.218.71.198")
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
char* ip_addr_string(int ip_addr) {
|
|
|
|
in_addr ia;
|
|
|
|
|
|
|
|
ia.s_addr = ip_addr;
|
|
|
|
return inet_ntoa(ia);
|
|
|
|
}
|
|
|
|
|
2002-07-18 21:14:32 +00:00
|
|
|
// Returns the number of seconds difference from UTC
|
2002-07-15 23:21:20 +00:00
|
|
|
//
|
2002-07-18 21:14:32 +00:00
|
|
|
int get_timezone( void ) {
|
2002-07-18 21:21:37 +00:00
|
|
|
tzset();
|
2002-07-18 23:05:34 +00:00
|
|
|
// TODO: get this to work on all platforms
|
2002-07-18 21:21:37 +00:00
|
|
|
// TODO: take daylight savings time into account
|
2002-07-18 23:05:34 +00:00
|
|
|
#ifdef HAVE_GMTOFF
|
|
|
|
//time_t cur_time;
|
|
|
|
//struct tm *time_data;
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2002-07-18 23:05:34 +00:00
|
|
|
//cur_time = time(NULL);
|
|
|
|
//time_data = localtime( &cur_time );
|
|
|
|
//return time_data->tm_gmtoff;
|
2002-07-18 21:30:17 +00:00
|
|
|
#else
|
|
|
|
#ifdef __timezone
|
2002-07-18 23:05:34 +00:00
|
|
|
//return __timezone;
|
2002-07-18 21:30:17 +00:00
|
|
|
#else
|
2002-07-18 23:05:34 +00:00
|
|
|
//return timezone;
|
2002-07-18 21:30:17 +00:00
|
|
|
#endif
|
2002-07-18 21:21:37 +00:00
|
|
|
#endif
|
2002-07-18 23:05:34 +00:00
|
|
|
return 0;
|
2002-04-30 22:22:54 +00:00
|
|
|
}
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Returns true if the host is currently running off battery power
|
|
|
|
// TODO: port this to other platforms (Windows, Mac OS X, others?)
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
bool host_is_running_on_batteries() {
|
|
|
|
float x1, x2;
|
|
|
|
int i1, i2;
|
|
|
|
|
|
|
|
// the following only works on Linux.
|
|
|
|
// Need to find something else for other systems
|
|
|
|
//
|
|
|
|
FILE* f = fopen("/proc/apm", "r");
|
|
|
|
|
|
|
|
if (!f) return false;
|
|
|
|
|
|
|
|
// Supposedly we're on batteries if the 4th entry is zero.
|
|
|
|
//
|
|
|
|
fscanf(f, "%f %f %x %x", &x1, &x2, &i1, &i2);
|
|
|
|
return (i2 == 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef linux
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// Determine the memory specifications for this host, including RAM and swap space
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
void parse_meminfo(HOST_INFO& host) {
|
|
|
|
char buf[256];
|
|
|
|
FILE* f = fopen("/proc/meminfo", "r");
|
|
|
|
if (!f) return;
|
|
|
|
while (fgets(buf, 256, f)) {
|
|
|
|
if (strstr(buf, "Mem:") == buf) {
|
|
|
|
sscanf(buf, "Mem: %lf", &host.m_nbytes);
|
|
|
|
}
|
|
|
|
if (strstr(buf, "Swap:") == buf) {
|
|
|
|
sscanf(buf, "Swap: %lf", &host.m_swap);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fclose(f);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unfortunately the format of /proc/cpuinfo is not standardized.
|
|
|
|
// See http://people.nl.linux.org/~hch/cpuinfo/ for some examples.
|
|
|
|
// The following is for Redhat Linux 2.2.14.
|
2002-07-15 23:21:20 +00:00
|
|
|
// TODO: get this to work on all platforms
|
2002-04-30 22:22:54 +00:00
|
|
|
void parse_cpuinfo(HOST_INFO& host) {
|
|
|
|
char buf[256];
|
|
|
|
int n;
|
|
|
|
|
|
|
|
FILE* f = fopen("/proc/cpuinfo", "r");
|
|
|
|
if (!f) return;
|
|
|
|
host.p_ncpus = 1;
|
|
|
|
while (fgets(buf, 256, f)) {
|
|
|
|
if (strstr(buf, "vendor_id\t: ") == buf) {
|
|
|
|
sscanf(buf, "vendor_id\t: %s", host.p_vendor);
|
|
|
|
}
|
|
|
|
if (strstr(buf, "model name\t: ") == buf) {
|
|
|
|
sscanf(buf, "model name\t: %s", host.p_model);
|
|
|
|
}
|
|
|
|
if (strstr(buf, "cache size\t: ") == buf) {
|
|
|
|
sscanf(buf, "cache size\t: %d", &n);
|
|
|
|
host.m_cache = n*1024;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fclose(f);
|
|
|
|
}
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
|
2002-07-03 22:37:24 +00:00
|
|
|
#if HAVE_SYS_UTSNAME_H
|
2002-07-15 23:21:20 +00:00
|
|
|
// Puts the operating system name and version into the HOST_INFO structure
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
void get_osinfo(HOST_INFO& host) {
|
|
|
|
struct utsname u;
|
|
|
|
uname(&u);
|
|
|
|
strcpy(host.os_name, u.sysname);
|
|
|
|
strcpy(host.os_version, u.release);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2002-07-22 23:07:14 +00:00
|
|
|
int get_host_info2(HOST_INFO &host);
|
|
|
|
|
2002-07-15 23:21:20 +00:00
|
|
|
// General function to get all relevant host information
|
|
|
|
//
|
2002-04-30 22:22:54 +00:00
|
|
|
int get_host_info(HOST_INFO& host) {
|
2002-08-07 22:52:10 +00:00
|
|
|
host.timezone = 0; // seconds added to local time to get UTC
|
2002-07-22 23:07:14 +00:00
|
|
|
strcpy(host.domain_name,"");
|
|
|
|
strcpy(host.serialnum,"");
|
|
|
|
strcpy(host.ip_addr,"");
|
|
|
|
|
|
|
|
host.on_frac = 0;
|
|
|
|
host.conn_frac = 0;
|
|
|
|
host.active_frac = 0;
|
|
|
|
|
|
|
|
host.p_ncpus = 0;
|
|
|
|
strcpy(host.p_vendor,"");
|
|
|
|
strcpy(host.p_model,"");
|
|
|
|
host.p_fpops = 0;
|
|
|
|
host.p_iops = 0;
|
|
|
|
host.p_membw = 0;
|
|
|
|
host.p_calculated = 0;
|
|
|
|
|
|
|
|
strcpy(host.os_name,"");
|
|
|
|
strcpy(host.os_version,"");
|
|
|
|
|
2002-06-27 23:33:23 +00:00
|
|
|
host.m_nbytes = 0;
|
|
|
|
host.m_cache = 0;
|
2002-07-01 18:16:31 +00:00
|
|
|
host.m_swap = 0;
|
2002-07-22 23:07:14 +00:00
|
|
|
|
|
|
|
host.d_total = 0;
|
|
|
|
host.d_free = 0;
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
return get_host_info2( host );
|
|
|
|
#endif
|
|
|
|
|
2002-07-03 22:37:24 +00:00
|
|
|
#if HAVE_SYS_SYSTEMINFO_H
|
2002-04-30 22:22:54 +00:00
|
|
|
struct statvfs foo;
|
2002-07-01 18:16:31 +00:00
|
|
|
char buf[256];
|
2002-06-06 18:50:12 +00:00
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
memset(&host, 0, sizeof(host));
|
2002-06-06 18:50:12 +00:00
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
get_local_domain_name(host.domain_name);
|
|
|
|
get_local_ip_addr_str(host.ip_addr);
|
2002-06-06 18:50:12 +00:00
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
statvfs(".", &foo);
|
|
|
|
host.d_total = (double)foo.f_bsize * (double)foo.f_blocks;
|
|
|
|
host.d_free = (double)foo.f_bsize * (double)foo.f_bavail;
|
|
|
|
|
|
|
|
int i, n;
|
|
|
|
sysinfo(SI_SYSNAME, host.os_name, sizeof(host.os_name));
|
|
|
|
sysinfo(SI_RELEASE, host.os_version, sizeof(host.os_version));
|
|
|
|
sysinfo(SI_HW_SERIAL, host.serialnum, sizeof(host.serialnum));
|
|
|
|
host.p_ncpus = sysconf(_SC_NPROCESSORS_ONLN);
|
|
|
|
host.m_nbytes = (double)sysconf(_SC_PAGESIZE)
|
|
|
|
* (double)sysconf(_SC_PHYS_PAGES);
|
|
|
|
|
|
|
|
swaptbl_t* s;
|
|
|
|
n = swapctl(SC_GETNSWP, 0);
|
|
|
|
s = (swaptbl_t*)malloc(n*sizeof(swapent_t) + sizeof(struct swaptable));
|
|
|
|
for (i=0; i<n; i++) {
|
|
|
|
s->swt_ent[i].ste_path = buf;
|
|
|
|
}
|
|
|
|
s->swt_n = n;
|
|
|
|
n = swapctl(SC_LIST, s);
|
|
|
|
for (i=0; i<n; i++) {
|
|
|
|
host.m_swap += 512.*(double)s->swt_ent[i].ste_length;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef linux
|
2002-07-05 19:20:00 +00:00
|
|
|
memset(&host, 0, sizeof(host));
|
2002-04-30 22:22:54 +00:00
|
|
|
parse_cpuinfo(host);
|
|
|
|
parse_meminfo(host);
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
2002-07-05 19:20:00 +00:00
|
|
|
get_local_domain_name(host.domain_name);
|
2002-07-05 22:01:12 +00:00
|
|
|
get_local_ip_addr_str(host.ip_addr);
|
2002-07-18 21:14:32 +00:00
|
|
|
host.timezone = get_timezone();
|
2002-07-03 22:37:24 +00:00
|
|
|
#ifdef HAVE_SYS_UTSNAME_H
|
2002-04-30 22:22:54 +00:00
|
|
|
get_osinfo(host);
|
2002-06-06 22:39:21 +00:00
|
|
|
#endif
|
2002-04-30 22:22:54 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2002-06-06 22:39:21 +00:00
|
|
|
|
|
|
|
|