14#define HEL_C_LINKAGE extern "C"
27 kHelCallSubmitAsyncNop = 3,
29 kHelCallCreateUniverse = 62,
30 kHelCallTransferDescriptor = 66,
31 kHelCallDescriptorInfo = 32,
32 kHelCallGetCredentials = 84,
33 kHelCallCloseDescriptor = 21,
35 kHelCallCreateQueue = 89,
36 kHelCallDriveQueue = 105,
37 kHelCallAlertQueue = 106,
39 kHelCallAllocateMemory = 51,
40 kHelCallResizeMemory = 83,
41 kHelCallCreateManagedMemory = 64,
42 kHelCallCopyOnWrite = 39,
43 kHelCallAccessPhysical = 30,
44 kHelCallCreateSliceView = 88,
45 kHelCallForkMemory = 40,
46 kHelCallCreateSpace = 27,
47 kHelCallCreateIndirectMemory = 45,
48 kHelCallAlterMemoryIndirection = 52,
49 kHelCallMapMemory = 44,
50 kHelCallSubmitProtectMemory = 99,
51 kHelCallSubmitSynchronizeSpace = 53,
52 kHelCallUnmapMemory = 36,
53 kHelCallPointerPhysical = 43,
54 kHelCallSubmitReadMemory = 77,
55 kHelCallSubmitWriteMemory = 78,
56 kHelCallMemoryInfo = 26,
57 kHelCallSubmitManageMemory = 46,
58 kHelCallUpdateMemory = 47,
59 kHelCallSubmitLockMemoryView = 48,
60 kHelCallLoadahead = 49,
61 kHelCallCreateVirtualizedSpace = 50,
63 kHelCallCreateThread = 67,
64 kHelCallQueryThreadStats = 95,
65 kHelCallSetPriority = 85,
67 kHelCallSubmitObserve = 74,
68 kHelCallKillThread = 87,
69 kHelCallInterruptThread = 86,
71 kHelCallLoadRegisters = 75,
72 kHelCallStoreRegisters = 76,
73 kHelCallQueryRegisterInfo = 102,
74 kHelCallWriteFsBase = 41,
75 kHelCallGetClock = 42,
76 kHelCallSubmitAwaitClock = 80,
77 kHelCallCreateVirtualizedCpu = 37,
78 kHelCallRunVirtualizedCpu = 38,
79 kHelCallGetRandomBytes = 101,
80 kHelCallWriteGsBase = 54,
81 kHelCallReadFsBase = 55,
82 kHelCallReadGsBase = 56,
83 kHelCallGetCurrentCpu = 57,
85 kHelCallCreateStream = 68,
86 kHelCallSubmitAsync = 79,
87 kHelCallShutdownLane = 91,
89 kHelCallFutexWait = 73,
90 kHelCallFutexWake = 71,
92 kHelCallCreateOneshotEvent = 96,
93 kHelCallCreateBitsetEvent = 97,
94 kHelCallRaiseEvent = 98,
95 kHelCallAccessIrq = 14,
96 kHelCallAcknowledgeIrq = 81,
97 kHelCallSubmitAwaitEvent = 82,
98 kHelCallAutomateIrq = 94,
100 kHelCallAccessIo = 11,
101 kHelCallEnableIo = 12,
102 kHelCallEnableFullIo = 35,
104 kHelCallBindKernlet = 93,
106 kHelCallGetAffinity = 103,
107 kHelCallSetAffinity = 100,
109 kHelCallCreateToken = 104,
111 kHelCallSuper = 0x80000000
116 kHelErrBufferTooSmall = 1,
117 kHelErrBadDescriptor = 2,
119 kHelErrNoDescriptor = 4,
120 kHelErrIllegalSyscall = 5,
121 kHelErrIllegalObject = 6,
122 kHelErrIllegalArgs = 7,
123 kHelErrLaneShutdown = 8,
124 kHelErrEndOfLane = 9,
126 kHelErrThreadTerminated = 11,
127 kHelErrCancelled = 12,
128 kHelErrTransmissionMismatch = 13,
129 kHelErrQueueTooSmall = 14,
130 kHelErrIllegalState = 15,
131 kHelErrNoHardwareSupport = 16,
132 kHelErrNoMemory = 17,
133 kHelErrUnsupportedOperation = 18,
134 kHelErrOutOfBounds = 19,
135 kHelErrDismissed = 20,
136 kHelErrRemoteFault = 21,
137 kHelErrAlreadyExists = 22,
138 kHelErrBadPermissions = 23,
140 kHelErrFutexRace = 25
143struct HelX86SegmentRegister {
147 uint8_t type, present, dpl, db, s, l, g, avl;
150struct HelX86DescriptorTable {
155struct HelX86VirtualizationRegs {
176 struct HelX86SegmentRegister cs, ds, es, fs, gs, ss;
177 struct HelX86SegmentRegister tr, ldt;
178 struct HelX86DescriptorTable gdt, idt;
180 uint64_t cr0, cr2, cr3, cr4, cr8;
187 kHelThisUniverse = -1,
193 kHelWaitInfinite = -1
202 kHelActionDismiss = 11,
204 kHelActionAccept = 6,
205 kHelActionImbueCredentials = 8,
206 kHelActionExtractCredentials = 9,
207 kHelActionSendFromBuffer = 1,
208 kHelActionSendFromBufferSg = 10,
209 kHelActionRecvInline = 7,
210 kHelActionRecvToBuffer = 3,
211 kHelActionPushDescriptor = 2,
212 kHelActionPullDescriptor = 4
217 kHelItemAncillary = 2,
218 kHelItemWantLane = (1 << 16),
221enum HelTransferDescriptorFlags {
222 kHelTransferDescriptorOut,
223 kHelTransferDescriptorIn,
240struct HelDescriptorInfo {
245 kHelAllocContinuous = 4,
246 kHelAllocOnDemand = 1,
249struct HelAllocRestrictions {
253enum HelManagedFlags {
254 kHelManagedReadahead = 1
257enum HelManageRequests {
258 kHelManageInitialize = 1,
259 kHelManageWriteback = 2
264 kHelMapProtRead = 256,
265 kHelMapProtWrite = 512,
266 kHelMapProtExecute = 1024,
267 kHelMapDontRequireBacking = 128,
269 kHelMapFixedNoReplace = 4096,
270 kHelMapPreferBottom = 8192
274 kHelSliceCacheWriteCombine = 1,
278 kHelThreadStopped = 1
283 kHelObserveInterrupt = 4,
284 kHelObservePanic = 3,
285 kHelObserveBreakpoint = 1,
286 kHelObservePageFault = 2,
287 kHelObserveGeneralFault = 5,
288 kHelObserveIllegalInstruction = 6,
289 kHelObserveDivByZero = 7,
290 kHelObserveSuperCall = 0x80000000
293enum HelRegisterSets {
298 kHelRegsVirtualization = 5,
301 kHelRegsPageFault = 8
304enum HelPageFaultFlags {
305 kHelPageFaultMapError = 1,
306 kHelPageFaultAccessError = 2
315#if defined(__x86_64__)
316enum HelRegisterIndex {
340 kHelRegNumber = kHelRegRdi,
341 kHelRegError = kHelRegRdi,
343 kHelRegArg0 = kHelRegRsi,
344 kHelRegArg1 = kHelRegRdx,
345 kHelRegArg2 = kHelRegRax,
346 kHelRegArg3 = kHelRegR8,
347 kHelRegArg4 = kHelRegR9,
348 kHelRegArg5 = kHelRegR10,
349 kHelRegArg6 = kHelRegR12,
350 kHelRegArg7 = kHelRegR13,
351 kHelRegArg8 = kHelRegR14,
353 kHelRegOut0 = kHelRegRsi,
354 kHelRegOut1 = kHelRegRdx,
355 kHelRegOut2 = kHelRegRax
358#elif defined(__aarch64__)
359enum HelRegisterIndex {
399 kHelRegNumber = kHelRegX0,
400 kHelRegError = kHelRegX0,
402 kHelRegArg0 = kHelRegX1,
403 kHelRegArg1 = kHelRegX2,
404 kHelRegArg2 = kHelRegX3,
405 kHelRegArg3 = kHelRegX4,
406 kHelRegArg4 = kHelRegX5,
407 kHelRegArg5 = kHelRegX6,
408 kHelRegArg6 = kHelRegX7,
409 kHelRegArg7 = kHelRegX8,
410 kHelRegArg8 = kHelRegX9,
412 kHelRegOut0 = kHelRegX1,
413 kHelRegOut1 = kHelRegX2,
414 kHelRegOut2 = kHelRegX3
417#elif defined(__riscv) && __riscv_xlen == 64
418enum HelRegisterIndex {
454 kHelRegNumber = kHelRegA0,
455 kHelRegError = kHelRegA0,
456 kHelRegArg0 = kHelRegA1,
457 kHelRegArg1 = kHelRegA2,
458 kHelRegArg2 = kHelRegA3,
459 kHelRegArg3 = kHelRegA4,
460 kHelRegArg4 = kHelRegA5,
461 kHelRegArg5 = kHelRegA6,
462 kHelRegArg6 = kHelRegA7,
463 kHelRegArg7 = kHelRegS2,
464 kHelRegArg8 = kHelRegS3,
466 kHelRegOut0 = kHelRegA1,
467 kHelRegOut1 = kHelRegA2,
468 kHelRegOut2 = kHelRegA3
473struct HelQueueParameters {
475 unsigned int numChunks;
477 unsigned int numSqChunks;
587 uint64_t cancellationTag;
731struct HelSimpleResult {
736struct HelCredentialsResult {
739 char credentials[16];
742struct HelManageResult {
749struct HelObserveResult {
751 unsigned int observation;
754struct HelInlineResult {
761struct HelInlineResultNoFlex {
767struct HelLengthResult {
773struct HelHandleResult {
779struct HelEventResult {
786 kHelAckAcknowledge = 2,
789 kHelAckClear = 0x100,
792union HelKernletData {
796struct HelThreadStats {
802 kHelVmexitTranslationFault = 1,
803 kHelVmexitError = -1,
804 kHelVmexitUnknownPlatformSpecificExitCode = -2,
807struct HelVmexitReason {
816 kHelLogSeverityEmergency,
817 kHelLogSeverityAlert,
818 kHelLogSeverityCritical,
819 kHelLogSeverityError,
820 kHelLogSeverityWarning,
821 kHelLogSeverityNotice,
823 kHelLogSeverityDebug,
836HEL_C_LINKAGE HelError
helLog(
const enum HelLogSeverity severity,
const char *
string,
size_t length);
843HEL_C_LINKAGE
void helPanic(
const char *
string,
size_t length)
844 __attribute__ (( noreturn ));
874HEL_C_LINKAGE HelError
876 enum HelTransferDescriptorFlags direction, HelHandle *outHandle);
878HEL_C_LINKAGE HelError helDescriptorInfo(HelHandle handle,
struct HelDescriptorInfo *info);
918HEL_C_LINKAGE HelError
helDriveQueue(HelHandle queueHandle, uint32_t flags, uint32_t notifyMask);
942 const struct HelAllocRestrictions *restrictions, HelHandle *handle);
964 HelHandle *backingHandle, HelHandle *frontalHandle);
977 uintptr_t offset,
size_t size, HelHandle *handle);
979HEL_C_LINKAGE HelError helAccessPhysical(uintptr_t physical,
980 size_t size, HelHandle *handle);
1006 HelHandle memoryHandle, uintptr_t offset,
size_t size);
1008HEL_C_LINKAGE HelError helCreateSliceView(HelHandle bundle, uintptr_t offset,
size_t size,
1009 uint32_t flags, HelHandle *handle);
1042HEL_C_LINKAGE HelError
helMapMemory(HelHandle memoryHandle, HelHandle spaceHandle,
1043 void *pointer, uintptr_t offset,
size_t size, uint32_t flags,
void **actualPointer);
1056HEL_C_LINKAGE HelError
helUnmapMemory(HelHandle spaceHandle,
void *pointer,
size_t size);
1058HEL_C_LINKAGE HelError helPointerPhysical(HelHandle spaceHandle,
const void *pointer, uintptr_t *physical);
1060HEL_C_LINKAGE HelError helMemoryInfo(HelHandle handle,
1063HEL_C_LINKAGE HelError helUpdateMemory(HelHandle handle,
int type, uintptr_t offset,
size_t length);
1075HEL_C_LINKAGE HelError
helLoadahead(HelHandle handle, uintptr_t offset,
size_t length);
1077HEL_C_LINKAGE HelError helCreateVirtualizedSpace(HelHandle *handle);
1097 HelAbi abi,
void *ip,
void *sp, uint32_t flags, HelHandle *handle);
1165HEL_C_LINKAGE HelError helWriteFsBase(
void *pointer);
1167HEL_C_LINKAGE HelError helReadFsBase(
void **pointer);
1169HEL_C_LINKAGE HelError helWriteGsBase(
void *pointer);
1171HEL_C_LINKAGE HelError helReadGsBase(
void **pointer);
1182HEL_C_LINKAGE HelError helCreateVirtualizedCpu(HelHandle handle, HelHandle *out_handle);
1184HEL_C_LINKAGE HelError helRunVirtualizedCpu(HelHandle handle,
struct HelVmexitReason *reason);
1186HEL_C_LINKAGE HelError helGetRandomBytes(
void *buffer,
size_t wantedSize,
size_t *actualSize);
1197HEL_C_LINKAGE HelError
helGetAffinity(HelHandle handle, uint8_t *mask,
size_t size,
size_t *actualSize);
1219HEL_C_LINKAGE HelError
helCreateStream(HelHandle *lane1, HelHandle *lane2, uint32_t attach_credentials);
1221HEL_C_LINKAGE HelError helShutdownLane(HelHandle handle);
1244HEL_C_LINKAGE HelError
helFutexWait(
int *pointer,
int expected, int64_t deadline);
1272HEL_C_LINKAGE HelError helAccessIrq(
int number, HelHandle *handle);
1274HEL_C_LINKAGE HelError helAcknowledgeIrq(HelHandle handle, uint32_t flags, uint64_t sequence);
1276HEL_C_LINKAGE HelError helAutomateIrq(HelHandle handle, uint32_t flags, HelHandle kernlet);
1282HEL_C_LINKAGE HelError helAccessIo(uintptr_t *port_array,
size_t num_ports,
1290HEL_C_LINKAGE HelError helEnableFullIo();
1306 const union HelKernletData *data,
size_t numData, HelHandle *boundHandle);
1310extern inline __attribute__ (( always_inline ))
const char *_helErrorString(HelError code) {
1314 case kHelErrIllegalSyscall:
1315 return "Illegal syscall";
1316 case kHelErrIllegalArgs:
1317 return "Illegal arguments";
1318 case kHelErrIllegalState:
1319 return "Illegal state";
1320 case kHelErrUnsupportedOperation:
1321 return "Unsupported operation";
1322 case kHelErrNoDescriptor:
1323 return "No such descriptor";
1324 case kHelErrBadDescriptor:
1325 return "Illegal descriptor for this operation";
1326 case kHelErrThreadTerminated:
1327 return "Thread terminated already";
1328 case kHelErrLaneShutdown:
1329 return "Lane shutdown";
1330 case kHelErrEndOfLane:
1331 return "End of lane";
1332 case kHelErrDismissed:
1333 return "IPC item dismissed by remote";
1334 case kHelErrBufferTooSmall:
1335 return "Buffer too small";
1336 case kHelErrQueueTooSmall:
1337 return "Buffer too small";
1340 case kHelErrNoHardwareSupport:
1341 return "Missing hardware support for this feature";
1342 case kHelErrNoMemory:
1343 return "Out of memory";
1344 case kHelErrTransmissionMismatch:
1345 return "Transmission mismatch";
1346 case kHelErrCancelled:
1348 case kHelErrOutOfBounds:
1349 return "Out of bounds";
1350 case kHelErrAlreadyExists:
1351 return "Already exists";
1357extern inline __attribute__ (( always_inline ))
void _helCheckFailed(HelError err_code,
1358 const char *
string,
int fatal) {
1359 helLog(kHelLogSeverityError,
string, strlen(
string));
1361 const char *err_string = _helErrorString(err_code);
1363 err_string =
"(Unexpected error code)";
1364 helLog(kHelLogSeverityError, err_string, strlen(err_string));
1365 helLog(kHelLogSeverityError,
"\n", 1);
1371#define HEL_STRINGIFY_AUX(x) #x
1372#define HEL_STRINGIFY(x) HEL_STRINGIFY_AUX(x)
1374#define HEL_CHECK(expr) do { HelError __error = expr; if(__error != kHelErrNone) \
1375 _helCheckFailed(__error, "HEL_CHECK failed: " #expr "\n" \
1376 " In file " __FILE__ " on line " HEL_STRINGIFY(__LINE__) "\n", 1); } while(0)
1377#define HEL_SOFT_CHECK(expr) do { HelError __error = expr; if(__error != kHelErrNone) \
1378 _helCheckFailed(__error, "HEL_SOFT_CHECK failed: " #expr "\n" \
1379 " In file " __FILE__ " on line " HEL_STRINGIFY(__LINE__) "\n", 0); } while(0)
HEL_C_LINKAGE HelError helLog(const enum HelLogSeverity severity, const char *string, size_t length)
Writes a text message (e.g., a line of text) to the kernel's log.
HEL_C_LINKAGE HelError helSetPriority(HelHandle handle, int priority)
Set the priority of a thread.
HEL_C_LINKAGE HelError helYield()
Yields the current thread.
static const int kHelUserNotifyAlert
Set in userNotify when the queue is alerted.
Definition hel.h:487
HEL_C_LINKAGE HelError helTransferDescriptor(HelHandle handle, HelHandle universeHandle, enum HelTransferDescriptorFlags direction, HelHandle *outHandle)
Copies descriptors from the current universe to another universe.
HEL_C_LINKAGE HelError helCloseDescriptor(HelHandle universeHandle, HelHandle handle)
Closes a descriptor.
HEL_C_LINKAGE HelError helQueryRegisterInfo(int set, struct HelRegisterInfo *info)
Query register-related information.
HEL_C_LINKAGE HelError helMapMemory(HelHandle memoryHandle, HelHandle spaceHandle, void *pointer, uintptr_t offset, size_t size, uint32_t flags, void **actualPointer)
Maps memory objects into an address space.
HEL_C_LINKAGE HelError helSetAffinity(HelHandle handle, uint8_t *mask, size_t size)
Set a thread's CPU affinity mask.
static const int kHelKernelNotifySqProgress
Set in kernelNotify after userspace has added SQ elements.
Definition hel.h:490
static const uint32_t kHelSubmitInvalidateMemory
SQ opcode: invalidate memory.
Definition hel.h:528
HEL_C_LINKAGE HelError helQueryThreadStats(HelHandle handle, struct HelThreadStats *stats)
Query run-time statistics of a thread.
HEL_C_LINKAGE HelError helAlterMemoryIndirection(HelHandle indirectHandle, size_t slotIndex, HelHandle memoryHandle, uintptr_t offset, size_t size)
Modifies indirect memory objects.
HEL_C_LINKAGE HelError helCreateBitsetEvent(HelHandle *handle)
Create an event consisting of multiple bits that can fire independently.
HEL_C_LINKAGE HelError helGetCredentials(HelHandle handle, uint32_t flags, char *credentials)
Returns the credentials associated with a given descriptor.
HEL_C_LINKAGE HelError helKillThread(HelHandle handle)
Kill (i.e., terminate) a thread.
static const uint32_t kHelSubmitWriteMemory
SQ opcode: write memory.
Definition hel.h:514
HEL_C_LINKAGE HelError helGetAffinity(HelHandle handle, uint8_t *mask, size_t size, size_t *actualSize)
Get a thread's CPU affinity mask.
static const uint32_t kHelSubmitAsyncNop
SQ opcode: asynchronous no-op (for testing/profiling).
Definition hel.h:500
HEL_C_LINKAGE HelError helGetClock(uint64_t *counter)
Read the system-wide monotone clock.
HEL_C_LINKAGE HelError helLoadahead(HelHandle handle, uintptr_t offset, size_t length)
Notifies the kernel that a certain range of memory should be preloaded.
HEL_C_LINKAGE HelError helLoadRegisters(HelHandle handle, int set, void *image)
Load a register image (e.g., from a thread).
HEL_C_LINKAGE HelError helCopyOnWrite(HelHandle memory, uintptr_t offset, size_t size, HelHandle *handle)
Creates memory object that obtains its memory by copy-on-write from another memory object.
HEL_C_LINKAGE void helPanic(const char *string, size_t length) __attribute__((noreturn))
Kills the current thread and writes an error message to the kernel's log.
HEL_C_LINKAGE HelError helUnmapMemory(HelHandle spaceHandle, void *pointer, size_t size)
Unmaps memory from an address space.
HEL_C_LINKAGE HelError helFutexWake(int *pointer, unsigned int count)
Wakes up all waiters of a futex.
HEL_C_LINKAGE HelError helResizeMemory(HelHandle handle, size_t newSize)
Resizes a memory object.
static const int kHelProgressMask
Mask to extract the number of valid bytes in the chunk.
Definition hel.h:557
static const uint32_t kHelSubmitManageMemory
SQ opcode: manage memory.
Definition hel.h:516
HEL_C_LINKAGE HelError helCreateManagedMemory(size_t size, uint32_t flags, HelHandle *backingHandle, HelHandle *frontalHandle)
Creates a memory object that is managed by userspace.
static const uint32_t kHelSubmitForkMemory
SQ opcode: fork memory.
Definition hel.h:524
HEL_C_LINKAGE HelError helInterruptThread(HelHandle handle)
Interrupt a thread.
static const int kHelProgressFull
Set by the producer once the chunk is full (i.e., no more bytes will be written).
Definition hel.h:561
static const uint32_t kHelSubmitSynchronizeSpace
SQ opcode: synchronize space.
Definition hel.h:510
HEL_C_LINKAGE HelError helRaiseEvent(HelHandle handle)
Raise an event.
static const uint32_t kHelDriveWait
Flag for helDriveQueue: wait until userNotify has any bits not in notifyMask set.
Definition hel.h:495
static const uint32_t kHelSubmitObserve
SQ opcode: observe thread.
Definition hel.h:520
HEL_C_LINKAGE HelError helForkMemory(HelHandle handle, HelHandle *forkedHandle)
Forks memory objects, i.e., copies them using copy-on-write.
HEL_C_LINKAGE HelError helCreateQueue(const struct HelQueueParameters *params, HelHandle *handle)
Creates an IPC queue.
HEL_C_LINKAGE HelError helCreateToken(HelHandle *handle)
Create a token object.
HEL_C_LINKAGE HelError helAllocateMemory(size_t size, uint32_t flags, const struct HelAllocRestrictions *restrictions, HelHandle *handle)
Creates a memory object consisting of unmanaged RAM.
HEL_C_LINKAGE HelError helCreateThread(HelHandle universe, HelHandle spaceHandle, HelAbi abi, void *ip, void *sp, uint32_t flags, HelHandle *handle)
Create a new thread.
HEL_C_LINKAGE HelError helResume(HelHandle handle)
Resume a suspended thread.
static const uint32_t kHelSubmitExchangeMsgs
SQ opcode: exchange messages on a stream.
Definition hel.h:502
static const uint32_t kHelSubmitReadMemory
SQ opcode: read memory.
Definition hel.h:512
static const int kHelNextPresent
Marks the next field as present.
Definition hel.h:554
static const int kHelKernelNotifySupplyCqChunks
Set in kernelNotify after userspace has supplied new chunks.
Definition hel.h:492
HEL_C_LINKAGE HelError helSubmitAsyncNop(HelHandle queueHandle, uintptr_t context)
Does nothing, asynchronously (useful only for profiling).
HEL_C_LINKAGE HelError helStoreRegisters(HelHandle handle, int set, const void *image)
Store a register image (e.g., to a thread).
static const uint32_t kHelSubmitAwaitEvent
SQ opcode: wait for an event.
Definition hel.h:506
static const uint32_t kHelSubmitAwaitClock
SQ opcode: wait for time to pass.
Definition hel.h:504
static const uint32_t kHelSubmitPopulateSpace
SQ opcode: populate a space.
Definition hel.h:530
HEL_C_LINKAGE HelError helAlertQueue(HelHandle queueHandle)
Alerts an IPC queue.
HEL_C_LINKAGE HelError helCreateStream(HelHandle *lane1, HelHandle *lane2, uint32_t attach_credentials)
Create a stream (which always consists of two lanes).
static const uint32_t kHelSubmitProtectMemory
SQ opcode: protect memory.
Definition hel.h:508
static const int kHelUserNotifySupplySqChunks
Set in userNotify after kernel has supplied new SQ chunks.
Definition hel.h:483
HEL_C_LINKAGE HelError helCreateIndirectMemory(size_t numSlots, HelHandle *handle)
Creates a memory object that obtains its memory by delegating to other memory objects.
HEL_C_LINKAGE HelError helGetCurrentCpu(int *cpu)
Gets the index of the cpu which the calling thread is running on.
HEL_C_LINKAGE HelError helNop()
Does nothing (useful only for profiling).
HEL_C_LINKAGE HelError helFutexWait(int *pointer, int expected, int64_t deadline)
Waits on a futex.
HEL_C_LINKAGE HelError helBindKernlet(HelHandle handle, const union HelKernletData *data, size_t numData, HelHandle *boundHandle)
Bind parameters to a kernlet.
static const int kHelUserNotifyCqProgress
Set in userNotify after kernel has written progress.
Definition hel.h:481
HEL_C_LINKAGE HelError helCreateSpace(HelHandle *handle)
Creates a virtual address space that threads can run in.
static const uint32_t kHelSubmitWritebackFence
SQ opcode: writeback fence.
Definition hel.h:526
static const uint32_t kHelSubmitResizeMemory
SQ opcode: resize memory.
Definition hel.h:522
HEL_C_LINKAGE HelError helCreateOneshotEvent(HelHandle *handle)
Create an event that fires at most once.
HEL_C_LINKAGE HelError helDriveQueue(HelHandle queueHandle, uint32_t flags, uint32_t notifyMask)
Drives an IPC queue.
static const uint32_t kHelSubmitLockMemoryView
SQ opcode: lock memory view.
Definition hel.h:518
HEL_C_LINKAGE HelError helCreateUniverse(HelHandle *handle)
Creates a new universe descriptor.
static const int kHelProgressDone
Set by the producer once it retires the chunk.
Definition hel.h:559
HEL_C_LINKAGE HelError helEnableIo(HelHandle handle)
Enable userspace access to hardware I/O resources.
static const int kHelUserNotifyError
Set in userNotify if the queue encounters a contract violation.
Definition hel.h:485
static const uint32_t kHelSubmitCancel
SQ opcode: cancel an asynchronous operation.
Definition hel.h:498
A single element of a HelQueue.
Definition hel.h:576
unsigned int length
Length of the element in bytes.
Definition hel.h:578
void * context
User-defined value.
Definition hel.h:582
unsigned int opcode
Operation code (for SQ elements).
Definition hel.h:580
In-memory kernel/user-space queue.
Definition hel.h:533
int kernelNotify
Futex that is used to wake the kernel.
Definition hel.h:542
int userNotify
Futex that is used to wake userspace.
Definition hel.h:537
int cqFirst
Index of the first chunk of the completion queue.
Definition hel.h:546
int sqFirst
Index of the first chunk of the submission queue.
Definition hel.h:550
Register-related information returned by helQueryRegisterInfo.
Definition hel.h:310
int setSize
Size of the selected register set.
Definition hel.h:312
SQ data for kHelSubmitAwaitClock.
Definition hel.h:602
uint64_t cancellationTag
Tag to cancel this operation.
Definition hel.h:606
uint64_t counter
Deadline in nanoseconds since boot.
Definition hel.h:604
SQ data for kHelSubmitAwaitEvent.
Definition hel.h:610
HelHandle handle
Handle to the event descriptor.
Definition hel.h:612
uint64_t cancellationTag
Tag to cancel this operation.
Definition hel.h:616
uint64_t sequence
Previous sequence number.
Definition hel.h:614
SQ data for kHelSubmitCancel.
Definition hel.h:586
SQ data for kHelSubmitExchangeMsgs.
Definition hel.h:592
uint32_t flags
Flags.
Definition hel.h:598
size_t count
Number of actions.
Definition hel.h:596
HelHandle lane
Handle to the lane.
Definition hel.h:594
SQ data for kHelSubmitForkMemory.
Definition hel.h:696
HelHandle handle
Handle to the memory object.
Definition hel.h:698
SQ data for kHelSubmitInvalidateMemory.
Definition hel.h:712
HelHandle handle
Handle to the memory object.
Definition hel.h:714
size_t size
Size of the range.
Definition hel.h:718
uintptr_t offset
Offset within the memory object.
Definition hel.h:716
SQ data for kHelSubmitLockMemoryView.
Definition hel.h:672
size_t size
Size to lock.
Definition hel.h:678
uintptr_t offset
Offset within the memory object.
Definition hel.h:676
HelHandle handle
Handle to the memory object.
Definition hel.h:674
SQ data for kHelSubmitManageMemory.
Definition hel.h:666
HelHandle handle
Handle to the memory object.
Definition hel.h:668
SQ data for kHelSubmitObserve.
Definition hel.h:682
HelHandle handle
Handle to the thread.
Definition hel.h:684
SQ data for kHelSubmitPopulateSpace.
Definition hel.h:722
HelHandle handle
Handle to the memory space.
Definition hel.h:724
uintptr_t address
Address within the memory space.
Definition hel.h:726
size_t length
Length of the range.
Definition hel.h:728
SQ data for kHelSubmitProtectMemory.
Definition hel.h:620
size_t size
Size of the mapping.
Definition hel.h:626
void * pointer
Pointer to the mapping.
Definition hel.h:624
uint32_t flags
Protection flags.
Definition hel.h:628
HelHandle spaceHandle
Handle to the address space.
Definition hel.h:622
SQ data for kHelSubmitReadMemory.
Definition hel.h:642
uintptr_t address
Address within the memory object.
Definition hel.h:646
HelHandle handle
Handle to the memory object.
Definition hel.h:644
size_t length
Length in bytes.
Definition hel.h:648
void * buffer
Buffer to read into.
Definition hel.h:650
SQ data for kHelSubmitResizeMemory.
Definition hel.h:688
HelHandle handle
Handle to the memory object.
Definition hel.h:690
size_t newSize
New size in bytes.
Definition hel.h:692
SQ data for kHelSubmitSynchronizeSpace.
Definition hel.h:632
void * pointer
Pointer to the mapping.
Definition hel.h:636
size_t size
Size of the mapping.
Definition hel.h:638
HelHandle spaceHandle
Handle to the address space.
Definition hel.h:634
SQ data for kHelSubmitWriteMemory.
Definition hel.h:654
HelHandle handle
Handle to the memory object.
Definition hel.h:656
size_t length
Length in bytes.
Definition hel.h:660
const void * buffer
Buffer to write from.
Definition hel.h:662
uintptr_t address
Address within the memory object.
Definition hel.h:658
SQ data for kHelSubmitWritebackFence.
Definition hel.h:702
HelHandle handle
Handle to the memory object.
Definition hel.h:704
size_t size
Size of the range.
Definition hel.h:708
uintptr_t offset
Offset within the memory object.
Definition hel.h:706