1
1

opal/datatype: plug a memory leak in opal_datatype_t destructor

correctly free ptypes if the datatype is not pre-defined.

Thanks Axel Huebl for reporting this.

Refs. open-mpi/ompi#6291

Signed-off-by: Gilles Gouaillardet <gilles@rist.or.jp>
Этот коммит содержится в:
Gilles Gouaillardet 2019-01-22 10:57:57 +09:00
родитель 352b667323
Коммит 7c938f070f

Просмотреть файл

@ -11,6 +11,8 @@
* Copyright (c) 2004-2006 The Regents of the University of California. * Copyright (c) 2004-2006 The Regents of the University of California.
* All rights reserved. * All rights reserved.
* Copyright (c) 2009 Oak Ridge National Labs. All rights reserved. * Copyright (c) 2009 Oak Ridge National Labs. All rights reserved.
* Copyright (c) 2019 Research Organization for Information Science
* and Technology (RIST). All rights reserved.
* $COPYRIGHT$ * $COPYRIGHT$
* *
* Additional copyrights may follow * Additional copyrights may follow
@ -77,7 +79,7 @@ static void opal_datatype_destruct( opal_datatype_t* datatype )
} }
} }
/* dont free the ptypes of predefined types (it was not dynamically allocated) */ /* dont free the ptypes of predefined types (it was not dynamically allocated) */
if( (NULL != datatype->ptypes) && (datatype->id >= OPAL_DATATYPE_MAX_PREDEFINED) ) { if( (NULL != datatype->ptypes) && (!opal_datatype_is_predefined(datatype)) ) {
free(datatype->ptypes); free(datatype->ptypes);
datatype->ptypes = NULL; datatype->ptypes = NULL;
} }