| [4b31bcf] | 1 | /*
|
|---|
| 2 | cl_kernel kernel;
|
|---|
| 3 | kernel = clCreateKernel(arguments, "nothing");
|
|---|
| 4 |
|
|---|
| 5 | ((args*)kernel.arguments)->param[0] = (int*)malloc(sizeof(int));
|
|---|
| 6 | memcpy(((args*)kernel.arguments)->param[0], &star, sizeof(int));
|
|---|
| 7 |
|
|---|
| 8 | ((args*)kernel.arguments)->param[1] = one;
|
|---|
| 9 |
|
|---|
| 10 | clReleaseKernel(kernel);
|
|---|
| 11 |
|
|---|
| 12 | printf("single kernel works\n");
|
|---|
| 13 | */
|
|---|
| 14 |
|
|---|
| [6fce7853] | 15 |
|
|---|
| 16 | #include "cl.cvl"
|
|---|
| 17 | #include <stdio.h>
|
|---|
| 18 | #include <stdlib.h>
|
|---|
| 19 | #include <string.h>
|
|---|
| 20 | #include <civlc.h>
|
|---|
| [ed1d441] | 21 | #include "multiplekernel.cvl"
|
|---|
| [6fce7853] | 22 |
|
|---|
| [efe0043] | 23 | int numArgs = 2;
|
|---|
| [3192d8e] | 24 | int numKernels = 3;
|
|---|
| [ed1d441] | 25 | /*
|
|---|
| 26 | This version of the kernel has a flag for each element in the param array
|
|---|
| 27 | If the mallocflag is set to 1, it means that it will be freed by clReleaseKernel
|
|---|
| 28 | */
|
|---|
| [6fce7853] | 29 | typedef struct
|
|---|
| 30 | {
|
|---|
| [efe0043] | 31 | void * param[numArgs];
|
|---|
| 32 | int mallocflag[numArgs];
|
|---|
| [6fce7853] | 33 | }args;
|
|---|
| [ed1d441] | 34 | /*
|
|---|
| 35 | clCreateKernel in this iteration turns each flag to 0 to start off with, otherwise it gets a symbolic expression
|
|---|
| 36 | */
|
|---|
| [6fce7853] | 37 | cl_kernel clCreateKernel(args * argument, char * function)
|
|---|
| 38 | {
|
|---|
| 39 | cl_kernel kernel;
|
|---|
| 40 | kernel.arguments = argument;
|
|---|
| 41 | kernel.method = function;
|
|---|
| 42 |
|
|---|
| [efe0043] | 43 | for(int j = 0; j < numArgs; j++)
|
|---|
| 44 | {
|
|---|
| 45 | ((args*)kernel.arguments)->mallocflag[j] = 0;
|
|---|
| 46 | }
|
|---|
| 47 |
|
|---|
| [6fce7853] | 48 | return kernel;
|
|---|
| 49 | }
|
|---|
| [ed1d441] | 50 | /*
|
|---|
| 51 | Checks the flag to make sure that it was a local variable that must be freed every step of the way
|
|---|
| 52 | */
|
|---|
| [6fce7853] | 53 | void clReleaseKernel(cl_kernel kernel)
|
|---|
| 54 | {
|
|---|
| [efe0043] | 55 | for (int i = 0; i < numArgs; i++)
|
|---|
| [6fce7853] | 56 | {
|
|---|
| [efe0043] | 57 | printf("I am argument %d with value %d\n", i, ((args*)kernel.arguments)->mallocflag[i]);
|
|---|
| 58 | if (((args*)kernel.arguments)->mallocflag[i] == 1)
|
|---|
| 59 | {
|
|---|
| 60 | printf("and I pass the flag check\n");
|
|---|
| 61 | free(((args*)kernel.arguments)->param[i]);
|
|---|
| 62 | }
|
|---|
| [6fce7853] | 63 | }
|
|---|
| 64 | }
|
|---|
| 65 |
|
|---|
| 66 | int main(int argc, char** argv)
|
|---|
| 67 | {
|
|---|
| 68 | args * arguments;
|
|---|
| [3192d8e] | 69 | arguments = (args*)malloc(sizeof(args) * numKernels);
|
|---|
| [ed1d441] | 70 | //Must have enough arguments for each kernel
|
|---|
| [6fce7853] | 71 |
|
|---|
| 72 | int star = 1;
|
|---|
| 73 |
|
|---|
| 74 | int * one = (int*)malloc(sizeof(int));
|
|---|
| 75 | memcpy(one, &star, sizeof(int));
|
|---|
| [4b31bcf] | 76 |
|
|---|
| [3192d8e] | 77 | //cl_kernel *kernels = (cl_kernel*)malloc(numKernels * sizeof(cl_kernel));
|
|---|
| 78 | cl_kernel kernels[numKernels];
|
|---|
| [6fce7853] | 79 |
|
|---|
| [4b31bcf] | 80 | printf("%d, %d\n", star, *one);
|
|---|
| [ed1d441] | 81 |
|
|---|
| 82 | //For loop to create multiple kernels, the programmer must put the loop himself
|
|---|
| [3192d8e] | 83 | for (int i = 0; i < numKernels; i++)
|
|---|
| [4b31bcf] | 84 | {
|
|---|
| [efe0043] | 85 | kernels[i] = clCreateKernel(arguments+i, "eh");
|
|---|
| [3192d8e] | 86 |
|
|---|
| 87 |
|
|---|
| [4b31bcf] | 88 | }
|
|---|
| [ed1d441] | 89 | //For each kernel, put in the variables
|
|---|
| [3192d8e] | 90 | for (int j = 0; j < numKernels; j++)
|
|---|
| [6fce7853] | 91 | {
|
|---|
| [ed1d441] | 92 |
|
|---|
| [efe0043] | 93 | ((args*)kernels[j].arguments)->param[0] = (int*)malloc(sizeof(int));
|
|---|
| 94 | ((args*)kernels[j].arguments)->mallocflag[0] = 1;
|
|---|
| 95 | memcpy(((args*)kernels[j].arguments)->param[0], &star, sizeof(int));
|
|---|
| [b144b24] | 96 |
|
|---|
| [ed1d441] | 97 | //param[0] is a __local variable, so it gets the flag put to 1
|
|---|
| [3192d8e] | 98 |
|
|---|
| [ed1d441] | 99 | //printf("I am kernel of index %d, with a value of %d\n", j, ((args*)kernels[j].arguments)->param[0]);
|
|---|
| [3192d8e] | 100 |
|
|---|
| [ed1d441] | 101 | ((args*)kernels[j].arguments)->param[1] = one;
|
|---|
| 102 | //This is a __global variable, so it does not get the flag changed in this iteration.
|
|---|
| 103 | //TODO: determine if global variables were freed by clReleaseKernel or the programmer.
|
|---|
| [6fce7853] | 104 | }
|
|---|
| [193af13] | 105 |
|
|---|
| [efe0043] | 106 | //printf("assigned properly\n");
|
|---|
| 107 |
|
|---|
| [3192d8e] | 108 | for (int k = 0; k < numKernels; k++)
|
|---|
| [193af13] | 109 | {
|
|---|
| [efe0043] | 110 | clReleaseKernel(kernels[k]);
|
|---|
| [193af13] | 111 | }
|
|---|
| [b144b24] | 112 |
|
|---|
| [3192d8e] | 113 | for (int k = 0; k < numKernels; k++)
|
|---|
| [b144b24] | 114 | {
|
|---|
| [efe0043] | 115 | //free(((args*)kernels[k].arguments)->param[0]);
|
|---|
| [b144b24] | 116 | }
|
|---|
| [6fce7853] | 117 |
|
|---|
| 118 |
|
|---|
| [4b31bcf] | 119 | free(one);
|
|---|
| [6fce7853] | 120 | free(arguments);
|
|---|
| 121 | return 0;
|
|---|
| 122 | }
|
|---|
| 123 |
|
|---|
| 124 |
|
|---|