Commit 5d2f79de authored by Mats Kindahl's avatar Mats Kindahl

Bug #47645: Segmentation fault when out of memory during handlerton initialization

There is a missing check for memory allocation failure when allocating
memory for the handlerton structure. If the handlerton init function
tries to de-reference the pointer, it will cause a segmentation fault
and crash the server.

This patch fixes the problem by not calling the init function if memory
allocation failed, and instead prints an informative error message and
reports the error to the caller.

sql/handler.cc:
  Add a check if memory allocation succeeded before calling the init
  function. If it failed, it is not necessary to free the memory,
  but the plugin->data is set to NULL to ensure that it can be checked
  for failure.
parent d47710c8
...@@ -430,6 +430,14 @@ int ha_initialize_handlerton(st_plugin_int *plugin) ...@@ -430,6 +430,14 @@ int ha_initialize_handlerton(st_plugin_int *plugin)
hton= (handlerton *)my_malloc(sizeof(handlerton), hton= (handlerton *)my_malloc(sizeof(handlerton),
MYF(MY_WME | MY_ZEROFILL)); MYF(MY_WME | MY_ZEROFILL));
if (hton == NULL)
{
sql_print_error("Unable to allocate memory for plugin '%s' handlerton.",
plugin->name.str);
goto err_no_hton_memory;
}
/* Historical Requirement */ /* Historical Requirement */
plugin->data= hton; // shortcut for the future plugin->data= hton; // shortcut for the future
if (plugin->plugin->init && plugin->plugin->init(hton)) if (plugin->plugin->init && plugin->plugin->init(hton))
...@@ -540,6 +548,7 @@ err_deinit: ...@@ -540,6 +548,7 @@ err_deinit:
err: err:
my_free((uchar*) hton, MYF(0)); my_free((uchar*) hton, MYF(0));
err_no_hton_memory:
plugin->data= NULL; plugin->data= NULL;
DBUG_RETURN(1); DBUG_RETURN(1);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment