-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathos.h
146 lines (111 loc) · 5.19 KB
/
os.h
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
// Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
#ifndef RUNTIME_VM_OS_H_
#define RUNTIME_VM_OS_H_
#include "vm/globals.h"
// Forward declarations.
struct tm;
namespace dart {
// Forward declarations.
class Zone;
// Interface to the underlying OS platform.
class OS {
public:
// Returns the name of the given OS. For example "linux".
static const char* Name() { return kHostOperatingSystemName; }
// Returns the current process id.
static intptr_t ProcessId();
// Returns a time-zone name for the given instant.
// The name is provided by the underlying platform.
// The returned string may be Zone allocated.
static const char* GetTimeZoneName(int64_t seconds_since_epoch);
// Returns the difference in seconds between local time and UTC for the given
// instant.
// For example 3600 for CET, and 7200 for CEST.
static int GetTimeZoneOffsetInSeconds(int64_t seconds_since_epoch);
// Returns the current time in milliseconds measured
// from midnight January 1, 1970 UTC.
static int64_t GetCurrentTimeMillis();
// Returns the current time in microseconds measured
// from midnight January 1, 1970 UTC.
static int64_t GetCurrentTimeMicros();
// Returns the current time used by the tracing infrastructure.
static int64_t GetCurrentMonotonicMicros();
// Returns the raw clock value from the monotonic clock.
static int64_t GetCurrentMonotonicTicks();
// Returns the frequency of the monotonic clock.
static int64_t GetCurrentMonotonicFrequency();
// Returns the value of current thread's CPU usage clock in microseconds.
// NOTE: This clock will return different values depending on the calling
// thread. It is only expected to increase in value as the thread uses
// CPU time.
// NOTE: This function will return -1 on OSs that are not supported.
static int64_t GetCurrentThreadCPUMicros();
// If the tracing/timeline configuration on takes timestamps as input, returns
// the same value as |GetCurrentMonotonicMicros|. Otherwise, returns -1.
static int64_t GetCurrentMonotonicMicrosForTimeline();
// Returns the activation frame alignment constraint or one if
// the platform doesn't care. Guaranteed to be a power of two.
static intptr_t ActivationFrameAlignment();
// Returns number of available processor cores.
static int NumberOfAvailableProcessors();
// Sleep the currently executing thread for millis ms.
static void Sleep(int64_t millis);
// Sleep the currently executing thread for micros microseconds.
static void SleepMicros(int64_t micros);
// Debug break.
static void DebugBreak();
// Returns the current program counter.
static uintptr_t GetProgramCounter();
// Print formatted output to stdout/stderr for debugging.
// Tracing and debugging prints from the VM should strongly prefer to use
// PrintErr to avoid interfering with the application's output, which may
// be parsed by another program.
static void Print(const char* format, ...) PRINTF_ATTRIBUTE(1, 2);
static void PrintErr(const char* format, ...) PRINTF_ATTRIBUTE(1, 2);
static void VFPrint(FILE* stream, const char* format, va_list args);
// Allocate a string and print formatted output into the buffer.
// Uses the zone for allocation if one if provided, and otherwise uses
// malloc.
static char* SCreate(Zone* zone, const char* format, ...)
PRINTF_ATTRIBUTE(2, 3);
static char* VSCreate(Zone* zone, const char* format, va_list args);
// Converts a C string which represents a valid dart integer into a 64 bit
// value.
// Returns false if it is unable to convert the string to a 64 bit value,
// the failure could be because of underflow/overflow or invalid characters.
// On success the function returns true and 'value' contains the converted
// value.
static bool StringToInt64(const char* str, int64_t* value);
// Register code observers relevant to this OS.
static void RegisterCodeObservers();
// Initialize the OS class.
static void Init();
// Cleanup the OS class.
static void Cleanup();
// Only implemented on Windows, prevents cleanup code from running.
static void PrepareToAbort();
DART_NORETURN static void Abort();
DART_NORETURN static void Exit(int code);
// Retrieves the DSO base for the given instructions image.
static const uint8_t* GetAppDSOBase(const uint8_t* snapshot_instructions);
static uword GetAppDSOBase(uword snapshot_instructions) {
return reinterpret_cast<uword>(
GetAppDSOBase(reinterpret_cast<const uint8_t*>(snapshot_instructions)));
}
struct BuildId {
intptr_t len;
const uint8_t* data;
};
// Retrieves the build ID information for the given instructions image.
// If found, returns a BuildId with the length of the build ID and a pointer
// to its contents, otherwise returns a BuildId with contents {0, nullptr}.
static BuildId GetAppBuildId(const uint8_t* snapshot_instructions);
static BuildId GetAppBuildId(uword snapshot_instructions) {
return GetAppBuildId(
reinterpret_cast<const uint8_t*>(snapshot_instructions));
}
};
} // namespace dart
#endif // RUNTIME_VM_OS_H_