2016-07-13 23:54:47 +08:00
|
|
|
/*
|
|
|
|
* Copyright 2010-2011 INRIA Saclay
|
|
|
|
*
|
|
|
|
* Use of this software is governed by the MIT license
|
|
|
|
*
|
|
|
|
* Written by Sven Verdoolaege, INRIA Saclay - Ile-de-France,
|
|
|
|
* Parc Club Orsay Universite, ZAC des vignes, 4 rue Jacques Monod,
|
|
|
|
* 91893 Orsay, France
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ppcg_options.h"
|
|
|
|
|
|
|
|
static struct isl_arg_choice target[] = {
|
|
|
|
{"c", PPCG_TARGET_C},
|
|
|
|
{"cuda", PPCG_TARGET_CUDA},
|
|
|
|
{"opencl", PPCG_TARGET_OPENCL},
|
|
|
|
{0}
|
|
|
|
};
|
|
|
|
|
2017-07-20 23:48:13 +08:00
|
|
|
/* Set defaults that depend on the target.
|
|
|
|
* In particular, set --schedule-outer-coincidence iff target is a GPU.
|
|
|
|
*/
|
|
|
|
void ppcg_options_set_target_defaults(struct ppcg_options *options)
|
|
|
|
{
|
|
|
|
char *argv[2] = { NULL };
|
|
|
|
|
|
|
|
argv[0] = "ppcg_options_set_target_defaults";
|
|
|
|
if (options->target == PPCG_TARGET_C)
|
|
|
|
argv[1] = "--no-schedule-outer-coincidence";
|
|
|
|
else
|
|
|
|
argv[1] = "--schedule-outer-coincidence";
|
|
|
|
|
|
|
|
isl_options_parse(options->isl, 2, argv, ISL_ARG_ALL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Callback that is called whenever the "target" option is set (to "val").
|
|
|
|
* The callback is called after target has been updated.
|
|
|
|
*
|
|
|
|
* Call ppcg_options_set_target_defaults to reset the target-dependent options.
|
|
|
|
*/
|
|
|
|
static int set_target(void *opt, unsigned val)
|
|
|
|
{
|
|
|
|
struct ppcg_options *options = opt;
|
|
|
|
|
|
|
|
ppcg_options_set_target_defaults(options);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARGS_START(struct ppcg_debug_options, ppcg_debug_options_args)
|
|
|
|
ISL_ARG_BOOL(struct ppcg_debug_options, dump_schedule_constraints, 0,
|
|
|
|
"dump-schedule-constraints", 0, "dump schedule constraints")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_debug_options, dump_schedule, 0,
|
|
|
|
"dump-schedule", 0, "dump isl computed schedule")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_debug_options, dump_final_schedule, 0,
|
|
|
|
"dump-final-schedule", 0, "dump PPCG computed schedule")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_debug_options, dump_sizes, 0,
|
|
|
|
"dump-sizes", 0,
|
|
|
|
"dump effectively used per kernel tile, grid and block sizes")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_debug_options, verbose, 'v', "verbose", 0, NULL)
|
|
|
|
ISL_ARGS_END
|
|
|
|
|
|
|
|
ISL_ARGS_START(struct ppcg_options, ppcg_opencl_options_args)
|
|
|
|
ISL_ARG_STR(struct ppcg_options, opencl_compiler_options, 0, "compiler-options",
|
|
|
|
"options", NULL, "options to pass to the OpenCL compiler")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, opencl_use_gpu, 0, "use-gpu", 1,
|
|
|
|
"use GPU device (if available)")
|
|
|
|
ISL_ARG_STR_LIST(struct ppcg_options, opencl_n_include_file,
|
|
|
|
opencl_include_files, 0, "include-file", "filename",
|
|
|
|
"file to #include in generated OpenCL code")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, opencl_print_kernel_types, 0,
|
|
|
|
"print-kernel-types", 1,
|
|
|
|
"print definitions of types in the kernel file")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, opencl_embed_kernel_code, 0,
|
|
|
|
"embed-kernel-code", 0, "embed kernel code into host code")
|
|
|
|
ISL_ARGS_END
|
|
|
|
|
|
|
|
ISL_ARGS_START(struct ppcg_options, ppcg_options_args)
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_CHILD(struct ppcg_options, isl, "isl", &isl_options_args, "isl options")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_CHILD(struct ppcg_options, debug, NULL, &ppcg_debug_options_args,
|
|
|
|
"debugging options")
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, group_chains, 0, "group-chains", 1,
|
|
|
|
"group chains of interdependent statements that are executed "
|
|
|
|
"consecutively in the original schedule before scheduling")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, reschedule, 0, "reschedule", 1,
|
2017-07-20 23:48:13 +08:00
|
|
|
"replace original schedule by isl computed schedule")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, scale_tile_loops, 0,
|
|
|
|
"scale-tile-loops", 1, NULL)
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, wrap, 0, "wrap", 1, NULL)
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, use_shared_memory, 0, "shared-memory", 1,
|
|
|
|
"use shared memory in kernel code")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, use_private_memory, 0, "private-memory", 1,
|
|
|
|
"use private memory in kernel code")
|
|
|
|
ISL_ARG_STR(struct ppcg_options, ctx, 0, "ctx", "context", NULL,
|
|
|
|
"Constraints on parameters")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, non_negative_parameters, 0,
|
|
|
|
"assume-non-negative-parameters", 0,
|
|
|
|
"assume all parameters are non-negative)")
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, tile, 0, "tile", 0,
|
|
|
|
"perform tiling (C target)")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_INT(struct ppcg_options, tile_size, 'S', "tile-size", "size", 32, NULL)
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, isolate_full_tiles, 0, "isolate-full-tiles",
|
|
|
|
0, "isolate full tiles from partial tiles (hybrid tiling)")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_STR(struct ppcg_options, sizes, 0, "sizes", "sizes", NULL,
|
|
|
|
"Per kernel tile, grid and block sizes")
|
|
|
|
ISL_ARG_INT(struct ppcg_options, max_shared_memory, 0,
|
|
|
|
"max-shared-memory", "size", 8192, "maximal amount of shared memory")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, openmp, 0, "openmp", 0,
|
|
|
|
"Generate OpenMP macros (only for C target)")
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_USER_OPT_CHOICE(struct ppcg_options, target, 0, "target", target,
|
|
|
|
&set_target, PPCG_TARGET_CUDA, PPCG_TARGET_CUDA,
|
|
|
|
"the target to generate code for")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, linearize_device_arrays, 0,
|
|
|
|
"linearize-device-arrays", 1,
|
|
|
|
"linearize all device arrays, even those of fixed size")
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, allow_gnu_extensions, 0,
|
|
|
|
"allow-gnu-extensions", 1,
|
|
|
|
"allow the use of GNU extensions in generated code")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, live_range_reordering, 0,
|
|
|
|
"live-range-reordering", 1,
|
|
|
|
"allow successive live ranges on the same memory element "
|
|
|
|
"to be reordered")
|
2017-07-20 23:48:13 +08:00
|
|
|
ISL_ARG_BOOL(struct ppcg_options, hybrid, 0, "hybrid", 0,
|
|
|
|
"apply hybrid tiling whenever a suitable input pattern is found "
|
|
|
|
"(GPU targets)")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, unroll_copy_shared, 0, "unroll-copy-shared",
|
|
|
|
0, "unroll code for copying to/from shared memory")
|
|
|
|
ISL_ARG_BOOL(struct ppcg_options, unroll_gpu_tile, 0, "unroll-gpu-tile", 0,
|
|
|
|
"unroll code inside tile on GPU targets")
|
2016-07-13 23:54:47 +08:00
|
|
|
ISL_ARG_GROUP("opencl", &ppcg_opencl_options_args, "OpenCL options")
|
|
|
|
ISL_ARG_STR(struct ppcg_options, save_schedule_file, 0, "save-schedule",
|
|
|
|
"file", NULL, "save isl computed schedule to <file>")
|
|
|
|
ISL_ARG_STR(struct ppcg_options, load_schedule_file, 0, "load-schedule",
|
|
|
|
"file", NULL, "load schedule from <file>, "
|
|
|
|
"using it instead of an isl computed schedule")
|
|
|
|
ISL_ARGS_END
|