mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 07:13:33 +03:00
MDEV-22069 UBSAN: runtime error: member access within null pointer of type 'MY_DIR_HANDLE' in mysys/my_lib.c
This is an error handling bug. When opendir() fails dirh is NULL and we shouldn't try to free it.
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
/* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
/* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
Copyright (c) 2008, 2020, MariaDB Corporation.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
@@ -183,7 +184,8 @@ MY_DIR *my_dir(const char *path, myf MyFlags)
|
|||||||
my_errno=errno;
|
my_errno=errno;
|
||||||
if (dirp)
|
if (dirp)
|
||||||
(void) closedir(dirp);
|
(void) closedir(dirp);
|
||||||
my_dirend(&dirh->dir);
|
if (dirh)
|
||||||
|
my_dirend(&dirh->dir);
|
||||||
if (MyFlags & (MY_FAE | MY_WME))
|
if (MyFlags & (MY_FAE | MY_WME))
|
||||||
my_error(EE_DIR, MYF(ME_BELL | ME_WAITTANG), path, my_errno);
|
my_error(EE_DIR, MYF(ME_BELL | ME_WAITTANG), path, my_errno);
|
||||||
DBUG_RETURN(NULL);
|
DBUG_RETURN(NULL);
|
||||||
|
Reference in New Issue
Block a user