mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
Rework the statistics macros to be reusable by external entities.
Rename handlers to triggers. Dynamically allocate space for the statistics thus allow reusability.
This commit is contained in:
parent
7669d7681a
commit
41ead37c04
4 changed files with 114 additions and 161 deletions
|
@ -43,188 +43,137 @@ extern const MYSQLND_STRING mysqlnd_stats_values_names[];
|
|||
#endif
|
||||
|
||||
#define MYSQLND_CHECK_AND_CALL_HANDLER(stats, statistic, value) \
|
||||
{ \
|
||||
if ((stats)->triggers[(statistic)] && (stats)->in_trigger == FALSE) { \
|
||||
(stats)->in_trigger = TRUE; \
|
||||
(stats)->triggers[(statistic)]((stats), (statistic), (value) TSRMLS_CC); \
|
||||
(stats)->in_trigger = FALSE; \
|
||||
} \
|
||||
|
||||
|
||||
|
||||
#define MYSQLND_INC_GLOBAL_STATISTIC(statistic) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics) && (statistic) != STAT_LAST) { \
|
||||
DBG_INF_FMT("Global stat increase [%s]", mysqlnd_stats_values_names[(statistic)].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, (statistic), 1); \
|
||||
mysqlnd_global_stats->values[(statistic)]++; \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_DEC_CONN_STATISTIC(conn_stats, statistic) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics) && (statistic) != STAT_LAST) { \
|
||||
DBG_INF_FMT("Global&conn stat decrease [%s]", mysqlnd_stats_values_names[(statistic)].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, (statistic), -1); \
|
||||
mysqlnd_global_stats->values[(statistic)]--; \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
if ((conn_stats)) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), (statistic), -1); \
|
||||
} \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_GLOBAL_STATISTIC_W_VALUE2(statistic1, value1, statistic2, value2) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics)) { \
|
||||
uint64_t v1 = (uint64_t) (value1); \
|
||||
uint64_t v2 = (uint64_t) (value2); \
|
||||
enum_mysqlnd_collected_stats _s1 = (statistic1);\
|
||||
enum_mysqlnd_collected_stats _s2 = (statistic2);\
|
||||
\
|
||||
if (_s1 != STAT_LAST) DBG_INF_FMT("Global stat increase1 [%s]", mysqlnd_stats_values_names[_s1].s); \
|
||||
if (_s2 != STAT_LAST) DBG_INF_FMT("Global stat increase2 [%s]", mysqlnd_stats_values_names[_s2].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
if (_s1 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s1, v1); \
|
||||
mysqlnd_global_stats->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s2, v2); \
|
||||
mysqlnd_global_stats->values[_s2]+= v2; \
|
||||
} \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC(conn_stats, statistic) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics) && (statistic) != STAT_LAST) { \
|
||||
DBG_INF_FMT("Global&Conn stat increase [%s]", mysqlnd_stats_values_names[(statistic)].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, (statistic), 1); \
|
||||
mysqlnd_global_stats->values[(statistic)]++; \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
if (conn_stats) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), (statistic), 1); \
|
||||
(conn_stats)->values[(statistic)]++; \
|
||||
} \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE(conn_stats, statistic, value) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics) && (statistic) != STAT_LAST) { \
|
||||
uint64_t v = (uint64_t) (value); \
|
||||
DBG_INF_FMT("Global&Conn stat increase w value [%s]", mysqlnd_stats_values_names[(statistic)].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, (statistic), v); \
|
||||
mysqlnd_global_stats->values[(statistic)] += v; \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
if (conn_stats) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), (statistic), v); \
|
||||
(conn_stats)->values[(statistic)]+= v; \
|
||||
} \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE2(conn_stats, statistic1, value1, statistic2, value2) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics)) { \
|
||||
uint64_t v1 = (uint64_t) (value1); \
|
||||
uint64_t v2 = (uint64_t) (value2); \
|
||||
enum_mysqlnd_collected_stats _s1 = (statistic1);\
|
||||
enum_mysqlnd_collected_stats _s2 = (statistic2);\
|
||||
\
|
||||
if (_s1 != STAT_LAST) DBG_INF_FMT("Global stat increase1 [%s]", mysqlnd_stats_values_names[_s1].s); \
|
||||
if (_s2 != STAT_LAST) DBG_INF_FMT("Global stat increase2 [%s]", mysqlnd_stats_values_names[_s2].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
if (_s1 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s1, v1); \
|
||||
mysqlnd_global_stats->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s2, v2); \
|
||||
mysqlnd_global_stats->values[_s2]+= v2; \
|
||||
} \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
if (conn_stats) { \
|
||||
if (_s1 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), _s1, v1); \
|
||||
(conn_stats)->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), _s2, v2); \
|
||||
(conn_stats)->values[_s2]+= v2; \
|
||||
} \
|
||||
} \
|
||||
} \
|
||||
|
||||
#define MYSQLND_DEC_STATISTIC(enabler, stats, statistic) \
|
||||
{ \
|
||||
enum_mysqlnd_collected_stats _s = (statistic);\
|
||||
MYSQLND_STATS * _p_s = (MYSQLND_STATS *) (stats); \
|
||||
if ((enabler) && _p_s && _s != _p_s->count) { \
|
||||
MYSQLND_STATS_LOCK(_p_s); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s, -1); \
|
||||
_p_s->values[_s]--; \
|
||||
MYSQLND_STATS_UNLOCK(_p_s); \
|
||||
}\
|
||||
}
|
||||
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE3(conn_stats, statistic1, value1, statistic2, value2, statistic3, value3) \
|
||||
#define MYSQLND_INC_STATISTIC(enabler, stats, statistic) \
|
||||
{ \
|
||||
if (MYSQLND_G(collect_statistics)) { \
|
||||
enum_mysqlnd_collected_stats _s = (statistic);\
|
||||
MYSQLND_STATS * _p_s = (MYSQLND_STATS *) (stats); \
|
||||
if ((enabler) && _p_s && _s != _p_s->count) { \
|
||||
MYSQLND_STATS_LOCK(_p_s); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s, 1); \
|
||||
_p_s->values[_s]++; \
|
||||
MYSQLND_STATS_UNLOCK(_p_s); \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_STATISTIC_W_VALUE(enabler, stats, statistic, value) \
|
||||
{ \
|
||||
enum_mysqlnd_collected_stats _s = (statistic);\
|
||||
MYSQLND_STATS * _p_s = (MYSQLND_STATS *) (stats); \
|
||||
if ((enabler) && _p_s && _s != _p_s->count) { \
|
||||
uint64_t v = (uint64_t) (value); \
|
||||
MYSQLND_STATS_LOCK(_p_s); \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s, v); \
|
||||
_p_s->values[_s] += v; \
|
||||
MYSQLND_STATS_UNLOCK(_p_s); \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_STATISTIC_W_VALUE2(enabler, stats, statistic1, value1, statistic2, value2) \
|
||||
{ \
|
||||
MYSQLND_STATS * _p_s = (MYSQLND_STATS *) (stats); \
|
||||
if ((enabler) && _p_s) { \
|
||||
uint64_t v1 = (uint64_t) (value1); \
|
||||
uint64_t v2 = (uint64_t) (value2); \
|
||||
enum_mysqlnd_collected_stats _s1 = (statistic1);\
|
||||
enum_mysqlnd_collected_stats _s2 = (statistic2);\
|
||||
MYSQLND_STATS_LOCK(_p_s); \
|
||||
if (_s1 != _p_s->count) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s1, v1); \
|
||||
_p_s->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != _p_s->count) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s2, v2); \
|
||||
_p_s->values[_s2]+= v2; \
|
||||
} \
|
||||
MYSQLND_STATS_UNLOCK(_p_s); \
|
||||
}\
|
||||
}
|
||||
|
||||
#define MYSQLND_INC_STATISTIC_W_VALUE3(enabler, stats, statistic1, value1, statistic2, value2, statistic3, value3) \
|
||||
{ \
|
||||
MYSQLND_STATS * _p_s = (MYSQLND_STATS *) (stats); \
|
||||
if ((enabler) && _p_s) { \
|
||||
uint64_t v1 = (uint64_t) (value1); \
|
||||
uint64_t v2 = (uint64_t) (value2); \
|
||||
uint64_t v3 = (uint64_t) (value3); \
|
||||
enum_mysqlnd_collected_stats _s1 = (statistic1); \
|
||||
enum_mysqlnd_collected_stats _s2 = (statistic2); \
|
||||
enum_mysqlnd_collected_stats _s3 = (statistic3); \
|
||||
\
|
||||
if (_s1 != STAT_LAST) DBG_INF_FMT("Global stat increase1 [%s]", mysqlnd_stats_values_names[_s1].s); \
|
||||
if (_s2 != STAT_LAST) DBG_INF_FMT("Global stat increase2 [%s]", mysqlnd_stats_values_names[_s2].s); \
|
||||
if (_s3 != STAT_LAST) DBG_INF_FMT("Global stat increase3 [%s]", mysqlnd_stats_values_names[_s3].s); \
|
||||
\
|
||||
MYSQLND_STATS_LOCK(mysqlnd_global_stats); \
|
||||
if (_s1 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s1, v1); \
|
||||
mysqlnd_global_stats->values[_s1]+= v1; \
|
||||
enum_mysqlnd_collected_stats _s1 = (statistic1);\
|
||||
enum_mysqlnd_collected_stats _s2 = (statistic2);\
|
||||
enum_mysqlnd_collected_stats _s3 = (statistic3);\
|
||||
MYSQLND_STATS_LOCK(_p_s); \
|
||||
if (_s1 != _p_s->count) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s1, v1); \
|
||||
_p_s->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s2, v2); \
|
||||
mysqlnd_global_stats->values[_s2]+= v2; \
|
||||
if (_s2 != _p_s->count) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s2, v2); \
|
||||
_p_s->values[_s2]+= v2; \
|
||||
} \
|
||||
if (_s3 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(mysqlnd_global_stats, _s3, v3); \
|
||||
mysqlnd_global_stats->values[_s3]+= v3; \
|
||||
if (_s3 != _p_s->count) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER(_p_s, _s3, v3); \
|
||||
_p_s->values[_s3]+= v3; \
|
||||
} \
|
||||
MYSQLND_STATS_UNLOCK(mysqlnd_global_stats); \
|
||||
if (conn_stats) { \
|
||||
if (_s1 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), _s1, v1); \
|
||||
(conn_stats)->values[_s1]+= v1; \
|
||||
} \
|
||||
if (_s2 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), _s2, v2); \
|
||||
(conn_stats)->values[_s2]+= v2; \
|
||||
} \
|
||||
if (_s3 != STAT_LAST) { \
|
||||
MYSQLND_CHECK_AND_CALL_HANDLER((conn_stats), _s3, v3); \
|
||||
(conn_stats)->values[_s3]+= v3; \
|
||||
} \
|
||||
} \
|
||||
} \
|
||||
MYSQLND_STATS_UNLOCK(_p_s); \
|
||||
}\
|
||||
}
|
||||
|
||||
|
||||
#define MYSQLND_INC_GLOBAL_STATISTIC(statistic) \
|
||||
MYSQLND_INC_STATISTIC(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic))
|
||||
|
||||
#define MYSQLND_DEC_CONN_STATISTIC(conn_stats, statistic) \
|
||||
MYSQLND_DEC_STATISTIC(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic))
|
||||
|
||||
#define MYSQLND_INC_GLOBAL_STATISTIC_W_VALUE2(statistic1, value1, statistic2, value2) \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE2(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic1), (value1), (statistic2), (value2))
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC(conn_stats, statistic) \
|
||||
MYSQLND_INC_STATISTIC(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic)); \
|
||||
MYSQLND_INC_STATISTIC(MYSQLND_G(collect_statistics), (conn_stats), (statistic));
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE(conn_stats, statistic, value) \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic), (value)); \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE(MYSQLND_G(collect_statistics), (conn_stats), (statistic), (value));
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE2(conn_stats, statistic1, value1, statistic2, value2) \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE2(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic1), (value1), (statistic2), (value2)); \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE2(MYSQLND_G(collect_statistics), (conn_stats), (statistic1), (value1), (statistic2), (value2));
|
||||
|
||||
#define MYSQLND_INC_CONN_STATISTIC_W_VALUE3(conn_stats, statistic1, value1, statistic2, value2, statistic3, value3) \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE3(MYSQLND_G(collect_statistics), mysqlnd_global_stats, (statistic1), (value1), (statistic2), (value2), (statistic3), (value3)); \
|
||||
MYSQLND_INC_STATISTIC_W_VALUE3(MYSQLND_G(collect_statistics), (conn_stats), (statistic1), (value1), (statistic2), (value2), (statistic3), (value3));
|
||||
|
||||
|
||||
void mysqlnd_fill_stats_hash(const MYSQLND_STATS * const stats, zval *return_value
|
||||
TSRMLS_DC ZEND_FILE_LINE_DC);
|
||||
|
||||
|
||||
PHPAPI void mysqlnd_stats_init(MYSQLND_STATS ** stats);
|
||||
PHPAPI void mysqlnd_stats_init(MYSQLND_STATS ** stats, size_t statistic_count);
|
||||
PHPAPI void mysqlnd_stats_end(MYSQLND_STATS * stats);
|
||||
|
||||
PHPAPI mysqlnd_stat_trigger mysqlnd_stats_set_trigger(MYSQLND_STATS * const stats, enum_mysqlnd_collected_stats stat, mysqlnd_stat_trigger trigger TSRMLS_DC);
|
||||
PHPAPI mysqlnd_stat_trigger mysqlnd_stats_reset_triggers(MYSQLND_STATS * const stats TSRMLS_DC);
|
||||
|
||||
|
||||
#endif /* MYSQLND_STATISTICS_H */
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue