[Beignet] [PATCH] should check the return value of cl_program_new.
Yang, Rong R
rong.r.yang at intel.com
Mon Sep 21 01:34:04 PDT 2015
LGTM, pushed, thanks.
> -----Original Message-----
> From: Beignet [mailto:beignet-bounces at lists.freedesktop.org] On Behalf Of
> xionghu.luo at intel.com
> Sent: Monday, September 21, 2015 15:51
> To: beignet at lists.freedesktop.org
> Cc: Luo, Xionghu
> Subject: [Beignet] [PATCH] should check the return value of
> cl_program_new.
>
> From: Luo Xionghu <xionghu.luo at intel.com>
>
> catch the error: out of host memery.
>
> Signed-off-by: Luo Xionghu <xionghu.luo at intel.com>
> ---
> src/cl_program.c | 18 ++++++++++++++++++
> 1 file changed, 18 insertions(+)
>
> diff --git a/src/cl_program.c b/src/cl_program.c index 0564b6f..82dd3e3
> 100644
> --- a/src/cl_program.c
> +++ b/src/cl_program.c
> @@ -224,6 +224,10 @@ cl_program_create_from_binary(cl_context
> ctx,
> }
>
> program = cl_program_new(ctx);
> + if (UNLIKELY(program == NULL)) {
> + err = CL_OUT_OF_HOST_MEMORY;
> + goto error;
> + }
>
> // TODO: Need to check the binary format here to return
> CL_INVALID_BINARY.
> TRY_ALLOC(program->binary, cl_calloc(lengths[0], sizeof(char))); @@ -
> 379,6 +383,11 @@ cl_program_create_from_llvm(cl_context ctx,
> INVALID_VALUE_IF (file_name == NULL);
>
> program = cl_program_new(ctx);
> + if (UNLIKELY(program == NULL)) {
> + err = CL_OUT_OF_HOST_MEMORY;
> + goto error;
> + }
> +
> program->opaque = compiler_program_new_from_llvm(ctx->device-
> >device_id, file_name, NULL, NULL, NULL, program->build_log_max_sz,
> program->build_log, &program->build_log_sz, 1);
> if (UNLIKELY(program->opaque == NULL)) {
> err = CL_INVALID_PROGRAM;
> @@ -417,6 +426,11 @@ cl_program_create_from_source(cl_context ctx,
> // the real compilation step will be done at build time since we do not have
> // yet the compilation options
> program = cl_program_new(ctx);
> + if (UNLIKELY(program == NULL)) {
> + err = CL_OUT_OF_HOST_MEMORY;
> + goto error;
> + }
> +
> TRY_ALLOC (lens, cl_calloc(count, sizeof(int32_t)));
> for (i = 0; i < (int) count; ++i) {
> size_t len;
> @@ -633,6 +647,10 @@ cl_program_link(cl_context context,
> }
>
> p = cl_program_new(context);
> + if (UNLIKELY(p == NULL)) {
> + err = CL_OUT_OF_HOST_MEMORY;
> + goto error;
> + }
>
> if (!check_cl_version_option(p, options)) {
> err = CL_BUILD_PROGRAM_FAILURE;
> --
> 1.9.1
>
> _______________________________________________
> Beignet mailing list
> Beignet at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/beignet
More information about the Beignet
mailing list