Commit c9ab025d authored by Marc Alff's avatar Marc Alff

Bug#56521 Assertion failed: (m_state == 2), function allocated_to_free, pfs_lock.h (138)

Before this fix, it was possible to build the server:
- with the performance schema
- with a dummy implementation of my_atomic (MY_ATOMIC_MODE_DUMMY).

In this case, the resulting binary will just crash,
as this configuration is not supported.

This fix enforces that the build will fail with a compilation error in this
configuration, instead of resulting in a broken binary.
parent 712a8a2e
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
*/ */
#include "my_global.h" #include "my_global.h"
#include "my_atomic.h"
#include "my_pthread.h" #include "my_pthread.h"
#include "sql_plugin.h" #include "sql_plugin.h"
#include "mysql/plugin.h" #include "mysql/plugin.h"
...@@ -28,6 +29,17 @@ ...@@ -28,6 +29,17 @@
#include "pfs_instr_class.h" #include "pfs_instr_class.h"
#include "pfs_instr.h" #include "pfs_instr.h"
#ifdef MY_ATOMIC_MODE_DUMMY
/*
The performance schema can can not function with MY_ATOMIC_MODE_DUMMY,
a fully functional implementation of MY_ATOMIC should be used instead.
If the build fails with this error message:
- either use a different ./configure --with-atomic-ops option
- or do not build with the performance schema.
*/
#error "The performance schema needs a functional MY_ATOMIC implementation."
#endif
handlerton *pfs_hton= NULL; handlerton *pfs_hton= NULL;
static handler* pfs_create_handler(handlerton *hton, static handler* pfs_create_handler(handlerton *hton,
......
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