/*
* Copyright 2016 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can
* be found in the LICENSE file.
*
*/
#pragma once
//
//
//
#include <CL/opencl.h>
#include <stdint.h>
#include <stdbool.h>
//
//
//
#include "hs_cl_target.h"
//
//
//
struct hs_cl *
hs_cl_create(struct hs_cl_target const * const target,
cl_context context,
cl_device_id device_id);
//
//
//
void
hs_cl_release(struct hs_cl * const hs);
//
// Determine what padding will be applied to the input and output
// buffers.
//
// Always check to see if the allocated buffers are large enough.
//
// count : number of keys
// count + count_padded_in : additional keys required for sorting
// count + count_padded_out : additional keys required for merging
//
void
hs_cl_pad(struct hs_cl const * const hs,
uint32_t const count,
uint32_t * const count_padded_in,
uint32_t * const count_padded_out);
//
// Sort the keys in the vin buffer and store them in the vout buffer.
//
// If vout is NULL then the sort will be performed in place.
//
// The implementation assumes the command queue is out-of-order.
//
void
hs_cl_sort(struct hs_cl const * const hs,
cl_command_queue cq,
uint32_t const wait_list_size,
cl_event * wait_list,
cl_event * event,
cl_mem vin,
cl_mem vout,
uint32_t const count,
uint32_t const count_padded_in,
uint32_t const count_padded_out,
bool const linearize);
//
//
//