ccubes-cl/clccubes.h

66 lines
1.2 KiB
C
Raw Normal View History

2025-03-20 19:32:25 +02:00
#ifndef CLccubes_H__
#define CLccubes_H__
2025-03-26 11:35:52 +02:00
#include <stdbool.h>
2025-03-20 19:32:25 +02:00
#include "cl_setup.h"
#ifndef _MSC_VER
#include <stdint.h>
#else
#include <stdint_msvc.h>
#endif
#define ROW_DIM 0
#define COL_DIM 1
struct ccubes_context {
struct cl_uctx *clctx;
2025-03-21 18:52:41 +02:00
cl_program ccubes_program;
2025-03-20 19:32:25 +02:00
cl_kernel ccubes_task;
/* internal memory sizes */
int k;
int ninputs;
int posrows;
int negrows;
int implicant_words;
int value_bit_width;
int pichart_words;
/* INPUTS */
cl_mem nofvalues;
cl_mem ON_set;
cl_mem OFF_set;
cl_mem p_implicants_pos;
cl_mem p_implicants_val;
cl_mem last_index;
cl_mem p_covered;
cl_mem p_pichart_pos;
/* OUTPUTS */
cl_mem coverage;
cl_mem fixed_bits;
cl_mem value_bits;
cl_mem pichart_values;
/* Host outputs */
bool *h_coverage;
unsigned int *h_fixed_bits;
unsigned int *h_value_bits;
unsigned int *h_pichart_values;
/* ND-Range */
size_t gws; /* global work size */
2025-03-20 19:32:25 +02:00
};
2025-03-21 18:52:41 +02:00
int ccubes(void);
2025-03-20 19:32:25 +02:00
int
clccubes(struct ccubes_context *ccubesctx, cl_mem alpha0, cl_mem G, size_t signals,
size_t atoms, uint32_t sparsity, uint32_t pcoding, cl_mem gamma, cl_uint
num_events_in_wait_list, const cl_event *event_wait_list, cl_event *ev_ccubes);
#endif