175 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			175 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Copyright (c) 2021-2022 Barcelona Supercomputing Center (BSC)
 | 
						|
 * SPDX-License-Identifier: MIT */
 | 
						|
 | 
						|
#ifndef OVNI_H
 | 
						|
#define OVNI_H
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
#include <limits.h>
 | 
						|
#include <linux/limits.h>
 | 
						|
#include <stdint.h>
 | 
						|
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <string.h>
 | 
						|
#include <sys/types.h>
 | 
						|
 | 
						|
/* Hardcode the JSON_Value to avoid a dependency with janson */
 | 
						|
typedef struct json_value_t JSON_Value;
 | 
						|
 | 
						|
#define OVNI_METADATA_VERSION 1
 | 
						|
 | 
						|
#define OVNI_TRACEDIR "ovni"
 | 
						|
#define OVNI_MAX_HOSTNAME 512
 | 
						|
 | 
						|
/* Reserved buffer for event allocation per thread */
 | 
						|
#define OVNI_MAX_EV_BUF (2 * 1024LL * 1024LL) /* 2 MiB */
 | 
						|
 | 
						|
#define OVNI_STREAM_MAGIC "ovni"
 | 
						|
#define OVNI_STREAM_VERSION 1
 | 
						|
#define OVNI_MODEL_VERSION "O1 V1 T1 M1 D1 K1 61"
 | 
						|
 | 
						|
#define OVNI_STREAM_EXT ".obs"
 | 
						|
 | 
						|
/* Follow https://semver.org rules for versioning */
 | 
						|
#define OVNI_LIB_VERSION "1.0.0"
 | 
						|
 | 
						|
/* ----------------------- common ------------------------ */
 | 
						|
 | 
						|
enum ovni_ev_flags {
 | 
						|
	OVNI_EV_JUMBO = 0x10,
 | 
						|
};
 | 
						|
 | 
						|
struct __attribute__((__packed__)) ovni_jumbo_payload {
 | 
						|
	uint32_t size;
 | 
						|
	uint8_t data[1];
 | 
						|
};
 | 
						|
 | 
						|
union __attribute__((__packed__)) ovni_ev_payload {
 | 
						|
	int8_t i8[16];
 | 
						|
	int16_t i16[8];
 | 
						|
	int32_t i32[4];
 | 
						|
	int64_t i64[2];
 | 
						|
 | 
						|
	uint8_t u8[16];
 | 
						|
	uint16_t u16[8];
 | 
						|
	uint32_t u32[4];
 | 
						|
	uint64_t u64[2];
 | 
						|
 | 
						|
	struct ovni_jumbo_payload jumbo;
 | 
						|
};
 | 
						|
 | 
						|
struct __attribute__((__packed__)) ovni_ev_header {
 | 
						|
	/* first 4 bits reserved, last 4 for payload size */
 | 
						|
	uint8_t flags;
 | 
						|
	uint8_t model;
 | 
						|
	uint8_t category;
 | 
						|
	uint8_t value;
 | 
						|
	uint64_t clock;
 | 
						|
};
 | 
						|
 | 
						|
struct __attribute__((__packed__)) ovni_ev {
 | 
						|
	struct ovni_ev_header header;
 | 
						|
 | 
						|
	/* The payload size may vary depending on the ev type:
 | 
						|
	 *   - normal: 0, or 2 to 16 bytes
 | 
						|
	 *   - jumbo: 0 to 2^32 - 1 bytes */
 | 
						|
	union ovni_ev_payload payload;
 | 
						|
};
 | 
						|
 | 
						|
struct __attribute__((__packed__)) ovni_stream_header {
 | 
						|
	char magic[4];
 | 
						|
	uint32_t version;
 | 
						|
};
 | 
						|
 | 
						|
/* ----------------------- runtime ------------------------ */
 | 
						|
 | 
						|
/* State of each thread on runtime */
 | 
						|
struct ovni_rthread {
 | 
						|
	/* Current thread id */
 | 
						|
	pid_t tid;
 | 
						|
 | 
						|
	/* Stream trace file descriptor */
 | 
						|
	int streamfd;
 | 
						|
 | 
						|
	int ready;
 | 
						|
 | 
						|
	/* The number of bytes filled with events */
 | 
						|
	size_t evlen;
 | 
						|
 | 
						|
	/* Buffer to write events */
 | 
						|
	uint8_t *evbuf;
 | 
						|
};
 | 
						|
 | 
						|
/* State of each process on runtime */
 | 
						|
struct ovni_rproc {
 | 
						|
	/* Where the process trace is finally copied */
 | 
						|
	char procdir_final[PATH_MAX];
 | 
						|
 | 
						|
	/* Where the process trace is flushed */
 | 
						|
	char procdir[PATH_MAX];
 | 
						|
 | 
						|
	/* If needs to be moved at the end */
 | 
						|
	int move_to_final;
 | 
						|
 | 
						|
	int app;
 | 
						|
	int pid;
 | 
						|
	char loom[OVNI_MAX_HOSTNAME];
 | 
						|
	int ncpus;
 | 
						|
	clockid_t clockid;
 | 
						|
 | 
						|
	int ready;
 | 
						|
 | 
						|
	JSON_Value *meta;
 | 
						|
};
 | 
						|
 | 
						|
#define ovni_version_check() ovni_version_check_str(OVNI_LIB_VERSION)
 | 
						|
void ovni_version_check_str(const char *version);
 | 
						|
 | 
						|
void ovni_proc_init(int app, const char *loom, int pid);
 | 
						|
 | 
						|
/* Sets the MPI rank of the current process and the number of total nranks */
 | 
						|
void ovni_proc_set_rank(int rank, int nranks);
 | 
						|
 | 
						|
void ovni_proc_fini(void);
 | 
						|
 | 
						|
void ovni_thread_init(pid_t tid);
 | 
						|
 | 
						|
void ovni_thread_free(void);
 | 
						|
 | 
						|
int ovni_thread_isready(void);
 | 
						|
 | 
						|
void ovni_ev_set_mcv(struct ovni_ev *ev, const char *mcv);
 | 
						|
 | 
						|
/* Gets the event clock in ns */
 | 
						|
uint64_t ovni_ev_get_clock(const struct ovni_ev *ev);
 | 
						|
 | 
						|
/* Sets the event clock in ns */
 | 
						|
void ovni_ev_set_clock(struct ovni_ev *ev, uint64_t clock);
 | 
						|
 | 
						|
/* Returns the current value of the ovni clock in ns */
 | 
						|
uint64_t ovni_clock_now(void);
 | 
						|
 | 
						|
void ovni_payload_add(struct ovni_ev *ev, const uint8_t *buf, int size);
 | 
						|
 | 
						|
int ovni_ev_size(const struct ovni_ev *ev);
 | 
						|
 | 
						|
int ovni_payload_size(const struct ovni_ev *ev);
 | 
						|
 | 
						|
void ovni_add_cpu(int index, int phyid);
 | 
						|
 | 
						|
/* Adds the event to the events buffer. The buffer is flushed first if the event
 | 
						|
 * doesn't fit in the buffer. */
 | 
						|
void ovni_ev_emit(struct ovni_ev *ev);
 | 
						|
void ovni_ev_jumbo_emit(struct ovni_ev *ev, const uint8_t *buf, uint32_t bufsize);
 | 
						|
 | 
						|
void ovni_flush(void);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 | 
						|
 | 
						|
#endif /* OVNI_H */
 |