mirror of
https://github.com/MariaDB/server.git
synced 2025-06-03 07:02:23 +03:00
A lot of small fixes and new test cases. client/mysqlbinlog.cc: Cast removed client/mysqltest.cc: Added missing DBUG_RETURN include/my_pthread.h: set_timespec_time_nsec() now only takes one argument mysql-test/t/date_formats.test: Remove --disable_ps_protocl as now also ps supports microseconds mysys/my_uuid.c: Changed to use my_interval_timer() instead of my_getsystime() mysys/waiting_threads.c: Changed to use my_hrtime() sql/field.h: Added bool special_const_compare() for fields that may convert values before compare (like year) sql/field_conv.cc: Added test to get optimal copying of identical temporal values. sql/item.cc: Return that item_int is equal if it's positive, even if unsigned flag is different. Fixed Item_cache_str::save_in_field() to have identical null check as other similar functions Added proper NULL check to Item_cache_int::save_in_field() sql/item_cmpfunc.cc: Don't call convert_constant_item() if there is nothing that is worth converting. Simplified test when years should be converted sql/item_sum.cc: Mark cache values in Item_sum_hybrid as not constants to ensure they are not replaced by other cache values in compare_datetime() sql/item_timefunc.cc: Changed sec_to_time() to take a my_decimal argument to ensure we don't loose any sub seconds. Added Item_temporal_func::get_time() (This simplifies some things) sql/mysql_priv.h: Added Lazy_string_decimal() sql/mysqld.cc: Added my_decimal constants max_seconds_for_time_type, time_second_part_factor sql/table.cc: Changed expr_arena to be of type CONVENTIONAL_EXECUTION to ensure that we don't loose any items that are created by fix_fields() sql/tztime.cc: TIME_to_gmt_sec() now sets *in_dst_time_gap in case of errors This is needed to be able to detect if timestamp is 0 storage/maria/lockman.c: Changed from my_getsystime() to set_timespec_time_nsec() storage/maria/ma_loghandler.c: Changed from my_getsystime() to my_hrtime() storage/maria/ma_recovery.c: Changed from my_getsystime() to mmicrosecond_interval_timer() storage/maria/unittest/trnman-t.c: Changed from my_getsystime() to mmicrosecond_interval_timer() storage/xtradb/handler/ha_innodb.cc: Added support for new time,datetime and timestamp unittest/mysys/thr_template.c: my_getsystime() -> my_interval_timer() unittest/mysys/waiting_threads-t.c: my_getsystime() -> my_interval_timer()
95 lines
2.4 KiB
C
95 lines
2.4 KiB
C
/* Copyright (C) 2006-2008 MySQL AB, 2008 Sun Microsystems, Inc.
|
|
|
|
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
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
#include <my_global.h>
|
|
#include <my_sys.h>
|
|
#include <my_atomic.h>
|
|
#include <tap.h>
|
|
|
|
volatile uint32 bad;
|
|
pthread_attr_t thr_attr;
|
|
pthread_mutex_t mutex;
|
|
pthread_cond_t cond;
|
|
uint running_threads;
|
|
|
|
void do_tests();
|
|
|
|
void test_concurrently(const char *test, pthread_handler handler, int n, int m)
|
|
{
|
|
pthread_t t;
|
|
ulonglong now= my_interval_timer();
|
|
|
|
bad= 0;
|
|
|
|
diag("Testing %s with %d threads, %d iterations... ", test, n, m);
|
|
for (running_threads= n ; n ; n--)
|
|
{
|
|
if (pthread_create(&t, &thr_attr, handler, &m) != 0)
|
|
{
|
|
diag("Could not create thread");
|
|
abort();
|
|
}
|
|
}
|
|
pthread_mutex_lock(&mutex);
|
|
while (running_threads)
|
|
pthread_cond_wait(&cond, &mutex);
|
|
pthread_mutex_unlock(&mutex);
|
|
|
|
now= my_interval_timer() - now;
|
|
ok(!bad, "tested %s in %g secs (%d)", test, ((double)now)/1e9, bad);
|
|
}
|
|
|
|
int main(int argc __attribute__((unused)), char **argv)
|
|
{
|
|
MY_INIT("thd_template");
|
|
|
|
if (argv[1] && *argv[1])
|
|
DBUG_SET_INITIAL(argv[1]);
|
|
|
|
pthread_mutex_init(&mutex, 0);
|
|
pthread_cond_init(&cond, 0);
|
|
pthread_attr_init(&thr_attr);
|
|
pthread_attr_setdetachstate(&thr_attr,PTHREAD_CREATE_DETACHED);
|
|
|
|
#ifdef MY_ATOMIC_MODE_RWLOCKS
|
|
#if defined(HPUX11) || defined(__POWERPC__) /* showed to be very slow (scheduler-related) */
|
|
#define CYCLES 300
|
|
#else
|
|
#define CYCLES 3000
|
|
#endif
|
|
#else
|
|
#define CYCLES 3000
|
|
#endif
|
|
#define THREADS 30
|
|
|
|
diag("N CPUs: %d, atomic ops: %s", my_getncpus(), MY_ATOMIC_MODE);
|
|
|
|
do_tests();
|
|
|
|
/*
|
|
workaround until we know why it crashes randomly on some machine
|
|
(BUG#22320).
|
|
*/
|
|
#ifdef NOT_USED
|
|
sleep(1);
|
|
#endif
|
|
pthread_mutex_destroy(&mutex);
|
|
pthread_cond_destroy(&cond);
|
|
pthread_attr_destroy(&thr_attr);
|
|
my_end(0);
|
|
return exit_status();
|
|
}
|
|
|