Files
vortex/runtime/include/vx_intrinsics.h
2020-06-27 14:13:13 -04:00

64 lines
1.1 KiB
C

#ifndef VX_INTRINSICS_H
#define VX_INTRINSICS_H
#ifdef __cplusplus
extern "C" {
#endif
// Spawn warps
void vx_wspawn(int num_warps, unsigned func_ptr);
// Set thread mask
void vx_tmc(int num_threads);
// Warp Barrier
void vx_barrier(int barried_id, int num_warps);
// Split on a predicate
void vx_split(int predicate);
// Join
void vx_join();
// Return the warp's unique thread id
int vx_thread_id();
// Return the core's unique warp id
int vx_warp_id();
// Return processsor unique core id
int vx_core_id();
// Return processsor global thread id
int vx_thread_gid();
// Return processsor global warp id
int vx_warp_gid();
// Return the number of threads in a warp
int vx_num_threads();
// Return the number of warps in a core
int vx_num_warps();
// Return the number of cores in the processsor
int vx_num_cores();
// Return the number of cycles
int vx_num_cycles();
// Return the number of instructions
int vx_num_instrs();
#define __if(b) vx_split(b); \
if (b)
#define __else else
#define __endif vx_join();
#ifdef __cplusplus
}
#endif
#endif