1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/*************************************************
* Exim - an Internet mail transport agent *
*************************************************/
/* See the file NOTICE for conditions of use and distribution. */
/* GNU-specific code. This is concatenated onto the generic src/os.c file.
GNU/Hurd has approximately the same way to determine the load average as NeXT,
so a variant of this could also be in the generic os.c file. See the GNU EMacs
getloadavg.c file, from which this snippet was derived. getloadavg.c from Emacs
is copyrighted by the FSF under the terms of the GPLv2 or any later version.
Changes are hereby placed under the same license, as requested by the GPL. */
#ifndef OS_LOAD_AVERAGE
#define OS_LOAD_AVERAGE
#include <mach.h>
static processor_set_t default_set;
static int getloadavg_initialized;
int
os_getloadavg (void)
{
host_t host;
struct processor_set_basic_info info;
unsigned info_count;
if (!getloadavg_initialized)
{
if (processor_set_default (mach_host_self(), &default_set) == KERN_SUCCESS)
getloadavg_initialized = 1;
}
if (getloadavg_initialized)
{
info_count = PROCESSOR_SET_BASIC_INFO_COUNT;
if (processor_set_info(default_set, PROCESSOR_SET_BASIC_INFO, &host,
(processor_set_info_t)&info, &info_count) != KERN_SUCCESS)
getloadavg_initialized = 0;
else
{
#if LOAD_SCALE == 1000
return info.load_average;
#else
return (int) (((double) info.load_average * 1000) / LOAD_SCALE));
#endif
}
}
return -1;
}
#endif /* OS_LOAD_AVERAGE */
ssize_t
os_pipe_read(int fd, void * buf, size_t count)
{
int rc;
for (int retries = 10; retries > 0; retries--)
{
if ((rc = read(fd, buf, count)) >= 0) break;
if (rc != -1 || errno != EINTR) break;
}
return rc;
}
ssize_t
os_pipe_write(int fd, void * buf, size_t count)
{
int rc;
for (int retries = 10; retries > 0; retries--)
{
if ((rc = write(fd, buf, count)) >= 0) break;
if (rc != -1 || errno != EINTR) break;
}
return rc;
}
ssize_t
os_pipe_writev(int fd, const struct iovec * iov, int iovcnt)
{
int rc;
for (int retries = 10; retries > 0; retries--)
{
if ((rc = writev(fd, iov, iovcnt)) >= 0) break;
if (rc != -1 || errno != EINTR) break;
}
return rc;
}
/* End of os.c-GNU */
|